Hey,
I have an incredibly large number of points for display on a world map, numbering in the millions, arranged into individual cells. The cells are anything from rectangular to very varied boundaries following a coastline. On the boundaries of these cells,
even on the straight lines, are an insane number of extra points which are completely unnecessary  SharpMap takes a long time to load them and a large time to redraw the map every time it is scrolled/zoomed. I am sure these points can be reduced by at least
10x and still retain the overall topology of these cells. I am talking here about some kind of preprocessing before the data is even delivered to SharpMap but thought that this would still be the best place to ask.
I have been trying out various algorithms  the most promising so far has been a combination of my own tweaks (stepping through the points in turn and if either the lat or long is equal to the previous one, the new point is removed  this helps with any
rectangular elements of a cell) and the DouglasPeucker algorithm but the latter is not good at preserving topology. Silly things happen like the corner points of cells being chopped off leaving me with various cells with missing corners.
My results when googling are clouded by allsorts of unhelpful results regarding either splitting polygons for 3D graphics optimisation or the mathematical definition of topology  really struggling to even know where to look here.
Any help or suggestions would be greatly appreciated.
