セクションの複数ページをまとめています。 印刷またはPDF形式で保存...

もとのページに戻る

2024-12-02 現在

TWELITE DIP

超簡単!標準アプリを使ってデジタル・アナログ信号を伝送する
超簡単!無線モジュール TWELITE DIP は、TWELITE を 2.54mm ピッチの基板へ搭載した製品です。手作業による配線を容易に行えるため、試作や小規模ロット生産に適しています。
外観

外観

すぐに使用できる無線モジュール

超簡単!標準アプリ

工場出荷時の TWELITE DIP には 超簡単!標準アプリ(App_Twelite)をインストールしています。

超簡単!標準アプリは、デジタル・アナログ信号の伝送を行うファームウェアです。

デジタルアナログUARTI2C
一方のデジタル入力をもう一方のデジタル出力へ一方のアナログ入力をもう一方の PWM 出力へ一方のシリアル入力をもう一方のシリアル出力へ子機のターゲットへ親機からアクセス

クイックマニュアル(PDF)

シンプルな無線通信

TWELITE は、起動直後から通信できます。Bluetooth のようなペアリングを行いません。

周波数チャネルを合わせた端末同士で同報通信を行います。したがって、同一の周波数チャネルでは、同時に複数の端末が送信を行うことはできません。自分宛でないパケットは無視します。トランシーバやインカムの動作をイメージすると分かりやすいかもしれません。

TWELITE は受信を伴わずとも送信できるため、省電力性能に優れた端末を実現できます。

データ量の多い通信には適していないものの、単純な信号伝送といった用途には最適です。

ピンの機能

ピン配置表

ピン配置表

超簡単!標準アプリで使用するピンの機能には、いくつかの種類があります。

  • 電源入力(3.3V)
    • VCC/GND 2.3-3.6V
  • デジタル・アナログ入出力
    • DIxDOxへ反映
    • AIxPWMxへ反映
  • シリアル通信
    • TX/RX UART
    • SCL/SDA I2C
  • 設定入力
    • Mx 動作モード切り替え
    • BPS 代替ボーレート選択
  • RST リセット入力

x: 任意の番号

1 - まずは使ってみる

初期設定の超簡単!標準アプリを使ってデジタル・アナログ信号を伝送する
超簡単!標準アプリ(App_Twelite)では、配線するだけで基本的な信号伝送を実現できます。

使用する製品

TWELITE DIP
TWELITE 親機/子機/中継機
超簡単!標準アプリ
2個(中継機使用時は3個)

片方向の信号伝送

親機へ入力された信号を、子機から出力できます。

デジタル信号

親機へ接続したスイッチを押すと子機へ接続した LED が点灯し、親機へ接続したスイッチを離すと子機へ接続した LED が消灯します。

親機の配線

親機の配線

子機の配線

子機の配線

上記の例では DI1DO1 だけを使っていますが、ポートは合計4つあります。他のポートも同様に使用できます。

アナログ信号

親機へ接続したボリュームを回すと、子機へ接続した LED の明るさが変化します。

親機の配線

親機の配線

子機の配線

子機の配線

上記の例では AI1PWM1 だけを使っていますが、ポートは合計4つあります。他のポートも同様に使用できます。

双方向の信号伝送

信号伝送は、親機から子機だけではなく、子機から親機へも同様に行えます。

デジタル信号の伝送例を双方向に拡張してみましょう。なおアナログ信号の伝送例も同様に拡張できます。

親機へ接続したスイッチを押すと子機へ接続した LED が点灯し、親機へ接続したスイッチを離すと子機へ接続した LED が消灯します。 同時に子機へ接続したスイッチを押すと親機へ接続した LED が点灯し、子機へ接続したスイッチを離すと親機へ接続した LED が消灯します。

親機の配線

親機の配線

子機の配線

子機の配線

上記の例では DI1DO1 だけを使っていますが、ポートは合計4つあります。他のポートも同様に使用できます。

中継機の設置

中継機として設定したものを親機と子機の間へ設置することで、通信距離を延長できます。最大3段まで中継できます。

中継機の配線

中継機の配線

M2GND へ接続します。

2 - インタラクティブモードによるカスタマイズ

インタラクティブモードを利用して機能をカスタマイズする
インタラクティブモードを利用すると、ネットワークのグループ分けや低レイテンシモードの有効化といった各種パラメータの変更を行うことができます。

インタラクティブモードとは

インタラクティブモードは、TWELITE シリーズを PC へ接続して設定を行う際に利用するモードです。TWELITE シリーズを USBアダプター TWELITE R シリーズを介して PC へ接続することで、UART 通信により各種パラメータの変更を行うことができます。

カスタム例

目的別に TWELITE DIP のカスタム例を示します。

興味のあるものを選んでお試しください。

ネットワークのグループ分け

初期状態では、すべての TWELITE DIP が相互に通信できる状態にあります。親機と子機のペアを2つ用意した場合、親機の入力は双方の子機へ反映されるほか、子機の入力も双方の親機へ反映されます。

インタラクティブモードによってアプリケーションIDと周波数チャネルを変更し、2つのペアを同時に独立して使用できるようにしましょう。

使用する製品

TWELITE DIPTWELITE R2
TWELITE 親機/子機USB アダプター
超簡単!標準アプリ-
4個1個

カスタムの内容

