LSS-P - Communication Protocol

Version 10.1 by Coleman Benson on 2023/06/26 14:59

More information coming soon

Page Contents

Serial Protocol

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.

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). 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.

Action Commands

<div class="cmdcnt"><div class="cmdpad"></div><div class="cmdtxt">
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>

1. Start with a number sign **#** (Unicode Character: U+0023) 
1. Servo ID number as an integer (assigning an ID described below)
1. Action command (one or more letters, no whitespace, capital or lowercase from the list below)
1. Action value in the correct units with no decimal
1. End with a carriage return **&#92;r** or **&lt;cr&gt;** Unicode Character (U+000D)

(((
Ex: #5D1800&lt;cr&gt;<div class="wikimodel-emptyline"></div>

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.
<div class="wikimodel-emptyline"></div></div></div>

Modifiers

Modifiers can only be used with certain action commands. The format to include a modifier is:
  1. Start with a number sign # (Unicode Character: U+0023)
  2. Servo ID number as an integer
  3. Action command (one to three letters, no spaces, capital or lowercase from a subset of action commands below)
  4. Action value in the correct units with no decimal
  5. Modifier command (one or two letters from the list of modifiers below)
  6. Modifier value in the correct units with no decimal
  7. End with a carriage return \r or <cr> Unicode Character (U+000D)
Ex: #5D1800T1500<cr>
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).
Tags:
Created by Eric Nantel on 2023/06/21 10:43
Copyright RobotShop 2018