LSS FlowArm


Page Contents
Description
The LSS FlowArm application is intended to allow easy control of the standard Lynxmotion Servo Erector Set (S.E.S.) v2 articulated robotic arm. The graphical interface shows multiple views of the arm which can be controlled via drag and drop, as well as by manually inputting coordinates. The full-featured built-in sequencer allows you create sequences which have the arm move automatically from one position ("frame") to the next. Make use of the "teach mode" to position the arm where you want and record frames which can be modified and played back. Associating each pattern with input keys means you can easily play back and test multiple sequences.
FlowBotics Studio was used to create this app and includes hundreds of built-in components that allow you to interface your PC to many standard computer peripherals and robotics components, and you can quickly design new components for new hardware. Easily create new projects with custom GUI screens, knobs, buttons, switches, etc. that will run live from within FlowBotics Studio without needing to wait for compilation, or export as stand-alone executable files. FlowBotics Studio includes a powerful graphics engine that allows you to make custom graphical objects by using standard bitmaps or by drawing your own shapes on the screen. Using this system, you can build entirely custom interfaces like this one for your projects and integrate photographs, drawings, and graphs.
Features
- Graphical interface for the Lynxmotion SES V2 articulated robot arm
- Full featured sequencer allows recording and playback of many sequences via keyboard input
- Teach mode allows the user to move the arm and have the virtual arm follow
- Position the arm using rectangular or cylindrical coordinates, virtual joysticks or mouse drag
- Application can be modified via FlowBotics Studio
- Optional data log shows what commands are sent and received and can be saved as a .csv file.
- LSS FlowArm is intended only for Windows operating systems 7 or higher.
Initial Setup
In order to understand the features, functionality and nuances of the Lynxmotion smart servos, it is suggested to read through the lynxmotion-smart-servo section of the wiki.
Before assembling the arm, each of the IDs assigned to the servos must correspond with what is needed in the software.
- Base: 1
- Shoulder: 2
- Elbow: 3
- Wrist: 4
- Gripper: 5
To do so, the LSS Configuration Software is used. Follow the procedure outlined here: lss-config-configure-ids
Important note: The software does not take into consideration if a servo has been improperly assembled as part of the structure. If you see that your arm moves differently than the arm on screen, be sure to check the following:
- Servo ID is correctly assigned to each servo and there are no duplicate IDs
- Servos have been assembled in correct orientation (as per assembly manual)
- Servo offsets have been updated if necessary (see procedure below).
Interface
Header

STORE OFFSETS
During the assembly process, if the servo's driving output horn was not rotated (they are shipped with the driving horn centered at 0 degrees), and was connected to the brackets at the correct angle (parallel or perpendicular depending on the servo being assembled), there should not be any servo offset needed and the arm should match what is displayed on screen. However, should the driving horn have rotated and/or the brackets were not connected at optimal angles, the "STORE OFFSETS" button configures the all of the servo offsets (this makes use of the CO command as part of the LSS Communication Protocol). Before pressing the button, be sure to orient the arm as follows (with the gripper closed), and only then click the STORE OFFSETS button.

LIMP
Causes all servos to immediately go LIMP (i.e. lose torque). The arm will collapse. It's important to note that the software will not constantly query all servos for their position, and as such the virtual arm on screen will not update frequently if at all. If you want the virtual arm on screen to update as you move the real arm, use TEACH mode described below.
STOP
Causes all servos to immediately stop their motion and hold their position.
TEACH
Teach mode allows a user to physically move the arm and have the virtual arm on screen follow. This is used primarily to manually add frames to sequences, determine the optimal closed position for the gripper etc. In order to ensure the arm does not collapse, pressing the TEACH button will start a 5 second countdown during which the arm will slowly lose torque (angular force) until all servos are limp. When in teach mode, an orange outline appears over all on-screen fields which would cause a conflict and therefore cannot be used.
CAREFUL: Do not move the servos or the arm too quickly. We suggest holding the gripper servo to move the arm, or temporarily removing the arm's aesthetic shell.
Once the arm is limp, it can be moved physically, and the application will regularly send position query commands to all of the servos and update the virtual arm on screen to match the servo's responses. Use the sequencer to record each position (frame) while in teach mode. For more information on the sequencer, refer to the sequencer section below.
GRID / Units
Grid spacing can be toggled between Metric or Imperial. Options include 2cm, 3cm, 5cm and 1in, 2in and 3in.
BAUD
The default (and suggested) baud rate is 115200, which is the baud rate at which the servos are shipped. Should a user have changed the baud rate on the servos, it can be selected using the drop down. Note that the baud rate must be configured to the same value for all servos in order to work.
COM
When the software is opened, a scan of all of your computer's COM ports is done automatically and a list of all available COM ports will be found in the drop down menu, along with OFF (stop searching for a COM port), and AUTO (the application tries to automatically find the correct COM port by sending a query command at the corresponding BAUD rate). Select which of your computer's COM ports is connected to the LSS Adapter (which is provided with the standard SES v2 articulated robot arm). If you have a list of available COM ports and are unsure which is associated with the LSS Adapter, go to Device Manager in Windows, and view the list of USB devices connected. The LSS Adapter uses an FTDI USB to serial chip. Alternatively, simply unplug the USB from the arm and see which of the COM ports disappears from the list.
- If the red and green lights next to the field are flashing, the correct COM port has not yet been found, and the user may need to manually select the correct COM port.
- If the red light is solid, then no correct COM port has been located.
- If the green light is solid, the a COM port has been located.
Window Size

