5 Software Overview

5.1 Connecting to the Robot

The included iPad can be connected to multiple RO1 robots (if needed) after pairing with them.

The home screen of the Standard Bots app shows the list of paired robots and their connection status. Tapping on the “…” button for a robot allows you to: * delete that robot * re-configure it (i.e. to change its network settings, PIN, etc) * show a details screen that can allow you to troubleshoot connectivity issues.

If a robot is powered on but not showing up here, after confirming the tablet is on the same network, check its details and contact customer support.


To connect to your robot, enter your PIN to log in. The default PIN is 0000:

Logging in to a robot

5.1.1 Home Page

The Home Page shows the routines, the current robot, and the end effector that is connected to the robot. In the “routines” tab, you are able to load, edit, and create new routines for the robot. In the tab that shows the connected robot, this is where you can go to move the robot.

Home Page


Once connected to an RO1, the software has a set of global controls in the footer of every page:

Global navigation


There are several important features worth calling out:


Element Name Description
Notifications Notifications Contains a log of failures, errors, and other notifications that have occurred when running the robot. If there are unread items here, there will be a red dot on this icon.
E-Stop E-Stop Trigger an emergency stop and brake the robot.
Robot menu Robot Menu See status of current robot and access settings (see below).
Loaded Routine Loaded Routine Shows what routine is loaded onto the robot.

5.1.2.1 Robot Statuses

The robot menu displays the name of the robot and may show several status indicators:

Status Description
DISCONNECTED The tablet is not able to connect to the robot.
LOADING The tablet is trying to connect to the robot.
MOVING The robot is being manually jogged now.
ANTI-GRAVITY The robot is being moved in Anti-Gravity (hand-guided) mode.
RECOVERING The robot has exceeded joint limits and can be moved back within limits now.
RUNNING The robot is running a routine.
PAUSED The robot is paused in a previously-running routine. You can press ‘Play’ to resume it.
E-STOP The robot is in Emergency Stop mode. Reset the E-Stop button on the control box and any external E-stop buttons.
BRAKED The robot is braked (either from having manually braked it or from a previous E-Stop). It can be unbraked in the Move screen.
FAILED The robot has encountered a collision or has been affected by some other hardware issue.
(blue dot) A software update is available. Check “Software Update” under “Settings”.
INSTALLING The robot is installing a software update.

5.2 Jogging the Robot

The “Move Robot” tab brings you into the Move page.

This shows a visualization of the RO1. The switch on the top allows you to switch between visualizing (and controlling) the real robot or a simulated robot.


Move page


At the right of this screen are several useful tabs:

Icon Tab Name Description
Tooltip Move Menu to access the “Joints” and “Tooltip” Tabs
Joint Joints Controls position of individual joints.
Gripper Gripper Controls any connected gripper
Space Space Allows defining points and grids that can be referenced in the routine
I/O I/O Shows the status of the I/O ports and allows manually toggling them. Hidden behind the three dots icon.
Joint Tooltip Jogs the robot’s tooltip in Cartesian space

5.2.1 Jogging Tooltip

When jogging the tooltip, you are able to control the X, Y, Z coordinates of the tooltip, as well as the roll, pitch, and yaw.

This can be switched between “Base” (where the reference frame is the robot base) and “Tooltip” (where the reference frame is on the robot’s tool flange). Moving to tooltip mode can be useful for maneuvering the tooltip in and out of tight spaces.

Base, Tooltip, and Mode icons

Selecting the “Mode” icon allows you to switch between continuous and incremental jogging. With continuous jogging, holding down a move robot icon will allow to robot to move as long as the icon is held down. With incremental jogging, when tapping on a move robot icon, the robot will only move a specified distance, this can be useful when fine tuning positions.

Jog Modes

For safety, manually jogging the robot is always capped at a speed below the maximum that will apply when running. To make the robot jog even slower, you can change the global speed % slider in the robot menu.

5.2.2 Jogging Joints

The robot’s joints can also be moved directly. This can be useful in avoiding collisions and in planning moves to minimize cycle time.

When moving the robot, there could be times when the robot cannot further move in a direction when the robot is not fully extended (certain actions will be grayed out). When this happens, check your Jog Joints tab to make sure there isn’t a joint that is at it’s joint limit.

Motion Limits
J3 Joint Limit

5.2.3 Entering Exact Values

When jogging in either mode, if you want to enter a more precise value, you can press the blue mode button in the top right. Once you’ve entered the values you want, hold down the “Hold to Apply Changes” button at the bottom of the panel.

Entering exact values for tooltip Entering exact values for joint positions

5.3 Managing Equipment

To manage equipment in the cell, including grippers, 7th axis devices, CNC machines, and more, open “Equipment” from the robot menu.

Robot equipment menu

The equipment configured on the robot can be seen in the list on the left. To add new equipment, press the plus sign button in the upper right. Various settings for each connected device can be controlled on the right.

Equipment Page

Currently, only one gripper can be added at a time (except when using the onRobot Dual Quick Changer). When adding a single tool on a single changer, you do not need to define a changer and instead simply add the tool.


Add New Equipment Tab