インタラクティブモードの値を次のように設定し、2つのペアをグループAとBに分けます。

カスタム方法

  1. TWELITE DIP を TWELITE R2 へ差し込み、USB-C ケーブルを使って PC と接続する
  2. TWELITE STAGE アプリを立ち上げ、シリアルポート選択から対象の TWELITE R2 を選択する
  3. メインメニューの「3: インタラクティブモード」を選択する
  4. 大文字のRを押下して、設定を初期状態へ戻す
  5. aを押下したのち、AAAAAAAA/BBBBBBBBを入力してEnterを押下する
  6. cを押下したのち、11/26を入力してEnterを押下する
  7. 大文字のSを押下して、設定を適用する(TWELITE はリセットされる)
  8. ESCを何度か押してメインメニューへ戻り、TWELITE R2 の USB-C ケーブルを抜く
  9. TWELITE DIP を取り外し、ブレッドボード等へ差し込み、回路へ接続する

動作確認

グループAとグループBの双方を「まずは使ってみる」の片方向デジタル信号の例のように配線し、親機へスイッチを、子機へ LED を接続します。

  • グループAの親機のスイッチを押すと、グループAの子機の LED だけが光ります
  • グループBの親機のスイッチを押すと、グループBの子機の LED だけが光ります

グループBの子機のアプリケーションIDを0xAAAAAAAAへ、周波数チャネルを11へ変更します。

  • グループAの親機のスイッチを押すと、2台の子機の LED がどちらも光ります

低レイテンシモードの使用

初期状態では、送信元のDIxが送信先のDOxへ反映されるまでに30-70ms程度の遅延が生じます。チャタリングや無線パケットの干渉を避けるための処理が存在するからです。

低レイテンシモードは、これらの処理を簡略化することで遅延を3-10ms程度に短縮します。

インタラクティブモードによって送信側の端末の低レイテンシモードを有効化してみましょう。

使用する製品

TWELITE DIPTWELITE R2
TWELITE 親機/子機USB アダプター
超簡単!標準アプリ-
2個1個

カスタムの内容

インタラクティブモードの値を次のように設定し、送信側(親機)の低レイテンシモードを有効化します。

カスタム方法

  1. TWELITE DIP を TWELITE R2 へ差し込み、USB-C ケーブルを使って PC と接続する
  2. TWELITE STAGE アプリを立ち上げ、シリアルポート選択から対象の TWELITE R2 を選択する
  3. メインメニューの「3: インタラクティブモード」を選択する
  4. 大文字のRを押下して、設定を初期状態へ戻す
  5. oを押下したのち、00000001を入力してEnterを押下する
  6. 大文字のSを押下して設定を適用する(TWELITE はリセットされる)
  7. ESCを何度か押してメインメニューへ戻り、TWELITE R2 の USB-C ケーブルを抜く
  8. TWELITE DIP を取り外し、ブレッドボード等へ差し込み、回路へ接続する

動作確認

親機と子機を「まずは使ってみる」の片方向デジタル信号の例のように配線し、親機へスイッチを、子機へ LED を接続します。

  • 親機のスイッチを押すと、子機の LED が光ります
  • 動作は初期状態と変わりませんが、少しレスポンスが向上したことを感じ取れるかもしれません
  • 親機のDO1と子機のDI1へオシロスコープを接続して比較すると、その効果を確認できます

ボタン押下時のみ送信させる

初期状態では、入力状態が変化したときに送信を行うほか、1秒おきに送信します。

このとき、例えば送信側のボタンを押したまま電源を断つと、受信側の出力は残り続けてしまいます。

ボタン押下時のみ送信 設定では、送信側のDIxがLowのときに繰り返し送信を行い、Highへ遷移しても1秒間は送信を続けます。受信側のDOxをLowとしてから受信が途絶えた場合はHighへ戻します。

インタラクティブモードによってボタン押下時のみ送信するように変更してみましょう。

使用する製品

TWELITE DIPTWELITE R2
TWELITE 親機/子機USB アダプター
超簡単!標準アプリ-
2個1個

カスタムの内容

インタラクティブモードの値を次のように設定し、送信側(親機)と受信側(子機)のデジタル入出力の振る舞いを変更します。

カスタム方法

  1. TWELITE DIP を TWELITE R2 へ差し込み、USB-C ケーブルを使って PC と接続する
  2. TWELITE STAGE アプリを立ち上げ、シリアルポート選択から対象の TWELITE R2 を選択する
  3. メインメニューの「3: インタラクティブモード」を選択する
  4. 大文字のRを押下して、設定を初期状態へ戻す
  5. oを押下したのち、00000100を入力してEnterを押下する
  6. 大文字のSを押下して設定を適用する(TWELITE はリセットされる)
  7. ESCを何度か押してメインメニューへ戻り、TWELITE R2 の USB-C ケーブルを抜く
  8. TWELITE DIP を取り外し、ブレッドボード等へ差し込み、回路へ接続する

動作確認

親機と子機を「まずは使ってみる」の片方向デジタル信号の例のように配線し、親機へスイッチを、子機へ LED を接続します。

  • 親機のスイッチを押すと、子機の LED が光ります
  • 親機のスイッチを押したまま電源供給を断つと、子機のLEDは消えます(初期状態は消えない)

3 - UART機能によるPCとの連携

