Skip to content

SERIAL_SINGLE_MEASUREMENT

Take a single data reading from a connected serial device (such as an Arduino connected by USB).Params:baudrate : intBaud rate for the serial communication.comport : stringDefines the communication port on which the serial device is connected.Returns:out : OrderedPairthe y axis contains the reading
Python Code
from typing import Optional

import numpy as np
import serial
from flojoy import OrderedPair, SerialDevice, flojoy


@flojoy(deps={"pyserial": "3.5"})
def SERIAL_SINGLE_MEASUREMENT(
    device: SerialDevice,
    default: Optional[OrderedPair] = None,
    baudrate: int = 9600,
) -> OrderedPair:
    """Take a single data reading from a connected serial device (such as an Arduino connected by USB).

    Parameters
    ----------
    baudrate : int
        Baud rate for the serial communication.
    comport : string
        Defines the communication port on which the serial device is connected.

    Returns
    -------
    OrderedPair
        the y axis contains the reading
    """

    set = serial.Serial(device.port, timeout=1, baudrate=baudrate)
    s = ""
    while s == "":
        s = set.readline().decode()

    reading = s[:-2].split(",")
    reading = np.array(reading)  # Create an array
    reading = reading.astype("float64")  # Convert the array to float
    x = np.arange(0, reading.size)  # Create a second array

    return OrderedPair(x=x, y=reading)

Find this Flojoy Block on GitHub

Example

Having problems with this example app? Join our Discord community and we will help you out!
React Flow mini map

In this example, we use the SERIAL_SINGLE_MEASUREMENT node to extract some measurements received from an Arduino microcontroller and visualize the output.

First, you need to connect the Arduino to your computer. Then, you’ll need to upload an Arduino script to your board to define its behavior (with the Arduino IDE software). When your Arduino sends data to the serial monitor of the Arduino IDE, you can start using the SERIAL_SINGLE_MEASUREMENT node. After placing the node on Flojoy, you must specify the communication port to which the Arduino is connected. This port is found in the Arduino IDE software under Tools/Port.

The SERIAL_SINGLE_MEASUREMENT node receives data through serial communication with the Arduino, and stores the measured values in a table called reading. The Arduino then prints new values on the serial console for each loop. The SERIAL_SINGLE_MEASUREMENT node extracts a measurement (which can contain single or multiple values, as seen in the output).

The TABLE node displays all values stored in the single measurement.

Remarks about the Arduino code:

This example works with the arduino_example.ino Arduino code (see Appendix).

The last line that the Arduino should return, is the data with a new line at the end (i.e. println()).

For example:

print(reading0)
print(",")
println(reading1)

The SERIAL_SINGLE_MEASUREMENT node receives data from the Arduino serial console as a string and splits it using ”,” as a separator. It then returns the values measured in a list called reading.

Update the Single Measurement with a Loop:

To update the values received from the Arduino, use the LOOP node to create a loop around the SERIAL_SINGLE_MEASUREMENT and TABLE nodes.

The loop allows the user to update measurements, but only the last measurement will be saved and displayed.

To record all the measurements for a given period, use the SERIAL_TIMESERIES node.