To remove equipment select the equipment that you would like to remove.

Then select the ‘circle with the three dots’ icon at the upper right of the tab to reveal the delete icon.

Delete Equipment Icon

Certain m8 equipment will need access to the flange inputs and outputs. To make your customer gripper for this equipment, to go to the Equipment tab, select the robot’s name in the lower left corner of the page and then select Equipment. Once here select the plus icon, then gripper, then custom gripper.

Custom Gripper Icon

In the custom gripper page, select Add Interface, and then change the Type to Tool Flange I/O. Here you can view the pin map, change the voltage from 24V to 12V and change the circuit type from PNP to NPN

Custom Gripper Interface

In the Tooltips tab you can add a new tooltip and adjust the TCP offset and rotation of the equipment. In the Actions tab you are able to control the actions such as actuate, reset, clamp, unclamp. You can also change the control from the control box I/O to the tool flange I/O. And in the sensors tab you can add sensors and change their input ports.

To access the flange I/O in the move robot page, go to the three dots icon in the upper right, select I/O, then select Flange.

Flange I/O, Move Robot Page

To access the flange outputs in the routine editor page, go to Add Step, then select the Set I/O Output step. On the right side of the page there will be a list of outputs to select. At the bottom of the list will be the flange outputs.

Flange Outputs, Routine Editor Page

You are able to access the flange inputs for routines as well. For example, in a wait step, select Rule, then I/O, then at the bottom of the list you can find the flange I/O. So in this wait step, the routine will wait until one of the flange I/O goes high or low.

Flange Inputs, Routine Editor Page

5.4 Robot Settings

Settings for the robot are accessed via the robot menu. User interface settings are accessed separately within settings via the hamburger menu.

Robot menu  Robot settings menu


The following options are available on the RO1:

Section Name Description
Safety Speed limits, configuration of safeguard devices connected to I/O ports, and collision sensitivity settings
PIN Update the robot’s PIN
Robot Name Name displayed in UI to distinguish it from any other RO1s you may be using.
Software Update Allows checking for and installing any available software updates
Backups Allows making and restoring from backups via external disk connected to USB
Interface Settings Allows switching between imperial and metric units for displaying lengths in the UI
Box Robot Places robot into pose that allows it to fit in Standard Bots’ provided foam case in case it needs to be returned.

5.5 Singularities

A singularity is a configuration in which the robot end-effector becomes blocked in certain directions. A robot is unable to maintain a constant velocity while passing one.

The RO1 handles this by never planning motion paths through singularities. If the robot is programmed in a manner in which it will encounter a singularity, the UI will display a “Motion Planning Failed” error and the robot will not attempt the movement.


To ensure routines are not created in which the robot will encounter a singularity, the user interface requires a play-through of any new routine in a simulation mode before running it on a real system. This ensures all motion plans are valid before running on a physical robot arm.

5.6 Routines

Standard Bots uses an intuitive “no-code” approach to programming the RO1 robot. The programs in the robots are referred to as “Routines”. The routine reads as a story. Routines can be developed and tested in simulation without moving the actual robot. The robot can store multiple routines. Routines contain all information the robot needs to complete the programmed task including moves, speeds, setting/reading IO, communicating with external equipment and more.

5.6.1 Routine Creation Example

Routine Access

To get to the Routines area of the interface, return to the home page.

Existing Routines will be shown in the main window, and can be viewed and edited by clicking on them. To create a new routine select New.

New routine
Routine Name

To create a new routine, give it a name under Routine Name.

Routine Interface

The routine interface is where you can add a description of your routine, and to edit and create steps.


1.Return to the Space.

2.Return to Routine list.

3.The Routine name.

4.Go to the Space.

5.Add variable to use in the Routine.

6.Lock or unlock editing.

7.Load this Routine onto the robot.

8.Add a new Step into the Routine.

9.List of Steps in the Routine

10.List of Step types that can be added to the routine.


If you are using a Standard Bots-supported tool, first add it using the manage equipment button on the robot page. If you are not using a supported tool, no need to add it. It will be controlled over I/O directly.

Equipment Page
Add Equipment

You will be directed back to the equipment tab to add the equipment. Click the +add to add the equipment. Select the equipment you have from the list. For our example, select OnRobot 2FG7. When adding a single tool on a single changer, you do not need to define a changer and instead simply add the tool.

Return to Home

Select the back arrow in the upper left to go to the Home Page and then select on your routine to return to the Routine Page.

Add Step

Click Add Step to begin creating the routine.

Move Arm

The menu will show all available step types with descriptions. For the sample routine, we will start with a Move Arm Step. A Move Arm step is how you tell the robot to go to a position. Click the Move Arm step to add it to the Routine.

Move Arm Added

The Move Arm step will be added to the first line of the Routine. The yellow ! Indicates that an action is required for that step. Click the step to edit the step.