親機をPCへ接続して、UARTを通じたデータの受信と送信を行う
UART 通信を利用することで、親機を PC と連携させることができます。

使用する製品

TWELITE DIPTWELITE R2
TWELITE 親機/子機USB アダプター
超簡単!標準アプリ-
2個1個

なお、TWELITE DIP と TWELITE R2 のペアは MONOSTICK 単体と同等です。次の組み合わせでも構いません。

TWELITE DIPMONOSTICK
TWELITE 子機TWELITE 親機
超簡単!標準アプリ親機・中継機アプリ
1個1個

TWELITE STAGE アプリの導入

TWELITE STAGE アプリは、ファームウェアの設定や書き換えに加え、親機との送受信を評価するための機能を備えたツールです。

TWELITE STAGE アプリは、TWELITE STAGE SDK に含まれています。

TWELITE STAGE アプリによる受信

超簡単!標準アプリの子機が送信するデータは、DIx/AIxポートの入力状態や電源電圧、送信元の論理デバイスIDといった情報を含んでいます。

シリアル文字列の表示

親機が子機から受信したデータは、親機がシリアル通信(UART)で出力する文字列を解釈することで取得できます。まずはこの文字列を表示してみましょう。

TWELITE STAGE アプリを立ち上げ、シリアルポート選択で親機を選択します。メインメニュー「1: ビューア」「1: ターミナル」を開いてください。

子機のデータを受信すると、次のようなメッセージを表示します。

:78811501C98201015A000391000C2E00810301FFFFFFFFFB

親機が出力するこのような文字列を解釈することで、子機が送信したデータを得ることができます。

なお、TWELITE の親機が出力する文字列は、基本的に次の形式へ従います。

ヘッダペイロードチェックサムフッタ
:00-FFの繰り返しペイロードのLRC8CRLF
  • すべて ASCII 文字※
  • 先頭は : (0x3A)
  • 末端は CRLF (\r\n/0x0D 0x0A)
  • ビッグエンディアン

※ シリアル通信アプリのバイナリ書式を除く

標準アプリ ビューア

上記のような形式はコンピュータにやさしいものですが、人間が確認するにはこれを解釈する必要があります。TWELITE STAGE アプリには、超簡単!標準アプリの子機が送信したデータを表す文字列を解釈して表示する機能があります。後述の Python ライブラリはこの解釈を行います。

メインメニュー「1: ビューア」へ戻り、「2: 標準アプリ ビューア」を開いてください。

タイムスタンプと論理デバイスID、シリアルIDとDIx/AIxの値を確認できます。

標準アプリ ビューアの画面

標準アプリ ビューアの画面

TWELITE STAGE アプリによる送信

これまでとは反対に、親機から子機へ無線パケットを送信し、子機の出力状態を変更することもできます。

コマンダー

メインメニュー「1: ビューア」へ戻り、「5: コマンダー」を開いてください。

DIxおよびAIxの入力をシミュレートしたパケットを送信できます。

コマンダーの画面

コマンダーの画面

使い方

  • 送信先と入力状態を選択
  • 送信をクリック

Python スクリプト

TWELITE STAGE アプリの「標準アプリ ビューア」および「コマンダー」は、どちらもシリアル通信によって文字列をやりとりしているに過ぎません。シリアル通信を利用できる環境であれば、自作のアプリケーションと親機を連携させることができます。

Python スクリプトを応用すれば、受信したデータを加工して保存したり、自作のソフトウェアから出力ポートを操作したりといった仕組みを実現できます。

MWings ライブラリの導入

MWings ライブラリは、TWELITE と Python スクリプトの連携を簡単に実現するためのライブラリです。具体的には、子機から受信したデータを表す文字列の解釈と、子機へ送信するデータの構築を行います。

PyPI からインストールできます。

Python スクリプトによる受信

TWELITE DIP のDI1へ接続したボタンが押された際にメッセージを表示する Python スクリプトを実装してみます。

サンプルスクリプトの実行

下記の内容のスクリプト dip_show_di1.py を作成してください。

# -*- coding:utf-8 -*-
# TWELTIE DIP start guide: receiving in python

import mwings as mw


def main():
    twelite = mw.Twelite(mw.utils.ask_user_for_port())

    @twelite.on(mw.common.PacketType.APP_TWELITE)
    def on_app_twelite(packet):
        if packet.di_state[0]:
            print("DI1 Pressed")

    try:
        twelite.daemon = True
        twelite.start()
        print("Started receiving")
        while True:
            twelite.join(0.5)
    except KeyboardInterrupt:
        print("Flushing...")
        twelite.stop()
        print("Completed")


if __name__ == "__main__":
    main()

スクリプトを実行すると、子機のDI1が Low になったときに DI1 Pressed と出力します。

実行時に複数の TWELITE R シリーズや MONOSTICK シリーズが接続されているときは、親機へ接続されたシリアルポートを選択してください。


poetry run python dip_show_di1.py
Multiple ports detected.
[1] /dev/cu.usbserial-R2xxxxxx TWE-Lite-R (Genuine)
[2] /dev/cu.usbserial-R2xxxxxx TWE-Lite-R (Genuine)
Select [1-2]: 2
Selected: /dev/cu.usbserial-R2xxxxxx
Started receiving
DI1 Pressed
DI1 Pressed
^CFlushing...
Completed

上記は macOS における例です。WindowsではCOMポート名を表示します。

