はじめに
趣味的ロボット研究所の管理人(@404backG)ことbackgroundです。
先日、Node-RED MCU本の補足書に執筆させていただきました。Qiitaには初投稿です。
Node-RED Advent Calendar 2023 の14日目を担当します。この記事ではNode-RED MCU用のノードの作成について書かせていただきます。
▼普段はホームページにいろいろ書いています。
▼ホームページでのNode-RED関連の記事はこちらにまとめています。
▼補足書にも書いたのですが、Node-RED MCU用のLINE Notifyノードは作成したことがあります。
この記事の目的
Node-REDで使うことができるノードは、そのすべてがNode-RED MCUに対応しているわけではありません。 また、今回扱うサーボモーターのように、知識が無いと使い方が分からないこともあると思います。まだまだ足りていないノードがあるのです。
こういった現状の問題を解決するには、有識者がノードを作れば良いと考えています。
この記事では、電子工作やプログラミングにはじめて触れる人でも簡単に使える便利なノードを作ることを目的とします。
今回の内容ぐらいならJavaScriptで書いてfunctionノードで実行することもできるのですが、ノードを並べるだけで使えるようにした方が第三者にとって便利でしょう。
詳しく書くと膨大な量になるので、私の作成の手順を簡単に紹介します。
環境について
▼Node-RED MCUの環境はRaspberry Pi 400に構築しています。
10/12にリリースされたModdable SDK 4.2で、ESP-IDFのバージョン5.1.1が必要になりました。
『はじめてのNode-RED MCU Edition』とは環境構築の方法が変わっているところがありますので、ご注意ください。
変更内容は以下のページからご確認ください。
https://www.kohgakusha.co.jp/support/node-red-mcu/index.html
バージョンアップデートに合わせて、補足書も出版されています。11月11日版は私も執筆させて頂きました。
https://techbookfest.org/product/b3T2EQ7Sw4BGzjwvv1ak1K?productVariantID=6KyS0CyiTvYmyBZDtLb4Uh
https://techbookfest.org/product/wwADMShyx2RuB9zjnrUaz0?productVariantID=6v5hDHmdjF9Qv0t8H2KgUj
ボードはModdable Twoを使います。ESP32とタッチディスプレイを搭載しています。
▼ハッカソンでも使いました。
既存のノードでサーボモーターを制御してみる
Arduino IDEならServo.hなどのライブラリを使えば簡単にサーボモーターを制御できますが、Node-RED MCUには現状、サーボモーター用のノードがありません。
サーボモーターを制御する方法を知る必要があります。以前、XIAO ESP32C3でServo.hが使えなかったので、パルスで制御したことがあります。
▼180°回転のサーボについてはこちら
▼連続回転サーボについてはこちら
今回はPWM outノードで制御してみます。
ここではSG90に準拠して、周期は20ms、パルス幅は500μs~2400μsとします。連続回転サーボの場合はパルス幅が異なります。
▼ピンのHIGHとLOWを制御するのですが、その時間間隔で角度を調整できます。
PWM outノードには0~1の値で、HIGHとLOWの割合を入力します。周波数を設定できるので、周期20msから換算して50Hzで設定しておきましょう。
▼PWM outノードの設定画面はこちら
▼例えば0°の場合はパルス幅が0.5msであり、一周期のうちの割合でいうと0.025になります。これをPWM outノードに送ります。
▼実行するフローはこちら。msg.payloadに0°、90°、180°の場合の値が順番に代入されます。
▼実際にSG90を動かしたときの様子。
▼パルス幅を700~2300に変更して、連続回転サーボのSG90-HVも動かしてみました。回転速度や向きを制御できます。
サーボモーター用のノードを作成する
既存のノードでサーボモーターを制御できたので、自作ノードにまとめていきましょう。
PWM outノードのようにピンからの出力ができるようにすることも考えたのですが、node-red-mcuリポジトリの構造を理解する必要があって大変です。ここでは簡単に、受け取った角度から計算して、PWM outノードに数値を渡すようにします。
ノードの作成については、Node-RED User Group Japanの「ノードの開発」に関するページが非常に参考になります。
https://nodered.jp/docs/creating-nodes/
Node-REDには多種多様なノードがありますが、見方を変えるとサンプルが大量にあるということでもあります。 参考になりそうなものは積極的に取り入れていきます。
主に以下の4つのファイルを用意します。
- .htmlファイル:Node-REDでのノードの表示を設定する
- .jsファイル:ノード内の処理を記述する
- package.json:.jsファイルがどこにあるのかを示す
- manifest.json:ビルド時、ノードを含めるために必要
manifest.jsonはNode-RED用のノードを作成する場合とは異なりますね。credentialsの扱いも異なるのでご注意ください。 LINE Notify用のノードを作成したときに直面しました。
通常のノードでは、パスワードなどの資格情報はcredentialsとして扱われます。これはフローを書き出す際に含まれないので、フローを安全に共有することができます。
その影響で、Node-RED MCUでビルドするときも含まれません。マイコンに資格情報を保存したいときは、credentials以外のプロパティとして扱う必要があります。
フローを第三者と共有する場合などにおける、資格情報の扱いには十分に気を付けてください。
node-red-mcuリポジトリには、ノードを作成する際のサンプルとしてlower-caseノード が用意されています。各ファイルの記述やmsg.payloadの扱いについては、こちらが最小限の構成で分かりやすいです。
さて、サーボモーターによってパルスの幅が異なるので、パルス幅の最大値と最小値、周期を入力できるようにしておけば汎用性があるでしょう。0~180°ではなく、0~270°の場合もあるので、角度の最大値と最小値も入力できるようにします。また、初心者でも使いやすいようにデフォルト値はSG90に合わせておきます。
最大値と最小値の入力といえば、dashboardノードのsliderにちょうど良さそうな入力項目があります。今回はこれを取り入れます。
Rangeノードも参考になりそうですね。こちらでは数値型への変更をしています。
主にプログラムを書くのはhtmlファイルとJavaScriptファイルです。ノードの開発に関するページを読みつつ、ソースコードと実際のノードを観察しつつ、ノードをインストールしてデバッグを繰り返すと形になっていくかと思います。
自作ノードをインストールする
node-red-mcuリポジトリ内にて、lower-caseで検索するとnode_types.jsonにlower-caseノードのパスが指定されていることが分かります。 自作ノードでも同様に、パスの追加を忘れないようにしましょう。
私の場合はWindowsのVSCodeで開発してGitHub DesktopからCommit & Pushし、Raspberry Pi環境のDesktopフォルダにCloneしています。インストールするときにファイルのパスが必要なので、分かりやすい場所に置いておきましょう。
ノードをインストールするには、LX Terminalを開いて以下のコマンドを実行します。
cd .node-red
npm install ファイルのパス
Node-REDを再起動するには以下のコマンドを用います。
sudo systemctl restart nodered.service
Node-REDをサービスとして起動しているので、プロンプトから実行する場合とは違い、LX TerminalにNode-REDの起動状態やエラーなどが表示されません。この場合、以下のコマンドでサービスの状態を確認することができます。
sudo journalctl -f -u nodered
自作ノードがNode-REDに反映されていない場合は、エラーが出ていないか確認しましょう。
今回私が作成したノードは、GitHubに公開しています。
▼実際にServoノードをインストールして、フローを作成しました。
▼ノードの設定画面はこちら。初期値が既に設定されているので、ノードを繋ぐだけで使うことができます。
▼実際の動作はこちら。Moddable Twoに表示されたsliderを動かすと、サーボモーターも回転します。
最後に
ノードの作成について述べてきましたが、いかがでしたでしょうか。
ノードを使うだけならまだしも、作成するのは難しそうだと感じている方もいるかもしれませんがご安心ください。私もNode-RED初心者であって、完全には理解できていません。
私はそもそも機械系の学生であって、プログラミングに関してはほぼ独学です。JavaScriptとHTMLに触ったのは最近のことで、バッククオーテーションを使うことにビックリしていたほどです。それでも既存のノードを参考にしつつ形にすることができました。
これからノードを作成してみたい!という方の参考になれば幸いです。
今回はPWM outノードに接続して使うようにしていますが、Servoノードだけで使えるようにしたいなと考えています。GPIO関連のファイルを参照するので、別のパッケージとして作るよりnode-red-mcuリポジトリにプルリクエストを出すべきじゃないかなと思いつつ。勉強します…