Move Arm Details
  1. Editable description for this Step.

  2. Specify the position for the robot to go to based on the current position.

  3. Specify the position for the robot to go to based on a saved position from the Space.

  4. Specify the position for the robot to go to based a math function and/or variables.

  5. Edit the position for the robot to go to based on the current robot position.

  6. Go to this position in a straight line (from the Tooltip perspective),

  7. The robot can sometimes reach a point in multiple ways, this tells the robot to use this exact orientation when going to this point.

  8. Reduces the motion smoothing like overshooting or false collisions.

  9. Set the speed as a % of maximum defined in the Edit Motion Limits Settings.

  10. Shows that the position has been saved.

Add from Space

For our example we are going to select From Space. Defining a point in the Space allows you to use it in multiple places in the routine. Defining a point in the Space also lets you more easily modify the point in the future.

Add from Space Details
  1. The indicated drop down will have all the positions from the Space listed. We have not defined any yet.

  2. Select the Manage Space button to go to the Move Robot view.

Adding Variable Position

You will be brought back to the Move Robot view under the Space option in the upper right. Click the + button to add a new variable position.

Add Single Position

Select Single Position to create a new saved position.

Add From Space Details
  1. Give the position a name.

  2. Select Create.

Set Position
  1. Set will set the position named “Position 1” to the current robot location.
Go Here
  1. Go Here will drive the robot to the saved position if held down.

    Tooltip jogging area
  2. Use the Tooltip jogging area to move the robot to the desired initial position.

  3. We are going to set a safe position above our work area for the robot to go to every time we start the routine.

Jog Robot
  1. Jog the robot to the desired position using the arrows.

  2. If needed, use the menu to change the robot speed.

  3. Once you are in the desired position, use the Space icon to return to the Space positions.

Set Position
  1. Set the position to the variable “Position 1”.

  2. Select the back arrow to go back to the routine.

Save Position

Select our new saved position “Position 1” from the drop down.

Next Step
  1. We now have our first step at the beginning of the routine.

  2. Click + Add Step to add our next step.

Actuate Gripper

Often you will want to set your tool configuration at the beginning of the routine as you do not know how it will be left every time the robot stops. Select Actuate Gripper.

Select the Actuate Gripper the step to edit the step.

Actuate Gripper Details
  1. If we want to close the tool with some force select the Grip object with force checkbox. Since we are opening, we will change this option to Move To Position.

  2. Set the GRIP DIRECTION to inward.

  3. Set the gripper WIDTH, since we are opening, we will set it wide open

  4. Set the FORCE to grip with. We will leave at 20N as we are opening.

  5. Set the PAYLOAD for the target. Since we are just opening, this will be left at 0kg

  6. Set the TOLERANCE for the gripper to be considered successful. This will be left at 2mm.

  7. Click Configure End Effector Target.

  8. The live robot page will open. Press the “Hold to Apply Changes” and then “Confirm End Effector Position” in the upper left. You’ll then be brought back to the Routine page.

Add Loop Step
  1. Select + Add Step as we did for the last two steps to add another step.

  2. Select Loop.

  3. Click on the Loop step to be able to edit the step.

Loop Details

For Loop under Basic Options you can choose to:

•Loop Forever: Loop until the program is stopped by the user.

•Loop specific number of times: Loop the number of times specified before going to the next step.

•Use Rules: Allows you to use math and variables to set the number of times the loop runs.

For our case leave as Loop Forever

•Under Main Loop you can choose:

•Automatically assign Main Loop: Set the loop that is to count the number of times the routine runs as the one index most left in the routine window.

•Manually assign Main Loop: Set the loop that is to count the number of times the routine runs manually in the Loop setting using the checkbox below.

For our case leave as Automatically assign Main Loop.

Loop in Routine

The Loop will have a warning that steps are required below it when first added to the routine. Steps that are indexed to the right will loop according to what we set as the Loop parameters. If we add a step that is in line with our last Actuate Gripper instead of indexed over to the right, they would happen after the loop. Click Add Step in the transparent area below the loop to add a new step.

Add Offset

Often you want to approach a position from an offset based on the end position, for example when picking a part. If you do not set an in between point to ensure you approach the part from the top, you may approach it from the side and knock into it with the tool. Select Add Offset to add an offset to our next move in the loop. Click the step to edit our newly added Add Offset.

Add Offset Details

You can offset the part in X, Y or Z by a positive or negative offset.

We will be picking from above the part, so add a 0.1 meter offset in Z.

Add Offset Index

The newly added Add Offset will have a warning that it requires another step below it to offset. Any move below and indexed to the right of our Add Offset will be offset by the .1 meters we set in positive Z. Select Add Step in the translucent step below Add Offset

Offset Move Arm

Select another Move Arm command. As we did in the first step, use the Space to move the robot to the pick position and create a new Single Position as a variable named Pick Position in the space.

Add Offset Details
  1. Select another Move Arm command.

  2. As we did in the first step, use the Space to move the robot to the pick position that you want, and create a new Single Position as a variable in the space.

  3. Select From Space.

  4. Set the target as our new position Pick Position.

  5. Ensure Match Joint Angles Specified is not checked as this is not allowed inside of an offset.

Add Another Step