サンプルスクリプトの解説

MWings ライブラリのインポート

import mwings as mw

短縮名 mw を使って呼び出せるようにしています。pandas as pdnumpy as np と同様です。

オブジェクトの作成

    twelite = mw.Twelite(mw.utils.ask_user_for_port())

親機をとやりとりするためのインタフェースとなる Twelite オブジェクトを作成しています。

引数にはシリアルポートを指定しますが、ここでは mw.utils.ask_users_for_port() ユーティリティを呼び出し、動的に決定しています。この関数はシリアルポートが存在しないときにエラーメッセージを出力し、1つだけ存在する場合はそのポートを、複数存在する場合はユーザが指定したポートを返します。

受信イベントハンドラの登録

    @twelite.on(mw.common.PacketType.APP_TWELITE)
    def on_app_twelite(packet):
        if packet.di_state[0]:
            print("DI1 Pressed")

超簡単!標準アプリの子機からのパケットを受信したときに呼び出されるイベントハンドラを登録しています。

イベントハンドラの登録は、Python のデコレータ(?)を使って行います。今回は超簡単!標準アプリ(App_Twelite)のデータを対象とするため、@twelite.on(mw.common.PacketType.APP_TWELITE) を記述しています。この記述の直後に定義された関数がハンドラとなります。関数名は問いませんが、Tweliteオブジェクトの初期化後に定義する必要があります。

今回は子機のDI1がLowになったことを検知するため、受信ハンドラが受け取る変数 packetmwings.parsers.app_twelite.ParsedPacket)のうち、DIxの状態を示す List-like なオブジェクト di_state(デジタルインタフェースの状態)0番目の真偽値を判定しています。di_stateの各値は、Trueのときに Low を示します。

データの待機

        twelite.daemon = True
        twelite.start()
        print("Started receiving")
        while True:
            twelite.join(0.5)

ここでは、別のスレッドで親機からのデータの待機を行っています。

Tweliteのオブジェクトは threading.Thread のサブクラスであり、ここではその機能によってデーモンスレッドを立ち上げ、スクリプトを終了するまでメインスレッドをブロックしています。

終了処理

        print("Flushing...")
        twelite.stop()
        print("Completed")

Ctrl-C が押された際には、twelite.stop()を呼び出すことでサブスレッドを終了しています。

Python スクリプトによる送信

次は、反対に TWELITE DIP のDO1へ接続された LED をPCから点滅させる Python スクリプトを実装してみます。

サンプルスクリプトの実行

下記の内容のスクリプト dip_blink_led.py を作成してください。

# -*- coding:utf-8 -*-
# TWELITE DIP start guide: blinking from python

from time import sleep

import mwings as mw


def main():
    twelite = mw.Twelite(mw.utils.ask_user_for_port())

    initial = {
        "destination_logical_id": 0x78,
        "di_to_change": [True, False, False, False],
        "di_state": [False, False, False, False],
    }
    command = mw.serializers.app_twelite.Command(**initial)

    while True:
        command.di_state[0] = not command.di_state[0]
        twelite.send(command)
        print(f"Flip DO1: {command.di_state[0]}")
        sleep(1)


if __name__ == "__main__":
    try:
        main()
    except KeyboardInterrupt:
        print("...Aborting")

スクリプトを実行すると、子機のDO1が一秒おきに点滅します。

実行時に複数の TWELITE R シリーズや MONOSTICK シリーズが接続されているときは、親機へ接続されたシリアルポートを選択してください。


poetry run python dip_blink_led.py
Multiple ports detected.
[1] /dev/cu.usbserial-R2xxxxxx TWE-Lite-R (Genuine)
[2] /dev/cu.usbserial-R2xxxxxx TWE-Lite-R (Genuine)
Select [1-2]: 2
Selected: /dev/cu.usbserial-R2xxxxxx
Flip DO1: True
Flip DO1: False
Flip DO1: True
Flip DO1: False
Flip DO1: True
^C...Aborting

サンプルスクリプトの解説

MWings ライブラリのインポート

import mwings as mw

短縮名 mw を使って呼び出せるようにしています。pandas as pdnumpy as np と同様です。

オブジェクトの作成

    twelite = mw.Twelite(mw.utils.ask_user_for_port())

親機をとやりとりするためのインタフェースとなる Twelite オブジェクトを作成しています。

引数にはシリアルポートを指定しますが、ここでは mw.utils.ask_users_for_port() ユーティリティを呼び出し、動的に決定しています。この関数はシリアルポートが存在しないときにエラーメッセージを出力し、1つだけ存在する場合はそのポートを、複数存在する場合はユーザが指定したポートを返します。

親機へ送信するコマンドの作成

    initial = {
        "destination_logical_id": 0x78,
        "di_to_change": [True, False, False, False],
        "di_state": [False, False, False, False],
    }
    command = mw.serializers.app_twelite.Command(**initial)

超簡単!標準アプリの子機へ送信するパケットを生成するためのコマンドを表すデータ commandmwings.serializers.app_twelite.Command)を初期化しています。

辞書オブジェクト initial は、コマンドの初期状態を表しています。ここでは、送信先の論理デバイスIDを 0x78(全子機)としたうえで、DI1を変更対象、High 状態としています。

データの送信

    while True:
        command.di_state[0] = not command.di_state[0]
        twelite.send(command)
        print(f"Flip DO1: {command.di_state[0]}")
        sleep(1)

