diff --git a/.github/workflows/sdk_protos_map.csv b/.github/workflows/sdk_protos_map.csv index ef28ab50aa..36a69be7ff 100644 --- a/.github/workflows/sdk_protos_map.csv +++ b/.github/workflows/sdk_protos_map.csv @@ -38,18 +38,18 @@ board,GetPWM,Yes,get_pwm,PWM,pwm board,SetPWM,Yes,set_pwm,SetPWM,setPwm board,PWMFrequency,Yes,get_pwm_frequency,PWMFreq,pwmFrequency board,SetPWMFrequency,Yes,set_pwm_frequency,SetPWMFreq,setPwmFrequency -board,AnalogByName,No,analog_by_name,AnalogByName,analogReaderValue -## HACK: Omitting PySDK: write_analog, currently borked: https://python.viam.dev/autoapi/viam/components/board/client/index.html#viam.components.board.client.BoardClient.write_analog -board,Write,Yes,,Write,writeAnalog -board,GetDigitalInterruptValue,No,digital_interrupt_by_name,DigitalInterruptByName,, +board,GetDigitalInterruptValue,No,value,Value,digitalInterruptValue +board,ReadAnalogReader,Yes,read,Read,analogReaderValue +## HACK: PySDK: write_analog currently borked; deprecated in favor of write: https://python.viam.dev/autoapi/viam/components/board/client/index.html#viam.components.board.client.BoardClient.write_analog +board,WriteAnalog,Yes,write,Write,writeAnalog board,StreamTicks,No,stream_ticks,StreamTicks,streamTicks board,SetPowerMode,No,set_power_mode,SetPowerMode,setPowerMode -board,GetGeometries,No,get_geometries,, ## HACK: Board (python, go) provides additional helper functions, adding 5 pseudo-entries: -board,Read,Yes,read,Read, -board,Value,No,value,Value,digitalInterruptValue +board,AnalogByName,No,analog_by_name,AnalogByName, +board,DigitalInterruptByName,No,digital_interrupt_by_name,DigitalInterruptByName,, board,GPIOPinByName,No,gpio_pin_by_name,GPIOPinByName, ## HACK: No proto for these (and/or inherited in Go SDK), manually mapping: +board,GetGeometries,No,get_geometries,, board,Reconfigure,No,,Reconfigure, board,DoCommand,Yes,do_command,DoCommand,doCommand board,Name,No,,Name, diff --git a/docs/appendix/changelog.md b/docs/appendix/changelog.md index 56df615fac..995ddd5374 100644 --- a/docs/appendix/changelog.md +++ b/docs/appendix/changelog.md @@ -90,7 +90,7 @@ The `errors_only` parameter has been removed from [`get_robot_part_logs()`](/app {{% changelog date="2024-05-28" color="changed" title="Return type of analog Read" %}} -The board analog API [`Read()`](/appendix/apis/components/board/#read) method now returns an `AnalogValue` struct instead of a single int. +The board analog API [`Read()`](/appendix/apis/components/board/#readanalogreader) method now returns an `AnalogValue` struct instead of a single int. The struct contains an int representing the value of the reading, min and max range of values, and the precision of the reading. {{% /changelog %}} @@ -144,7 +144,7 @@ detections = await detector.get_detections(cropped_frame) {{% changelog date="2024-05-08" color="removed" title="WriteAnalog from Go SDK" %}} The `WriteAnalog()` method has been removed from the Go SDK. -Use [`AnalogByName()`](/appendix/apis/components/board/#analogbyname) followed by [`Write()`](/appendix/apis/components/board/#write) instead. +Use [`AnalogByName()`](/appendix/apis/components/board/#analogbyname) followed by [`Write()`](/appendix/apis/components/board/#writeanalog) instead. {{% /changelog %}} diff --git a/static/include/components/apis/generated/board-table.md b/static/include/components/apis/generated/board-table.md index 92d6d62eab..869f299288 100644 --- a/static/include/components/apis/generated/board-table.md +++ b/static/include/components/apis/generated/board-table.md @@ -7,15 +7,15 @@ | [`SetPWM`](/appendix/apis/components/board/#setpwm) | Set the pin's Pulse-width modulation (PWM) duty cycle: a float [`0.0`, `1.0`] indicating the percentage of time the digital signal output of this pin is in the high state (active, >0V) relative to the interval period of the PWM signal (interval period being the mathematical inverse of the PWM frequency). |