Next we want to add another Move Arm step. We want this step to be within our Loop, but not offset by our Add Offset so instead of clicking the +Add Step, select the three dot icon to the right of the Add Offset step, and select Add Step Below (you and also drag and move steps by selecting the orange “Reorder” icon at the top of the page ).

Add Actuate Gripper

Next we will be adding another Actuate Gripper command.

  1. Select the three dot icon on our new Move Arm Step.

  2. Select Add Step Below.

  3. Choose Actuate Gripper.

Configure Actuate Gripper

Configure the tool as shown, which will close the tool on a part with 80N of force.

Add Another Offset Move

As we did before the pick, configure another offset move to move above the Pick Position. This will ensure we do not drag the part before we move to the place. The routine should look like the image above.

Final Routine

As we did for the pick, configure another set of steps to go to an offset above a new position, Place Position, go to the Place Position, Actuate the tool, and go to an offset above the Place Position. The routine should look like the image above. This routine should now continuously pick and place until it is manually stopped.

5.6.2 Running Routines

Run Routine

To test the routine, select the Play Routine icon.

Start Visualizer

Select Start Routine Visualizer.

Visualizer Details
  1. The robot will start completing the routine in a virtual environment.

  2. The step the robot is currently completing will show on the left side of the screen.

  3. The value of all Variables is shown in the upper right.

  4. The routine will only loop once the first time. If you hit the “resume routine” button again it will loop indefinitely.

IO Menu
  1. The I/O menu (hidden behind the three dot icon in the upper right) can be selected to show the IO values as the routine is running.
Gripper Menu

1.The Gripper menu can be selected to show the tool settings as the routine is running.

Go to Next Step

If the routine looks correct, it is ready to run on the physical robot. Select the blue Next button.

Run pre-flight Checks

Select Run Pre-flight Checks.

Verify Tool

Ensure the tool is in an acceptable position based on the start of your program. In our case we start by opening, so ensure the gripper is empty if you don’t want to drop the product.

Test Run Button

Click the blue Test Run button.

Set Maximum Speed

1.Select the maximum speed you want the end of the arm to move for the initial run by setting Max Tooltip Speed.

2.Click the Start Test Run on Live Robot button.

Run Routine
  1. Click and hold the Hold to Move Arm to Position button to move the robot to the first position in the routine.

  2. Watch the robot to ensure there are not going to be collisions during this move.

  3. The routine will run at the specified reduced speed once and stop.

  4. If the routine looks good, you can now play again with the “resume routine” icon that will appear in the upper right, and it will run at the speed specified in the menu in the lower left.

    Accessing the Routine’s Schema

    In the Standard Bots UI, you are able to access the routine’s schema. This allows you to copy, delete, and make changed to the schema of your desired robot routine.

    1. To access the routine’s schema, first go to the routine editor page of your desired routine.

    2. Next, select the three dots icon at that is located at the top of the page.

      Run Routine
    3. Then select the Schema icon

      Run Routine
    4. Once here you can access and make changes to the schema of your routine. At the bottom of the page are three buttons: Clear, Copy, and Update Routine. The Clear button deletes the schema, the Copy button copies the entire schema to your clipboard, and the Update Routine button saves the changes made to the schema. At the top of the page is a Create New Routine button. This allows you to create a separate routine with the changes you made instead of changing the existing routine.

      Run Routine

5.7 Advanced Routine Functionality

5.7.1 Variables

Variables can be used to assist with a variety of tasks within a routine such as:

Variables

To create a variable, locate the variables are in the routine editor.

Variable Settings

When creating a variable, be sure to set an initial value. If no value is set, the variable will be set to 0. The value in the initial value box will be used set for the variable every time the routine is started.

Using Variables

To use a variable in the routine, click the “Fx expressions” button in the given area of the step. There are several sets of variables available.

Expressions Reference: Help menu on how to construct expressions

Step Variables: Data from each routine step that can be used, for example the number of times it has been executed in a loop.

Environmental Variables: Variables created by the user in the routine.

IO Input Variables: Access to each of the 16 24VDC inputs, 0 if off 1 if on.

Gripper State: For supported grippers, inputs based on current state, for example closed or open.

Space: Data set in the space, such as saved positions.

Note: If you are using a variable, you must add it using the “Fx expressions” button and then go to the three dots icon to find what variable you want to use (custom variables made will be found in “Environment Variables”). Do not manually type it in. Manually typing the variable will not include the correct prefix and will result in an error.

Here is an example of how to “add 1” to the value of a variable:

  1. select the “set variable” step

  2. select the variable you wish to add to (this example uses a variable named “index”)

    Select Variable
  3. select the three dots icon and click “environmental variables”.

    Environmental Variable
  4. Then select the variable you wish to change, it should automatically appear in the value bar. Notice how it’s shown as “Environment_…”, typing in the name of your variable into the bar will not work.

  5. Then put “+1” in the value bar.

    +1 to variable
  6. Now every time the routine gets to this step, the value of “index” will increase by one.

This doesn’t have to be only for addition, other math functions can be done as well.

5.7.2 Javascript

The Standard Bots routine editor provides the necessary instructions that address the requirements for the majority of applications. Should you need to to incorporate more advanced functions, the routine editor allows you to write your own JavaScript into Loops, Add Offsets, Move Arm steps, and more.