ここでは、コマンドデータの文字列への変換および親機への送信を1秒おきに行っています。

コマンドデータのうち、DOxの状態を示す List-like なオブジェクト di_state(デジタルインタフェースの状態)0番目の真偽値を反転させることで、点滅を実現しています。

4 - バイナリデータの伝送

UART通信により任意のバイト列を伝送する
シリアル通信アプリを使うことで、任意のバイナリデータの送受信を行うことができます。

使用する製品

TWELITE DIPTWELITE R2
TWELITE 親機/子機USB アダプター
シリアル通信アプリ-
2個2個

なお、TWELITE DIP と TWELITE R2 のペアは MONOSTICK 単体と同等です。次の組み合わせでも構いません。

MONOSTICK
TWELITE 親機/子機
シリアル通信アプリ
2個

シリアル通信アプリ

TWELITE のファームウェアを、シリアル通信の無線化に特化したシリアル通信アプリ(App_Uart)へ書き換えます。超簡単!標準アプリはシリアル通信によるバイナリデータの伝送機能を備えているものの、その機能は非常に限られているからです。

ファームウェアの書き換え

親機と子機、すべての端末を書き換えます。

  1. TWELITE STAGE SDK を導入し、TWELITE STAGE アプリを立ち上げる
  2. シリアルポート選択から接続したデバイスを選択する
  3. メインメニュー」から「2: アプリ書換」を選択する
  4. 1: BINから選択」を選び、App_Uart... を選択する
  5. 書き込みが完了するまで、数回Enterを押す

通信モードの一覧

シリアル通信アプリには5つの通信モードがあり、用途に応じて使い分けることができます。

初期状態はヘッダ付き透過モードです。

ここでは、次の4つのモードを使った通信テストの手順を紹介します。気になるものを選んでお試しください。

  • ヘッダ付き透過モード
    • 送信側の書式はありません。
    • 受信側の書式から、送信元の論理デバイスIDや受信時の電波通信品質といった情報を得ることができます。
    • バランスのよいモードです。
  • 透過モード
    • 送受信双方に書式はありません。
    • 送信側の入力と受信側の出力は同等です。
    • 最も簡単ですが、機能は限られています。
  • 書式モード(アスキー)
    • 送受信双方へ書式を適用します。
    • 外部デバイスの対応が必要ですが、送信先の指定や送信元の識別ができます。
    • バイナリデータは16進数の文字列で表現します。
  • 書式モード(バイナリ)
    • 送受信双方へ書式を適用します。
    • 外部デバイスの対応が必要ですが、送信先の指定や送信元の識別ができます。
    • バイナリデータはそのまま表現します。

今回は同一のPCへ2台の TWELITE を接続し、データをループバックさせてみましょう。通常は外部デバイス同士を無線経由で接続します。

ヘッダ付き透過モード

ヘッダ付き透過モードを使用して、ASCIIデータHelloという文字列を双方から送信してみましょう。

設定方法

シリアル通信アプリの既定のモードはヘッダ付き透過モードです。よって初期設定のまま使用します。

通信テスト

1. TWELITE STAGE アプリを2つ立ち上げる

TWELITE STAGE アプリ(TWELITE_Stage.exe/.command/.run)を2つ立ち上げてください。

2. ターミナルを表示する

双方の TWELITE STAGE アプリにおいてシリアルポートを選択したのち、「1: ビューア」>「1: ターミナル」を選択します。

3. 片側から送信

片方の画面を選択し、Helloと入力してEnterを押します。もう片方の画面へ反映されます。

片側から送信

片側から送信

4. 反対側から送信

もう片方の画面を選択し、Helloと入力してEnterを押します。元の画面へ反映されます。

反対側から送信

反対側から送信

透過モード

透過モードを使用して、ASCIIデータHelloという文字列を双方から送信してみましょう。

設定方法

m:通信モードDとします。

通信テスト

1. TWELITE STAGE アプリを2つ立ち上げる

TWELITE STAGE アプリ(TWELITE_Stage.exe/.command/.run)を2つ立ち上げてください。

2. ターミナルを表示する

双方の TWELITE STAGE アプリにおいてシリアルポートを選択したのち、「1: ビューア」>「1: ターミナル」を選択します。

3. 片側から送信

片方の画面を選択し、Helloと入力してEnterを押します。もう片方の画面へ反映されます。

片側から送信

片側から送信

4. 反対側から送信

もう片方の画面を選択し、Helloと入力してEnterを押します。元の画面へ反映されます。

反対側から送信

反対側から送信

入出力のどちらにも書式がないため、入力したデータをそのまま出力します。

Hello

書式モード(アスキー)

書式モード(アスキー)を使用して、バイナリデータ 0x5A 0xAB 0x90 0x00 を双方から送信してみましょう。

Saab 9000 CD 2.3

Saab 9000 CD 2.3

設定方法

m:通信モードAとします。

片方の端末のi:論理デバイスID0(親機)としたうえで、もう片方の端末は1(子機、ID1)とします。

通信テスト(簡易形式)

まずは、簡易形式のシンプルな書式を試してみましょう。

1. TWELITE STAGE アプリを2つ立ち上げる

TWELITE STAGE アプリ(TWELITE_Stage.exe/.command/.run)を2つ立ち上げてください。

