120 lines
4.1 KiB
Python
120 lines
4.1 KiB
Python
from helpfunctions import *
|
|
import time
|
|
|
|
class UR:
|
|
|
|
import rtde_receive
|
|
import rtde_control
|
|
|
|
def __init__(self,_joint_min,_joint_max,_frequency_rtde_send=500,_frequency_rtde_receive=500):
|
|
self.frequency_rtde_send=_frequency_rtde_send
|
|
self.frequency_rtde_receive=_frequency_rtde_receive
|
|
|
|
self.controlEnabled=False
|
|
|
|
self.last_receivertde=0
|
|
self.last_sendrtde=0
|
|
|
|
self.joint_min=_joint_min
|
|
self.joint_max=_joint_max
|
|
|
|
self.rtde_r=None
|
|
self.rtde_c=None
|
|
|
|
|
|
# Parameters
|
|
self.velocity = 0.1
|
|
self.acceleration = 0.1
|
|
self.lookahead_time = 0.1
|
|
self.gain = 300
|
|
self.joint_q_aim=[0,0,0,0,0,0] #joint rotations aiming for
|
|
self.joint_q = [0,0,0,0,0,0] #joint rotation last sent
|
|
#self.velocitylimit=[1,1,1,3,3,3] #joint velocity limits
|
|
self.velocitylimit=[0.2,0.2,0.2,0.2,0.2,0.2] #joint velocity limits
|
|
|
|
|
|
self.joint_q_received=[0,0,0,0,0,0]
|
|
|
|
def connect(self,robotip):
|
|
|
|
self.rtde_r = self.rtde_receive.RTDEReceiveInterface(robotip, self.frequency_rtde_receive)
|
|
|
|
self.rtde_c = self.rtde_control.RTDEControlInterface(robotip)
|
|
|
|
def setJointQAim(self,q):
|
|
self.joint_q_aim=q
|
|
|
|
def isJointsWithinSafetyLimits(self,q):
|
|
return self.rtde_c.isJointsWithinSafetyLimits(q)
|
|
|
|
def enableControl(self):
|
|
if time.time()-self.last_receivertde<0.1: #if received position is recent
|
|
self.joint_q=self.joint_q_received #update current position to received position
|
|
self.joint_q_aim=self.joint_q_received
|
|
self.controlEnabled=True
|
|
def disableControl(self):
|
|
self.controlEnabled=False
|
|
|
|
def isControlEnabled(self):
|
|
return self.controlEnabled
|
|
|
|
def send(self,looptime):
|
|
|
|
if looptime-self.last_sendrtde<1.0/self.frequency_rtde_send:
|
|
return
|
|
self.last_sendrtde=looptime
|
|
|
|
if self.controlEnabled:
|
|
for i in range(6): #update joint_q with max speeds
|
|
self.joint_q[i] += constrain(self.joint_q_aim[i]-self.joint_q[i], -self.velocitylimit[i]/self.frequency_rtde_send,self.velocitylimit[i]/self.frequency_rtde_send) #constrain joint speeds
|
|
|
|
if self.rtde_c is not None:
|
|
self.rtde_c.servoJ(self.joint_q, self.velocity, self.acceleration, 1.0/self.frequency_rtde_send, self.lookahead_time, self.gain)
|
|
|
|
def receiveJoints(self,looptime):
|
|
|
|
#Get robot joint angles
|
|
if looptime-self.last_receivertde<1.0/self.frequency_rtde_receive:
|
|
return
|
|
self.last_receivertde=looptime
|
|
|
|
if self.rtde_r is not None:
|
|
self.joint_q_received=self.rtde_r.getActualQ()
|
|
else:
|
|
_offsets=[12.2,5.3,0,6,12.4,612.91]
|
|
_factors=[1.2,1.14,1.214,0.9921,1,1.092]
|
|
|
|
for _i,_offset in enumerate(_offsets): #generate mockup values
|
|
self.joint_q_received[_i]=(math.sin(time.time()*_factors[_i]+_offset)/2.0+0.5)*(self.joint_max[_i]-self.joint_min[_i])+self.joint_min[_i]
|
|
|
|
def receiveStatus(self,looptime):
|
|
|
|
if looptime-self.last_receivertde<1.0/self.frequency_rtde_receive:
|
|
return
|
|
self.last_receivertde=looptime
|
|
|
|
self.status_connected=self.rtde_r.isConnected()
|
|
self.status_timestamp=self.rtde_r.getTimestamp()
|
|
self.status_protectivestopped=self.rtde_r.isProtectiveStopped()
|
|
self.status_emergencystopped=self.rtde_r.isEmergencyStopped()
|
|
self.status_robotstatus=self.rtde_c.getRobotStatus()
|
|
'''
|
|
self.status_=self.rtde_r.()
|
|
self.status_=self.rtde_r.()
|
|
self.status_=self.rtde_r.()
|
|
self.status_=self.rtde_r.()
|
|
self.status_=self.rtde_r.()
|
|
self.status_=self.rtde_r.()
|
|
self.status_=self.rtde_r.()
|
|
'''
|
|
|
|
def getReceivedQ(self):
|
|
return self.joint_q_received
|
|
|
|
def disconnect(self):
|
|
if self.rtde_c is not None:
|
|
self.rtde_c.servoStop()
|
|
self.rtde_c.stopScript()
|
|
|
|
|
|
|