Changes for page LSS-PRO Communication Protocol
Last modified by Eric Nantel on 2025/10/02 08:47
Change comment: There is no comment for this version
Summary
-
Page properties (2 modified, 0 added, 0 removed)
Details
- Page properties
-
- Author
-
... ... @@ -1,1 +1,1 @@ 1 -xwiki:XWiki. ENantel1 +xwiki:XWiki.CBenson - Content
-
... ... @@ -1,5 +1,8 @@ 1 1 {{warningBox warningText="More information coming soon"/}} 2 2 3 + 4 + 5 + 3 3 (% class="wikigeneratedid" id="HTableofContents" %) 4 4 **Page Contents** 5 5 ... ... @@ -10,3 +10,40 @@ 10 10 The Lynxmotion Smart Servo (LSS) serial protocol was created in order to be as simple and straightforward as possible from a user perspective ("human readable format"), while at the same time staying compact and robust yet highly versatile. The protocol was based on Lynxmotion's SSC-32 & SSC-32U RC servo controllers and almost everything one might expect to be able to configure for a smart servomotor is available. 11 11 12 12 In order to be able to control each servo individually with commands, the first step should be to assign a different ID number to each servo (see details on the Configure ID, or "CID" command [[here>>doc:||anchor="HIdentificationNumber28ID29"]]). Only the servo(s) which have been configured to a specific ID will act on a command sent to that ID. There is currently no CRC or checksum implemented as part of the protocol. 16 + 17 += Action Commands = 18 + 19 +<div class="cmdcnt"><div class="cmdpad"></div><div class="cmdtxt"> 20 +Action commands tell the servo, within that session, to do something (i.e. "take an action"). The types of action commands which can be sent are described below, and they cannot be combined with other commands such as queries or configurations. Only one action command can be sent at a time. Action commands are session-specific, therefore once a servo is power cycled, it will not have any "memory" of previous actions or ~[~[virtual positions>>||anchor="HVirtualAngularPosition"]] (described below). Action commands are sent serially to the servo's Rx pin and must be sent in the following format:<div class="wikimodel-emptyline"></div> 21 + 22 +~1. Start with a number sign ~*~*#~*~* (Unicode Character: U+0023) 23 +~1. Servo ID number as an integer (assigning an ID described below) 24 +~1. Action command (one or more letters, no whitespace, capital or lowercase from the list below) 25 +~1. Action value in the correct units with no decimal 26 +~1. End with a carriage return ~*~*\r~*~* or ~*~*<cr>~*~* Unicode Character (U+000D) 27 + 28 +~(~(~( 29 +Ex: #5D1800<cr><div class="wikimodel-emptyline"></div> 30 + 31 +This sends a serial command to all servo's RX pins which are connected to the bus and only servo(s) with ID #5 will move to a position (1800 in tenths of degrees) of 180.0 degrees. Any servo on the bus which does not have ID 5 will take no action when receiving this command. 32 +<div class="wikimodel-emptyline"></div></div></div> 33 + 34 +== Modifiers == 35 + 36 +{{html clean="false" wiki="true"}} 37 +<div class="cmdcnt"><div class="cmdpad"></div><div class="cmdtxt"> 38 +Modifiers can only be used with certain **action commands**. The format to include a modifier is:<div class="wikimodel-emptyline"></div> 39 + 40 +1. Start with a number sign **#** (Unicode Character: U+0023) 41 +1. Servo ID number as an integer 42 +1. Action command (one to three letters, no spaces, capital or lowercase from a subset of action commands below) 43 +1. Action value in the correct units with no decimal 44 +1. Modifier command (one or two letters from the list of modifiers below) 45 +1. Modifier value in the correct units with no decimal 46 +1. End with a carriage return **\r** or **<cr>** Unicode Character (U+000D) 47 + 48 +Ex: #5D1800T1500<cr><div class="wikimodel-emptyline"></div> 49 + 50 +This results in the servo with ID #5 rotating to a position (1800 in tenths of degrees) of 180.0 degrees in a time ("T") of 1500 milliseconds (1.5 seconds).<div class="wikimodel-emptyline"></div> 51 +<div class="wikimodel-emptyline"></div></div></div> 52 +{{/html}}