hibigaku が 2019年10月09日05時12分12秒 に編集
初版
タイトルの変更
Sigfox Shield for Arduinoを使ってみる
タグの変更
sigfox
Arduino
IoT
LPWA
クラウド
センサー
記事種類の変更
セットアップや使用方法
本文の変更
低消費電力・低コスト・長距離伝送を特長としたLPWA Sigfoxの開発キットSigfox Shield for Arduino (UnaShield)の使い方を説明します。 ![UnaShield-V2S2-details-opt.jpg](https://camo.elchika.com/8d10e98874871ac427d350038b862fced33b84eb/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f66623632613138392d313936322d343830652d626638622d6564653131353538353838652f32306537636336382d623938642d343533392d393533332d353930636165656564346539/) # まず最初に まずは、開発キットの入手と1年間無料回線契約が必要になります。(Arduino Unoも必要です) ## 開発キットの入手 Sigfox Shield for Arduinoは、下記ネットショップから購入できます。 - [マルツエレック](https://www.marutsu.co.jp/pc/i/952284/) - [ソラコム](https://soracom.jp/products/sigfox/) - [共立電子産業](http://eleshop.jp/shop/g/gHAR311/) - [スイッチサイエンス](https://www.switch-science.com/catalog/3354/) ## 1年間無料回線契約 開発キットを入手したら、[Sigfox Buy](https://buy.sigfox.com/)サイトから"Activate my Devkit"ボタンを選択し、画面指示に従って無料回線を取得してください。この時、デバイスのIDとPACが必要になりますので、開発キットに添付されているQRコードを読みとり、入力してください。 取得後、[Sigfox backendクラウド](https://backend.sigfox.com)のアクセス権が払い出されますので、ログインして、ご自身のデバイスが登録されていることを確認してください。 # Sigfoxメッセージを送信する デバイスが登録されていることが確認できれば、早速ArduinoとSigfox Shield for Arduinoを使ってSigfoxメッセージを送信してみましょう。 サンプルスケッチを[こちら](https://github.com/kccs-iot/sigfox-shield-arduino)からダウンロードして、コンパイル後、Arduinoに書き込んでください。 ```arduino:basic-demo #include "SIGFOX.h" //必要に応じ書き換えてください //************************************ static const unsigned int MESSAGE_INTERVAL = 30000; //Sigfoxメッセージ送信間隔(30秒) static const unsigned int MAX_MESSAGE_CNT = 10; //Sigfoxメッセージ最大送信数(10回) //************************************ unsigned int message_cnt = 0; // IMPORTANT: Check these settings with UnaBiz to use the SIGFOX library correctly. static const String device = "NOTUSED"; // Set this to your device name if you're using UnaBiz Emulator. static const bool useEmulator = false; // Set to true if using UnaBiz Emulator. static const bool echo = true; // Set to true if the SIGFOX library should display the executed commands. static const Country country = COUNTRY_JP; // Set this to your country to configure the SIGFOX transmission frequencies. static UnaShieldV2S transceiver(country, useEmulator, device, echo); // Uncomment this for UnaBiz UnaShield V2S Dev Kit static String response; // Will store the downlink response from SIGFOX. // IMPORTANT: Check these settings with UnaBiz to use the SIGFOX library correctly. void setup() { Serial.begin(9600); // Arduinoハードウェアシリアルを起動(Arduino <-> PC) Serial.println("==========================="); Serial.println("Sigfox UnaShield Basic Sample"); Serial.print("Send a message in "); Serial.print(MAX_MESSAGE_CNT); Serial.print(" times for each "); Serial.print(MESSAGE_INTERVAL); Serial.println(" msec."); Serial.println("==========================="); //Sigfoxモジュールを起動 if (!transceiver.begin()) stop(F("Unable to init SIGFOX module, may be missing")); // Will never return. Serial.println("Waiting 3 seconds..."); delay(3000); } void loop() { //温度、バッテリー電圧を取得する float temperature = 0; float voltage = 0; transceiver.getTemperature(temperature); transceiver.getVoltage(voltage); if (sendSigfoxMessage(message_cnt, temperature, voltage)) { message_cnt++; } if (message_cnt >= MAX_MESSAGE_CNT) { stop(String("finish...(Message sent successfully)")); } Serial.print("Waiting "); Serial.print(MESSAGE_INTERVAL/1000); Serial.println(" seconds..."); delay(MESSAGE_INTERVAL); } //送信回数と温度、バッテリー電圧をSigfoxメッセージで送信する bool sendSigfoxMessage(unsigned int cnt, float temperature, float voltage) { Serial.println("\n*****SEND SIGFOX MESSAGE*****"); String sCnt = transceiver.toHex(cnt); String sTemp = convertFloatToHex(temperature); String sVoltage = convertFloatToHex(voltage); Serial.print("Count: "); Serial.print(cnt); Serial.print(" / Temperature: "); Serial.print(temperature); Serial.print(" / Voltage: "); Serial.println(voltage); Serial.print("Payload: "); Serial.println(sCnt + sTemp + sVoltage); bool success = transceiver.sendMessage(sCnt + sTemp + sVoltage); Serial.println("*****************************"); return success; } //Float型変数をIEEE754に準拠した16進文字列へ変換する String convertFloatToHex(float val) { union { uint32_t B32; float Float; } floatb32; floatb32.Float = val; return String(floatb32.B32, HEX); } ``` このスケッチを動かすことにより、送信回数と温度、バッテリー電圧をSigfoxメッセージで送信することができます。 次は、Sigfox backendクラウドで受信したかどうかを確認します。 # Sigfox backendクラウドで受信確認する [Sigfox backendクラウドのDEVICEリスト](https://backend.sigfox.com/device/list)から、ご自身のデバイスIDを選択し、左メニューから**MESSAGES**を選択すると、下図のように受信されたメッセージが確認できます。 ![sigfox-backend.png](https://camo.elchika.com/67276cb276217787797b2ede1c0b6b361c0ed34d/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f66623632613138392d313936322d343830652d626638622d6564653131353538353838652f63666232616166642d616165372d346430652d616138342d333964646162303330623735/) # Callback機能を使い3rd partyアプリケーションにメッセージを転送する SigfoxクラウドのCallback機能を使用することにより、外部アプリケーションにメッセージペイロードを転送することができます。 ## Callbackの設定方法 [Sigfox backendクラウドのDEVICETYPEリスト](https://backend.sigfox.com/devicetype/list)から、ご自身のデバイスタイプ名(Name)を選択し、左メニューから**CALLBACKS**を選択してください。 Sigfoxクラウドは、AWS IoTやMicrosoft Azure IoT hub、IBM Watson IoT Platform等との連携メニューがありますが、それ以外は、**Custom callback**を使います。 ![custom callback.png](https://camo.elchika.com/7f10b2973d39625ed528b234ce7dd87155de2f34/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f66623632613138392d313936322d343830652d626638622d6564653131353538353838652f30643531386463612d383530642d343538362d393165612d306465653632336334336434/) Callback設定画面では、Typeを[DATA]_[UPLINK]とし、下図のようにUrl patternに転送先アプリケーションサーバのURL、その他メッセージ送信方法を定義することにより、メッセージペイロードを転送することができます。 ![callback2.png](https://camo.elchika.com/19d291906003ed6b682393d71a5fe6672b2bf0de/687474703a2f2f73746f726167652e676f6f676c65617069732e636f6d2f656c6368696b612f76312f757365722f66623632613138392d313936322d343830652d626638622d6564653131353538353838652f37626662373932612d386363642d346139662d393430622d333665663639306532383035/) 上記の場合、Url pattern先に下記のJSONメッセージを転送します。 ```json:callback { "device": "1234AB", <-デバイスID "time": 1570565096, <-メッセージ受信時刻(UNIXタイムスタンプ) "data": "1234567890ABCDEF" <-ペイロード } ``` あとは、アプリケーションサーバ側で、JSONメッセージをパースするだけで結構です。 もし、お手軽にアプリケーションを作ってみたい場合は、Sigfox社が、初期検証目的で公開している[IoT Agency Platform](https://try.iotagency.sigfox.com)を使ってみてください。