Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add SG F1 starter kit documentation #1367

Merged
merged 7 commits into from
Sep 17, 2024
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added doc/content/devices/models/sg-f1/ctrl-install.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added doc/content/devices/models/sg-f1/f1-board.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
155 changes: 155 additions & 0 deletions doc/content/devices/models/sg-f1/index.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,155 @@
---
title: "SG Wireless F1 Starter Kit"
description: ""
weight:
---

{{< figure src="f1-board.png" alt="" class="float plain" width="80%">}}

The [SG Wireless F1 Starter Kit](https://eshop.sgwireless.com/bundle-f1-starter-kit-with-cap-t-sensor/) is an Arduino form factor board based on the F1 Smart Module, which features Wi-Fi, Bluetooth LE, LTE and LoRaWAN connectivity. It boasts a nano-SIM holder, micro-SD card holder and a li-po battery connector.

<!--more-->

In order to program the F1 Starter Kit, we must use Microsoft Visual Studio Code and the CtrlR plugin.

You will need the latest version of Visual Studio Code to proceed, which can be downloaded and installed [here](https://code.visualstudio.com/?wt.mc_id=vscom_downloads).

## Setting up CtrlR Plugin

Open Visual Studio Code and navigate to **Extensions**. Search for `ctrlr` and click **Install**.

{{< figure src="ctrl-install.png" alt="" >}}

Connect your F1 Starter Kit to your PC and turn it on (SW200 switch from OFF to ON).

Head over to the CtrlR tab and click on the **connect device** button (lightning bolt) for the device.

{{< figure src="connect-device.png" alt="" >}}

{{< note "If your PC doesn’t have the driver installed, an unknown device will be shown in your PC’s Device Manager. Download and install the [Virtual COM Port driver](https://www.silabs.com/developers/usb-to-uart-bridge-vcp-drivers), and the device should show up in your Device Manager." />}}

Then when it's connected, click the folder button.

{{< figure src="open-device.png" alt="" >}}

When the Explorer opens, open the folder structure of the device and open `main.py`

{{< figure src="main-file.png" alt="" >}}

In the main.py file, replace the code with the following one:

```py
import logs
import lora
import ubinascii
import time

logs.filter_subsystem('lora', False)

lora.mode(lora._mode.WAN)

# configure the stack on region EU-868 with Class A
lora.wan_params(region=lora._region.REGION_EU868, lwclass=lora._class.CLASS_A)

lora.commission(
type = lora._commission.OTAA,
version = lora._version.VERSION_1_1_X,
DevEUI = ubinascii.unhexlify('0000000000000000'),
JoinEUI = ubinascii.unhexlify('0000000000000000'),
AppKey = ubinascii.unhexlify('00000000000000000000000000000000'),
NwkKey = ubinascii.unhexlify('00000000000000000000000000000000')
)

lora.join()

while lora.is_joined() == False:
print("wait joining ...")
time.sleep(2)
pass
print("-- JOINED --")
lora.stats()

lora.port_open(1)

def get_event_str(event):
if event == lora._event.EVENT_TX_CONFIRM:
return 'EVENT_TX_CONFIRM'
elif event == lora._event.EVENT_TX_DONE:
return 'EVENT_TX_DONE'
elif event == lora._event.EVENT_TX_TIMEOUT:
return 'EVENT_TX_TIMEOUT'
elif event == lora._event.EVENT_TX_FAILED:
return 'EVENT_TX_FAILED'
elif event == lora._event.EVENT_TX_CONFIRM:
return 'EVENT_TX_CONFIRM'
elif event == lora._event.EVENT_RX_DONE:
return 'EVENT_RX_DONE'
elif event == lora._event.EVENT_RX_TIMEOUT:
return 'EVENT_RX_TIMEOUT'
elif event == lora._event.EVENT_RX_FAIL:
return 'EVENT_RX_FAIL'
else:
return 'UNKNOWN'

def port_any_cb(event, evt_data):
print('lora event [ {} ] --> data: {}'
.format(get_event_str(event), evt_data))

lora.callback(handler=port_any_cb)

lora.duty_set(10000)
lora.enable_rx_listening()
lora.duty_start()

# schedule sending some test messages
i = 1000
while i < 1010:
lora.send('1000', port=1, confirm=True, id = i)
i = i + 1
```

Now we have our code in place, but we need credentials for connecting it to {{% tts %}}.

## Onboarding to {{% tts %}}

The device has to be onboarded **manually**.

To onboard **manually**, in the **End device type** section, under **Input Method**, select the **Enter end device specifics manually** option. The [Manually adding devices]({{< ref "/devices/adding-devices/manual/" >}}) and [Over the Air Activation (OTAA)]({{< ref "/devices/adding-devices/manual/otaa/" >}}) guides explain this procedure in detail. Following details are specific to the F1:

- **LoRaWAN version:** LoRaWAN Specification 1.1.0
- **Regional parameters version:** RP001 Regional Parameters 1.1 revision B

For the Provisioning information, enter the following details:
- **JoinEUI:** `0000000000000000`
- **DevEUI:** Generate by clicking the **Generate** button.
- **AppKey:** Generate by clicking the **Generate** button.
- **NwkKey:** Generate by clicking the **Generate** button.

After configuring your device, select the **Register end device** button.

{{< figure src="f1-manual-register.png" alt="Settings for manual registration" >}}

## Updating code

Go back to the code and locate this portion:

```py
lora.commission(
type = lora._commission.OTAA,
version = lora._version.VERSION_1_1_X,
DevEUI = ubinascii.unhexlify('0000000000000000'),
JoinEUI = ubinascii.unhexlify('0000000000000000'),
AppKey = ubinascii.unhexlify('00000000000000000000000000000000'),
NwkKey = ubinascii.unhexlify('00000000000000000000000000000000')
)
```

In {{% tts %}}, copy the **DevEUI** and replace the `0000000000000000` with the devEUI you copied.

Repeat this for the **AppKey** and **NwkKey** too.

{{< figure src="f1-activ-info.png" alt="" >}}

Save the `main.py` file, right click the file, then **CtrlR** -> **Upload to Device**.

There should be activity showing up in the console. Now that you know how to connect the device to {{% tts %}}, you can create or add your application to the device!
Binary file added doc/content/devices/models/sg-f1/main-file.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added doc/content/devices/models/sg-f1/open-device.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading