Skip to content

Commit

Permalink
fix: initialize hardware during reconfigure, move out of get_readings (
Browse files Browse the repository at this point in the history
  • Loading branch information
HipsterBrown authored Dec 31, 2024
1 parent f79f8c2 commit 68e406e
Showing 1 changed file with 41 additions and 18 deletions.
59 changes: 41 additions & 18 deletions src/mcp300x.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
from typing import ClassVar, Mapping, Any, Dict, Optional, List, cast
from typing import ClassVar, Mapping, Any, Optional
from typing_extensions import Self

from viam.module.types import Reconfigurable
Expand All @@ -17,6 +17,7 @@

LOGGER = getLogger(__name__)


class mcp3xxx(Sensor, Reconfigurable):
# Defines new model's colon-delimited-triplet
MODEL: ClassVar[Model] = Model(ModelFamily("viamlabs", "sensor"), "mcp300x")
Expand All @@ -26,7 +27,9 @@ class mcp3xxx(Sensor, Reconfigurable):

# Constructor
@classmethod
def new(cls, config: ComponentConfig, dependencies: Mapping[ResourceName, ResourceBase]) -> Self:
def new(
cls, config: ComponentConfig, dependencies: Mapping[ResourceName, ResourceBase]
) -> Self:
sensor = cls(config.name)
sensor.reconfigure(config, dependencies)
return sensor
Expand All @@ -41,45 +44,65 @@ def validate(cls, config: ComponentConfig):
raise NameError("A sensor_pin must be defined")

if channel_map == "":
raise NameError("Channel map must be defined, refers to sensor type and which channel it connects to")
raise NameError(
"Channel map must be defined, refers to sensor type and which channel it connects to"
)

return

# Handles attribute reconfiguration
def reconfigure(self, config: ComponentConfig, dependencies: Mapping[ResourceName, ResourceBase]):
def reconfigure(
self, config: ComponentConfig, dependencies: Mapping[ResourceName, ResourceBase]
):
# Initializes the resource instance
self.sensor_pin = int(config.attributes.fields["sensor_pin"].number_value)
self.channel_map = dict(config.attributes.fields["channel_map"].struct_value)
LOGGER.info(f"Channel map is {self.channel_map}")
LOGGER.debug(f"Channel map is {self.channel_map}")

if getattr(self, "spi") is not None:
self.spi.deinit()

if getattr(self, "cs") is not None:
self.cs.deinit()

# Sensor Pin Logic
# Creates the SPI bus
self.spi = busio.SPI(clock=board.SCK, MISO=board.MISO, MOSI=board.MOSI)

# Creates the cs (chip select) with a gpio pin variable, we are using 24 GPIO 8 (SPI Chip Select 0), so 8 for the config
cs_pin = f"D{self.sensor_pin}"
self.cs = digitalio.DigitalInOut(getattr(board, cs_pin))

# Creates the MCP3008 object, works with MCP3002 and MCP3004 since it is all encompassing
self.mcp = MCP.MCP3008(self.spi, self.cs)
return

""" Implements the methods the Viam RDK defines for the Sensor API (rdk:components:sensor) """

# Implements the Viam Sensor API's get_readings() method
async def get_readings(
self, *, extra: Optional[Mapping[str, Any]] = None, timeout: Optional[float] = None, **kwargs
self,
*,
extra: Optional[Mapping[str, Any]] = None,
timeout: Optional[float] = None,
**kwargs,
) -> Mapping[str, Any]:
"""
Obtains the measurements/data specific to this sensor.
Returns:
Mapping[str, Any]: The measurements. Can be of any type.
"""
# Sensor Pin Logic
# Creates the SPI bus
spi = busio.SPI(clock=board.SCK, MISO=board.MISO, MOSI=board.MOSI)

# Creates the cs (chip select) with a gpio pin variable, we are using 24 GPIO 8 (SPI Chip Select 0), so 8 for the config
my_pin = f"D{self.sensor_pin}"
cs = digitalio.DigitalInOut(getattr(board, my_pin))

# Creates the MCP3008 object, works with MCP3002 and MCP3004 since it is all encompassing
mcp = MCP.MCP3008(spi, cs)

readings = {}
# Iterates over values
for label, channel in self.channel_map.items():
LOGGER.info(f"loop channel is {channel} and loop label is {label}")
LOGGER.debug(f"loop channel is {channel} and loop label is {label}")
# Create an analog input channel
chan = int(channel)
readings[label] = mcp.read(chan)
readings[label] = self.mcp.read(chan)

return readings

async def close(self):
self.spi.deinit()
self.cs.deinit()

0 comments on commit 68e406e

Please sign in to comment.