| | [`PWMFrequency`](/appendix/apis/components/board/#pwmfrequency) | Get the PWM frequency of the GPIO pin. |

| | [`SetPWMFrequency`](/appendix/apis/components/board/#setpwmfrequency) | Set the pin to the given PWM `frequency` (in Hz). When `frequency` is 0, it will use the board’s default PWM frequency. |

| -| [`AnalogByName`](/appendix/apis/components/board/#analogbyname) | Get a configured `Analog` by `name`. |

| -| [`Write`](/appendix/apis/components/board/#write) | Write an analog value to a pin on the board. |

| -| [`GetDigitalInterruptValue`](/appendix/apis/components/board/#getdigitalinterruptvalue) | Get a configured `DigitalInterrupt` by `name`. |

| +| [`GetDigitalInterruptValue`](/appendix/apis/components/board/#getdigitalinterruptvalue) | Get the current value of a configured digital interrupt. |

| +| [`ReadAnalogReader`](/appendix/apis/components/board/#readanalogreader) | Read the current integer value of the digital signal output by the ADC. |

| +| [`WriteAnalog`](/appendix/apis/components/board/#writeanalog) | Write an analog value to a pin on the board. |

| | [`StreamTicks`](/appendix/apis/components/board/#streamticks) | Start a stream of `DigitalInterrupt` ticks. |

| | [`SetPowerMode`](/appendix/apis/components/board/#setpowermode) | Set the board to the indicated `PowerMode`. |

| -| [`GetGeometries`](/appendix/apis/components/board/#getgeometries) | Get all the geometries associated with the board in its current configuration, in the frame of the board. |

| -| [`Read`](/appendix/apis/components/board/#read) | Read the current integer value of the digital signal output by the ADC. |

| -| [`Value`](/appendix/apis/components/board/#value) | Get the current value of this interrupt. |

| +| [`AnalogByName`](/appendix/apis/components/board/#analogbyname) | Get a configured `Analog` by `name`. |

| +| [`DigitalInterruptByName`](/appendix/apis/components/board/#digitalinterruptbyname) | Get a DigitalInterrupt by `name`. |

| | [`GPIOPinByName`](/appendix/apis/components/board/#gpiopinbyname) | Get a `GPIOPin` by {{< glossary_tooltip term_id="pin-number" text="pin number" >}}. |

| +| [`GetGeometries`](/appendix/apis/components/board/#getgeometries) | Get all the geometries associated with the board in its current configuration, in the frame of the board. |

| | [`Reconfigure`](/appendix/apis/components/board/#reconfigure) | Reconfigure this resource. |

| | [`DoCommand`](/appendix/apis/components/board/#docommand) | Execute model-specific commands that are not otherwise defined by the component API. |

| | [`Name`](/appendix/apis/components/board/#name) | Get the name of the digital interrupt. |

| diff --git a/static/include/components/apis/generated/board.md b/static/include/components/apis/generated/board.md index fd69cc7f6b..4a3d901b35 100644 --- a/static/include/components/apis/generated/board.md +++ b/static/include/components/apis/generated/board.md @@ -510,42 +510,50 @@ For more information, see the [Flutter SDK Docs](https://flutter.viam.dev/viam_s {{% /tab %}} {{< /tabs >}} -### AnalogByName +### GetDigitalInterruptValue -Get a configured `Analog` by `name`. +Get the current value of a configured digital interrupt. +The value is the number of times the interrupt has been interrupted with a tick. {{< tabs >}} {{% tab name="Python" %}} **Parameters:** -- `name` ([str](https://docs.python.org/3/library/stdtypes.html#text-sequence-type-str)) (required): Name of the analog reader to be retrieved. +- `extra` (Mapping[[str](https://docs.python.org/3/library/stdtypes.html#text-sequence-type-str), Any]) (optional): Extra options to pass to the underlying RPC call. +- `timeout` ([float](https://docs.python.org/3/library/stdtypes.html#numeric-types-int-float-complex)) (optional): An option to set how long to wait (in seconds) before calling a time-out and closing the underlying RPC call. **Returns:** -- ([viam.components.board.board.Board.Analog](https://python.viam.dev/autoapi/viam/components/board/board/index.html#viam.components.board.board.Board.Analog)): The analog reader or writer. +- ([int](https://docs.python.org/3/library/stdtypes.html#numeric-types-int-float-complex)): The current value. **Example:** ```python {class="line-numbers linkable-line-numbers"} my_board = Board.from_robot(robot=machine, name="my_board") -# Get the Analog "my_example_analog_reader". -reader = await my_board.analog_by_name(name="my_example_analog_reader") +# Get the DigitalInterrupt "my_example_digital_interrupt". +interrupt = await my_board.digital_interrupt_by_name( + name="my_example_digital_interrupt") + +# Get the amount of times this DigitalInterrupt has been interrupted with a +# tick. +count = await interrupt.value() ``` -For more information, see the [Python SDK Docs](https://python.viam.dev/autoapi/viam/components/board/client/index.html#viam.components.board.client.BoardClient.analog_by_name). +For more information, see the [Python SDK Docs](https://python.viam.dev/autoapi/viam/components/board/client/index.html#viam.components.board.client.DigitalInterruptClient.value). {{% /tab %}} {{% tab name="Go" %}} **Parameters:** -- `name` [(string)](https://pkg.go.dev/builtin#string): Name of the analog pin you want to retrieve. Set as the `"name"` property in board configuration. +- `ctx` [(Context)](https://pkg.go.dev/context#Context): A Context carries a deadline, a cancellation signal, and other values across API boundaries. +- `extra` [(map[string]interface{})](https://go.dev/blog/maps): Extra options to pass to the underlying RPC call. **Returns:** -- [(Analog)](https://pkg.go.dev/go.viam.com/rdk/components/board#Analog): An interface representing an analog pin configured and residing on the board. +- [(int64)](https://pkg.go.dev/builtin#int64): The amount of ticks that have occurred. - [(error)](https://pkg.go.dev/builtin#error): An error, if one occurred. **Example:** @@ -553,52 +561,83 @@ For more information, see the [Python SDK Docs](https://python.viam.dev/autoapi/ ```go {class="line-numbers linkable-line-numbers"} myBoard, err := board.FromRobot(robot, "my_board") -// Get the Analog pin "my_example_analog". -analog, err := myBoard.AnalogByName("my_example_analog") +// Get the DigitalInterrupt "my_example_digital_interrupt". +interrupt, err := myBoard.DigitalInterruptByName("my_example_digital_interrupt") + +// Get the amount of times this DigitalInterrupt has ticked. +count, err := interrupt.Value(context.Background(), nil) ``` -For more information, see the [Go SDK Docs](https://pkg.go.dev/go.viam.com/rdk/components/board#Board). +For more information, see the [Go SDK Docs](https://pkg.go.dev/go.viam.com/rdk/components/board#DigitalInterrupt). {{% /tab %}} {{% tab name="Flutter" %}} **Parameters:** -- `analogReaderName` [String](https://api.flutter.dev/flutter/dart-core/String-class.html) (required) +- `digitalInterruptName` [String](https://api.flutter.dev/flutter/dart-core/String-class.html) (required) - `extra` [Map](https://api.flutter.dev/flutter/dart-core/Map-class.html)\<[String](https://api.flutter.dev/flutter/dart-core/String-class.html), dynamic\>? (optional) **Returns:** -- [Future](https://api.flutter.dev/flutter/dart-async/Future-class.html)\<[AnalogValue](https://flutter.viam.dev/viam_sdk/AnalogValue.html)\> +- [Future](https://api.flutter.dev/flutter/dart-async/Future-class.html)\<[int](https://api.flutter.dev/flutter/dart-core/int-class.html)\> **Example:** ```dart {class="line-numbers linkable-line-numbers"} -// Get the current value of an analog reader named "my_example_analog" -var analogVal = await myBoard.analogReaderValue('my_example_analog'); +// Get the current value of a digital interrupt named "my_example_digital_interrupt" +var interruptVal = await myBoard.digitalInterruptValue('my_example_digital_interrupt'); ``` -For more information, see the [Flutter SDK Docs](https://flutter.viam.dev/viam_sdk/Board/analogReaderValue.html). +For more information, see the [Flutter SDK Docs](https://flutter.viam.dev/viam_sdk/Board/digitalInterruptValue.html). {{% /tab %}} {{< /tabs >}} -### Write +### ReadAnalogReader -Write an analog value to a pin on the board. +Read the current integer value of the digital signal output by the ADC. Supported by `viam-micro-server`. {{< tabs >}} +{{% tab name="Python" %}} + +**Parameters:** + +- `extra` (Mapping[[str](https://docs.python.org/3/library/stdtypes.html#text-sequence-type-str), Any]) (optional): Extra options to pass to the underlying RPC call. +- `timeout` ([float](https://docs.python.org/3/library/stdtypes.html#numeric-types-int-float-complex)) (optional): An option to set how long to wait (in seconds) before calling a time-out and closing the underlying RPC call. + +**Returns:** + +- (viam.components.board.board.Board.Analog.Value): The current value, including the min, max, and step_size of the reader. + +**Example:** + +```python {class="line-numbers linkable-line-numbers"} +my_board = Board.from_robot(robot=robot, name="my_board") + +# Get the Analog "my_example_analog_reader". +reader = await my_board.analog_reader_by_name( + name="my_example_analog_reader") + +# Get the value of the digital signal "my_example_analog_reader" has most +# recently measured. +reading = await reader.read() +``` + +For more information, see the [Python SDK Docs](https://python.viam.dev/autoapi/viam/components/board/client/index.html#viam.components.board.client.AnalogClient.read). + +{{% /tab %}} {{% tab name="Go" %}} **Parameters:** - `ctx` [(Context)](https://pkg.go.dev/context#Context): A Context carries a deadline, a cancellation signal, and other values across API boundaries. -- `value` [(int)](https://pkg.go.dev/builtin#int): Value to write to the pin. - `extra` [(map[string]interface{})](https://go.dev/blog/maps): Extra options to pass to the underlying RPC call. **Returns:** +- [(AnalogValue)](https://pkg.go.dev/go.viam.com/rdk/components/board#AnalogValue): The current value, including the integer `Value` of the digital signal output by the analog pin and the `Min`, `Max`, and `StepSize` of the reader. - [(error)](https://pkg.go.dev/builtin#error): An error, if one occurred. **Example:** @@ -606,11 +645,13 @@ Supported by `viam-micro-server`. ```go {class="line-numbers linkable-line-numbers"} myBoard, err := board.FromRobot(robot, "my_board") -// Get the Analog pin "my_example_analog". +// Get the analog pin "my_example_analog". analog, err := myBoard.AnalogByName("my_example_analog") -// Set the pin to value 48. -err := analog.Write(context.Background(), 48, nil) +// Get the value of the analog signal "my_example_analog" has most recently measured. +reading, err := analog.Read(context.Background(), nil) +readingValue := reading.Value +stepSize := reading.StepSize ``` For more information, see the [Go SDK Docs](https://pkg.go.dev/go.viam.com/rdk/components/board#Analog). @@ -620,63 +661,68 @@ For more information, see the [Go SDK Docs](https://pkg.go.dev/go.viam.com/rdk/c **Parameters:** -- `pin` [String](https://api.flutter.dev/flutter/dart-core/String-class.html) (required) -- `value` [int](https://api.flutter.dev/flutter/dart-core/int-class.html) (required) +- `analogReaderName` [String](https://api.flutter.dev/flutter/dart-core/String-class.html) (required) - `extra` [Map](https://api.flutter.dev/flutter/dart-core/Map-class.html)\<[String](https://api.flutter.dev/flutter/dart-core/String-class.html), dynamic\>? (optional) **Returns:** -- [Future](https://api.flutter.dev/flutter/dart-async/Future-class.html)\ +- [Future](https://api.flutter.dev/flutter/dart-async/Future-class.html)\<[AnalogValue](https://flutter.viam.dev/viam_sdk/AnalogValue.html)\> **Example:** ```dart {class="line-numbers linkable-line-numbers"} -// Set pin 11 to value 48 -await myBoard.writeAnalog('11', 48); +// Get the current value of an analog reader named "my_example_analog" +var analogVal = await myBoard.analogReaderValue('my_example_analog'); ``` -For more information, see the [Flutter SDK Docs](https://flutter.viam.dev/viam_sdk/Board/writeAnalog.html). +For more information, see the [Flutter SDK Docs](https://flutter.viam.dev/viam_sdk/Board/analogReaderValue.html). {{% /tab %}} {{< /tabs >}} -### GetDigitalInterruptValue +### WriteAnalog -Get a configured `DigitalInterrupt` by `name`. +Write an analog value to a pin on the board. +Supported by `viam-micro-server`. {{< tabs >}} {{% tab name="Python" %}} **Parameters:** -- `name` ([str](https://docs.python.org/3/library/stdtypes.html#text-sequence-type-str)) (required): Name of the digital interrupt. +- `value` ([int](https://docs.python.org/3/library/stdtypes.html#numeric-types-int-float-complex)) (required): Value to write to the analog writer. +- `extra` (Mapping[[str](https://docs.python.org/3/library/stdtypes.html#text-sequence-type-str), Any]) (optional): Extra options to pass to the underlying RPC call. +- `timeout` ([float](https://docs.python.org/3/library/stdtypes.html#numeric-types-int-float-complex)) (optional): An option to set how long to wait (in seconds) before calling a time-out and closing the underlying RPC call. **Returns:** -- ([viam.components.board.board.Board.DigitalInterrupt](https://python.viam.dev/autoapi/viam/components/board/board/index.html#viam.components.board.board.Board.DigitalInterrupt)): The digital interrupt. +- None. **Example:** ```python {class="line-numbers linkable-line-numbers"} my_board = Board.from_robot(robot=machine, name="my_board") -# Get the DigitalInterrupt "my_example_digital_interrupt". -interrupt = await my_board.digital_interrupt_by_name( - name="my_example_digital_interrupt") +# Get the Analog "my_example_analog_writer". +writer = await my_board.analog_by_name( + name="my_example_analog_writer") + +await writer.write(42) ``` -For more information, see the [Python SDK Docs](https://python.viam.dev/autoapi/viam/components/board/client/index.html#viam.components.board.client.BoardClient.digital_interrupt_by_name). +For more information, see the [Python SDK Docs](https://python.viam.dev/autoapi/viam/components/board/client/index.html#viam.components.board.client.AnalogClient.write). {{% /tab %}} {{% tab name="Go" %}} **Parameters:** -- `name` [(string)](https://pkg.go.dev/builtin#string): Name of the digital interrupt you want to retrieve. Set as the `"name"` property in board configuration. +- `ctx` [(Context)](https://pkg.go.dev/context#Context): A Context carries a deadline, a cancellation signal, and other values across API boundaries. +- `value` [(int)](https://pkg.go.dev/builtin#int): Value to write to the pin. +- `extra` [(map[string]interface{})](https://go.dev/blog/maps): Extra options to pass to the underlying RPC call. **Returns:** -- [(DigitalInterrupt)](https://pkg.go.dev/go.viam.com/rdk/components/board#DigitalInterrupt): An interface representing a configured interrupt on the board. - [(error)](https://pkg.go.dev/builtin#error): An error, if one occurred. **Example:** @@ -684,11 +730,36 @@ For more information, see the [Python SDK Docs](https://python.viam.dev/autoapi/ ```go {class="line-numbers linkable-line-numbers"} myBoard, err := board.FromRobot(robot, "my_board") -// Get the DigitalInterrupt "my_example_digital_interrupt". -interrupt, err := myBoard.DigitalInterruptByName("my_example_digital_interrupt") +// Get the Analog pin "my_example_analog". +analog, err := myBoard.AnalogByName("my_example_analog") + +// Set the pin to value 48. +err := analog.Write(context.Background(), 48, nil) ``` -For more information, see the [Go SDK Docs](https://pkg.go.dev/go.viam.com/rdk/components/board#Board). +For more information, see the [Go SDK Docs](https://pkg.go.dev/go.viam.com/rdk/components/board#Analog). + +{{% /tab %}} +{{% tab name="Flutter" %}} + +**Parameters:** + +- `pin` [String](https://api.flutter.dev/flutter/dart-core/String-class.html) (required) +- `value` [int](https://api.flutter.dev/flutter/dart-core/int-class.html) (required) +- `extra` [Map](https://api.flutter.dev/flutter/dart-core/Map-class.html)\<[String](https://api.flutter.dev/flutter/dart-core/String-class.html), dynamic\>? (optional) + +**Returns:** + +- [Future](https://api.flutter.dev/flutter/dart-async/Future-class.html)\ + +**Example:** + +```dart {class="line-numbers linkable-line-numbers"} +// Set pin 11 to value 48 +await myBoard.writeAnalog('11', 48); +``` + +For more information, see the [Flutter SDK Docs](https://flutter.viam.dev/viam_sdk/Board/writeAnalog.html). {{% /tab %}} {{< /tabs >}} @@ -829,7 +900,7 @@ For more information, see the [Python SDK Docs](https://python.viam.dev/autoapi/ - `ctx` [(Context)](https://pkg.go.dev/context#Context): A Context carries a deadline, a cancellation signal, and other values across API boundaries. - `mode` [(pb.PowerMode)](https://pkg.go.dev/go.viam.com/api/component/board/v1#PowerMode): Options to specify power usage of the board: `boardpb.PowerMode_POWER_MODE_UNSPECIFIED`, `boardpb.PowerMode_POWER_MODE_NORMAL`, and `boardpb.PowerMode_POWER_MODE_OFFLINE_DEEP`. -- `duration` [(*time.Duration)](https://pkg.go.dev/time#Duration): If provided, the board will exit the given power mode after the specified duration. +- `duration` [(\*time.Duration)](https://pkg.go.dev/time#Duration): If provided, the board will exit the given power mode after the specified duration. **Returns:** @@ -874,82 +945,42 @@ For more information, see the [Flutter SDK Docs](https://flutter.viam.dev/viam_s {{% /tab %}} {{< /tabs >}} -### GetGeometries - -Get all the geometries associated with the board in its current configuration, in the [frame](/services/frame-system/) of the board. -The [motion](/services/motion/) and [navigation](/services/navigation/) services use the relative position of inherent geometries to configured geometries representing obstacles for collision detection and obstacle avoidance while motion planning. - -{{< tabs >}} -{{% tab name="Python" %}} - -**Parameters:** - -- `extra` (Mapping[[str](https://docs.python.org/3/library/stdtypes.html#text-sequence-type-str), Any]) (optional): Extra options to pass to the underlying RPC call. -- `timeout` ([float](https://docs.python.org/3/library/stdtypes.html#numeric-types-int-float-complex)) (optional): An option to set how long to wait (in seconds) before calling a time-out and closing the underlying RPC call. - -**Returns:** - -- ([List[viam.proto.common.Geometry]](https://python.viam.dev/autoapi/viam/proto/common/index.html#viam.proto.common.Geometry)): The geometries associated with the Component. - -**Example:** - -```python {class="line-numbers linkable-line-numbers"} -geometries = await my_board.get_geometries() - -if geometries: - # Get the center of the first geometry - print(f"Pose of the first geometry's centerpoint: {geometries[0].center}") -``` - -For more information, see the [Python SDK Docs](https://python.viam.dev/autoapi/viam/components/board/client/index.html#viam.components.board.client.BoardClient.get_geometries). - -{{% /tab %}} -{{< /tabs >}} - -### Read +### AnalogByName -Read the current integer value of the digital signal output by the ADC. -Supported by `viam-micro-server`. +Get a configured `Analog` by `name`. {{< tabs >}} {{% tab name="Python" %}} **Parameters:** -- `extra` (Mapping[[str](https://docs.python.org/3/library/stdtypes.html#text-sequence-type-str), Any]) (optional): Extra options to pass to the underlying RPC call. -- `timeout` ([float](https://docs.python.org/3/library/stdtypes.html#numeric-types-int-float-complex)) (optional): An option to set how long to wait (in seconds) before calling a time-out and closing the underlying RPC call. +- `name` ([str](https://docs.python.org/3/library/stdtypes.html#text-sequence-type-str)) (required): Name of the analog reader to be retrieved. **Returns:** -- (viam.components.board.board.Board.Analog.Value): The current value, including the min, max, and step_size of the reader. +- ([viam.components.board.board.Board.Analog](https://python.viam.dev/autoapi/viam/components/board/board/index.html#viam.components.board.board.Board.Analog)): The analog reader or writer. **Example:** ```python {class="line-numbers linkable-line-numbers"} -my_board = Board.from_robot(robot=machine, name="my_board") +my_board = Board.from_robot(robot=robot, name="my_board") # Get the Analog "my_example_analog_reader". -reader = await my_board.analog_reader_by_name( - name="my_example_analog_reader") - -# Get the value of the digital signal "my_example_analog_reader" has most -# recently measured. -reading = await reader.read() +reader = await my_board.analog_by_name(name="my_example_analog_reader") ``` -For more information, see the [Python SDK Docs](https://python.viam.dev/autoapi/viam/components/board/client/index.html#viam.components.board.client.AnalogClient.read). +For more information, see the [Python SDK Docs](https://python.viam.dev/autoapi/viam/components/board/client/index.html#viam.components.board.client.BoardClient.analog_by_name). {{% /tab %}} {{% tab name="Go" %}} **Parameters:** -- `ctx` [(Context)](https://pkg.go.dev/context#Context): A Context carries a deadline, a cancellation signal, and other values across API boundaries. -- `extra` [(map[string]interface{})](https://go.dev/blog/maps): Extra options to pass to the underlying RPC call. +- `name` [(string)](https://pkg.go.dev/builtin#string): Name of the analog pin you want to retrieve. Set as the `"name"` property in board configuration. **Returns:** -- [(AnalogValue)](https://pkg.go.dev/go.viam.com/rdk/components/board#AnalogValue): The current value, including the integer `Value` of the digital signal output by the analog pin and the `Min`, `Max`, and `StepSize` of the reader. +- [(Analog)](https://pkg.go.dev/go.viam.com/rdk/components/board#Analog): An interface representing an analog pin configured and residing on the board. - [(error)](https://pkg.go.dev/builtin#error): An error, if one occurred. **Example:** @@ -957,35 +988,28 @@ For more information, see the [Python SDK Docs](https://python.viam.dev/autoapi/ ```go {class="line-numbers linkable-line-numbers"} myBoard, err := board.FromRobot(robot, "my_board") -// Get the analog pin "my_example_analog". +// Get the Analog pin "my_example_analog". analog, err := myBoard.AnalogByName("my_example_analog") - -// Get the value of the analog signal "my_example_analog" has most recently measured. -reading, err := analog.Read(context.Background(), nil) -readingValue := reading.Value -stepSize := reading.StepSize ``` -For more information, see the [Go SDK Docs](https://pkg.go.dev/go.viam.com/rdk/components/board#Analog). +For more information, see the [Go SDK Docs](https://pkg.go.dev/go.viam.com/rdk/components/board#Board). {{% /tab %}} {{< /tabs >}} -### Value - -Get the current value of this interrupt. +### DigitalInterruptByName +Get a DigitalInterrupt by `name`. {{< tabs >}} {{% tab name="Python" %}} **Parameters:** -- `extra` (Mapping[[str](https://docs.python.org/3/library/stdtypes.html#text-sequence-type-str), Any]) (optional): Extra options to pass to the underlying RPC call. -- `timeout` ([float](https://docs.python.org/3/library/stdtypes.html#numeric-types-int-float-complex)) (optional): An option to set how long to wait (in seconds) before calling a time-out and closing the underlying RPC call. +- `name` ([str](https://docs.python.org/3/library/stdtypes.html#text-sequence-type-str)) (required): Name of the digital interrupt. **Returns:** -- ([int](https://docs.python.org/3/library/stdtypes.html#numeric-types-int-float-complex)): The current value. +- ([viam.components.board.board.Board.DigitalInterrupt](https://python.viam.dev/autoapi/viam/components/board/board/index.html#viam.components.board.board.Board.DigitalInterrupt)): The digital interrupt. **Example:** @@ -995,25 +1019,20 @@ my_board = Board.from_robot(robot=machine, name="my_board") # Get the DigitalInterrupt "my_example_digital_interrupt". interrupt = await my_board.digital_interrupt_by_name( name="my_example_digital_interrupt") - -# Get the amount of times this DigitalInterrupt has been interrupted with a -# tick. -count = await interrupt.value() ``` -For more information, see the [Python SDK Docs](https://python.viam.dev/autoapi/viam/components/board/client/index.html#viam.components.board.client.DigitalInterruptClient.value). +For more information, see the [Python SDK Docs](https://python.viam.dev/autoapi/viam/components/board/client/index.html#viam.components.board.client.BoardClient.digital_interrupt_by_name). {{% /tab %}} {{% tab name="Go" %}} **Parameters:** -- `ctx` [(Context)](https://pkg.go.dev/context#Context): A Context carries a deadline, a cancellation signal, and other values across API boundaries. -- `extra` [(map[string]interface{})](https://go.dev/blog/maps): Extra options to pass to the underlying RPC call. +- `name` [(string)](https://pkg.go.dev/builtin#string): Name of the digital interrupt you want to retrieve. Set as the `"name"` property in board configuration. **Returns:** -- [(int64)](https://pkg.go.dev/builtin#int64): The amount of ticks that have occurred. +- [(DigitalInterrupt)](https://pkg.go.dev/go.viam.com/rdk/components/board#DigitalInterrupt): An interface representing a configured interrupt on the board. - [(error)](https://pkg.go.dev/builtin#error): An error, if one occurred. **Example:** @@ -1023,33 +1042,9 @@ myBoard, err := board.FromRobot(robot, "my_board") // Get the DigitalInterrupt "my_example_digital_interrupt". interrupt, err := myBoard.DigitalInterruptByName("my_example_digital_interrupt") - -// Get the amount of times this DigitalInterrupt has ticked. -count, err := interrupt.Value(context.Background(), nil) -``` - -For more information, see the [Go SDK Docs](https://pkg.go.dev/go.viam.com/rdk/components/board#DigitalInterrupt). - -{{% /tab %}} -{{% tab name="Flutter" %}} - -**Parameters:** - -- `digitalInterruptName` [String](https://api.flutter.dev/flutter/dart-core/String-class.html) (required) -- `extra` [Map](https://api.flutter.dev/flutter/dart-core/Map-class.html)\<[String](https://api.flutter.dev/flutter/dart-core/String-class.html), dynamic\>? (optional) - -**Returns:** - -- [Future](https://api.flutter.dev/flutter/dart-async/Future-class.html)\<[int](https://api.flutter.dev/flutter/dart-core/int-class.html)\> - -**Example:** - -```dart {class="line-numbers linkable-line-numbers"} -// Get the current value of a digital interrupt named "my_example_digital_interrupt" -var interruptVal = await myBoard.digitalInterruptValue('my_example_digital_interrupt'); ``` -For more information, see the [Flutter SDK Docs](https://flutter.viam.dev/viam_sdk/Board/digitalInterruptValue.html). +For more information, see the [Go SDK Docs](https://pkg.go.dev/go.viam.com/rdk/components/board#Board). {{% /tab %}} {{< /tabs >}} @@ -1106,6 +1101,38 @@ For more information, see the [Go SDK Docs](https://pkg.go.dev/go.viam.com/rdk/c {{% /tab %}} {{< /tabs >}} +### GetGeometries + +Get all the geometries associated with the board in its current configuration, in the [frame](/services/frame-system/) of the board. +The [motion](/services/motion/) and [navigation](/services/navigation/) services use the relative position of inherent geometries to configured geometries representing obstacles for collision detection and obstacle avoidance while motion planning. + +{{< tabs >}} +{{% tab name="Python" %}} + +**Parameters:** + +- `extra` (Mapping[[str](https://docs.python.org/3/library/stdtypes.html#text-sequence-type-str), Any]) (optional): Extra options to pass to the underlying RPC call. +- `timeout` ([float](https://docs.python.org/3/library/stdtypes.html#numeric-types-int-float-complex)) (optional): An option to set how long to wait (in seconds) before calling a time-out and closing the underlying RPC call. + +**Returns:** + +- ([List[viam.proto.common.Geometry]](https://python.viam.dev/autoapi/viam/proto/common/index.html#viam.proto.common.Geometry)): The geometries associated with the Component. + +**Example:** + +```python {class="line-numbers linkable-line-numbers"} +geometries = await my_board.get_geometries() + +if geometries: + # Get the center of the first geometry + print(f"Pose of the first geometry's centerpoint: {geometries[0].center}") +``` + +For more information, see the [Python SDK Docs](https://python.viam.dev/autoapi/viam/components/board/client/index.html#viam.components.board.client.BoardClient.get_geometries). + +{{% /tab %}} +{{< /tabs >}} + ### Reconfigure Reconfigure this resource. diff --git a/static/include/components/apis/overrides/protos/board.GetDigitalInterruptValue.md b/static/include/components/apis/overrides/protos/board.GetDigitalInterruptValue.md index f9514d4e07..39f84087e8 100644 --- a/static/include/components/apis/overrides/protos/board.GetDigitalInterruptValue.md +++ b/static/include/components/apis/overrides/protos/board.GetDigitalInterruptValue.md @@ -1 +1,2 @@ -Get a configured `DigitalInterrupt` by `name`. +Get the current value of a configured digital interrupt. +The value is the number of times the interrupt has been interrupted with a tick. diff --git a/static/include/components/apis/overrides/protos/board.Read.md b/static/include/components/apis/overrides/protos/board.ReadAnalogReader.md similarity index 100% rename from static/include/components/apis/overrides/protos/board.Read.md rename to static/include/components/apis/overrides/protos/board.ReadAnalogReader.md diff --git a/static/include/components/apis/overrides/protos/board.Value.md b/static/include/components/apis/overrides/protos/board.Value.md deleted file mode 100644 index a10439dc3d..0000000000 --- a/static/include/components/apis/overrides/protos/board.Value.md +++ /dev/null @@ -1 +0,0 @@ -Get the current value of this interrupt. diff --git a/static/include/components/apis/overrides/protos/board.Write.md b/static/include/components/apis/overrides/protos/board.WriteAnalog.md similarity index 100% rename from static/include/components/apis/overrides/protos/board.Write.md rename to static/include/components/apis/overrides/protos/board.WriteAnalog.md diff --git a/static/include/components/board/board-digital-interrupts.md b/static/include/components/board/board-digital-interrupts.md index c2ff7944d9..5d72def2a4 100644 --- a/static/include/components/board/board-digital-interrupts.md +++ b/static/include/components/board/board-digital-interrupts.md @@ -2,7 +2,7 @@ Configuring digital interrupts to monitor GPIO pins on your board is useful when your application needs to know precisely when there is a change in GPIO value between high and low. - When an interrupt configured on your board processes a change in the state of the GPIO pin it is configured to monitor, it ticks to record the state change. - You can stream these ticks with the board API's [`StreamTicks()`](/appendix/apis/components/board/#streamticks), or get the current value of the digital interrupt with [`Value()`](/appendix/apis/components/board/#value). + You can stream these ticks with the board API's [`StreamTicks()`](/appendix/apis/components/board/#streamticks), or get the current value of the digital interrupt with [`Value()`](/appendix/apis/components/board/#getdigitalinterruptvalue). - Calling [`GetGPIO()`](/appendix/apis/components/board/#getgpio) on a GPIO pin, which you can do without configuring interrupts, is useful when you want to know a pin's value at specific points in your program, but is less precise and convenient than using an interrupt. Integrate `digital_interrupts` into your machine in the `attributes` of your board by following the **Config Builder** instructions, or by adding the following to your board's JSON configuration: