-
Notifications
You must be signed in to change notification settings - Fork 16
/
Robot.py
executable file
·53 lines (49 loc) · 1.42 KB
/
Robot.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
from ConfigRobot import *
from Kinematics import *
import numpy as np
class Robot(object):
"""docstring for Robot"""
def __init__(self):
super(Robot, self).__init__()
self.cf = ConfigRobot()
self.q = self.cf.q_init
self.d = self.cf.d
self.a = self.cf.a
self.alpha = self.cf.alpha
self.fwd = FwdKinematics()
self.inv = InvKinematics()
self.JVars = self.cf.q_init[1:]
self.q1P = self.JVars
self.q2P = self.JVars
self.EVars = np.array([])
self.EVars = self.fwd.Cal_Fwd_Position(self.JVars)
def CalFwdPostion(self, JVars):
self.JVars = JVars
self.q1P = self.q2P = JVars
self.EVars = self.fwd.Cal_Fwd_Position(JVars)
def CalInvPostion(self, EVars):
sol = self.inv.FindTheBestSolution(EVars, self.q1P, self.q2P)
if sol != None:
result = self.inv.Cal_Inv_Position(EVars, sol)
if result[0] != False:
self.EVars = EVars
self.JVars= result[1]
self.q2P = self.q1P
self.q1P = self.JVars
else:
print("error while calculate")
def CalInvPositionEx(self, EVars, q1p=None, q2p=None, sol = -1):
if sol == -1:
sol = self.inv.FindTheBestSolution(EVars, q1p, q2p)
if sol != None:
result = self.inv.Cal_Inv_Position(EVars, sol)
if result[0] != False:
JVars= result[1]
return True, JVars
else:
print("error while calculate")
return False,
else:
return False,
def GetCurrentStatus(self):
return self.EVars