Sophie

Sophie

distrib > Mandriva > 2010.0 > i586 > media > contrib-release > by-pkgid > 789a4dca4953f037223e830336ef4af3 > files > 1064

python-enthought-enable-3.2.0-2mdv2010.0.i586.rpm

import numpy

from enthought.kiva import agg

poly = numpy.array((( 0.0,  0.0),
                    (10.0,  0.0),
                    (10.0, 10.0),
                    ( 0.0, 10.0)))

print agg.point_in_polygon(-1,-1,poly)
print agg.point_in_polygon(0.0,0.0,poly)
print agg.point_in_polygon(5,5,poly)
print agg.point_in_polygon(10,10,poly)
print agg.point_in_polygon(15,15,poly)

pts = numpy.array(((-1.0, -1.0),
                   ( 0.1,  0.0),
                   ( 0.0,  0.1),
                   ( 0.0,  0.0),
                   ( 5.0,  5.0),
                   ( 10.0, 10.0),
                   ( 15.0, 15.0)))

results = agg.points_in_polygon(pts, poly)

print results

pts = numpy.random.random_sample((20000, 2))*12.5-2.5

import time
t1 = time.clock()
results = agg.points_in_polygon(pts, poly)
t2 = time.clock()
print 'points_in_polygon() for %d pts in %d point polygon (sec): %f' % \
      (len(pts), len(poly), t2-t1)
print pts[:5]
print results[:5]

poly = numpy.array((( 0.0,  0.0),
                    ( 2.0,  0.0),
                    ( 5.0,  0.0),
                    ( 7.5,  0.0),
                    (10.0,  0.0),
                    (10.0,  2.5),
                    (10.0,  5.0),
                    (10.0,  7.5),
                    (10.0, 10.0),
                    ( 7.5, 10.0),
                    ( 5.0, 10.0),
                    ( 2.5, 10.0),
                    ( 0.0, 10.0)))

t1 = time.clock()
results = agg.points_in_polygon(pts, poly)
t2 = time.clock()
print 'points_in_polygon() for %d pts in %d point polygon (sec): %f' % \
      (len(pts), len(poly), t2-t1)
print pts[:5]
print results[:5]