Skip to content

Commit

Permalink
Merge branch 'master' of github.com:firmata/protocol
Browse files Browse the repository at this point in the history
  • Loading branch information
soundanalogous committed Mar 25, 2017
2 parents 80744c5 + 7e0041f commit 7a23ef3
Show file tree
Hide file tree
Showing 2 changed files with 147 additions and 64 deletions.
195 changes: 138 additions & 57 deletions proposals/stepper-2.0.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,10 @@ Current implementation supports 10 stepper motors at the same time (#[0-9]).

Includes optional support for acceleration and deceleration of the motor.

Also includes multiStepper support which allows groups of steppers to be simultaneously passed different ```to``` values and the duration of their movements will match. Up to five multiStepper groups can be created. The total number of steppers is still limited to 10.
Also includes multiStepper support which allows groups of steppers to be simultaneously controlled. Up to five multiStepper groups can be created. The total number of steppers is still limited to 10.

Stepper 2.0 sends and receives floats in a custom format described at the end
of this document.

Example files:
* Version 2.0 of the stepper protocol has not yet been implemented.
Expand Down Expand Up @@ -36,23 +39,20 @@ Protocol
XXXXXX0 = no enable pin
XXXXXX1 = has enable pin)
5 minPulseWidth (0-127 measured in us)
6 num steps-per-revolution LSB
7 num steps-per-revolution MSB
8 maxSpeed LSB
9 maxSpeed MSB
10 motorPin1 or directionPin number (0-127)
11 motorPin2 or stepPin number (0-127)
12 [when interface >= 0x0110000] motorPin3 (0-127)
13 [when interface >= 0x1000000] motorPin4 (0-127)
14 [when interface && 0x0000001] enablePin (0-127)
15 [optional] pins to invert (lower 5 bits = pins:
5 num steps-per-revolution LSB
6 num steps-per-revolution MSB
7 motorPin1 or directionPin number (0-127)
8 motorPin2 or stepPin number (0-127)
9 [when interface >= 0x0110000] motorPin3 (0-127)
10 [when interface >= 0x1000000] motorPin4 (0-127)
11 [when interface && 0x0000001] enablePin (0-127)
12 [optional] pins to invert (lower 5 bits = pins:
XXXXXX1 = invert motorPin1
XXXXX1X = invert motorPin2
XXXX1XX = invert motorPin3
XXX1XXX = invert motorPin4
XX1XXXX = invert enablePin)
16 END_SYSEX (0xF7)
13 END_SYSEX (0xF7)
```

**Stepper zero**
Expand All @@ -66,16 +66,9 @@ Protocol

**Stepper step (relative move)**

Position is specified as a 32-bit signed long.

The speed value is a float composed of a 23-bit significand (mantissa) and a 4-bit exponent
(biased -18 with an explicit 1's bit) and a sign bit.

|27 |26-23 |22-0 |
|-----|--------|-----------|
|sign |exponent|significant|
|1 bit|4 bits |23 bits |
Steps to move is specified as a 32-bit signed long.

The speed value is a float passed using Stepper 2.0's custom float format described below.

```
0 START_SYSEX (0xF0)
Expand All @@ -99,24 +92,18 @@ The speed value is a float composed of a 23-bit significand (mantissa) and a 4-b
Sets a stepper to a desired position based on the number of steps from the zero position.
Position is specified as a 32-bit signed long.

The speed value is float composed of a 23-bit significand (mantissa) and a 4-bit exponent
(biased -18 with an explicit 1's bit) and a sign bit.

|27 |26-23 |22-0 |
|-----|--------|-----------|
|sign |exponent|significant|
|1 bit|4 bits |23 bits |
The speed value is a float passed using Stepper 2.0's custom float format described below.

```
0 START_SYSEX (0xF0)
1 Stepper Command (0x62)
2 to command (0x03)
3 device number (0-9)
4 num steps, bits 0-6
5 num steps, bits 7-13
6 num steps, bits 14-20
7 num steps, bits 21-27
8 num steps, bits 28-32
4 position, bits 0-6
5 position, bits 7-13
6 position, bits 14-20
7 position, bits 21-27
8 position, bits 28-32
9 speed, bits 0-6 (steps per second)
10 speed, bits 7-13
11 speed, bits 14-20
Expand Down Expand Up @@ -178,13 +165,8 @@ When a limit pin (digital) is set to its limit state, movement in that direction

**Stepper set acceleration**

Sets the acceleration/deceleration in steps/sec^2. The accel value is composed of a 23-bit
significand (mantissa) and a 4-bit exponent (biased -18 with an explicit 1's bit) and a sign bit.

|27 |26-23 |22-0 |
|-----|--------|-----------|
|sign |exponent|significant|
|1 bit|4 bits |23 bits |
Sets the acceleration/deceleration in steps/sec^2. The accel value is passed
using Stepper 2.0's custom float format described below.


```
Expand All @@ -199,6 +181,36 @@ significand (mantissa) and a 4-bit exponent (biased -18 with an explicit 1's bit
8 END_SYSEX (0xF7)
```

**Stepper set maxSpeed**

Sets the maximum speed in steps per second. . The speed value is passed
using Stepper 2.0's custom float format described below.

```
0 START_SYSEX (0xF0)
1 Stepper Command (0x62)
2 set acceleration command (0x09)
3 device number (0-9) (Supports up to 10 motors)
4 maxSpeed, bits 0-6 (maxSpeed in steps per sec)
5 maxSpeed, bits 7-13
6 maxSpeed, bits 14-20
7 maxSpeed, bits 21-28
8 END_SYSEX (0xF7)
```

**Stepper set pulse width**

Adds a delay for each step in microseconds

```
0 START_SYSEX (0xF0)
1 Stepper Command (0x62)
2 set minPulseWidth command (0x0A)
3 device number (0-9) (Supports up to 10 motors)
4 minPulseWidth (minimum pulse width in microseconds)
5 END_SYSEX (0xF7)
```

**MultiStepper configuration**

Stepper instances that have been created with the stepper configuration command above can be added to a multiStepper group. Groups can be sent a list of devices/positions in a single command and their movements will be coordinated to begin and end simultaneously. Note that multiStepper does not support acceleration or deceleration.
Expand All @@ -223,21 +235,27 @@ Stepper instances that have been created with the stepper configuration command

**MultiStepper to**

Sets each stepper in a group to a desired position based on the number of
steps from its zero position. Positions are specified as a 32-bit signed long.

Stepper movements will be coordinated so that all arrive at their desired
position simultaneously. The duration of this move is based on which stepper
will take the longest given the change in position and the stepper's max speed.

```
0 START_SYSEX (0xF0)
1 Stepper Command (0x62)
2 multi to command (0x21)
3 group number (0-127)
4 member number (0-9)
5 num steps, bits 0-6
6 num steps, bits 7-13
7 num steps, bits 14-20
8 num steps, bits 21-27
9 num steps, bits 28-32
4 position, bits 0-6
5 position, bits 7-13
6 position, bits 14-20
7 position, bits 21-27
8 position, bits 28-32
*Optionally repeat 4 through 9 for each device in group*
*Repeat 4 through 8 for each device in group*
63 END_SYSEX (0xF7)
53 END_SYSEX (0xF7)
```

**MultiStepper stop**
Expand All @@ -258,14 +276,77 @@ Sent when a move completes or stop is called.
1 Stepper Command (0x62)
2 multi stop reply command (0x24)
3 group number (0-127)
4 member number (0-9)
5 position, bits 0-6
6 position, bits 7-13
7 position, bits 14-20
8 position, bits 21-27
9 position, bits 28-32
4 position, bits 0-6
5 position, bits 7-13
6 position, bits 14-20
7 position, bits 21-27
8 position, bits 28-32
*Optionally repeat 4 through 9 for each device in group*
*Repeat 4 through 8 for each device in group*
63 END_SYSEX (0xF7)
53 END_SYSEX (0xF7)
```

Stepper 2 Custom Float Format
---

Floats sent and received by Stepper 2 are composed of a 23-bit significand (mantissa)
and a 4-bit, base 10 exponent (biased -17 with an explicit 1's bit) and a sign bit.

|27 |26-23 |22-0 |
|-----|--------|-----------|
|sign |exponent|significant|
|1 bit|4 bits |23 bits |

Those values allow a range from 8.388608*10^-11 to 83886.08.

**Example 1: 1 step per hour**

1 step per hour = 1 step / 60 minutes / 60 seconds = 0.000277... steps per second

The largest integer that can be represented in 23 bits is 8388608 so the
significand will be limited to 6 or 7 digits. In this case 2777778.

The exponent is 4 bits which limits the range to 0-15, but we subtract
17 from that value on the receiving end to give us a range from -17 to -2. In
this example we pass 7 to give us a -10 value in the exponent.

| | Decimal| Binary |
|-----------------------|--------|------------------------|
|Sign (bit 27) | 0| 0|
|Exponent (bits 26-23) | 7| 0110|
|Significand (bits 22-0)| 2777778| 01010100110001010110010|

Values in firmata are passed in the 7 least significant bits of each message byte
so we will be passing in 4 bytes:

| | Binary | Hex |
|-------------------------------------------|---------|-----|
| Sign, Exponent and 2 most significant bits| 00011001| 0x19|
| Next most significant bits | 00101001| 0x29|
| Next most significant bits | 01000101| 0x45|
| Least most significant bits | 00110010| 0x32|


**Example 2: 100 steps per second**

We have to pad our significand on the right with four zeros to get our full
precision. That makes the significand 1000000 and our exponent value will be -4.
Since the value we send will be biased -17 on the receiving end, we send 13 in
the exponent.

| | Decimal| Binary |
|-----------------------|--------|------------------------|
|Sign (bit 27) | 0| 0|
|Exponent (bits 26-23) | 13| 1101|
|Significand (bits 22-0)| 1000000| 00011110100001001000000|

Values in firmata are passed in the 7 least significant bits of each message byte
so we would be passing in 4 bytes:

| | Binary | Hex |
|-------------------------------------------|---------|-----|
| Sign, Exponent and 2 most significant bits| 00110100| 0x29|
| Next most significant bits | 00111101| 0x29|
| Next most significant bits | 00000100| 0x45|
| Least most significant bits | 01000000| 0x32|
16 changes: 9 additions & 7 deletions protocol.md
Original file line number Diff line number Diff line change
Expand Up @@ -127,7 +127,7 @@ PIN_STATE_RESPONSE 0x6E // reply with a pin's current mode and state (d
EXTENDED_ANALOG 0x6F // analog write (PWM, Servo, etc) to any pin
STRING_DATA 0x71 // a string message with 14-bits per char
REPORT_FIRMWARE 0x79 // report name and version of the firmware
SAMPLEING_INTERVAL 0x7A // the interval at which analog input is sampled (default = 19ms)
SAMPLING_INTERVAL 0x7A // the interval at which analog input is sampled (default = 19ms)
SYSEX_NON_REALTIME 0x7E // MIDI Reserved for non-realtime messages
SYSEX_REALTIME 0X7F // MIDI Reserved for realtime messages
```
Expand All @@ -154,8 +154,10 @@ Receive Firmware Name and Version (after query)
1 queryFirmware (0x79)
2 major version (0-127)
3 minor version (0-127)
4 first 7-bits of firmware name
5 second 7-bits of firmware name
4 first char of firmware name (LSB)
5 first char of firmware name (MSB)
6 second char of firmware name (LSB)
7 second char of firmware name (MSB)
... for as many bytes as it needs
N END_SYSEX (0xF7)
```
Expand Down Expand Up @@ -326,10 +328,10 @@ error messages to the client.
1 STRING_DATA (0x71)
2 first char LSB
3 first char MSB
3 second char LSB
4 second char MSB
4 second char LSB
5 second char MSB
... additional bytes up to half the buffer size - 3 (START_SYSEX, STRING_DATA, END_SYSEX)
N END_SYSEX (0xF7)
N END_SYSEX (0xF7)
```

Sampling Interval
Expand All @@ -344,5 +346,5 @@ will be read.
1 SAMPLING_INTERVAL (0x7A)
2 sampling interval on the millisecond time scale (LSB)
3 sampling interval on the millisecond time scale (MSB)
4 END_SYSEX (0xF7)
4 END_SYSEX (0xF7)
```

0 comments on commit 7a23ef3

Please sign in to comment.