Skip to content
Philippe Coval edited this page Oct 6, 2018 · 51 revisions

SENSORS AND ACTUATORS

INTRODUCTION:

In IoT and embedded world, sensors and actuators are key components to interact with the external physical world, which is the base of many use cases or Concepts.

While there is only two types of operations:

  • READ: Measuring some physical energy
  • WRITE: Delivering some energy to some device that can alter an established situation

Some devices are combining both, that's the reason sometimes actuators are sometimes mixed with sensors.

To avoid any ambiguity I'll use those 2 terms:

  • Sensor for reading input data (sensing)
  • Actuator for writing outout data (acting)

In WoT context, those two elements are defined as properties which could be readable or writable, other semantics are also used: BooleanProperty, OnOffProperty, BinarySensor, SwitchOnOff, don't be confused.

Note that when real time monitoring is needed (for Sensor) you may consider to use webthing-node which is fully supporting websockets (this is demonstrated by "Clap Sensor" part of "Smart Orchid" demo).

DEMO:

To illustrate Concept, watch Sensor part of the "Smart Orchid" demo video:

web-of-things-agriculture-20180712rzr.webm

The simplest use case is just basic interaction from the RaspberryPi's button to the artik ARTIK05x's LED.

To recap here are all elements we will explain in following chapters:

  • ARTIK05s on board LED is simplest Actuator running on IoT.js and TizenRT
  • "Button sensor" on RaspberryPi is simplest sensor running on IoT.js on RaspberryPi, (connected to earlier Actuator via Gateway)
  • "Clap sensor" using webthing-node (on RaspberryPI)
  • "Ambient Light" and "Temperature" using generic-sensor-lite connected to RaspberryPi
  • "Moisture" Level Sensor on Extra Arduino MCU board
  • Actuator RGB Lamp on ESP8266 MCU

IO

IO.js

GPIO

General Purpose Input/Output interface is widely used digital communication (on/off):