Expressions Reference

You can access the above help menu by clicking “Fx” in any text window in the routine editor and selecting “Expressions Reference”.

Row Loop

In the above example, this loop will iterate until the loop has iterated more than the value set in an environmental variable, partsPerRow. After the loop has iterated more times than the value of partsPerRow, the routine will move to the next step after what is contained in this loop.

If Javascript If Javascript

In the above example, the code is checking if a variable boxCountOnPallet is less than or equal to 16 but more than 8. If the above condition is true, whatever is indented below the If statement in the routine will execute.

Some Examples of JavaScript Code are Below:

Command Description
> Greater Than
< Less Than
>= Greater Than or Equal To
<= Less Than or Equal To
== Equal To
=== Strictly Equal To
!= Not Equal To
!== Strictly Not Equal To

Basic Math Symbols Apply “+” for Addition, “-” for Subtraction, “*” for Multiplication, and “/” for Division.

Programming Example: We want to wait for Variable 1 to equal 18. That would be created in a If Fx Expression as follows: Environment_variable1 == 18 where Enviroment_variable1 is Variable 1 and we are waiting for it to be equal to 18 to continue the program.

5.7.3 Grid Position Lists

Grids are often used in robot programming when a large number of parts needs to be processed by a robot. Using the Grid Position List functionality when creating a routine can save significant time and effort.

Grid Positions

To create a grid, go to the Move Robot area, go to the Space (square icon), select the Plus icon, and then select Grid Position List.

Grid Name

Give a name to the Grid Position List.

Grid Creation

To create the grid, first drive the robot to a corner of the grid using the Jog Robot functionality in the Move Robot view. Set the position. Repeat for 3 corners of the grid.

Under Layout, select the number of rows and columns in the grid. This will be the layout of the parts within the grid.

Generate Grid Positions

Select “Generate Position List”.

Grid Tuning

After the grid is generated, you can go to the positions using “Go Here”, tune them by using “Replace Position” (hidden behind the three dot icon), or exit.

Move Arm Grid

To use the grid, use a Move Arm command within a loop and select the grid within the “From Space” option. The robot will move to the positions in the grid, in order, each time the loop executes.

To program a grid with multiple layers, use an “Add Offset” to set an offset to the grid positions based on the number of times the loop has executed.

5.7.4 Freeform Position Lists

A Freeform Position List is a list of positions in an array. This can be useful when programming if you need to go to positions in order in a loop that are not in a grid, or indirectly address positions.

Freeform Position List

To create a Freeform Position List, go to the Move Robot area, go to the space (square icon), select the Plus icon, and then select Freeform Position List.

Position List Name

Give the position list a name.

Position List Set

You can now drive to your first position using the Jog Robot functionality in the Move Robot view. Set the position. Repeat for the number of positions needed. Create the next position in the list using the “+” icon.

Position List Finished

You can touch up the positions using “Go Here” and “Replace” (which is hidden behind the three dots icon). Once finished simply exit.

Position List From Space

To go to the positions in order, use a Move Arm command and select the list from the Space.

Position List From Space

To access positions in the list not in order, use the “Expressions” option as shown. In this example we are going to the position in the list based off the environmental variable “index”.

5.7.5 Push Mode

Push Mode allows you to perform actions while the robot is pushing against an object. The first move arm step will have the robot push against an object until the custom force requirement was reached. That step is finished once the force requirement is reached. Then the next step would be moving the robot away from the object. The steps are performed without the collision detection, allowing the robot to detect the needed amount of force.

Here is an example of implementing Push Mode into a routine:

Step 1 in this example is used to move the robot into the initial position to push the object.

Initial position for Push Mode

Step 2 in this example is enabling the push mode. Set the required amount of force for the robot to stop.

Setting up Push Mode

Step 3 in this example is the robot pushing the object to it’s final position. The robot will stop when it detects the selected force percentage. It is required that “move in a straight line” is selected for this step to work.

Pushing Object

Step 4 in this example is the robot arm backing away from the object. This step is done still under Push Mode because Push Mode turns off collision detection. Once the routine is out of Push Mode, collision detection is back on and if the robot is still pushed against the object an error will happen. “Move in a straight line” will still need to be selected for this step.

Backing away from pushed object

Once the robot is backed away from the pushed object, the steps after can leave Push Mode.

5.7.6 Machine Tending Application

5.7.6.1 Introduction:

Standard Bots offers machine tending solutions by the ability to add a CNC machine into your robot’s equipment. If you are using a Haas machine and are interested in using the Haas Ethernet Integration system, go to chapter 5.7.6.

5.7.6.2 Required components:

5.7.6.3 Integrating CNC Machine:

To add the CNC machine into your robot’s equipment, tap on the robot’s name at the lower left corner of the screen, tap the tab that’s labeled Equipment, then in the equipment tab press the orange plus icon in the upper right. Here you will see the list of the different CNC machines (general lathe, general mill, Haas lathe, Haas mill).

Adding your CNC Machine