2. ターミナルを表示する

双方の TWELITE STAGE アプリにおいてシリアルポートを選択したのち、「1: ビューア」>「1: ターミナル」を選択します。

3. 親機側から送信

まず、以下の系列をコピーします。

:01235AAB900047

次に、親機側の画面を選択します。

最後に、Alt+V/⌘+Vを押してペーストし、Enterを押します。子機側の画面へ反映されます。

親機側から送信

親機側から送信

4. 子機側から送信

まず、以下の系列をコピーします。

:00235AAB900048

次に、子機側の画面を選択します。

最後に、Alt+V/⌘+Vを押してペーストし、Enterを押します。親機側の画面へ反映されます。

子機側から送信

子機側から送信

通信テスト(拡張形式)

次に、拡張形式の高度な書式を試してみましょう。

1. TWELITE STAGE アプリを2つ立ち上げる

TWELITE STAGE アプリ(TWELITE_Stage.exe/.command/.run)を2つ立ち上げてください。

2. ターミナルを表示する

双方の TWELITE STAGE アプリにおいてシリアルポートを選択したのち、「1: ビューア」>「1: ターミナル」を選択します。

3. 親機側から送信

まず、以下の系列をコピーします。

:01A0CDFF5AAB9000FE

次に、親機側の画面を選択します。

最後に、Alt+V/⌘+Vを押してペーストし、Enterを押します。子機側の画面へ反映されます。

親機側から送信

親機側から送信

4. 子機側から送信

まず、以下の系列をコピーします。

:00A0CDFF5AAB9000FF

次に、子機側の画面を選択します。

最後に、Alt+V/⌘+Vを押してペーストし、Enterを押します。親機側の画面へ反映されます。

子機側から送信

子機側から送信

書式モード(バイナリ)

書式モード(バイナリ)を使用して、バイナリデータ 0x5A 0xAB 0x90 0x00 を双方から送信してみましょう。

Saab 9000 CD 2.3

Saab 9000 CD 2.3

設定方法

m:通信モードBとします。

片方の端末のi:論理デバイスID0(親機)としたうえで、もう片方の端末は1(子機、ID1)とします。

バイナリへ対応した環境を用意

TWELITE STAGE アプリのターミナル機能や TeraTerm はバイナリデータの扱いに対応していないため、バイナリ形式に対応したターミナルソフトを導入する必要があります。

ここでは、一例としてCoolTermを使用します。

通信テスト(簡易形式)

まずは、簡易形式のシンプルな書式を試してみましょう。

1. CoolTerm の画面を2つ開く

CoolTerm の画面を2つ開き、それぞれのデバイスへ接続します。

受信したデータを16進数で表示するために、View > View Hex を選択しておきます。Connect を押して接続します。

2つの画面を開いた様子

2つの画面を開いた様子

2. 親機側から送信

親機側の画面を選択し、Connection > Send String... を選択して送信画面を開き、ラジオボタンのHex を選んでおきます。

送信画面を開いた様子

送信画面を開いた様子

次の内容を入力し、Send を押して親機へ送信します。

A5 5A 80 06 01 23 5A AB 90 00 43 04
親機側から送信

親機側から送信

3. 子機側から送信

親機と同様に子機側の画面を選択し、Connection > Send String... を選択して送信画面を開き、ラジオボタンのHex を選んでおきます。

次の内容を入力し、Send を押して親機へ送信します。

A5 5A 80 06 00 23 5A AB 90 00 42 04
子機側から送信

子機側から送信

通信テスト(拡張形式)

次に、拡張形式の高度な書式を試してみましょう。

1. CoolTerm の画面を2つ開く

CoolTerm の画面を2つ開き、それぞれのデバイスへ接続します。

受信したデータを16進数で表示するために、View > View Hex を選択しておきます。Connect を押して接続します。

2つの画面を開いた様子

2つの画面を開いた様子

2. 親機側から送信

親機側の画面を選択し、Connection > Send String... を選択して送信画面を開き、ラジオボタンのHex を選んでおきます。

送信画面を開いた様子

送信画面を開いた様子

次の内容を入力し、Send を押して子機へ送信します。

A5 5A 80 08 01 A0 CD FF 5A AB 90 00 F2 04
親機側から送信

親機側から送信

3. 子機側から送信

親機と同様に子機側の画面を選択し、Connection > Send String... を選択して送信画面を開き、ラジオボタンのHex を選んでおきます。

次の内容を入力し、Send を押して親機へ送信します。

A5 5A 80 08 00 A0 CD FF 5A AB 90 00 F3 04
子機側から送信

子機側から送信

5 - リモコンアプリによる高度なデジタル伝送

リモコンアプリを使用して、デジタル信号に特化した高度な機能を使用する
ファームウェアを超簡単!標準アプリ(App_Twelite)からリモコンアプリ(App_IO)へ書き換えることで、デジタル信号に特化した高度な機能を使用することができます。

使用する製品

TWELITE DIPTWELITE R2
TWELITE 親機/子機USB アダプター
超簡単!標準アプリ-
2個1個

リモコンアプリ

TWELITE のファームウェアを、デジタル信号の伝送に特化したリモコンアプリ(App_IO)へ書き換えます。超簡単!標準アプリはデジタル信号の伝送機能を備えているものの、入出力は4本に限られています。リモコンアプリは入出力を増やし、その組み合わせを切り替えることができます。

