Example #1
0
def repulsive_poly_point(point_center, point_a, point_b):
    angle_center_a = find_angle(point_center, point_a)
    angle_center_b = find_angle(point_center, point_b)

    # debug print
    # print(angle_center_a)
    # print(angle_center_b)

    angle_new = (angle_center_a + angle_center_b)/2
    if angle_center_a > angle_center_b:
        if angle_new == math.pi:
            angle_new = 0
        elif angle_new == 0:
            angle_new = math.pi
        elif angle_new > 0:
            angle_new -= math.pi
        elif angle_new < 0:
            angle_new += math.pi

    x = math.cos(angle_new) * REPULSIVE_POLY_MULTIPLIER + point_center.x
    y = math.sin(angle_new) * REPULSIVE_POLY_MULTIPLIER + point_center.y
    new_point = Point(x, y)

    # print(x, '; ', y)
    return new_point
Example #2
0
def closest_point_to_obstacle(point_test, polygon):
    ref_point = []
    distance = INITIAL_DISTANCE_VALUE
    for n in range(len(polygon) + 1):
        ref_point.append(n % len(polygon))

    # distance = list
    closest_point_on_obstacle = Point(0, 0)
    for n in range(len(polygon)):
        # line_temp = polygon[n].find_line_point_to_point(polygon[n + 1])
        # distance.append(point_test, line_temp)
        point_obstacle = closest_point_to_line(point_test, polygon[ref_point[n]], polygon[ref_point[n + 1]])
        if point_test.find_distance_between_points(point_obstacle) < distance:
            distance = point_test.find_distance_between_points(point_obstacle)
            closest_point_on_obstacle.x = point_obstacle.x
            closest_point_on_obstacle.y = point_obstacle.y
    return closest_point_on_obstacle
Example #3
0
def get_polygon_centroid(polygon):
    x = []
    y = []
    for p in polygon:
        x.append(p.x)
        y.append(p.y)
    sum_x = sum(x)
    sum_y = sum(y)
    c_x = sum_x / len(x)
    c_y = sum_y / len(y)
    return Point(c_x, c_y)
Example #4
0
def potential_get_path(polygon, point_start, point_goal):
    path = [Point(point_start.x, point_start.y)]
    point_current = point_start
    step = 0
    while point_current.find_distance_between_points(point_goal) >= TARGET_RANGE and step <= TOTAL_STEP:
        att_vector = attraction_force(point_current, point_goal)
        point_obstacle = closest_point_to_obstacle(point_current, polygon)
        print('current \npoint obstacle\nattraction\nrepulsive')
        point_current.show_value()
        point_obstacle.show_value()
        # print(point_current.find_distance_between_points(point_obstacle))
        if point_current.find_distance_between_points(point_obstacle) <= REPULSIVE_RANGE:
            rep_vector = repulsive_force(point_current, point_obstacle, polygon)
        else:
            rep_vector = Point(0, 0)
        att_vector.show_value()
        rep_vector.show_value()
        total_vector = total_potential_force(att_vector, rep_vector)
        # force_ponit = po
        # point_current.plot_line_between_two_point()
        # point_current.show_value()
        point_current.add_point(total_vector, STEP_SIZE)
        #point_current.show_value()
        path.append(Point(point_current.x, point_current.y))
        step += 1

    return path
Example #5
0
def repulsive_force(point_to_test, point_obstacle, polygon_obs):
    distance = point_to_test.find_distance_between_points(point_obstacle)
    repulsive_vector = Point(0, 0)
    if distance <= REPULSIVE_RANGE:
        repulsive_magnitude = (0.5*REPULSIVE_COEFFICIENT)*((1/REPULSIVE_RANGE) + (1/distance))*(1/distance**2)
        repulsive_vector.set_x((point_to_test.x - point_obstacle.x) * repulsive_magnitude)
        repulsive_vector.set_y((point_to_test.y - point_obstacle.y) * repulsive_magnitude)

    return repulsive_vector
