This is an approach to create applications with RUI3 without writing code.
It is as well trying to work without any installation effort.
The simple IDE is written in Python and might require to install some additional modules.
This code is Work in progress and far from finished. It is based on Python, but at the moment works only on Windows (Linux and MacOS needs testing).
The repo is missing the required BSP's because the files are too large. The complete ZIP file including the BSP's can be downloaded from Google Drive.
Unzip the downloaded compressed file into a folder on your harddisk. Avoid long pathnames, keep it close to the root of a drive e.g. C:/RUI3-my-IDEa
.
Start the application with _rui3_my_idea_win.exe
( Windows ) or rui3_my_idea_linux
( Linux_ ).
On the first start the application will download the required files for the WisBlock Core modules. This can take some time. Make sure you have a stable internet connection and can access Github.com.
Unzip the downloaded compressed file into your Documents folder. Do not use other folders or the application might not work.
Start the application with _rui3_my_idea_mac
_.
Due to some limitations in Mac OS X, starting the application might take some time.
On the first start the application will download the required files for the WisBlock Core modules. This can take some time. Make sure you have a stable internet connection and can access Github.com.
Instead of installing Arduino IDE, installing BSP's and libraries, the usage of RUI3-Modular is be limited to just downloading the compressed IDE, unzipping it on your computer, start a Python script and start creating an RUI3 based application for RAK3172, RAK4630 and RAK11720.
On the first start it will install the required BSP files automatically.
For Windows an executable file is included in the compressed folder. rui3-my-idea.exe can be used only on Windows. It does not require to have Python installed.
This small IDE has ready to use files for many WisBlock Modules. No code parts need to be edited for a simple application using multiple of the available WisBlock Modules.
Only a few steps are required to add a module to the application.
The complete LoRaWAN communication is handled by RUI3, setup is done with WisToolBox or AT commands.
This is a generic description for the six steps required to build an application. See below an example for two WisBlock modules.
1) Start the GUI either from a shell with _py ./rui3_my_idea.pyw
or by double clicking on the rui3_my_idea.exe
_ executable file (Only Windows for now).
REMARK
_If the Python script doesn't start it might be that the Python library tkinter is missing. You can install the missing module with
post_install.bat
orpost_install.sh
.
_The .exe executable file is only for Windows**_
2) Select a core module, either RAK3372, RAK4631 or RAK11722
3) Prepare a WisBlock Base Board with the selected Core module and the WisBlock modules that are used in the application.
4) Connect the WisBlock Base Board with the modules to the USB port of the computer
5) Select the modules used in the application with the buttons in the GUI
REMARK
Some modules that are using GPIO's require to select the WisBlock Sensor Slot in which the modules are used
5) (Optional) Use the Verify function from the Menu to run a compilation test
6) Use the Upload function from the Menu to compile the code and upload it to the WisBlock Core module
7) After successful uploading the code, the Serial terminal is activated and shows the log output of the WisBlock Core module
https://user-images.githubusercontent.com/512690/210194382-a8e5de1e-5967-4b9f-9a99-4c5674832612.mp4
Module | Function | Supported |
---|---|---|
RAK4631-R ⤴️ | WisBlock Core module with RUI3 | ✔ |
RAK3372 ⤴️ | WisBlock Core module with RUI3 | ✔ |
RAK19007 ⤴️ | WisBlock Base board | ✔ |
RAK19003 ⤴️ | WisBlock Mini Base board | ✔ |
RAK19001 ⤴️ | WisBlock Fullsize Base board | ✔ |
RAK1901 ⤴️ | WisBlock Temperature and Humidty Sensor | ✔ |
RAK1902 ⤴️ | WisBlock Barometer Pressure Sensor | ✔ |
RAK1903 ⤴️ | WisBlock Ambient Light Sensor | ✔ |
RAK1904 ⤴️ | WisBlock Acceleration Sensor (used for GNSS solutions) | ✔ |
RAK1905 ⤴️ | WisBlock 9 DOF sensor | ✔ |
RAK1906 ⤴️ | WisBlock Environment Sensor | ✔ |
WisBlock GNSS Sensor | Work in progress | |
RAK1921 ⤴️ | WisBlock OLED display | ✔ |
RAK12002 ⤴️ | WisBlock RTC module | ✔ |
RAK12003 ⤴️ | WisBlock FIR sensor | ✔ |
WisBlock MQ2 Gas sensor | Work in progress | |
WisBlock MG812 CO2 Gas sensor | Work in progress | |
WisBlock MQ3 Alcohol Gas sensor | Work in progress | |
RAK12010 ⤴️ | WisBlock Ambient Light sensor | ✔ |
RAK12014 ⤴️ | WisBlock Laser ToF sensor | ✔ |
RAK12019 ⤴️ | WisBlock UV Light sensor | ✔ |
WisBlock Gyroscope sensor | Work in progress | |
RAK12027 ⤴️ | WisBlock Seismic sensor | ✔ |
WisBlock Soil Moisture and Temperature sensor | Work in progress | |
RAK12037 ⤴️ | WisBlock CO2 sensor | ✔ |
RAK12039 ⤴️ | WisBlock PM sensor | ✔ |
RAK12040 ⤴️ | WisBlock AMG8833 temperature array sensor | ✔ |
RAK12047 ⤴️ | WisBlock VOC sensor | ✔ |
RAK12500 ⤴️ | WisBlock GNSS Sensor | ✔ |
RAK13011 ⤴️ | WisBlock Reed Relay Switch | ✔ |
WisBlock 3 button touch pad | Work in progress | |
WisBlock LED bar display | Work in progress | |
WisBlock Gesture sensor | Work in progress |
No need to install any of this, the Arduino CLI, the needed BSP's and libraries are already in the ZIP file!
This list is just an overview what is used.
The packet data is made compatible with the extended Cayenne LPP encoding from ElectronicCats/CayenneLPP ⤴️.
The content of the packet depends on the modules installed on the WisBlock Base Board:
Data | Channel # | Channel ID | Length | Comment | Required Module | Decoded Field Name |
---|---|---|---|---|---|---|
Battery value | 1 | 116 | 2 bytes | 0.01 V Unsigned MSB | RAK4631 | voltage_1 |
Humidity | 2 | 104 | 1 bytes | in %RH | RAK1901 | humidity_2 |
Temperature | 3 | 103 | 2 bytes | in °C | RAK1901 | temperature_3 |
Barometric Pressure | 4 | 115 | 2 bytes | in hPa (mBar) | RAK1902 | barometer_4 |
Illuminance | 5 | 101 | 2 bytes | 1 lux unsigned | RAK1903 | illuminance_5 |
Humidity 2 | 6 | 104 | 1 bytes | in %RH | RAK1906 | humidity_6 |
Temperature 2 | 7 | 103 | 2 bytes | in °C | RAK1906 | temperature_7 |
Barometric Pressure 2 | 8 | 115 | 2 bytes | in hPa (mBar) | RAK1906 | barometer_8 |
Gas Resistance 2 | 9 | 2 | 2 bytes | 0.01 signed (kOhm) | RAK1906 | analog_9 |
GNSS stand. resolution | 10 | 136 | 9 bytes | 3 byte lon/lat 0.0001 °, 3 bytes alt 0.01 meter | RAK12500 | gps_10 |
GNSS enhanced resolution | 10 | 137 | 11 bytes | 4 byte lon/lat 0.000001 °, 3 bytes alt 0.01 meter | RAK12500 | gps_10 |
Soil Temperature | 11 | 103 | 2 bytes | in °C | RAK12023/RAK12035 | temperature_11 |
Soil Humidity | 12 | 104 | 1 bytes | in %RH | RAK12023/RAK12035 | humidity_12 |
Soil Humidity Raw | 13 | 2 | 2 bytes | 0.01 signed | RAK12023/RAK12035 | analog_in_13 |
Soil Data Valid | 14 | 102 | 1 bytes | bool | RAK12023/RAK12035 | presence_14 |
Illuminance 2 | 15 | 101 | 2 bytes | 1 lux unsigned | RAK12010 | illuminance_15 |
VOC | 16 | 138 | 2 bytes | VOC index | RAK12047 | voc_16 |
MQ2 Gas | 17 | 2 | 2 bytes | 0.01 signed | RAK12004 | analog_in_17 |
MQ2 Gas Percentage | 18 | 120 | 1 bytes | 1-100% unsigned | RAK12004 | percentage_18 |
MG812 Gas | 19 | 2 | 2 bytes | 0.01 signed | RAK12008 | analog_in_19 |
MG812 Gas Percentage | 20 | 120 | 1 bytes | 1-100% unsigned | RAK12008 | percentage_20 |
MQ3 Alcohol Gas | 21 | 2 | 2 bytes | 0.01 signed | RAK12009 | analog_in_21 |
MQ3 Alcohol Gas Perc. | 22 | 120 | 1 bytes | 1-100% unsigned | RAK12009 | percentage_22 |
ToF distance | 23 | 2 | 2 bytes | 0.01 signed | RAK12014 | analog_in_23 |
ToF Data Valid | 24 | 102 | 1 bytes | bool | RAK12014 | presence_24 |
Gyro triggered | 25 | 134 | 6 bytes | 2 bytes per axis, 0.01 °/s | RAK12025 | gyrometer_25 |
Gesture detected | 26 | 0 | 1 byte | 1 byte with id of gesture | RAK14008 | digital_in_26 |
LTR390 UVI value | 27 | 2 | 2 byte | 0.01 signed | RAK12019 | analog_in_27 |
LTR390 UVS value | 28 | 101 | 2 bytes | 1 lux unsigned | RAK12019 | illuminance_28 |
INA219 Current | 29 | 2 | 2 byte | 0.01 signed | RAK16000 | analog_29 |
INA219 Voltage | 30 | 2 | 2 byte | 0.01 signed | RAK16000 | analog_30 |
INA219 Power | 31 | 2 | 2 byte | 0.01 signed | RAK16000 | analog_31 |
Touchpad left | 32 | 102 | 1 bytes | bool | RAK14002 | presence_32 |
Touchpad middle | 33 | 102 | 1 bytes | bool | RAK14002 | presence_33 |
Touchpad right | 34 | 102 | 1 bytes | bool | RAK14002 | presence_34 |
SCD30 CO2 concentration | 35 | 125 | 2 bytes | 1 ppm unsigned | RAK12037 | concentration_35 |
SCD30 temperature | 36 | 103 | 2 bytes | in °C | RAK12037 | temperature_36 |
SCD30 humidity | 37 | 104 | 1 byte | in %RH | RAK12037 | humidity_37 |
MLX90632 sensor temp | 38 | 103 | 2 bytes | in °C | RAK12003 | temperature_38 |
MLX90632 object temp | 39 | 103 | 2 bytes | in °C | RAK12003 | temperature_39 |
PM 1.0 value | 40 | 103 | 2 bytes | in ug/m3 | RAK12003 | voc_40 |
PM 2.5 value | 41 | 103 | 2 bytes | in ug/m3 | RAK12003 | voc_41 |
PM 10 value | 42 | 103 | 2 bytes | in ug/m3 | RAK12003 | voc_42 |
Earthquake event | 43 | 102 | 1 byte | bool | RAK12027 | presence_43 |
Earthquake SI value | 44 | 2 | 2 bytes | analog 10 * m/s | RAK12027 | analog_44 |
Earthquake PGA value | 45 | 2 | 2 bytes | analog 10 * m/s2 | RAK12027 | analog_45 |
Earthquake SHUTOFF alert | 46 | 102 | 1 byte | bool | RAK12027 | presence_46 |
Earthquake collapse alert | 47 | 102 | 1 byte | bool | RAK12027 | presence_47 |
Channel ID's in cursive are extended format and not supported by standard Cayenne LPP data decoders.
Example decoders for TTN, Chirpstack, Helium and Datacake can be found in the folder decoders ⤴️
This list is constantly extended as we add new WisBlock modules. Check out the RAKwireless Standardized Payload repo for the latest status.
The setup of the device (LoRaWAN region, DevEUI, AppEUI, AppKey, ....) can be done with AT commands over the USB port or with WisToolBox
Example AT commands:
AT+NWM=1
AT+NJM=1
AT+BAND=10
AT+DEVEUI=1000000000000001
AT+APPEUI=AB00AB00AB00AB00
AT+APPKEY=AB00AB00AB00AB00AB00AB00AB00AB00
ATC+SENDINT=600
Command | Explanation | |
---|---|---|
AT+NWM=1 | set the node into LoRaWAN mode | |
AT+NJM=1 | set network join method to OTAA | |
AT+BAND=10 | set LPWAN region (here AS923-3) see AT Command Manual ⤴️ for all regions | |
AT+DEVEUI=1000000000000001 | set the device EUI, best to use the DevEUI that is printed on the label of your WisBlock Core module | |
AT+APPEUI=AB00AB00AB00AB00 | set the application EUI, required on the LoRaWAN server | |
AT+APPKEY=AB00AB00AB00AB00AB00AB00AB00AB00 | set the application Key, used to encrypt the data packet during network join | |
ATC+SENDINT=600 | set the interval the sensor node will send data packets. 600 == 10 x 60 seconds == 10minutes |
The manual for all AT commands can be found here: AT-Command Manual ⤴️
There are additional custom AT commands implemented:
ATC+STATUS
to get the current status of the device.
Example:
atc+status=?
Device Status:
Module: RAK4630
Version: RUI_3.5.2b_175_RAK4631
Send time: 120 s
Network mode LoRaWAN
Network joined
Region: 10
Region: AS923-3
OTAA mode
DevEUI = AC1F09FFFE057110
AppEUI = AC1F09FFFE057110
AppKey = 2B84E0B09B68E5CB42176FE753DCEE79
+EVT:RAK1901 OK
+EVT:RAK1902 OK
+EVT:RAK1903 OK
+EVT:RAK12019 OK
OK
ATC+SENDINT
to get and set the automatic send interval
Example:
atc+sendfreq=?
ATC+SENDINT=120s
OK
atc+sendfreq=120
OK
If an RAK12002 RTC module is used, the command ATC+RTC
is available to get and set the date time
Example:
atc+rtc=?
ATC+RTC=2000.01.01 0:00:21
atc+rtc=2022:10:21:14:15
OK
atc+rtc=?
ATC+RTC=2022.10.21 14:15:25
If an RAK12500 GNSS module is used, the command ATC+GNSS
is available to change GNSS precision and payload format.
It accepts 4 different values:
0 = 4digit prec., 1 = 6digit prec, 2 = Helium Mapper format, 3 = Field Tester format
Example:
atc+gnss=?
GNSS 4 digit Cayenne LPP
atc+gnss=1
OK
```log
atc+gnss=?
GNSS 6 digit extended Cayenne LPP