mithi/hexapod-robot-simulator

View on GitHub
hexapod/ik_solver/shared.py

Summary

Maintainability
A
0 mins
Test Coverage
# Functions used for solving inverse kinematics
from hexapod.points import is_counter_clockwise, angle_between, rotz


def update_hexapod_points(hexapod, leg_id, points):
    leg = hexapod.legs[leg_id]
    for point, leg_point in zip(points, leg.all_points):
        point.name = leg_point.name
    leg.all_points = points


def find_twist_frame(hexapod, unit_coxia_vector):
    twist = angle_between(unit_coxia_vector, hexapod.x_axis)
    is_ccw = is_counter_clockwise(unit_coxia_vector, hexapod.x_axis, hexapod.z_axis)
    if is_ccw:
        twist = -twist

    twist_frame = rotz(twist)
    return twist, twist_frame


def compute_twist_wrt_to_world(alpha, coxia_axis):
    alpha = (alpha - coxia_axis) % 360
    if alpha > 180:
        return alpha - 360
    return alpha