If you are using a generic lathe or mill, select the desired one. Once doing so you will be brought to the generals page. On the generals page you will be able to name your equipment, enable/disable your equipment, and add Modbus TCP and Haas NGC if desired.

General Page

You can then select Cycle Control which can be seen on the top of the page. To tend a machine, the robot requires the ability to start the machine and to know when the machine is finished.

If the machine and the robot cannot be connected directly, these tasks can be accomplished by manually pushing buttons and by reading screens/lights with the robot’s camera.

In the Cycle Control page you will see Start cycle and Machine status.

Cycle Control Page

In the Start cycle page you will be able to choose which output or relay is used to start the machine’s cycle as well as if it goes high or low. You will be able to choose whether the output is set or if it is just a pulse. If pulse time is chosen you will also be able to choose the length of the pulse time. At the bottom of the page you can test the start cycle as well as add more outputs if needed. Make sure to save any changes in the upper right

Start Cycle Page

In the Machine status page you can set the inputs for machine running as well as machine faulting. For machine running, the robot will have assigned inputs which will monitor the machine’s status during its routine. For machine faulted, the robot can have assigned inputs which will monitor the machine for a fault status.

Machine Status Page

You can then backout and select the Door icon which can be seen on the top of the page next to Cycle control. Here you can set outputs which can control the opening and closing of the machine’s door. You will be able to choose whether the output is set or if it is just a pulse. At the bottom of the page you can add more actions if needed.

Door Page

Next, in the Workholding page, you can set workholding equipment in your machine which the robot can send outputs to. At the bottom of the page you can add more workholding equipment if needed.

Workholding Page

The actions for the workholding equipment are separated into Clamp and Unclamp. For each one you are able to choose the output from the control box, its state, and whether that state is a pulse or if it’s set. You are able to add more outputs to each action if needed. At the bottom of the page you can add more actions if desired.

Chuck Configuration

When done, make sure to save your machine. Your machine will now be shown in the equipment tab. To make any new changes to it, simply click on your machine’s name.

Equipments Tab

5.7.6.4 Accessing CNC Machine:

Once your machine is added to your equipment list, you are able to access it on your move robot page. Once there, go to the three dots icon in the upper right corner of the page and select your machine.

Here you can see the status of your machine, as well as the ability to start the cycle, open and close the doors, and open and close your workholding equipment.

Machine Status

5.7.6.5 Creating a Routine- Generic CNC Machine:

In the routine editor page you can find tasks that are made for a machine tending routine. These steps are: Monitor Machine, Operate Autodoor, Run Program, and Operate Workholding.

Machine Tending Steps

For the Monitor Machine step, you are able to choose the machine you created earlier. You dedicate this section of the routine to controlling your machine.

Monitor Machine Step

For the Operate Autodoor step, you can select the machine, as well as choose the action you want to perform with the door (open or close).

Operate Autodoor Step

For the Operate Workholding step, you can select the machine, the workholding piece, as well as choose the action you want to perform with the workholding equipment (clamp or unclamp).

Operate Workholding Step

For the Run Program step, you are able to select your machine that you wish to run. You are also able to choose whether you want the robot’s routine to pause until the machine is done.

Run Program Step

5.7.6.6 Creating a Routine- Haas Machine:

There are also Haas specific steps you can use if you are using a Haas machine. These steps are Monitor Haas Machine and Run Haas Program.

The Monitor Haas Machine step specifies a section of the routine to control the Haas machine. Here you have to enter the ethernet endpoint for the Haas. Here you can also choose whether you want Cell Safe on and if you’d rather use RS232 serial instead of ethernet.

Monitor Haas Machine Step

The Run Haas Program step runs a program on the Haas machine that’s connected over ethernet. Here you will have to enter the program name for the Haas to call (ex: 900.nc). You will also have to once again enter the ethernet endpoint for the Haas. You can choose if you want Cell Safe on, to wait on this step until the Haas is complete, and if you’d rather use RS232 serial instead of ethernet.

Run Haas Program Step

5.8 External IP Communication

5.8.1 Haas Ethernet Integration

5.8.1.1 Introduction

For Haas machines that support Next Generation control (generally 2017 or newer machines) Standard Bots provides a first-class integration suite that allows for ethernet communication between the Standard Bots robot and Haas machine. This allows for quicker setup and more flexibility with less wiring.

Standard Bots provides a set of sample .nc files to get started with an ethernet Haas integration. The integration works by running a main program on the Haas machine (in the example this program is 6000.nc). It then uses Macros 10850 and 10851 to complete handshaking between the Haas machine and Standard Bots robot as shown below:

HAAS Integration Flowchart

Please be sure to review the comments in the sample code. G103 P1 is a required step in the 6000.nc main sample code to ensure the integration that happens through the macros functions correctly. Do not remove this step. If needed, add a G103 P0 as well as several empty lines after to the beginning the machine programs you create to run from the robot (called through macros from 6000.nc) to re-enable lookahead during those programs and ensure the fastest program speed. A P0 will disable block limiting, allowing the machine to look ahead as much as it wants. A number option will limit the number of blocks to look ahead.

5.8.1.2 Requirements:

