/BF-018

JJY Simulator for M5StickC, M5StickC Plus and Plus2

Primary LanguageC++

JJY Simulator for M5StickC, M5StickC Plus and M5StickC Plus2

M5StickC, M5StickC Plus, M5StickC Plus2で動作する標準電波(JJY)シミュレータ

2024/3/20 修正

  • BF-018Rev3.ino を修正しました。コンパイラ警告レベルをデフォルトよりも上げると、Serial.printf()の%d指定でエラーを検出していました。

2024/2/22 修正

  • BF-018Rev3を公開しました。M5StickC, M5StickC Plus, M5StickC Plus2に対応しています。

2023/10/9 修正

  • BF-018Rev2.inoにおいてLCDバックライトに関するライブラリ非互換に対処しました。

2023/4/27 修正

  • BF-018Rev2.inoにおいてPWMの設定を改善しました。

Rev.3

  • フォルダ: BF-018Rev3
  • ソース修正不要で、M5StickC, M5StickC Plus, M5StickC Plus2に対応します。
  • Arduino IDEのBoards managerで、上記対象のBoardのいずれかを選択してください。
  • 機能についてはRev.2から変更ありません。
  • 変更内容は、「9. Rev3 変更内容」を参照ください。

Rev.2

  • フォルダ: BF-018Rev2
  • Rev.3は、Rev.2を改良したものです。Rev.3をご使用ください。
  • M5StickCの場合は、#define M5STICKCPLUS をコメントアウトしてください。
  • 変更内容は、「8. Rev2 変更内容」を参照ください

Rev.1(無印)

  • フォルダ: BF-018
  • Rev.2は、Rev.1を改良したものです。Rev.2をご使用ください。
  • M5StickCPlusの場合は、#include <M5StickC.h> をコメントアウトして無効にし、#include <M5StickCPlus.h> を有効にしてください。

1. 概要

M5StickC/CPlusで電波時計のためのJJY信号もどきを生成します。JJY信号が届かないところにある電波時計の時刻合わせができます。Wifi経由のNTPで時刻を取得し、GPIOからJJY信号を出力します。

2. ソフトウェア

Rev.3を2024/2/22に確認した環境は以下のとおりです。

Arduino IDE:

  • 2.3.2 (Windows11)

Boards manager:

  • M5Stack by M5Stack official version 2.1.0

Library:

  • M5Unified 0.1.12
  • M5GFX 0.1.12
  • tzapu/WifiManager by Tablatronix 2.0.16-rc.2

3. ハードウェア

JJY信号の送信にはアンテナが必要です。GPIO26とGND間に1kΩ程度の抵抗を途中に挟んで1m程度の電線を接続して実験できます。電線を電波時計の至近距離に這わせると電波時計が電線からの磁界を受信してくれます。M5StickC Plusは、M5StickCとは異なり、特にアンテナを接続しなくても時刻が合うことがあります。電波時計の機種にも依るかもしれません。

アンテナパターンを搭載したプリント基板を作成しました。

4. 動作

  • 電源投入またはリセット後、まずWifi接続の動作に入ります
  • Wifi接続が完了後、NTPで日時を取得し、標準信号の送出を開始します
  • JJY信号オンを内蔵LEDでモニターできます

5. Wifi 接続

tzapu/WiFiManagerを使用しています。使い方は、tzapu/WiFiManagerの説明を参照ください。

5. LCD

ボタンAで状況(SSID, IPアドレス, 日付、時刻, LEDモニタ-オン・オフ)を表示します。約5秒で自動的に表示が消えます。
※Rev.2では、LEDモニタ-オン・オフの表示を省略しました。また、表示時間を約10秒としました。

6. LED

ボタンBでLEDによるモニターをオン・オフできます。

7. シリアルモニタ

動作の状況を監視できます。

8. Rev.2変更内容

(1) WiFi接続についてのリカバリ処理を改善

