This numato-lab module implements a Numato-lab GPIO Peripheral Modules using the rdk:component:board
API.
Note
Before configuring your board, you must create a machine.
Navigate to the CONFIGURE tab of your machine in the Viam app. Add board / numato-lab:usb-gpio to your machine.
On the new component panel, copy and paste the following attribute template into your board's attributes field:
{
"pins": <number>,
}
The following attributes are available for viam:numato-lab:usb-gpio
boards:
Attribute | Type | Required? | Description |
---|---|---|---|
pins |
int | Required | Number of GPIO pins available on the module. |
analogs |
object | Optional | Attributes of any pins that can be used as Analog-to-Digital Converter (ADC) inputs. |
For instructions on implementing analogs, see Analogs configuration.
{
"name": "<your-numato-lab-usb-gpio-board-name>",
"model": "viam:numato-lab:usb-gpio",
"type": "board",
"namespace": "rdk",
"attributes": {
},
"depends_on": []
}
- To test your board, expand the TEST section of its configuration pane or go to the CONTROL tab.
- To write code against your board, use one of the available SDKs.
- To view examples using a board component, explore these tutorials.
An analog-to-digital converter (ADC) takes a continuous voltage input (analog signal) and converts it to an discrete integer output (digital signal).
To integrate an ADC into your machine, you must first physically connect the pins on your ADC to your board.
Then, integrate analogs
into your board by adding the following to your board's attributes
configuration:
"analogs": [
{
"name": "<your-analog-reader-name>",
"pin": "<pin-number-on-adc>",
"spi_bus": "<your-spi-bus-index>",
"chip_select": "<chip-select-index>",
"average_over_ms": <int>,
"samples_per_sec": <int>
}
]
The following attributes are available for analogs
:
Name | Type | Required? | Description |
---|---|---|---|
name |
string | Required | Your name for the analog reader. |
pin |
string | Required | The pin number of the ADC's connection pin, wired to the board. This should be labeled as the physical index of the pin on the ADC. |
chip_select |
string | Required | The chip select index of the board's connection pin, wired to the ADC. |
spi_bus |
string | Required | The index of the SPI bus connecting the ADC and board. |
average_over_ms |
int | Optional | Duration in milliseconds over which the rolling average of the analog input should be taken. |
samples_per_sec |
int | Optional | Sampling rate of the analog input in samples per second. |
{
"components": [
{
"name": "<your-numato-lab-board-name>",
"model": "viam:numato-lab:usb-gpio",
"type": "board",
"namespace": "rdk",
"attributes": {
"analogs": [
{
"name": "current",
"pin": "1",
"spi_bus": "1",
"chip_select": "0"
},
{
"name": "pressure",
"pin": "0",
"spi_bus": "1",
"chip_select": "0"
}
]
}
}
]
}