Example #6
0
def closest_point_to_line(point_test, line_point_1, line_point_2):
    line_temp_list = line_point_1.find_line_point_to_point(line_point_2)
    line_temp = Line(line_temp_list[0], line_temp_list[1], line_temp_list[2])
    # line_temp.show_line_function()
    # line_temp.plot_line()
    orthogonal_line = line_temp.orthogonal_line_cross_point(point_test)
    orthogonal_line.plot_line()
    # orthogonal_line.show_line_function()
    # orthogonal_line.plot_line()
    # orthogonal_line = Line(orthogonal_line_list[0], orthogonal_line_list[1], orthogonal_line_list[2])
    projection_point_list = line_temp.interception_between_two_lines(
        orthogonal_line)
    projection_point = Point(projection_point_list[0][0],
                             projection_point_list[1][0])
    # projection_point.plot_point()
    # projection_point.show_value()
    # obstacle_point = Point(0, 0)
    if line_temp.check_point_on_line(point_test):
        if (line_point_1.x <= point_test.x <= line_point_2.x or line_point_2.x <= point_test.x <= line_point_2.x) and\
                (line_point_1.y <= point_test.y <= line_point_2.y or line_point_2.y <= point_test.y <= line_point_2.y):
            obstacle_point = Point(point_test.x, point_test.y)
        else:
            distance_point_1 = point_test.find_distance_between_points(
                line_point_1)
            distance_point_2 = point_test.find_distance_between_points(
                line_point_2)

            if distance_point_1 < distance_point_2:
                obstacle_point = Point(line_point_1.x, line_point_1.y)
            else:
                obstacle_point = Point(line_point_2.x, line_point_2.y)
    elif (line_point_1.x - ALPHA <= projection_point.x <= line_point_2.x + ALPHA or
            line_point_1.x + ALPHA >= projection_point.x >= line_point_2.x - ALPHA) and\
            (line_point_1.y - ALPHA <= projection_point.y <= line_point_2.y + ALPHA or
             line_point_1.y + ALPHA >= projection_point.y >= line_point_2.y - ALPHA):
        obstacle_point = Point(projection_point.x, projection_point.y)
    else:
        distance_point_1 = point_test.find_distance_between_points(
            line_point_1)
        distance_point_2 = point_test.find_distance_between_points(
            line_point_2)

        if distance_point_1 < distance_point_2:
            obstacle_point = Point(line_point_1.x, line_point_1.y)
        else:
            obstacle_point = Point(line_point_2.x, line_point_2.y)

    return obstacle_point
Example #7
0
def repulsive_force(point_to_test, obs_distance, polygon_centroid, point_obs):
    # distance_to_obstacle = point_to_test.find_distance_between_points(point_obstacle)
    # distance_to_center = point_to_test.find_distance_between_points(polygon_centroid)
    repulsive_vector = Point(0, 0)
    # abs_distance = distance_to_center - distance_to_obstacle
    # if abs_distance <= REPULSIVE_RANGE:
    repulsive_magnitude = REPULSIVE_COEFFICIENT * (1 / (obs_distance**2))
    # *(1/abs_distance**2)
    vector_magnitude = point_to_test.find_distance_between_points(
        polygon_centroid)
    repulsive_vector.set_x((point_to_test.x - polygon_centroid.x) *
                           repulsive_magnitude / vector_magnitude)
    repulsive_vector.set_y((point_to_test.y - polygon_centroid.y) *
                           repulsive_magnitude / vector_magnitude)

    return repulsive_vector
Example #8
0
def repulsive_force(point_to_test, point_obstacle, polygon_centroid):
    distance_to_obstacle = point_to_test.find_distance_between_points(
        point_obstacle)
    distance_to_center = point_to_test.find_distance_between_points(
        polygon_centroid)
    repulsive_vector = Point(0, 0)
    abs_distance = distance_to_center - distance_to_obstacle
    if distance_to_center <= REPULSIVE_RANGE:
        repulsive_magnitude = (0.5 * REPULSIVE_COEFFICIENT) * (
            1 / (distance_to_center - 3)**2)
        # *(1/abs_distance**2)
        vector_magnitude = point_to_test.find_distance_between_points(
            polygon_centroid)
        repulsive_vector.set_x((point_to_test.x - polygon_centroid.x) *
                               repulsive_magnitude / vector_magnitude)
        repulsive_vector.set_y((point_to_test.y - polygon_centroid.y) *
                               repulsive_magnitude / vector_magnitude)

    return repulsive_vector