ファームウェアの書き換え

親機と子機、すべての端末を書き換えます。

  1. TWELITE STAGE SDK を導入し、TWELITE STAGE アプリを立ち上げる
  2. シリアルポート選択から接続したデバイスを選択する
  3. メインメニュー」から「2: アプリ書換」を選択する
  4. 1: BINから選択」を選び、App_IO... を選択する
  5. 書き込みが完了するまで、数回Enterを押す

まずは使ってみる

初期状態のリモコンアプリは、次のように子機が12本のデジタル入力ポートを、親機が12本のデジタル出力ポートを備えた片方向伝送の設定としています。まずは配線してみましょう。

名称子機親機標準DIP #
I1/O5I1O5DI115
I2/O6I2O6DI216
I3/O7I3O7DI317
I4/O8I4O8DI418
I5/O1I5O1DO15
I6/O2I6O2DO28
I7/O3I7O3DO39
I8/O4I8O4DO412
I9/O9I9O9SCL2
I10/O10I10O10SDA19
I11/O11I11O11PWM14
I12/O12I12O12PWM411

親機の配線

初期状態のとき、親機は最大12本のデジタル信号を受信できます。

親機の配線図

親機の配線図

上図では DIP 9番 O3 ピンを出力として使用していますが、他のOxピンも同様に使用できます。また、超簡単!標準アプリにはないチャネル上書き機能を検証するため、DIP 23番 C1 ピンへタクトスイッチを接続しています。

子機の配線

初期状態のとき、子機は最大12本のデジタル信号を送信できます。

子機の配線図

子機の配線図

上図では DIP 17番 I3 ピンを入力として使用していますが、他のIxピンも同様に使用できます。また、こちらも同様にチャネル上書き機能を検証するため、DIP 23番 C1 ピンへタクトスイッチを接続しています。

動作確認

  • 子機のI3へ接続したボタンを押したり離したりします
    • 親機のO3へ接続した LED が点灯したり消灯したりします。
  • 子機のC1へ接続したボタンを押しながら、I3 のボタンを押したり離したりします
  • 親機と子機のC1へ接続したボタンを押しながら、子機のI3へ接続したボタンを押したり離したりします
    • 親機と子機の周波数チャネルを両方とも上書きするため、再び通信できるようになります。

高度な機能を使ってみる

次のようなシチュエーションを想定して、インタラクティブモードによる設定変更を行ってみましょう。

  • 子機と親機の入出力の割り当てを変更し、双方とも6入力6出力とする
  • 子機の入力を最短で親機へ反映する
  • パケットが断絶した際に出力信号を復帰させる
  • 子機を省電力リモコンとする
  • 子機を長押しによる連続送信へ対応した省電力リモコンとする

子機と親機を6入力6出力とする

インタラクティブモードからオプションビットの値を変更することで、入出力の割り当てを下記のなかから選ぶことができます。

子機入力子機出力親機入力親機出力備考
120012初期状態
8448オプションビット0x00001000
6666オプションビット0x00002000
012120オプションビット0x00003000

ここでは、双方とも6入力6出力としてみましょう。

  1. TWELITE STAGE アプリを立ち上げる
  2. シリアルポート選択から接続したデバイスを選択する
  3. メインメニュー」から「3: インタラクティブモード」を選択する
  4. Enterを押し、設定項目が表示されることを確認する
  5. o(小文字)を入力し、オプションビットの値 00002000 を入力してEnterを押下する
  6. S(大文字)を入力して保存し、ESCを押下して終了

これで次のように、子機と親機がともに6本の入出力をもつ割り当てとなります。

名称子機親機標準DIP #
I1/O5I1I1DI115
I2/O6I2I2DI216
I3/O7I3I3DI317
I4/O8I4I4DI418
I5/O1O1O1DO15
I6/O2O2O2DO28
I7/O3O3O3DO39
I8/O4O4O4DO412
I9/O9O5I5SCL2
I10/O10O6I6SDA19
I11/O11I5O5PWM14
I12/O12I6O6PWM411

子機の入力を最短で親機へ反映する

子機の連続モードを使用するとき、子機の入力から親機の出力までに通常は 30-70ms 程度の遅延が発生します。すばやい応答が必要とされる場面では、この遅延を小さくするためにインタラクティブモードからオプションビット0x00000001:低レイテンシモードを設定します。

子機の設定

  1. TWELITE STAGE アプリを立ち上げる
  2. シリアルポート選択から接続したデバイスを選択する
  3. メインメニュー」から「3: インタラクティブモード」を選択する
  4. Enterを押し、設定項目が表示されることを確認する
  5. o(小文字)を入力し、オプションビットの値 00000001 を入力してEnterを押下する
  6. S(大文字)を入力して保存し、ESCを押下して終了

パケットの断絶時に信号を復帰させる

いずれかの入力がLoの状態のまま電波が途切れた場合には、実際の入力がLoからHiへ戻っても出力はLoを維持します。

パケットが断絶した際に信号を元の状態へ戻すには、リモコン長押しモードを適用します。リモコン長押しモードでは、送信側の入力が変化してからしばらくの間、継続的に信号を送信します。受信側では、Lo 状態を示すパケットが断絶してから一定の時間が経過すると、タイムアウトして出力を Hi へ戻します。