WiFiのステータスに応じたリカバリ処理を追加しました。リカバリ処理には5分、10分、あるいはWiFiアクセスポイントが回復するまでなど、長時間を要する場合があります。放置して、いつの間にか正常動作をしていることを目指しています。リカバリ処理の内容は試行錯誤に基づくもので、必ずしもベストではありません。アドバイスなどありましたら是非お知らせください。

(2) RTCの利用を追加

電源投入時やリセット時においてWiFiが一時的に接続できないときでも、RTCの時刻に基づいてJJY信号を発信します。このための準備として、NTPの時刻同期のタイミングでRTCの時刻をアップデートします。RTCは、直近のアップデートに基づいた現在時刻を保持しています。M5StickC, M5StickC PlusはRTC(Real Time Clock)を内蔵しています。

(3) SSID/Keyを消去する操作を追加

接続先のWiFiアクセスポイントを変更する場合、SSID/Keyの設定を変更します。古いアクセスポイントが撤去済の場合、WiFiManagerのconfigration portalが自動的に起動します。古いアクセスポイントが稼働中の場合、まずEEPROMに保存されたSSID/Keyの消去することで新規設定ができます。EEPROMのSSID/Keyを消去するには、ボタンAを押しながら電源オンし"SSID/Key erased"が表示されるまでボタンAを押し続けます。まもなく"configuration portal"が起動します。

(4) 6040kHzを使用

JJY信号は、福島県の送信所から40kHz、佐賀県の送信所から60kHzで送信されています。PWM周波数は40kHzとしています。ESP32では60KHzぴったりの信号を生成できませんが、かなり近い周波数で生成できます。東日本の場合、疑似JJY信号を60kHzとすることで、福島からの信号に同期したのか、疑似信号に同期したのかを区別することができます。疑似信号を4060kHzに設定するには、BF-018ARev2.inoのledc_frequencyを4000060000に修正ください。

// PWM for TCO signal
const uint8_t  ledc_pin(26);           // GPIO26 for TCO
const uint8_t  ledc_channel(0);
const uint32_t ledc_frequency(40000);  // 40kHz(east), 60kHz(west)
const uint8_t  ledc_resolution(8);     // 2^8 = 256
const uint32_t ledc_duty_on(128);      // 128/256 = 50%
const uint32_t ledc_duty_off(0);       // 0

ledcのfrequenncyの型がdoubleからuint32_tに変更されました。

参考: Qiita ESP32においてLEDC(LED PWM Controller)に設定する分解能をExcelシートで検討する

(5) LCD表示

  • WiFiの接続状態を表示
    WL_CONNECTED以外の場合、LCDの最上段に赤字で表示
  • config portalの情報を表示
    WiFiManagerがconfig portalを起動した場合、アクセス先のSSIDとIPアドレスを表示

詳細: [JJYシミュレータの状態表示]

(6) M5StickC PlusのLCD表示の文字の大きさを改善

GFXFontを使用して適当な大きさの文字で表示する様にしました。フォルダにFree_Fonts.hを含めていますが、M5StickC Plusのライブラリの次回リリースで取り込まれると思いますので、それ以降は削除して参照部分も修正する予定です。

8. Rev.2変更内容

(1) M5Unifiedを使用

M5Unifiedを使用し、ライブラリのincludeの修正を不要としました。Boards managerで使用するBoardをM5StickC, M5StickC Plus, M5StickC Plus2の中から選択してください。

(2) パラメータ類をソースの先頭に移動

JJY信号の周波数や、timezone, NTPサーバーなど、修正が必要な場合に便利な様にパラメータの修正を容易にしました。

//..:....1....:....2....:....3....:....4....:....5....:....6....:....7..
// for TCO(Time Code Output)
const int jjy_frequency(40000); // 40kHz(east), 60kHz(west)

//..:....1....:....2....:....3....:....4....:....5....:....6....:....7..
// for NTP
const char* time_zone  = "JST-9";
const char* ntp_server = "pool.ntp.org";

以上