5.8.1.3 Network Configuration:

In order to ensure a reliable solution the network between the robot and Haas machine must be configured correctly. Setting a static address without consulting the router/network configuration can cause duplicate IP addresses and other issues which will result in the robot not being able to run the Haas programs remotely. The Haas machine must have a known set IP address reachable by the robot for the integration to work through power cycles. There are several acceptable methods to setup a network between the robot and Haas machine:

  1. Configure the Haas machine on a wireless network. The IP address must be set to static on the machine with an address outside of any DHCP range or must be configured to always have the same IP address through the router configuration.
  2. Configure the Haas machine on a wired network with router. The IP address must be set to static on the machine with an address outside of any DHCP range or must be configured to always have the same IP address through the router configuration. Allow the robot to DHCP through the network router.
  3. Run a single cable between the robot and Haas machine. The Haas machine must have a static IP address set manually. Contact Standard Bots Support for assistance setting a static IP address on the robot on the same subnet as the Haas machine.

5.8.1.4 Integration:

  1. Ensure program numbers 6000.nc-6005.nc are available on the Haas machine.

  2. Load Standard Bots sample NC files onto the Haas machine.

    HAAS Network Settings
  3. If using a wired connection, run an ethernet cable from the Ro1 cabinet to the Haas machine cabinet. The ethernet port on the Ro1 box is on the underside of the IO connection points in the box. The ethernet port on the Haas for Machine Data Collect is usually on the upper left when looking at the back of it. To get to the ethernet settings on the Haas navigate to Settings→Network→Wired/Wireless Connection.

  4. Set the Haas machine up to communicate with the robot. The robot and Haas machine must be on the same subnet (3rd set of numbers in IP address) and be on the same wireless or wired network to communicate with each other. To ensure Haas can talk to the robot even through a power cycle the Haas must be set to a static IP address (no DHCP) or have network provisions made to ensure it is always the same IP address.

  5. Enable machine data collect on the Haas (settings 143) and set the port to 5551.

  6. If you are using a wired connection without DHCP, use the Standard Bots tablet application to set the IP address. You may need to log out of the User Interface by going to robot name menu in the bottom left then selecting Logout.

  7. Load the sample “haas test” program provided by Standard Bots into the routine editor by going to Actions-> Edit Routine Schema and pasting the contents of the text file in. Then select “Create Routine”.

    Monitor Haas
  8. Edit the first step of the sample routine. Leave the “Send Haas Cell Safe” button checked. This allows the robot to run routines with the door open, which is often required (IE, when you need to close the door).

  9. Update the IP address of the Monitor Haas Machine step to match the IP address of the Haas. Ensure the port remains at the end of the address. The format is: http://xxx.xxx.xxx.xxx:port . I.e., http://192.168.215.175:5551. Save the step.

  10. Go back and edit Step 4, Run Haas Program.

    Run Haas
  11. The “haas test” program will attempt to run 2020.nc. In many Haas machines, this is the spindle warmup program. If needed, change this program number to a different program under “Program Name”.

  12. Leave “Wait until Complete” checked. This will ensure the routine stays at the current step until the Haas has completed the program sent above under “Program Name”.

  13. Update the IP address of the Monitor Haas Machine step to match the IP address of the Haas. Ensure the port remains at the end of the address. The format is: http://xxx.xxx.xxx.xxx:port . I.e., http://192.168.215.175:5551. Do not use 127.0.0.1 as that is the default loopback address. Save the step.

  14. Start program 6000.nc on the Haas using the standard cycle start button on the Haas.

  15. Start the sample program on the robot by running the routine.

  16. The spindle warmup program (or alternative program chosen above) should now run. If it does not work verify the 10850 macro variable on the Haas is updating to the program number you put in the Run Haas Program step. If it is not, verify communication between robot and machine. The Haas machine must be running the 6000.ns]c program with no errors first, then you must start the robot program.

5.8.2 Modbus

One way for the robot to communicate with other devices is through Modbus, one of the oldest and most widely used communication protocols in industrial settings. Modbus provides a common language that enables different devices to communicate with each other (such as an Allen Bradley PLC talking to a Siemens PLC), allowing devices from different manufacturers to work together. A Modbus Controller initiates communication and manages the data exchange between the compatible devices.

Modbus can operate over various physical layers, including serial communication methods like RS-232, RS-485, and RS-422, as well as Ethernet. Modbus TCP allows Modbus communication to occur over TCP/IP networks, enabling it to coexist alongside other Ethernet protocols.

Modbus can be used to send commands to the Robot, which would allow the Robot to integrate into the automation system. Modbus uses master-slave architecture for communication. In this setup, the Modbus Controller sends requests to the slave devices (such as the Robot) and manages the communication flow. Each slave device responds to requests from the Controller, allowing for data exchange. This architecture simplifies the network.

Modbus Master-Slave

5.8.3 Setting up Modbus

Utilize the following steps to setup Modbus.

Step1) To setup Modbus communication with your RO1 click on the menu in the bottom left corner and select equipment.

Step 1

Step 2) Click on add equipment, generic I/O, Modbus TCP Server.