Example #9
0
def closest_point_to_obstacle(point_test, polygon):
    ref_point = []
    distance = INITIAL_DISTANCE_VALUE
    for n in range(polygon.get_length() + 1):
        ref_point.append(n % polygon.get_length())

    closest_point_on_obstacle = Point(0, 0)
    for n in range(polygon.get_length()):
        # line_temp = polygon[n].find_line_point_to_point(polygon[n + 1])
        # distance.append(point_test, line_temp)
        # print(ref_point[n], ref_point[n+1])
        point_obstacle = closest_point_to_line(point_test,
                                               polygon.poly[ref_point[n]],
                                               polygon.poly[ref_point[n + 1]])
        if point_test.find_distance_between_points(point_obstacle) < distance:
            distance = point_test.find_distance_between_points(point_obstacle)
            closest_point_on_obstacle.x = point_obstacle.x
            closest_point_on_obstacle.y = point_obstacle.y
    closest_point_on_obstacle.plot_point()
    return closest_point_on_obstacle
Example #10
0
def main():
    '''
    # Baxter Setup
    """RSDK Joint Position Waypoints Example

        Records joint positions each time the navigator 'OK/wheel'
        button is pressed.
        Upon pressing the navigator 'Rethink' button, the recorded joint positions
        will begin playing back in a loop.
        """
    arg_fmt = argparse.RawDescriptionHelpFormatter
    parser = argparse.ArgumentParser(formatter_class=arg_fmt,
                                     description=main.__doc__)
    required = parser.add_argument_group('required arguments')
    required.add_argument(
        '-l', '--limb', required=True, choices=['left', 'right'],
        help='limb to record/playback waypoints'
    )
    parser.add_argument(
        '-s', '--speed', default=0.3, type=float,
        help='joint position motion speed ratio [0.0-1.0] (default:= 0.3)'
    )
    parser.add_argument(
        '-a', '--accuracy',
        default=baxter_interface.settings.JOINT_ANGLE_TOLERANCE, type=float,
        help='joint position accuracy (rad) at which waypoints must achieve'
    )
    args = parser.parse_args(rospy.myargv()[1:])

    print("Initializing node... ")

    # initialized node
    rospy.init_node("rsdk_joint_position_waypoints_%s" % (args.limb,))
    '''

    p_1 = Point(2, 1)
    p_2 = Point(10, 1)
    p_3 = Point(10, 10)
    p_4 = Point(2, 10)
    p_5 = Point(2, 8)
    p_6 = Point(6, 6)
    p_7 = Point(6, 4)
    p_8 = Point(1, 2)

    polygon = Polygon()
    polygon.add_point(p_1)
    polygon.add_point(p_2)
    polygon.add_point(p_3)
    polygon.add_point(p_4)
    polygon.add_point(p_5)
    polygon.add_point(p_6)
    polygon.add_point(p_7)
    polygon.add_point(p_8)

    polygon.polygon_plot('r-')
    convex_polygon = polygon.concave_convex_conversion()
    convex_polygon.polygon_plot('g-')
    safe_range_polygon = convex_polygon.repulsive_poly(
        REPULSIVE_POLY_MULTIPLIER)
    safe_range_polygon.polygon_plot('b-')
    point_centroid = safe_range_polygon.get_polygon_centroid()
    # p = Point(-5, -5)
    point_centroid.plot_point()
    point_start = Point(-5, 5)
    p_obs = closest_point_to_obstacle(point_start, safe_range_polygon)
    point_start.plot_point()
    p_obs.plot_point()
    point_goal = Point(15, 0)
    point_goal.plot_point()
    # path = potential_get_path(safe_range_polygon, point_start, point_goal, point_centroid)
    # plot_path(path)
    plt.show()
