by
Mohammad Ali Abam, Mark de Berg, Peter Hachenberger and Alireza ZareiSummary
Given a streaming input of data points, it may be impossible to store the complete set. A compromise would be to create an simplification or approximation ot those points. The simplification problem is give a path P with points p0, p1,..pn to find a path Q with fewer vertices. If Q is a subset of P it is a restricted version, in an unrestricted version this does not have to be so. There are two type of optimization problems min-k and min-delta. Min-k is given a maximum error find a simplification with as few vertices as possible that is below the error threshold. With min-delta, given a maximum of K vertices find the simplification with the smallest possible error that uses at most K vertices. Iterative algorithms are needed due to the streaming nature, and thus many existing line simplification algorithms cannot be used for streaming.The error function between the simplified version and the original is calculated using Hausdorff and Frechet distances. The goal is to get competitive ratio in comparison between the optimal offline algorithm and the simplification algorithm.
The algorithm uses a priority queue to hold the vertex links. We compute the error of the incoming link, and insert it into the queue at the appropriate priority. Then we extract the vertex from the from the queue with the minimum priority and update the priorities of the vertices on both sides. The paper goes on to define c-montone as the error of a link cannot be worse that c times the error of any link that encloses it.
The paper goes on to discuss the Hausdorff error function, and discuss how the oracle makes use of that function. The same treatment if given to Freceht, who uses two parameters: width of the points and length of the largest back path. Each distance function is successful at differing type of point distributions.
3 comments:
With a streaming algorithm like this I can't see how we would not beautify the stroke as the user continues to draw. Otherwise you're keeping 2 sets of points (drawing and simplified), which would completely defeat the purpose of the algorithm. As long as the simplification is relatively accurate it shouldn't matter, but if the algorithm has any jumps the user might be frustrated.
I do agree on your point that the algorithm itself was very easy to understand. Unfortunately, the complications begin once the details unraveled from the use of the error function in the algorithm, which then opened up huge complexities in comprehension. The use of oracles for predicting errors is very critical in the algorithm, but I believe it was explained very unfriendly. I believe that this style of writing is common with Abam, since I've heard similar complaints from the computation geometry students whom had to read Abam's other papers. Did you know Abam's only currently a PhD student? :O
Good words.
Post a Comment