子機の設定

  1. M1/M2/M3を開放し、子機:連続モード を設定する
  2. TWELITE STAGE アプリを立ち上げる
  3. シリアルポート選択から接続したデバイスを選択する
  4. メインメニュー」から「3: インタラクティブモード」を選択する
  5. Enterを押し、設定項目が表示されることを確認する
  6. o(小文字)を入力し、オプションビットの値 00000100 を入力してEnterを押下する
  7. d(小文字)を入力し、ホールド/長押しモードの対象000000001010ならI2I4、長押し時に連続送信するポート)を入力してEnterを押下する
  8. D(大文字)を入力し、ホールド/長押しモードの時間(すべての入力がLoからHiへ戻ったあとに送信を続ける時間)を入力してEnterを押下する
  9. S(大文字)を入力して保存し、ESCを押下して終了

親機の設定

  1. M1/M2/M3を開放し、子機:連続モード を設定する
  2. TWELITE STAGE アプリを立ち上げる
  3. シリアルポート選択から接続したデバイスを選択する
  4. メインメニュー」から「3: インタラクティブモード」を選択する
  5. Enterを押し、設定項目が表示されることを確認する
  6. o(小文字)を入力し、オプションビットの値 00000100 を入力してEnterを押下する
  7. d(小文字)を入力し、ホールド/長押しモードの対象000000001010ならO2O4、断絶時にタイムアウトするポート)を入力してEnterを押下する
  8. D(大文字)を入力し、ホールド/長押しモードの時間(Loの信号が途切れてからHiへ戻すまでの時間)を入力してEnterを押下する
  9. S(大文字)を入力して保存し、ESCを押下して終了

子機を省電力リモコンとする

子機を電池で駆動させる場合には、スリープと起床を繰り返す間欠モードが有効です。低レイテンシモードおよびホールドモードを併用することで、子機のボタンを押した際に親機の出力を設定した時間にわたって維持する動作を実現できます。

子機の設定

  1. M1/M2/M3GNDへ接続し、子機:間欠10秒モード を設定する
  2. TWELITE STAGE アプリを立ち上げる
  3. シリアルポート選択から接続したデバイスを選択する
  4. メインメニュー」から「3: インタラクティブモード」を選択する
  5. Enterを押し、設定項目が表示されることを確認する
  6. o(小文字)を入力し、オプションビットの値 00000001 を入力してEnterを押下する
  7. S(大文字)を入力して保存し、ESCを押下して終了

親機の設定

  1. M1/M2/M3を開放し、子機:連続モード を設定する
  2. TWELITE STAGE アプリを立ち上げる
  3. シリアルポート選択から接続したデバイスを選択する
  4. メインメニュー」から「3: インタラクティブモード」を選択する
  5. Enterを押し、設定項目が表示されることを確認する
  6. d(小文字)を入力し、ホールド/長押しモードの対象000000001010ならO2O4、ホールドするポート)を入力してEnterを押下する
  7. D(大文字)を入力し、ホールド/長押しモードの時間(ホールドする時間)を入力してEnterを押下する
  8. S(大文字)を入力して保存し、ESCを押下して終了

子機を長押し省電力リモコンとする

子機を電池で駆動させる場合には、スリープと起床を繰り返す間欠モードが有効です。低レイテンシモードおよびリモコン長押しモードを併用することで、子機のボタンを押している間に親機への送信を連続的に行うことができます。また、子機のボタンを離したあとに一定の時間にわたって送信を続け、親機側では子機のボタンを押した状態の電波が途切れてから一定の時間が経過した場合に出力を元に戻します。このため、省電力性能に優れた子機の入力をより確実に親機へ届けることができます。

子機の設定

  1. M1/M2/M3GNDへ接続し、子機:間欠10秒モード を設定する
  2. TWELITE STAGE アプリを立ち上げる
  3. シリアルポート選択から接続したデバイスを選択する
  4. メインメニュー」から「3: インタラクティブモード」を選択する
  5. Enterを押し、設定項目が表示されることを確認する
  6. o(小文字)を入力し、オプションビットの値 0000010300000100+00000001+00000002) を入力してEnterを押下する
  7. d(小文字)を入力し、ホールド/長押しモードの対象000000001010ならI2I4、長押し時に連続送信するポート)を入力してEnterを押下する
  8. D(大文字)を入力し、ホールド/長押しモードの時間(すべての入力がLoからHiへ戻ったあとに送信を続ける時間)を入力してEnterを押下する
  9. S(大文字)を入力して保存し、ESCを押下して終了

親機の設定

  1. M1/M2/M3を開放し、子機:連続モード を設定する
  2. TWELITE STAGE アプリを立ち上げる
  3. シリアルポート選択から接続したデバイスを選択する
  4. メインメニュー」から「3: インタラクティブモード」を選択する
  5. Enterを押し、設定項目が表示されることを確認する
  6. o(小文字)を入力し、オプションビットの値 00000100 を入力してEnterを押下する
  7. d(小文字)を入力し、ホールド/長押しモードの対象000000001010ならO2O4、断絶時にタイムアウトするポート)を入力してEnterを押下する
  8. D(大文字)を入力し、ホールド/長押しモードの時間(Loの信号が途切れてからHiへ戻すまでの時間)を入力してEnterを押下する
  9. S(大文字)を入力して保存し、ESCを押下して終了