Changes for page FlowArm LSS

Last modified by Eric Nantel on 2024/07/03 09:39

From version < 50.1 >
edited by Coleman Benson
on 2019/09/10 11:58
To version < 69.1 >
edited by Eric Nantel
on 2019/10/17 13:45
< >
Change comment: There is no comment for this version

Summary

Details

Page properties
Author
... ... @@ -1,1 +1,1 @@
1 -xwiki:XWiki.CBenson
1 +xwiki:XWiki.ENantel
Content
... ... @@ -1,6 +1,6 @@
1 -[[image:LSS-FlowArm.png||width="350"]]
1 +{{lightbox image="LSS-FlowArm.png" width="400"/}}
2 2  
3 -[[image:wiki-download.png]]
3 +[[[[image:lynxmotion-wiki-attachments.WebHome@DownloadNow.png]]>>https://www.lynxmotion.com/tools/LSS_FlowArm.zip]]
4 4  
5 5  **Page Contents**
6 6  
... ... @@ -28,20 +28,31 @@
28 28  
29 29  Before assembling the arm, each of the IDs assigned to the servos must correspond with what is needed in the software.
30 30  
31 -* Base: 1
32 -* Shoulder: 2
33 -* Elbow: 3
34 -* Wrist: 4
35 -* Gripper: 5
31 +{{lightbox image="https://www.robotshop.com/info/wiki/lynxmotion/download/servo-erector-set-robots-kits/ses-v2-robots/ses-v2-arms/lss-articulated-arm/lss-articulated-arm-servo-setup/WebHome/SESV2-LSS-ARTICULATED-ARM-IDS.PNG" width="350"/}}
36 36  
37 37  To do so, the [[LSS Configuration Software>>doc:lynxmotion-smart-servo.lss-configuration-software.WebHome]] is used. Follow the procedure outlined here: [[doc:lynxmotion-smart-servo.lss-configuration-software.lss-config-configure-ids.WebHome]]
38 38  
39 -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:
40 -
41 41  * Servo ID is correctly assigned to each servo and there are no duplicate IDs
42 42  * Servos have been assembled in correct orientation (as per assembly manual)
43 43  * Servo offsets have been updated if necessary (see procedure below).
44 44  
39 +== Connecting via USB ==
40 +
41 +The simplest way to connect is directly using the [[LSS-Adapter>>doc:servo-erector-set-system.ses-electronics.ses-modules.lss-adapter-board.WebHome]] (or any RS232 to USB interface). Here are the steps you need to follow in order to set this up. Follow the steps below:
42 +
43 +1. Connect the USB cable to the LSS Adapter board on your robot
44 +1. Plug the USB connector into the PC
45 +1. Connect your LSS to the LSS-Adapter with the Lynxmotion cable
46 +1. Connect the power to the LSS Adapter via the yellow XT60 plug
47 +1. Power on the robot (On/Off switch)
48 +1. Start the LSS FlowArm software
49 +1. Select the appropriate COM port from the drop-down list & the baudrate (115200)
50 +1. The software sends a query to servo ID1 and once a reply is received, it determines connection has been established.
51 +
52 +== Connecting via Bluetooth ==
53 +
54 +If you have purchased a Bluetooth module which is in XBee format, ensure to have the right baudrate on your bluetooth adapter, the default is 115 200 for the LSS.
55 +
45 45  = Interface =
46 46  
47 47  == Header ==
... ... @@ -50,8 +50,14 @@
50 50  
51 51  **STORE OFFSETS**
52 52  
53 -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>>doc:lynxmotion-smart-servo.lss-communication-protocol.WebHome]]). Before pressing the button, be sure to orient the arm as follows (with the gripper closed), and only then click the STORE OFFSETS button.
64 +The "STORE OFFSETS" button configures all of the servo offsets (this makes use of the CO command as part of the [[LSS Communication Protocol>>doc:lynxmotion-smart-servo.lss-communication-protocol.WebHome]]). Before pressing the button, orient the arm as shown below (with the gripper closed), and only then click the STORE OFFSETS button.
54 54  
66 +* Base servo aligned with the x axis
67 +* Shoulder to elbow along z axis (straight up)
68 +* Elbow to wrist along R axis (horizontal at 90 degrees to shoulder to elbow)
69 +* Wrist servo along R axis (parallel to elbow to wrist)
70 +* Gripper servo closed
71 +
55 55  [[image:lss-flowarm-offsets.jpg]]
56 56  
57 57  **LIMP**
... ... @@ -92,7 +92,7 @@
92 92  
93 93  A the top right of the window, there are three dark rectangles allowing you to change the application's window size.
94 94  
95 -== Virtual Arm ==
112 +== Simulator ==
96 96  
97 97  (% class="wikigeneratedid" id="HArmConfiguration" %)
98 98  The arm shown on screen is based on the assembly guide. The aesthetics of the arms will be changing for the next release version of the LSS Flowarm software.
... ... @@ -109,6 +109,22 @@
109 109  
110 110  **[[image:lss-flowarm-top-view.jpg]]**
111 111  
129 +=== Shortcuts ===
130 +
131 +**Base**: If you hold the SHIFT key while dragging with the mouse you can control base rotation.
132 +
133 +**Wrist Tilt**: You can tilt the hand by right-clicking and fragging the mouse up and down.
134 +
135 +**Gripper:** By holding the CTRL key whilst right-clicking and dragging you can open and close the gripper
136 +
137 +Just above the sequencer, you can find the following:
138 +
139 +[[image:lss-flowarm-keyboard-liveupdate.jpg]]
140 +
141 +**Keyboard: **When active (orange), the keyboard keys W/A/S/D and four arrows can fine tune the position of the arm. Note however that LSS FlowArm will respond to any of these keys being pressed even in another window, and for this reason, it is turned off by default.
142 +
143 +**Live Update: **When activate (orange), dragging the virtual arm on screen will send updated positions to the arm with a small time delay in between. With this option off, dragging the arm on screen will not cause any motion until the mouse is released.
144 +
112 112  == Left Menu ==
113 113  
114 114  **Gripper**
... ... @@ -132,39 +132,168 @@
132 132  
133 133  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.
134 134  
168 +When in keyboard mode, there is an overlay indicating which keys do what motion.
169 +
135 135  [[image:lss-flowarm-positioning.jpg]]
136 136  
137 137  == **Data Log** ==
138 138  
139 -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.
174 +The optional Data log (normally hidden) 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.
140 140  
141 141  [[image:lss-flowarm-data-log.jpg]]
142 142  
143 -== Sequencer ==
178 += Sequencer =
144 144  
145 145  [[image:lss-flowarm-sequencer.jpg]]
146 146  
147 -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:
182 +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.
148 148  
149 149  (% style="width:1303px" %)
150 -|(% style="width:257px" %)[[image:lss-flowarm-association.jpg]]|(% style="width:306px" %)Keyboard Association|(% style="width:758px" %)Patterns can be associated to keyboard keys F1 to F12, and keys E, F, G, and H
151 -|(% style="width:257px" %)[[image:lss-flowarm-pattern-list.jpg]]|(% style="width:306px" %)Active Pattern Name|(% style="width:758px" %)Click on the text to change the pattern name. Use the arrows to navigate between patterns
152 -|(% style="width:257px" %)[[image:lss-flowarm-patterns.jpg]]|(% style="width:306px" %)Pattern Options|(% style="width:758px" %)Add, remove, copy, save, open and delete patterns.
185 +|(% style="width:257px" %)[[image:lss-flowarm-association.jpg]]|(% style="width:306px" %)Assign Input|(% style="width:758px" %)Patterns can be associated to keyboard keys F1 to F12, and keys E, F, G, and H
186 +|(% style="width:257px" %)[[image:lss-flowarm-pattern-list.jpg]]|(% style="width:306px" %)Sequence List|(% style="width:758px" %)The sequence list is the first control on the sequencer.
187 +|(% style="width:257px" %)[[image:lss-flowarm-patterns.jpg]]|(% style="width:306px" %)Sequence Management|(% style="width:758px" %)(((
188 +Add, remove, duplicate, save, load and clear all patterns.
189 +)))
153 153  |(% style="width:257px" %)[[image:lss-flowarm-frames.jpg]]|(% style="width:306px" %)Frame Options|(% style="width:758px" %)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.
154 154  |(% style="width:257px" %)[[image:lss-flowarm-copy-paste.jpg]]|(% style="width:306px" %)Copy / Paste Frame|(% style="width:758px" %)Copy and paste a frame
155 -|(% style="width:257px" %)[[image:lss-flowarm-settings.jpg]]|(% style="width:306px" %)Settings|(% style="width:758px" %)Useful features include: Toggle pause before frame; Remove gaps between frames; Reverse frames
156 -|(% style="width:257px" %)[[image:lss-flowarm-lock.jpg]]|(% style="width:306px" %)Lock |(% style="width:758px" %)
192 +|(% style="width:257px" %)[[image:lss-flowarm-settings.jpg]]|(% style="width:306px" %)Operations / Settings|(% style="width:758px" %)Useful features include: Toggle pause before frame; Remove gaps between frames; Reverse frames
193 +|(% style="width:257px" %)[[image:lss-flowarm-lock.jpg]]|(% style="width:306px" %)Lock |(% style="width:758px" %)Timeline locking
157 157  |(% style="width:257px" %)[[image:lss-flowarm-loop.jpg]]|(% style="width:306px" %)Repeat / Loop Pattern|(% style="width:758px" %)Play once or loop; Set the playback speed using the up and down arrows.
158 -|(% style="width:257px" %)[[image:lss-flowarm-play.jpg]]|(% style="width:306px" %)Playback Options|(% style="width:758px" %)Restart sequence, play or stop
195 +|(% style="width:257px" %)[[image:lss-flowarm-play.jpg]]|(% style="width:306px" %)Sequence Playback|(% style="width:758px" %)Restart sequence, play or stop
159 159  
160 -[[image:lss-flowarm-keyboard-liveupdate.jpg]]
197 +**Sequences**
161 161  
162 -Just above the sequencer, you can find a the following:
199 +The sequencer allows you to make your robot move over time by transitioning from one position to another. Each transition we call a frame and a sequence of frames we call a sequence. You can create as many sequences as you like. You can play sequences back manually or using the keyboard inputs mentioned below. This section describes the sequence management functions of the Sequencer.
163 163  
164 -Keyboard: {More to come}
201 +**Sequence List**
165 165  
166 -Live Update:{More to come}
203 +[[image:lss-flowarm-pattern-list.jpg]]
167 167  
205 +The sequence list is the first control on the sequencer. If you click on the arrow on the right-hand edge you'll see a list of the sequences that have been created and by selecting one you can move to that sequence. You can also scroll through the list one-by-one using the up and down arrow buttons. Clicking on the name of a sequence will allow you to change this. Simply type in the box then press the Return key or click away.
206 +
207 +== Sequence Management ==
208 +
209 +[[image:lss-flowarm-patterns.jpg]]
210 +
211 +**Add a Sequence**
212 +
213 +To add a sequence click the add button. A new sequence will appear in the list and its name will open for editing.
214 +
215 +**Remove a Sequence**
216 +
217 +Click the remove sequence button to delete the currently selected sequence from the list. This action is irreversible so you will be asked for confirmation.
218 +
219 +**Duplicate a Sequence**
220 +
221 +If you want to make a new sequence based on an existing one then you can duplicate it.
222 +
223 +**Saving Sequences**
224 +
225 +IMPORTANT: If you want to keep any sequences you create then you must export them otherwise they will be lost when you return to the project browser. 
226 +To do this click the export button. You can choose whether to export all your sequences or just the currently selected one. Sequences are saved to files so you'll need to pick a filename and folder to save to. If a sequence uses sub sequences these will be saved even if you choose only to save the selected sequence.
227 +
228 +**Loading Sequences**
229 +
230 +If you have saved sequences that you want to restore then click the Import button. You will be asked to choose a previously saved sequence file.
231 +The sequences in the file will be added to the list. They do not replace the sequence list. Also it doesn't
232 +matter how many sequences the file contains, all of them will be imported.
233 +
234 +**Clear All Sequences**
235 +
236 +If you want to start from scratch you can clear all the sequences from the list using the clear all button.
237 +
238 +== **Frames** ==
239 +
240 +**[[image:lss-flowarm-frame.jpg]]**
241 +
242 +We now know how to manage sequences now lets see how you build one. As we said earlier a sequence is made up of frames. A frame represents a transition between robot states over time.
243 +In addition to frames, you can also add other sequences to a sequence. This allows quite complex series of movements to be built up very quickly and easily.
244 +
245 +[[image:lss-flowarm-frames.jpg]]
246 +
247 +**Adding Frames**
248 +
249 +To add a frame click the Add button. A new frame will be added at the end of the sequence. The duration of the frame will be whatever the last frame duration was. The frame will record whatever position the robot is currently set to. You can add a sub sequence to the sequence by clicking the arrow to the right of the Add button. A drop list of the available sequences will appear. Select one and it will be added to the end of the sequence.
250 +
251 +**Recording to a Frame**
252 +
253 +When you add a frame it will record the state that the robot is currently in. If you want to change this state first select the frame by clicking on it. Next move the robot to the position you want to record. When you're happy press the record button. The frame will flash to indicate that it has been updated.
254 +
255 +**Deleting Frames**
256 +
257 +To delete a sequence or frame from a sequence, click the Delete button.
258 +
259 +**Naming Frames**
260 +
261 +To name a frame, simply double-click the top blue part of it. You will then be able to enter a name by typing text directly. Save the new name by pressing the [Enter] key once donce. Warning: please note that when double-clicking a frame to name it, it will play the frame which may move your robotic arm suddenly. You may want to activate the STOP button first to prevent movement when naming frames.
262 +
263 +**Timeline Locking**
264 +
265 +[[image:lss-flowarm-lock.jpg]]
266 +
267 +The timeline is locked by default. This means that frames will automatically run from one to the next – you cannot create space in between. Moving a frame past another one will move it along the order in the timeline. If the timeline is unlocked then you can move frames independently of each other and also create gaps of time in between.
268 +
269 +**Moving and Resizing**
270 +
271 +To move a frame on the timeline, simply click on it and drag it to the time you want it to start. The start time will be displayed as you drag. How frames move relative to each other is determined by whether the timeline is locked (see previous section). To resize a frame grab the right-hand edge and drag it. When moving or resizing the mouse snaps to the nearest unit on the timeline. If you hold SHIFT while moving or resizing no snap will be applied. When the timeline is unlocked then if you hold CTRL while dragging or resizing a frame all frames to
272 +the right of the selected frame will be moved so that the time interval between the selected frame and the next one is maintained.
273 +
274 +**Auto Record**
275 +
276 +If you want changes you make to be automatically recorded you can lock the record button in place by double-clicking on it. Now whenever you change the robot position the currently elected frame will be updated. The record button will light up to show that auto record is on. To switch auto record off, double-click on the record button again.
277 +
278 +**Copy and Paste**
279 +
280 +[[image:lss-flowarm-copy-paste.jpg]]
281 +
282 +Sometimes you might want to copy the robot state from one frame to another. To do this we have copy and paste. To copy the data from a frame, select it then click the Copy button.
283 +To duplicate the data on another frame, select the target frame and click the Paste button.
284 +
285 +**Pause Before Frame**
286 +
287 +You can insert a pause before a frame commences. This is useful if you want the sequencer to stop and wait for some external event before continuing. First select the frame then click the Operations button and select Toggle Pause Before Frame. A red line will show at the start of the frame to show the pause. To remove the pause select the frame again and select Toggle Pause Before Frame after clicking on the Operations button.
288 +
289 +**Remove Gaps Between Frames**
290 +
291 +[[image:lss-flowarm-settings.jpg]]
292 +
293 +If the timeline is unlocked then you can instantly remove all the gaps between frames and push them up against each other by clicking the Operations button and choosing Remove Gaps Between Frames from the menu.
294 +
295 +== Sequencer ==
296 +
297 +**Reverse Frames**
298 +
299 +[[image:lss-flowarm-settings.jpg]]
300 +
301 +It's useful to be able to reverse the order of frames in a sequence. To do this click the Operations button and choose Reverse Frames.
302 +
303 +**Sequence Playback**
304 +
305 +[[image:lss-flowarm-play.jpg]]
306 +
307 +Once you have some frames in a sequence you can try playing it. Click the Play button to start the sequencer playing the current sequence. The play button lights up in green when the sequencer is playing. To stop playing click the Play button again or click the Stop button. You can reset the play position to the star by clicking the Reset button. You can also move the play position manually. Click on the black handle at the top of the playback position line and drag to move it.
308 +
309 +[[image:lss-sequencer-handle.jpg||height="70" width="241"]]
310 +
311 +**Assign an input to a sequence**
312 +
313 +[[image:lss-flowarm-association.jpg]]
314 +
315 +You can assign an input to a sequence by choosing one in the drop-down list left of the sequence name. By default a sequence does not have a input associated with it. When you click on that box, you will be presented with a list of possible inputs. A sequence can only have one input associated with it. Similarly, an input can only be associated with one sequence at a time. If you choose an input in the list that is already associated, it will be removed from its previous sequence and assigned to the current one. By clicking on the sequence list, you will see which input is associated to each sequence to the right of their name:
316 +If a sequence is already playing when its associated input is triggered, it will ignore that input and continue playing as normal. If an input that is associated is triggered when a different sequence is playing, it will be stopped and the
317 +
318 +**Decision Frame**
319 +
320 +**[[image:lss-flowarm-decision-frame.jpg]]**
321 +
322 +At the end of every sequence there is a permanent frame called the decision frame (it is orange for easy identification). Click on the top part (orange) to change the last action of the sequence. There are 3 options:
323 +
324 +* STOP: once the sequence is completed, nothing else will happen
325 +* LOOP: once the sequence is completed, it will repeat a set amount of time
326 +* GOTO: once the sequence is completed, it will trigger the input selected
327 +
328 +If another sequence is associated with that input, it will then play Playback Control. You can change the speed of playback by changing the speed multiplier. Click the up and down arrows to alter this. Normally a sequence plays to the end then stops. However, sometimes you want a sequence to repeat. You can toggle this by clicking the Loop button.
329 +
168 168  = Troubleshooting =
169 169  
170 170  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>>url:https://www.robotshop.com/community/forum/c/lynxmotion/electronics-software]]
LSS-flowarm-30812.jpg
Author
... ... @@ -1,1 +1,0 @@
1 -xwiki:XWiki.CBenson
Size
... ... @@ -1,1 +1,0 @@
1 -260.5 KB
Content
wiki-download.png
Author
... ... @@ -1,1 +1,0 @@
1 -xwiki:XWiki.CBenson
Size
... ... @@ -1,1 +1,0 @@
1 -3.9 KB
Content
lss-flowarm-decision-frame.jpg
Author
... ... @@ -1,0 +1,1 @@
1 +xwiki:XWiki.CBenson
Size
... ... @@ -1,0 +1,1 @@
1 +2.7 KB
Content
lss-flowarm-frame.jpg
Author
... ... @@ -1,0 +1,1 @@
1 +xwiki:XWiki.CBenson
Size
... ... @@ -1,0 +1,1 @@
1 +19.8 KB
Content
lss-sequencer-handle.jpg
Author
... ... @@ -1,0 +1,1 @@
1 +xwiki:XWiki.CBenson
Size
... ... @@ -1,0 +1,1 @@
1 +11.2 KB
Content
Copyright RobotShop 2018