Skip to content

Latest commit

 

History

History
92 lines (69 loc) · 5.9 KB

File metadata and controls

92 lines (69 loc) · 5.9 KB

Portenta Machine Control Library

Check Arduino status Compile Examples status Spell Check status

License

The Portenta Machine Control Library is a C++ library designed to efficiently manage the functionalities of the Portenta Machine Control board. It provides extensive support for inputs such as digital, analog, and encoder signals, while offering outputs including digital and analog signals. This library also menages communication through protocols like CAN-BUS and serial ports, and allows connectivity via Ethernet, USB, Wi-Fi, and Bluetooth Low Energy.

The library empowers users to easily initialize, control, and access the diverse functionalities of the Portenta Machine Control, enhancing its capability and adaptability for industrial applications.

📚 For more information about this library please visit us at: https://www.arduino.cc/reference/en/libraries/arduino_portentamachinecontrol/

Features

  • Manages input signals, including:

    • 8 digital inputs at 24Vdc
    • 2 channels for encoder readings
    • 3 analog inputs for PT100/J/K temperature probes
    • 3 analog inputs for 4-20mA/0-10V/NTC signals
  • Manages output signals, including:

    • 8 digital outputs at 24Vdc
    • 4 analog outputs at 0-10V
  • Provides control for other I/O:

    • 12 programmable digital I/O at 24V
  • Supports various communication protocols:

    • CAN-BUS
    • Serial protocols (RS232/RS422/RS485)
    • USB
  • Handles RTC (Real-Time Clock) functionality

Usage

To use this library, you must have a properly powered Portenta Machine Control board running at 24V. Once you have ensured the correct power supply and established the connection, you can include the machine control library in your Arduino sketch and use its functions to manage the board features.

Here is a minimal example to control a digital output:

// Include the Arduino PortentaMachineControl library
#include <Arduino_PortentaMachineControl.h>

void setup() {
    // Initialize the digital outputs module of the MachineControl library
    MachineControl_DigitalOutputs.begin();
}

void loop() {
    // Turn on the digital output at channel 0
    MachineControl_DigitalOutputs.write(0, HIGH);
    delay(1000);
    // Turn off the digital output at channel 0
    MachineControl_DigitalOutputs.write(0, LOW);
    delay(1000);
}

Examples

  • Analog_input_0_10V: This example demonstrates how to read analog input signals in the 0-10V range.
  • Analog_input_4_20mA: This example demonstrates how to read analog input signals in the 4-20mA range.
  • Analog_input_NTC: This example shows reading analog input signals from NTC temperature probes.
  • Fast_Analog_input_0_10V: This example demonstrates how to read analog input signals in the 0-10V range using the Arduino_AdvancedAnalog library.
  • Analog_Out: This example shows how to control analog output signals.
  • ReadCan: This example demonstrates how to read data using the CAN-BUS communication protocol.
  • WriteCan: This example demonstrates how to send data using the CAN-BUS communication protocol.
  • Digital_output: This example shows how to control digital output signals.
  • Digital_input: This example shows how to read digital input signals.
  • GPIO_programmable: This example demonstrates the usage of programmable digital I/O pins.
  • Encoders: This example shows how to work with encoder readings.
  • Ethernet: This example shows how to establish Ethernet communication and connects to a website.
  • RS232: This example demonstrates serial communication using the RS232 protocol.
  • RS485_fullduplex: This example demonstrates full-duplex serial communication using the RS485 protocol.
  • RS485_halfduplex: This example demonstrates half-duplex serial communication using the RS485 protocol.
  • RTC: This example shows how to interact with the Real-Time Clock functionality.
  • RTC_Alarm: This example demonstrates how to set up and utilize RTC alarms.
  • Temp_probes_RTD: This example demonstrates the temperature probe readings using RTD sensors.
  • Temp_probes_Thermocouples: This example demonstrates the temperature probe readings using thermocouple sensors.
  • USB_host: This example shows the USB host functionality.

API

The API documentation can be found here.

License

This library is released under the MPL-2.0 license.