calcMinDist.py 874 B

123456789101112131415161718192021222324252627282930313233
  1. #!/usr/bin/env python
  2. import numpy
  3. class Point:
  4. def __init__(self, x, y):
  5. self.x = x
  6. self.y = y
  7. def euclideanDist(p1, p2):
  8. from math import sqrt
  9. return sqrt((p1.x-p2.x)**2 + (p1.y-p2.y)**2)
  10. def getMinDist(p1, precision=0.001, startX=0, endX=3):
  11. """Get x of point on (x,x^2) that has minimal distance to given Point p."""
  12. minDist = -1
  13. for x in numpy.arange(startX, endX, precision):
  14. p2 = Point(x, x**2)
  15. dist = euclideanDist(p1, p2)
  16. if minDist == -1 or dist < minDist:
  17. minDist = dist
  18. return minDist
  19. """for i in numpy.arange(0, 3, 0.01):
  20. minDist = getMinDist(Point(0, i))
  21. if abs(i-minDist) < 0.005:
  22. print(i, minDist)"""
  23. print(getMinDist(Point(0,4.25), precision=0.001, startX=0, endX=3))
  24. #print(euclideanDist(Point(0,5),Point(2, 2**2)))
  25. #print(getMinDist(5, 0.00001, 2, 3))