Step 2

Step 3) Provide a Name for the Modbus TCP Server, IP Address, Port #, and Timeout.

Note: For this demonstration we will be using an IP address of 192.168.10.24, Port 502, as well as a 10 second timeout. This will vary based on your application.

Step 3

Step 4) Click on add field and select the field type you would like to use. You can choose from the following types: Holding Register, Input Register, Status Coil, or Input Coil.

Note: For this demonstration we will be using a Holding Register.

Step 4

Step 5) Provide a name for your field. When complete click save in the top right corner.Note: For this demonstration we will be naming the Field HR1 as we will be setting up a holding register. The offset will also remain zero for this demonstration.

Step 5

Note: To add additional fields repeat steps 4 & 5 as desired.

Step 6) Once you have selected save you should see your modbus tcp server added to the equipment list.

Step 6

Step 7) Once you have added a Modbus TCP Server to your equipment you can now utilize it in a routine. Open up the routine and add a new step. Select “Network Request”.

Step 7

Step 8) Select which Modbus server you would like to use.

Note: For this demonstration only one modbus server has been set up.

Step 8

Step 9) Select the type of Modbus function you would like to request. The user can select either Read holding register or write single register.

Note: For demonstration purposes we will be selecting “Write Single Register”.

Step 9

Step 10) Select what field you would like to write to, and what value you would like to write.

Note: HR1 was selected this was setup in step 4 & 5 We will be writing a value of 0 to HR1. This will be used to tell the external device that we are done with a particular step.

Step 10

Step 11) Next we will repeat steps 7,8,&9 however this time we will setup a read holding register request. Our read field will be HR1 and we will want this to be sent to our “Receive In” variable.

Note: See Creating a Global Variable section for setting up variables.

Step 11

5.8.4 Modbus Routine Examples

5.8.4.1 Reading from a Register Example

Note: This example demonstrates how Modbus can be employed to read a value from a single register and assign that data to a variable within the routine for subsequent use or decision-making. This approach proves beneficial later in the routine, as the value of the “vice status” variable can be leveraged to inform critical decisions.

Summary: Step 24 illustrates the process of reading the holding register, h1, following the closure of the vice in Step 22. The retrieved value is subsequently assigned to the Vice Status variable, as highlighted in Figure 1. Note: Vice status variable was setup prior to adding the network request step.

Figure 1

5.8.4.2 Writing to a Register Example

Note: This example illustrates a machine tending application, where Modbus is utilized to write a value to a single register for controlling an air blow-off nozzle mounted on the end effector. The primary function of the blow-off tool is to remove any debris from the part before the robot proceeds to pick up the finished component.

Summary: Steps 38-41 illustrate the process of writing a value to a holding register within a routine. This is clearly highlighted in Figure 1.

Figure 1

In step 39 a value of 68 is written to the holding register, h1, to turn on the valve for the blow off tool. This can be seen in Figure 2.

Figure 2

The robot arm then moves to its end location in step 40.

In step 41 a network request is then made again to shut the valve for the blow off tool off again. This is accomplished by writing a value of 0 to the holding register h1. This can be seen in Figure 3 below.

Figure 3

5.9 API

All APIs should be treated as Beta software. While software that is controlling the robot through the API is being developed the robot should be safety guarded as a mistake in the software being developed can result in unexpected motion. Access to the API is granted on a case by case basis. Please contact [email protected] to discuss access to the API.

5.10 Global Space & Variables

5.10.1 Introduction to Global Space Items.

(Note: section was written using software update version main 4608.)

The following section defines and explores use cases for global space items as well as global variable items.

5.10.1.1 Global Space Items

Global space items allow users the ability to access a saved robot position in space across all routines.

5.10.1.1.1 Types of Spaces

5.10.2 Creating a Global Space

Note: for this example we will be making a single position global.

Step 1) In your routine click on “Manage Space”

Manage Space Button

Step 2) Move the robot to the desired position and select “+” from there you will be prompted to choose the type of space you would like to add.

Move Robot To Space and Select “+”

Step 3) Click “Single Position”

Adding a new Single Position

Step 4) You will be prompted to name your position. (For this example we will name the position “Home”.)

Name Your Position

Step 5) After naming the space you will be asked to set its position.

Set Space Position

Step 6) Confirm the position was set, indicated by a green check mark that will appear on the left hand side.

Position was set when green check mark appears

Step 7) Once the space has been set, hit BACK found in the top right corner. This will take you back to the main space menu. Once you have returned to the main space menu, locate the space you would like to make global and click on the options for that space. The options button will be indicated by the ellipsis menu icon.

Ellipsis Menu Icon

Step 8) Once in the menu drop down select “Add to Globals” and this space will be able to be accessed across all routines.

Add to Globals Menu Drop Down

5.10.3 Creating a Global Variable

Step 1) In an open routine select add variable.

Add Variable

Step 2) Provide a name and an initial value for your variable.

Note: In this example we are making a part height offset and our initial value will be 1.

Naming a Variable

Step 3) To make this variable global click the switch that is labeled global. This should turn green. Click Save.

Select Global