Beefy Boxes and Bandwidth Generously Provided by pair Networks
No such thing as a small change
 
PerlMonks  

Re^2: Speeding up point-in-polygon -- take two

by roboticus (Chancellor)
on Aug 28, 2006 at 14:39 UTC ( #569987=note: print w/replies, xml ) Need Help??


in reply to Re: Speeding up point-in-polygon -- take two
in thread Speeding up point-in-polygon -- take two

Another thought--

If the aforementioned suggestion helps, then it may be possible to improve performance a bit more by adding even more polygons: You might break your polygons into rectangles, left triangles and right triangles, where a rectangle is 'definitely inside' a polygon, and the triangles are pasted to the left and right side of your set of rectangles to build the polygons you desire.

With the rectangles, you can avoid the subroutine call altogether. If your select statement returns one, you have the answer "Yep, it's in polygon A". If it's a triangle, then you only have one edge to check. (For a left triangle, your point is inside the polygon of $x is to the right of the edge; and for a right triangle, your point is inside if $x is to the left of the edge.)

By chewing on the problem, I'm certain you'll come up with a few other things to try...

--roboticus

  • Comment on Re^2: Speeding up point-in-polygon -- take two

Log In?
Username:
Password:

What's my password?
Create A New User
Node Status?
node history
Node Type: note [id://569987]
help
Chatterbox?
[marto]: life is a struggle :P I'm glad the GPW went well.
[Corion]: Hi choroba! Yeah, I brought the rain with me from Hamburg
[Corion]: marto: As am I ;) And we got two interested locations for next year, Munich and Cologne maybe, which is great as well. Not Berlin though ;)
[marto]: damn
[choroba]: Munich is kind of close from here

How do I use this? | Other CB clients
Other Users?
Others romping around the Monastery: (9)
As of 2017-06-29 08:13 GMT
Sections?
Information?
Find Nodes?
Leftovers?
    Voting Booth?
    How many monitors do you use while coding?















    Results (655 votes). Check out past polls.