Example #11
0
def total_potential_force(att_vector, rep_vector):
    total_vector = Point(att_vector.x + rep_vector.x,
                         att_vector.y + att_vector.y)
    return total_vector
Example #12
0
def attraction_force(point_to_test, point_goal):
    vector_magnitude = point_to_test.find_distance_between_points(point_goal)
    attraction_vector = Point(point_goal.x - point_to_test.x,
                              point_goal.y - point_to_test.y)
    attraction_vector.scale_point(ATTRACTION_COEFFICIENT / vector_magnitude)
    return attraction_vector
from point_2d_my import Point
from polygon_my import Polygon

import matplotlib.pyplot as plt

p_1 = Point(2, 1)
p_2 = Point(10, 1)
p_3 = Point(10, 10)
p_4 = Point(2, 10)
p_5 = Point(2, 8)
p_6 = Point(6, 6)
p_7 = Point(6, 4)
p_8 = Point(1, 2)

polygon = Polygon()
polygon.add_point(p_1)
polygon.add_point(p_2)
polygon.add_point(p_3)
polygon.add_point(p_4)
polygon.add_point(p_5)
polygon.add_point(p_6)
polygon.add_point(p_7)
polygon.add_point(p_8)


polygon.polygon_plot('r-')
poly_centroid = polygon.get_polygon_centroid()
poly_centroid.show_value()
plt.show()

Example #14
0
def main():
    p_1 = Point(2, 1)
    p_2 = Point(10, 1)
    p_3 = Point(10, 10)
    p_4 = Point(2, 10)
    p_5 = Point(2, 8)
    p_6 = Point(6, 6)
    p_7 = Point(6, 4)
    p_8 = Point(1, 2)

    polygon = [p_1, p_2, p_3, p_4, p_5, p_6, p_7, p_8]
    # polygon_plot(polygon, 'b-')
    # plt.show()
    convex_polygon = polygon_concave_convex_conversion(polygon)
    # polygon_plot(convex_polygon, 'r-')
    safe_range_polygon = repulsive_poly(convex_polygon)
    point_centroid = get_polygon_centroid(safe_range_polygon)
    # plt.show()
    p = Point(-5, -5)
    #p_obs = closest_point_to_obstacle(p, safe_range_polygon)

    #p_obs.show_value()
    #p.plot_line_between_two_points(p_obs)
    plt.axis([-20, 20, -20, 20])
    # projection_point = closest_point_to_line(Point(0, 3), Point(0, -1), Point(3, 2))
    # projection_point.show_value()
    point_start = Point(-5, -5)
    point_goal = Point(18, 0)
    path = potential_get_path(safe_range_polygon, point_start, point_goal)
    polygon_plot(safe_range_polygon, 'g-')
    plot_path(path)
    #for p in path:
    #    print(p.x, p.y)
    plt.show()
Example #15
0
def attraction_force(point_to_test, point_goal):
    attraction_vector = Point(point_goal.x - point_to_test.x, point_goal.y - point_to_test.y)
    attraction_vector.scale_point(ATTRACTION_COEFFICIENT)
    return attraction_vector
Example #16
0
        my_lower = np.array([0, 0, 0], dtype=np.uint8)
        my_upper = np.array([100, 100, 100], dtype=np.uint8)
        mask = cv2.inRange(self.img, my_lower, my_upper)
        # cv2.imshow('mask', mask)

        (flags, contours, h) = cv2.findContours(mask, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)

        # print(contours)
         return contours

img = cv2.imread('polygon_1.png')



shape_rec = ShapeRecognition(img)
contours = shape_rec.process()
all_points = []
print(contours[0].size)
print(len(contours[0]))
for i in range(len(contours[0])):
    all_points.append(Point(contours[0][i][0][0], -contours[0][i][0][1]))

for p in all_points:
    p.plot_point()

plt.show()
cv2.imshow('image', img)
cv2.waitKey(0)
cv2.destroyAllWindows()