Difference between revisions of "4-Axis Delta robot Setup"

From SoftMC-Wiki
Jump to: navigation, search
(Build & Configure)
(BackToTop button)
 
(38 intermediate revisions by 2 users not shown)
Line 1: Line 1:
 +
{{Languages|4-Axis_Delta_robot_Setup}}
 +
<div id="BackToTop"  class="noprint" style="background-color:; position:fixed; bottom:32px; left:95%; z-index:9999; padding:0; margin:0;">
 +
<span style="color:blue; font-size:8pt; font-face:verdana,sans-serif; border:0.2em outset:#ceebf7; padding:0.1em; font-weight:bolder; -moz-border-radius:8px; ">
 +
[[Image:TOP2.png|50px|link=#top]] </span></div>
 
= Introduction =  
 
= Introduction =  
'''This example is still under construction'''
+
[[File:PrevDeltasim.JPG|link=http://softmc.servotronix.com/img_auth.php/9/94/Deltasim.html|400px]] <br/> <br/>
 
 
 
In this example we will use softMC simulator to create Delta Robot, run it from terminal watch some parameters and finally run it with roboDK<br/>
 
In this example we will use softMC simulator to create Delta Robot, run it from terminal watch some parameters and finally run it with roboDK<br/>
  
Line 9: Line 12:
 
L2 = 270 [mm] <br/>
 
L2 = 270 [mm] <br/>
 
Rsmall = 40 [mm] <br/>
 
Rsmall = 40 [mm] <br/>
Gear 1:1 <br/>
+
Gear 1:10 <br/>
Typical velocity is 18,000 [deg/sec] 3000 [RPM] <br/>
+
Typical velocity is 18,000/10 [deg/sec] 3000 [RPM] <br/>
Typical max velocity is 30,000 [deg/sec] <br/>
+
Typical max velocity is 30,000/10 [deg/sec] <br/>
Typical Acceleration/Deceleration 720,000 [deg/sec] <br/>
+
Typical Acceleration/Deceleration 720,000/10 [deg/sec] <br/>
Typical Max Acceleration/Deceleration 900,000 [deg/sec] <br/>
+
Typical Max Acceleration/Deceleration 900,000/10 [deg/sec] <br/>
Typical Jerk is 2,160,000 [deg/sec] <br/>
+
Typical Jerk is 2,160,000/10 [deg/sec] <br/>
Typical Jerk is 2,700,000 [deg/sec] <br/>
+
Typical Jerk is 2,700,000/10 [deg/sec] <br/>
  
 
Note: <br/>
 
Note: <br/>
Line 72: Line 75:
 
'''Hint:''' <br/>
 
'''Hint:''' <br/>
 
If you have similar axis you can do all the setting than copy entire axis with right mouse clicking on the axis <br/><br/>
 
If you have similar axis you can do all the setting than copy entire axis with right mouse clicking on the axis <br/><br/>
The configuration window of the axes has few tabs.The "Properties" tab allows to set the axis properties. Set following properties appropriately to each axis <br />
+
The configuration window of the axes has few tabs.The '''"Properties"''' tab allows to set the axis properties. Set following properties appropriately to each axis <br /> <br />
 +
'''Important:''' this value are the final value after the gear <br /> <br />
 
for a simulated robot, change the "Simulated Axis" property to "True" <br />
 
for a simulated robot, change the "Simulated Axis" property to "True" <br />
 
velocity is 18,000 [deg/sec] 3000 [RPM] <br/>
 
velocity is 18,000 [deg/sec] 3000 [RPM] <br/>
Line 93: Line 97:
  
 
== General ==
 
== General ==
This tab allows to switch the axes which are linked to the group and to change the axes properties <br /> <br />
+
This tab allows to switch the axes which are linked to the group and to change the axes properties in cause you have more than 4 axis <br /> <br />
 
[[File:Delta18.jpg]]<br />
 
[[File:Delta18.jpg]]<br />
  
 
== Coupling ==  
 
== Coupling ==  
# The coupling matrix for the robot (which usually shouldn't be changed for a delta robot). <br />
+
# Coupling matrix shouldn't be changed for a delta robot (define if Motor axis rotate only specific joint or more than one joint)
# The joints position limits. <br /> <br />
+
# Each joints position limits per axis. <br /> <br />
  
 
[[File:Delta19.jpg]]<br />
 
[[File:Delta19.jpg]]<br />
Line 104: Line 108:
 
== Properties ==
 
== Properties ==
 
This tab allows to set the robot properties, such as: position limits, speed limits, acceleration limits, etc.  <br /><br/>
 
This tab allows to set the robot properties, such as: position limits, speed limits, acceleration limits, etc.  <br /><br/>
 +
Note:
 +
*Make sure to set Position error max to 10 in simple/Cartesian table "PeMax" (-->delta.pemax=10)
 +
 
[[File:Delta20.jpg]]<br />
 
[[File:Delta20.jpg]]<br />
  
 
== Configuration ==  
 
== Configuration ==  
 
This tab has 3 sub-tabs:  <br /> <br/>
 
This tab has 3 sub-tabs:  <br /> <br/>
[[File:Delta21.jpg]]<br />
+
*Make sure to set Tool Z axis to 15 to accomodate w RoboDK (-->delta.tool=#{0,0,15,0} )<br /><br/>
 +
For more information use the link <br/>
 +
[[Robot_Working_Frames#BASE|base]] <br/>
 +
[[Robot_Working_Frames#tool|tool]] <br/>
 +
[[Robot_Working_Frames#machinetable| machinetable ]] <br/>
 +
[[Robot_Working_Frames#workpiece | workpiece]] <br/> <br/>
 +
[[File:Deltatool.JPG]]<br />
  
 
=== Delta parameters ===
 
=== Delta parameters ===
Line 137: Line 150:
  
 
= Close Configurator =
 
= Close Configurator =
 +
Now exit the configurator we can go back to configurator later on <br/><br/>
 +
[[File:Delta29.jpg]]<br />
  
 
= Create solution =  
 
= Create solution =  
Open Project (apj file)
+
To create solution we have to do the following: <br/>
 +
*Open Project (apj file) created by Build & Configure
 +
*Save it as Solution (asn file)
 +
*Add Config.prg from the Controller to PC
 +
*Copy any user previews programs to the folders using explorer
 +
*Add File(s) to the Solution tree <br/> <br/>
 +
 
 +
'''Open Project''' (apj file) <br/> <br/>
 +
[[File:Delta30.jpg]]<br /> <br/>
 +
[[File:Delta32.jpg]]<br /> <br/>
 +
 
 +
'''Save it as Solution''' <br/> <br/>
 +
[[File:Delta33.jpg]]<br /> <br/>
 +
[[File:Delta34.jpg]]<br /> <br/>
 +
 
 +
'''Add Config.prg from the Controller to PC''' <br/> <br/>
 +
[[File:Delta35.jpg]]<br /> <br/>
 +
 
 +
'''Add File(s) to the Solution tree''' <br/> <br/>
 +
[[File:Delta36.jpg]]<br /> <br/>
 +
[[File:Delta37.jpg]]<br /> <br/>
  
 
= Add watches =
 
= Add watches =
 +
Lets look what we have from Terminal <br/>
 +
-->?grouplist <br/>
 +
DELTA:A1,A2,A3,A4 <br/>
 +
and Add Delta watch for Enable Position feedback and XYZR value <br/><br/>
 +
[[File:Delta38.jpg]]<br />
  
 
= Run the Robot =
 
= Run the Robot =
 +
== Run Robot now ==
 +
Now we can run the robot <br/>
 +
-->Delta.en=1 <br/>
 +
-->move delta {0,0,0,20} <br/>
 +
 +
== Run Robot after re cycle ==
 +
Do the following:
 +
*Run and start the softMCSIM
 +
*Run ControlStudio and connect to your softMCSIM
 +
*Open your Solution "Delta"
 +
*Double click on Program file "StartPRG.PRG"
 +
*Click on the Icon "Save and Load"
 +
'''Robot Delta is ready'''
  
 
= Run Robot with roboDK =
 
= Run Robot with roboDK =
 +
== Open TCP/IP server to work with RoboDK ==
 +
Save Load and run SERV4DEL.PRG, Than make sure you see "socket 2 is set" in ControlStudio Message log<br/>
 +
Tip: use windows key + left error to get ControlStudio on the half left windows
 +
 +
<syntaxhighlight lang="vb">
 +
' Version:    1.00
 +
' Author:      Ron Danon DVG
 +
' Description:
 +
' History:    2017-06-17  base on server.prg  V1.00
 +
'              Created
 +
'------------------------------------------------------------------------------
 +
dim shared numOfRobots as long = 1
 +
 +
program continue
 +
 +
  dim index as long
 +
  dim sockNum as long = 2
 +
  dim cPort as long = 7132
 +
  dim jointStr as string
 +
  dim robotGroups[1] as generic group 'same as size of numOfRobots
 +
    dim robotNames[1] as string 'same as size of numOfRobots
 +
   
 +
'---------------Define robot groups and names---------------'   
 +
robotGroups[1] = DELTA
 +
robotNames[1] = "robot1"
 +
'robotGroups[2] = PUMA2
 +
'robotNames[2] = robot2
 +
   
 +
'---------------Opening new socket---------------'
 +
  call openNewSocket(sockNum,cPort)
 +
 
 +
'---------------Connecting to client---------------' 
 +
  call connectClient(sockNum,cPort,0)
 +
 +
'---------------Main Loop---------------' 
 +
  while True
 +
    call createJsonStr(robotNames,robotGroups,jointStr)
 +
    call checkIfReady(sockNum,cPort)
 +
'    ?jointStr
 +
'    ?SIZE(jointStr)
 +
    print #sockNum,jointStr   
 +
  end while
 +
 +
'---------------Close sockets and exit---------------'
 +
  print #sockNum,"finish"
 +
  sleep 1000
 +
  close #sockNum
 +
  Print "Server Closed Sockets. Server Exits"
 +
 
 +
end program ' server.prg
 +
 +
 +
 +
 +
 +
 +
'---------------------------------------'
 +
'---------------Functions---------------'
 +
'---------------------------------------'
 +
 +
sub openNewSocket(sockNum as long,cPort as Long)
 +
  dim opened as long = 0
 +
  while not opened
 +
    Try
 +
      OpenSocket Options=1 as #sockNum
 +
      opened = 1
 +
    catch 5043 'socket is already open
 +
      print "socket", sockNum, "is already open. trying next socket"
 +
      sockNum = sockNum + 1
 +
    end Try
 +
  end while
 +
  print "socket", sockNum, "is set"
 +
end sub
 +
 +
 +
sub connectClient(sockNum as long, cPort as Long, ByVal sockIsOpen as long)
 +
  dim str1 as string
 +
  if sockIsOpen then
 +
    close #sockNum
 +
    OpenSocket Options=1 as #sockNum
 +
  end if
 +
  Accept(#sockNum, cPort)
 +
  sleep 500
 +
  str1=input$(loc(sockNum),#sockNum) 'receive data to check if connected
 +
  ?"client is connected"
 +
  sleep 200
 +
end sub
 +
 +
 +
sub checkIfReady(sockNum as long,cPort as Long)
 +
  'Waits for a 'ready' input from roboDK before sending the next JSON string
 +
  dim ready as long = 0
 +
  while not ready
 +
    Try
 +
      while loc(sockNum) = 0  'while no data is available
 +
        sleep 10
 +
      end while   
 +
    catch 5041 'client disconnected
 +
      print "client disconnected, waiting for connection"
 +
      call connectClient(sockNum,cPort,1)
 +
    end Try
 +
    ready = (input$(loc(sockNum),#sockNum) = "ready") 'check if the input is "ready"
 +
  end while
 +
end sub
 +
 +
 +
sub createJsonStr(robotNames[*] as string, robotGroups[*] as generic group, jointStr as string)
 +
'FORMAT --> '{"robotName": [double-a1, double-a2, double-a3, double-a4, double-a5, double-a6]}' <---
 +
'double is in precision of 2 digits after the point, i.e.: '0.12', '179.12'
 +
  dim index1 as long
 +
  dim index2 as long
 +
  dim jointValues as generic joint
 +
  dim temp as long = 50
 +
 
 +
  jointStr = "{"
 +
  for index1 = 1 to numOfRobots
 +
    jointValues = robotGroups[index1].PFb
 +
    jointStr = jointStr + chr$(34) + robotNames[index1] + chr$(34) + ": ["
 +
    for index2 = 1 to robotGroups[index1].ElementSize
 +
      if index2 = 4 then
 +
        temp = 0
 +
      else
 +
        temp = 50
 +
      end if
 +
      jointStr = jointStr + STRD$(-jointValues{index2} + temp, "%.2f") + ", " 
 +
    next
 +
    jointStr = LEFT$(jointStr,LEN(jointStr)-2) + "], "
 +
  next
 +
  jointStr = LEFT$(jointStr,LEN(jointStr)-2) + "}"
 +
end sub
 +
 +
'---------------End of functions---------------'
 +
 +
</syntaxhighlight>
 +
 +
== Run RoboDK ==
 +
Copy paste to your folder "Fanuc_Delta.rdk" prepared by Servotronix include
 +
*Delta robot from RoboDK library
 +
*Prog1 a pyton script which open TCP/IP socekt to work with softMCSIM / serv4del.prg
 +
 +
Double click on the Prog1 icon to open RoboDK TCP/IP port and make sure you see in ControlStudio Message "client is connected"
 +
 +
{| class="wikitable"
 +
|-
 +
! scope="col"|TCP/IP port <br/>Close || ! scope="col"| TCP/IP port <br/>Open
 +
|-
 +
|[[File:DeltaExample2.jpg]] ||[[File:DeltaExample3.jpg]]
 +
|}
 +
 +
 +
'''Prog1'''
 +
<syntaxhighlight lang="vb">
 +
import mcEnv
 +
   
 +
host, port = "192.168.56.103", 7132
 +
finsihedTransmit = False
 +
 +
MCE = mcEnv.MCenv()
 +
MCE.setSimulationSpeed(1000)
 +
MCE.connectClient(host,port)
 +
MCE.setRobot("robot1", "Fanuc M-1iA/0.5S")
 +
 +
robotList = ["robot1"]
 +
 +
while not finsihedTransmit:
 +
    MCE.writeStr("ready")
 +
    jsonStr = MCE.readJsonStr()
 +
    MCE.moveRobots(robotList, jsonStr)
 +
   
 +
raise Exception('Finished')
 +
</syntaxhighlight>
  
 
= Robot Programs Example =
 
= Robot Programs Example =
 +
Here is a simple Pick and place program
 +
Where P12 and P11 are the upper position and P2 and P1 are the lower position <br/> <br/>
 +
|[[File:DeltaCapture01.JPG|1200px]] <br/>
 +
 +
<syntaxhighlight lang="vb">
 +
'------------------------------------------------------------------------------
 +
' File:        PnPTDelta.prg
 +
' Purpose:    Robot Pick & Place
 +
' Version:    1.00
 +
' Author:      DVG
 +
' History:    15.Jun.2017    -    created
 +
'------------------------------------------------------------------------------
 +
 +
' module global "constants"
 +
 +
 +
' module global variables
 +
dim shared ZeroPosition as joint of xyzr = {0 , 0 , 0 , 0 }                'Moving as joint - for initial positioning
 +
dim shared P1Position as joint of xyzr = {0, 0, 0, 0}                      '{J1,J2,J3,J4}
 +
 +
dim shared P1    as location of xyzr = #{0 , 75 , 300 , 0 }    '{X,Y,Z,R}
 +
dim shared P11  as location of xyzr = #{0 , 75,  225 , 0}
 +
dim shared P22  as location of xyzr = #{0 , -75,  225 , 0}
 +
dim shared P2    as location of xyzr = #{0 , -75,  300 , 0}
 +
 +
dim shared RobotVelocity as double = 40.0
 +
dim shared RobotTranVelocity as double = 40.0
 +
 +
program
 +
 +
    with Delta                                'set default group element, no need to explicitly indicate the motion element
 +
        Attach                              'Attach the task to motion element (with Delta)
 +
            En = TRUE
 +
            Sleep 100
 +
            Vcruise = RobotVelocity          'Set robot's cruise velocity
 +
            Vtran = RobotTranVelocity
 +
            while NOT En
 +
                Sleep 100
 +
            end while
 +
            Move ZeroPosition                'moving to zero position
 +
            WaitForMotion Delta
 +
              call pickPlaceXYZ              'execute Pick and Place function
 +
            Move ZeroPosition
 +
            WaitForMotion Delta
 +
        Detach
 +
    end with   
 +
 +
end program
 +
 +
 +
sub pickPlaceXYZ
 +
 +
    dim i as long
 +
 +
    Move Delta P1Position
 +
    WaitForMotion Delta
 +
    Delta.BlendingMethod = 2                  'Type of motion blending - 2 is SuperPosition blending - in order to optimize movement, so that it will be as fast as possible
 +
    Delta.BlendingFactor = 80                'Percentage of the movement’s length that will not be blended with the next movement
 +
    Delta.Cp = 10                            'At continous path blednign, sets the blend radious value - bigger equal smoother
 +
    for i = 1 to 10
 +
        Moves Delta P11
 +
        WaitForMotion Delta
 +
        Moves Delta P1
 +
        WaitForMotion Delta
 +
        Moves Delta P11
 +
        WaitForMotion Delta
 +
        Moves Delta P22
 +
        WaitForMotion Delta
 +
        Moves Delta P2
 +
        WaitForMotion Delta
 +
        Moves Delta P22
 +
        WaitForMotion Delta
 +
    next i
 +
    Move Delta ZeroPosition
 +
    WaitForMotion Delta
 +
 +
end sub
 +
 +
</syntaxhighlight>

Latest revision as of 14:01, 6 August 2017

Language: English  • 中文(简体)‎

TOP2.png

Introduction

PrevDeltasim.JPG

In this example we will use softMC simulator to create Delta Robot, run it from terminal watch some parameters and finally run it with roboDK

We select Delta robot from roboDK library, robot parameters:
Rbig = 110 [mm]
L1 = 100 [mm]
L2 = 270 [mm]
Rsmall = 40 [mm]
Gear 1:10
Typical velocity is 18,000/10 [deg/sec] 3000 [RPM]
Typical max velocity is 30,000/10 [deg/sec]
Typical Acceleration/Deceleration 720,000/10 [deg/sec]
Typical Max Acceleration/Deceleration 900,000/10 [deg/sec]
Typical Jerk is 2,160,000/10 [deg/sec]
Typical Jerk is 2,700,000/10 [deg/sec]

Note:
Tool value is: tool = #{0,0,15,0}

Run softMC SIM

I run my softMC simulator with my VM, i login using mc for System login and Password than i type ifconfig to find my softMC simulator IP address, in the following example IP is 192.168.56.103

DeltaEx01.JPG

DeltaEx02.JPG

Run ControlStudio

Run ControlStudio and make sure you run the approporiate firmware version in following example we run Firmware 0.4.17.2-C2

Delta2.jpg

Delta3.jpg

Creating and Running a CONFIG.PRG file

The Configurator does not generate a CONFIG.PRG file, which is a necessary file.
The most simple CONFIG.PRG file will look like this:

Sys.NumberAxes = 4
program
    Sys.Name = "DVG_Delta"         
    Print "system is running  -  " ; Sys.Name
    Sys.DoubleFormat = 1           ; viewing the watch number
end program

NOTE: It is important that Sys.NumberAxes will be at least 4 as the Delta robot needs 4 axes.
Before opening the Configurator, make sure to run the CONFIG.PRG file by uploading it to the softMC using "Save and Load" and sending ">reset all" in the terminal.

Run Configurator Open new project

Run configurator from ControlStudio and open new Project

Delta5.jpg

Delta6.jpg

Important Notes:

  • You do not see any drive under Buses folder since you run in simulation
  • Make sure you see 4 axis (A1 A2 A3 A4)

Delta11.jpg

Create new Folder

Now we will create our folder and our configuration file, to do it we will use "Save As" create "New" folder and name our configurator file as Delta

Delta7.jpg

Delta8.jpg

Delta9.jpg

Delta10.jpg

Configuring Drive and Axes

Define Drives

Since we work with softMC simulation we do not have any drives and can skip to the next one

Define Axes

Press on the first axis and its configuration window will show:

  1. Choose the "Axis Type". Please choose: "Rotary Gear" for the Delta robot.
  2. Set the Gear Ratio value to the correct value. we will keep value 1

Repeat the last steps for each used axis.
Delta12.jpg

Hint:
If you have similar axis you can do all the setting than copy entire axis with right mouse clicking on the axis

The configuration window of the axes has few tabs.The "Properties" tab allows to set the axis properties. Set following properties appropriately to each axis

Important: this value are the final value after the gear

for a simulated robot, change the "Simulated Axis" property to "True"
velocity is 18,000 [deg/sec] 3000 [RPM]
max velocity is 30,000 [deg/sec]
Acceleration/Deceleration 720,000 [deg/sec]
Max Acceleration/Deceleration 900,000 [deg/sec]
Jerk is 2,160,000 [deg/sec]
max Jerk is 2,700,000 [deg/sec]
Position error max 10
Delta14.jpg

Create Delta Robot

Right clik on Group icon and select Add Group

Delta15.jpg

Select Robot
Group name DELTA
Select delta xyzr [rrrr]
Click on all four axis, note the frame color change from red to green

Delta17.jpg

General

This tab allows to switch the axes which are linked to the group and to change the axes properties in cause you have more than 4 axis

Delta18.jpg

Coupling

  1. Coupling matrix shouldn't be changed for a delta robot (define if Motor axis rotate only specific joint or more than one joint)
  2. Each joints position limits per axis.

Delta19.jpg

Properties

This tab allows to set the robot properties, such as: position limits, speed limits, acceleration limits, etc.

Note:

  • Make sure to set Position error max to 10 in simple/Cartesian table "PeMax" (-->delta.pemax=10)

Delta20.jpg

Configuration

This tab has 3 sub-tabs:

  • Make sure to set Tool Z axis to 15 to accomodate w RoboDK (-->delta.tool=#{0,0,15,0} )

For more information use the link
base
tool
machinetable
workpiece

Deltatool.JPG

Delta parameters

Here we set the Delta robot mechnical parameters:
Rbig = 110 [mm]
L1 = 100 [mm]
L2 = 270 [mm]
Rsmall = 40 [mm]

Delta22.jpg

Build & Configure

Now we are ready to generate setup and communication files and run them on the softMC, click on "Build & Configure"

Delta23.jpg ---> Delta25.jpg
Before Build & Configure After Build & Configure
Delta24.jpg Delta26.jpg
Delta27.jpg
Delta28.jpg

Close Configurator

Now exit the configurator we can go back to configurator later on

Delta29.jpg

Create solution

To create solution we have to do the following:

  • Open Project (apj file) created by Build & Configure
  • Save it as Solution (asn file)
  • Add Config.prg from the Controller to PC
  • Copy any user previews programs to the folders using explorer
  • Add File(s) to the Solution tree

Open Project (apj file)

Delta30.jpg

Delta32.jpg

Save it as Solution

Delta33.jpg

Delta34.jpg

Add Config.prg from the Controller to PC

Delta35.jpg

Add File(s) to the Solution tree

Delta36.jpg

Delta37.jpg

Add watches

Lets look what we have from Terminal
-->?grouplist
DELTA:A1,A2,A3,A4
and Add Delta watch for Enable Position feedback and XYZR value

Delta38.jpg

Run the Robot

Run Robot now

Now we can run the robot
-->Delta.en=1
-->move delta {0,0,0,20}

Run Robot after re cycle

Do the following:

  • Run and start the softMCSIM
  • Run ControlStudio and connect to your softMCSIM
  • Open your Solution "Delta"
  • Double click on Program file "StartPRG.PRG"
  • Click on the Icon "Save and Load"

Robot Delta is ready

Run Robot with roboDK

Open TCP/IP server to work with RoboDK

Save Load and run SERV4DEL.PRG, Than make sure you see "socket 2 is set" in ControlStudio Message log
Tip: use windows key + left error to get ControlStudio on the half left windows

' Version:     1.00
' Author:      Ron Danon DVG
' Description:
' History:     2017-06-17  base on server.prg  V1.00
'              Created
'------------------------------------------------------------------------------
dim shared numOfRobots as long = 1

program continue

  dim index as long
  dim sockNum as long = 2
  dim cPort as long = 7132
  dim jointStr as string
  dim robotGroups[1] as generic group 'same as size of numOfRobots
    dim robotNames[1] as string 'same as size of numOfRobots
    
'---------------Define robot groups and names---------------'    
robotGroups[1] = DELTA
robotNames[1] = "robot1"
'robotGroups[2] = PUMA2
'robotNames[2] = robot2
    
'---------------Opening new socket---------------'
  call openNewSocket(sockNum,cPort)
  
'---------------Connecting to client---------------'  
  call connectClient(sockNum,cPort,0)

'---------------Main Loop---------------'  
  while True
    call createJsonStr(robotNames,robotGroups,jointStr)
    call checkIfReady(sockNum,cPort) 
'    ?jointStr
'    ?SIZE(jointStr)
    print #sockNum,jointStr     
  end while

'---------------Close sockets and exit---------------' 
  print #sockNum,"finish"
  sleep 1000
  close #sockNum
  Print "Server Closed Sockets. Server Exits"
  
end program ' server.prg






'---------------------------------------'
'---------------Functions---------------' 
'---------------------------------------'

sub openNewSocket(sockNum as long,cPort as Long)
  dim opened as long = 0
  while not opened 
    Try
      OpenSocket Options=1 as #sockNum
      opened = 1
    catch 5043 'socket is already open
      print "socket", sockNum, "is already open. trying next socket"
      sockNum = sockNum + 1
    end Try
  end while
  print "socket", sockNum, "is set"
end sub


sub connectClient(sockNum as long, cPort as Long, ByVal sockIsOpen as long)
  dim str1 as string
  if sockIsOpen then
    close #sockNum
    OpenSocket Options=1 as #sockNum
  end if
  Accept(#sockNum, cPort)
  sleep 500
  str1=input$(loc(sockNum),#sockNum) 'receive data to check if connected
  ?"client is connected"
  sleep 200
end sub


sub checkIfReady(sockNum as long,cPort as Long)
  'Waits for a 'ready' input from roboDK before sending the next JSON string
  dim ready as long = 0
  while not ready
    Try
      while loc(sockNum) = 0   'while no data is available
        sleep 10
      end while    
    catch 5041 'client disconnected
      print "client disconnected, waiting for connection"
      call connectClient(sockNum,cPort,1)
    end Try
    ready = (input$(loc(sockNum),#sockNum) = "ready") 'check if the input is "ready"
  end while
end sub


sub createJsonStr(robotNames[*] as string, robotGroups[*] as generic group, jointStr as string)
'FORMAT --> '{"robotName": [double-a1, double-a2, double-a3, double-a4, double-a5, double-a6]}' <---
'double is in precision of 2 digits after the point, i.e.: '0.12', '179.12' 
  dim index1 as long
  dim index2 as long
  dim jointValues as generic joint
  dim temp as long = 50
  
  jointStr = "{"
  for index1 = 1 to numOfRobots
    jointValues = robotGroups[index1].PFb
    jointStr = jointStr + chr$(34) + robotNames[index1] + chr$(34) + ": ["
    for index2 = 1 to robotGroups[index1].ElementSize
      if index2 = 4 then
        temp = 0
      else
        temp = 50
      end if
      jointStr = jointStr + STRD$(-jointValues{index2} + temp, "%.2f") + ", "  
    next
    jointStr = LEFT$(jointStr,LEN(jointStr)-2) + "], "
  next
  jointStr = LEFT$(jointStr,LEN(jointStr)-2) + "}"
end sub

'---------------End of functions---------------'

Run RoboDK

Copy paste to your folder "Fanuc_Delta.rdk" prepared by Servotronix include

  • Delta robot from RoboDK library
  • Prog1 a pyton script which open TCP/IP socekt to work with softMCSIM / serv4del.prg

Double click on the Prog1 icon to open RoboDK TCP/IP port and make sure you see in ControlStudio Message "client is connected"

TCP/IP port
Close
TCP/IP port
Open
DeltaExample2.jpg DeltaExample3.jpg


Prog1

import mcEnv
    
host, port = "192.168.56.103", 7132
finsihedTransmit = False

MCE = mcEnv.MCenv()
MCE.setSimulationSpeed(1000)
MCE.connectClient(host,port)
MCE.setRobot("robot1", "Fanuc M-1iA/0.5S")

robotList = ["robot1"]

while not finsihedTransmit:
    MCE.writeStr("ready")
    jsonStr = MCE.readJsonStr()
    MCE.moveRobots(robotList, jsonStr)
    
raise Exception('Finished')

Robot Programs Example

Here is a simple Pick and place program Where P12 and P11 are the upper position and P2 and P1 are the lower position

|DeltaCapture01.JPG

'------------------------------------------------------------------------------
' File:        PnPTDelta.prg
' Purpose:     Robot Pick & Place
' Version:     1.00
' Author:      DVG
' History:     15.Jun.2017    -    created
'------------------------------------------------------------------------------

' module global "constants"

 
' module global variables
dim shared ZeroPosition as joint of xyzr = {0 , 0 , 0 , 0 }                'Moving as joint - for initial positioning
dim shared P1Position as joint of xyzr = {0, 0, 0, 0}                      '{J1,J2,J3,J4}

dim shared P1    as location of xyzr = #{0 , 75 , 300 , 0 }     '{X,Y,Z,R}
dim shared P11   as location of xyzr = #{0 , 75,  225 , 0}
dim shared P22   as location of xyzr = #{0 , -75,  225 , 0}
dim shared P2    as location of xyzr = #{0 , -75,  300 , 0}
 
dim shared RobotVelocity as double = 40.0
dim shared RobotTranVelocity as double = 40.0
 
program
 
    with Delta                                'set default group element, no need to explicitly indicate the motion element
        Attach                               'Attach the task to motion element (with Delta)
            En = TRUE
            Sleep 100
            Vcruise = RobotVelocity          'Set robot's cruise velocity 
            Vtran = RobotTranVelocity
            while NOT En
                Sleep 100
            end while
            Move ZeroPosition                'moving to zero position
            WaitForMotion Delta
              call pickPlaceXYZ              'execute Pick and Place function
            Move ZeroPosition
            WaitForMotion Delta
        Detach
    end with    
 
end program
 
 
sub pickPlaceXYZ
 
    dim i as long
 
    Move Delta P1Position
    WaitForMotion Delta
    Delta.BlendingMethod = 2                  'Type of motion blending - 2 is SuperPosition blending - in order to optimize movement, so that it will be as fast as possible
    Delta.BlendingFactor = 80                 'Percentage of the movement’s length that will not be blended with the next movement
    Delta.Cp = 10                             'At continous path blednign, sets the blend radious value - bigger equal smoother
    for i = 1 to 10
        Moves Delta P11 
        WaitForMotion Delta
        Moves Delta P1
        WaitForMotion Delta
        Moves Delta P11
        WaitForMotion Delta
        Moves Delta P22
        WaitForMotion Delta
        Moves Delta P2
        WaitForMotion Delta
        Moves Delta P22
        WaitForMotion Delta
    next i
    Move Delta ZeroPosition
    WaitForMotion Delta
 
end sub