NodeJS is suporting this with different external implementations, the most generic one is using "sysfs" (Linux kernel interface and thus provide genericity among different hardware (ARTIK, RPi etc):

While IoT.js uses a built in module, which can be optionnaly enabled at built time:

Unfortunately API are not aligned, so I made an abstraction class to provide portability:

Note Raspberry Pi users might be used to "WiringPi" library, it can be installed also as Node.js module:

To avoid rewriting GPIO calls, a wrapper class can be also used for IoT.js:

ON/OFF ACTUATORS:

LED ACTUATOR:

There are two onboard buttons that can be used on ARTIK 05x board, check following IoT.js code (made for TizenRT but portable to other OS):

RELAY ACTUATOR:

If you can turn on a LED then code is same to control a relay that can power an other device. All you need is to use or build an electronic circuit or use standalone module, like "Flex RaspberryPi's hat":

flex-hat

"Smart Orchid Demo" was using Gateway's GPIO Adapter, and relay is turning an USB fan (powered by 5V source).

Watch previously explanations for ARTIK10 (to prototype an IoTivity thing but it's same problem):

ON/OFF SENSORS:

BUTTONS SENSOR:

Webthing-node is now supporting GPIO, ARTIK530 is used as reference platform because it feature 2 onboard buttons.

Or we can validate GPIO inputs using an OpenSource hardware "buttons" board "PlayPHat":

USING NODEJS

project="webthing-node"
url="https://github.com/mozilla/${project}"
branch='master'
git clone --recursive --depth 1 -b "$branch" "$url" ; cd "$project"
make -C example/platform play-phat

Expected log:

NODE_PATH=.:../.. node index play-phat
log: board: play-phat: Loading
Usage:
/home/pi/.nvm/versions/node/v8.11.4/bin/node /home/pi/webthing-iotjs/example/platform/index [board] [port]
Try:
curl -H "Accept: application/json" http://localhost:8888

log: board: play-phat: Started
log: GPIO: Left: open:
log: GPIO: Right: open:
log: GPIO: Up: open:
log: GPIO: Down: open:
log: GPIO: A: open:
log: GPIO: B: open:
log: GPIO: Start: open:
log: GPIO: Select: open:

log: GPIO: Start: change: false
log: GPIO: Start: change: true

There are two onboard buttons that can be used on ARTIK 05x board, check following IoT.js code (made for TizenRT but portable to other OS):

If using Node.js and GPIO's module this example can be used as base on GPIO11 (here used for "Flex RaspberryPi hat"):

USING IOTJS

Same as nodejs but quicker but with mentionned limitations:

project="webthing-iotjs"
url="https://github.com/rzr/${project}"
branch="master"
git clone --recursive --depth 1 -b "$branch" "$url" ; cd "$project"
make -C example/platform play-phat

Expected log:

iotjs index.js play-phat
log: board: play-phat: Loading
Usage:
iotjs index.js [board] [port]
Try:
curl -H "Accept: application/json" http://localhost:8888

log: board: play-phat: Started
log: GPIO: Left: open: null (null expected)
(...)
log: GPIO: Start: change: true
(...)
  • TODO: on failure after reboot, run again

PlayPHat

RASPBERRY PI

Note that Pi's GPIOs input mode can be configured externally, using gpio tool. IoT.js and npm's gpio module are not (yet) supporting this.

For example check Pi Hats like TrafficPHat (and its 3 buttons mini hat):

project="webthing-iotjs"
url="https://github.com/rzr/${project}"
branch="sandbox/rzr/iotjs/master"

mkdir -p "${url}/${branch}"
cd "${url}/${branch}"

git clone --recursive --depth 1 -b "$branch" "$url" && cd "$project"
make start/board/traffic-phat

CLAP SENSOR:

"Smart Orchid Demo" showed a "Clap sensor", which is basically just a GPIO input of KY-037's digital pin:

I used it on a Raspberry Pi using node, but it should work on any other device.

For the record I used this PiHat, and modified it to plug additional sensor in (clap):

If curious check Mozilla blog post about an alternative way to build a "Clap sensing webthing" :

clap-sensing

ADC SENSOR

Status: In developement, TODO: (Double check and upstream).

Analog input signal can be monitored using ARTIK530 (or 710 this is the one I used).

USING IOTJS RUNTIME:

IoT.js is supporting Analog Digital Converter natively so it can be used easily:

project="webthing-iotjs"
board="artik530"
image="arm32v7/debian"
url="https://github.com/rzr/${project}"
branch="sandbox/rzr/iotjs/master"

git clone --recursive --depth 1 -b "$branch" "$url" && cd "$project"
sed -e "s|^FROM .*|FROM $image|g" -i Dockerfile

$sudo systemctl restart docker
time docker rm "${project}"
time docker build -t "${USER}/${project}" . # <20min first time
time docker run -t \
  --volume /sys:/sys --publish 8888:8888 --net "host" \
  --name "${project}" --rm \
  "${USER}/${project}" start/board/${board}

(...)
curl -H "Accept: application/json" http://localhost:8888
(...)
log: ADC: ADC0: open: null (null expected)
log: ADC: ADC1: open: null (null expected)
(...)
log: ADC: ADC0: change: 0%
log: ADC: ADC1: change: 0%
(...)

curl http://${HOSTNAME}.local:8888/properties/ADC0


{"ADC0":0}

If using TizenRT make sure to enable ADC driver and device enabled:

make menuconfig
Hardware Configuration > Chip Selection > S5J Peripheral Support > [*] ADC
  • TODO: Fix this in iotjs's defconfig

USING NODE RUNTIME:

Node.js is not supporting ADC natively but it's easy to get access to ADC driver, trough Linux kernel's sysfs interface (and docker needs to be exported to be used as RW):

board="artik530"
project="webthing-node"
url="https://github.com/mozilla-iot/${project}"
branch="master"
image="node:10"

git clone --recursive --depth 1 -b "$branch" "$url" && cd "$project"
sed -e "s|^FROM .*|FROM $image|g" -i Dockerfile

$sudo systemctl restart docker
time docker build -t "${USER}/${project}" . # <20min
time docker run \
  --volume /sys:/sys --publish 8888:8888 --net "host" \
  --name "${project}" --rm \
  "${USER}/${project}" node example/platform ${board}

(...)
log: ADC: ADC1: update: 0x791
log: ADC: ADC1: change: 41%
(...)

curl http://${HOSTNAME}.local:8888/properties/ADC0
{"ADC0":42}

Note: --net "host" option is needed, because you'll face an Express's 403 issue if not using localhost.

Related:

GENERIC SENSORS:

Note: It's possible to use I2C sensors on IoT.js but since some sensors changes are not yet upstreamed this chapter starts to explain the currently supported use.

In "Smart Orchid demo" "I2C sensors were connected to RaspberryPi's bus of Gateway (using Node,js runtime), then the "Generic sensors adapter" was installed as Gateway's addon (released since mozilla-iot-gateway-0.4).

mozilla-iot-gateway-sensors-20180406rzr

The adapter is built on a high level wrapper abstract drivers, o "generic-sensor-lite" module can be also used outside Gateway, check more detail on project page:

Check supported sensors For now I recommend to use either BH1650 or BMP082 modules, community implemented drivers, which are supported by NPM community, since my fixes were upstreamed.

Now you can try to create webthings, I suggest to start making them for supported Node.js and then port to IoT.js (in development).

STATUS: UPSTREAMING

For the record following repos were used:

LICENSE: CC-BY-SA-4.0

INDEX

Clone this wiki locally