A the top right of the window, there are three dark rectangles allowing you to change the application's window size.
Virtual Arm
The arm shown on screen is based on the assembly guide. BETA testers have been encouraged to use the 3:1 gear ratio in the shoulder and as such should have toggled switch 1 in the header. The aesthetics of the arms will be changing for the final / release version of the LSS Flowarm software.
Side View
The left view is a representation of the arm, where the orange circles represent the location of each axis of rotation. You can move the arm in this view by clicking on and dragging the wrist rotation servo.

Top View
The top view shows the arm top down. You can move the arm within this view by clicking on and dragging the wrist rotation servo.

Left Menu
Gripper
Assuming the gripper has been properly calibrated, The number below represents the opening at the tip. Fully closed should correspond to 0 degrees. In order to grasp an object, DO NOT have the servo rotate to a position which it cannot reach. In order to ensure the gripper servo does not go into error mode, the gripper should not exert much force on the object.
- Close the gripper to a position just slightly larger than the object
- Using the arrows, close the gripper until friction between the foam and the object prevent the object from falling out or moving.
- DO NOT apply too much pressure, or else the servo's current will spike and it will go into error mode and need to be reset.
- Use the last position as the "fully closed" position for the gripper for that object, in that specific orientation.

Wrist
The wrist angle can be locked or unlocked. The field allows for user input (click the numbers) or fine adjustments using the arrows.

End Effector Position
The position of the end effector can be controlled either by manually entering the information for R (radius), or the Cartesian x, y, z coordinates, or using the arrows.

Data Log
The optional Data log can be toggled on or off and allows the user to see all commands being sent to and received from the smart servos. The data can be saved to a file in a Comma Separated Values (.csv) format.

Sequencer

LSS FlowArm has a powerful pattern sequencer component (normally found only in the full version of FlowBotics Studio) that is used to create reusable patterns within minutes, instead of hours or days. From left to right:
|  | Keyboard Association | Patterns can be associated to keyboard keys F1 to F12, and keys E, F, G, and H | 
|  | Active Pattern Name | Click on the text to change the pattern name. Use the arrows to navigate between patterns | 
|  | Pattern Options | Add, remove, copy, save, open and delete patterns. | 
|  | Frame Options | Adding a frame adds a blank frame to the list. The drop-down list gives "useful" pre-made frames. Recording a frame copies the arm's current on-screen position. The X removes a selected frame. | 
|  | Copy / Paste Frame | Copy and paste a frame | 
|  | Settings | Useful features include: Toggle pause before frame; Remove gaps between frames; Reverse frames | 
|  | Lock | |
|  | Repeat / Loop Pattern | Play once or loop; Set the playback speed using the up and down arrows. | 
|  | Playback Options | Restart sequence, play or stop | 

Just above the sequencer, you can find a the following:
Keyboard: {More to come}
Live Update:{More to come}
Troubleshooting
If you encounter any bugs or issues when installing or using the LSS FlowArm application, please submit a new post on the Lynxmotion community sub-forum here: https://www.robotshop.com/community/forum/c/lynxmotion/electronics-software
{Work in progress}

