迷走の果て・Tiny Objects

迷走する日々の覚え書きです。自分で分かってることは省略してますので、念のため。

Tiny2313を使った周波数カウンタの実験・オーバーレンジ検出

Tiny2313周波数カウンタの測定上限は10MHzでそれ以上の周波数を入れると表示がおかしくなる。
サンプリングによるエイリアスのためである。
そこでオーバーレンジ検出をやってみた、ある周波数以上になるとLEDが点灯するという回路である。
リトリガブル ワンショットマルチとD-FFを使う方法も考えたが、手持ちに多数ある8pin PSoCを使うことにした。
ゲートタイム0.1秒で周波数をカウントし、ある周波数(ここでは9MHzとした)以上になるとLEDを点灯させる。

PSoCのカウンタはシステムクロック非同期にできるのでスペック上は50MHz近くまでカウントする。(実測では70MHz近くまでカウントした。)だからこういうマネができる。

実験してみたものの、どうにも動作がおかしい。設定した周波数以上でLEDは点灯するが、約1.3MHz以下でも点灯する。
これにはだいぶ悩まされた。

PSoCのカウンタモジュールはダウンカウンタである。周波数をカウントするには、先ずカウンタに適切な値(ここでは16777215とした)を書き込んでおく。
ゲートを開いて入力信号を入れ、一定時間(ゲートタイム)後にゲートを閉じる。
カウンタ値はゲートを開いている間のクロック数だけ減っているので、最初に書き込んだ値からカウント値を引けばゲートが開いている間のクロック数が解る。
ゲートタイムが1秒だったら計算したクロック数がそのまま周波数になる。
0.1秒だったらクロック数×10が周波数になる。
問題はどうもこの引き算にあるみたいだ。

カウンタはcounter24を使った、counter24の値はunsigned longなのだけど
当初
Freq = 16777215 - counter24の値
とした。(16777215 = 2^24-1)
これが何故かダメだったようで、

unsigned long Max24bit = 16777215
としておき
Freq = Max24bit - counter24の値
とすると問題なく動作した。理由がわからない、コンパイラのバグなのか、私の知識不足ゆえなのか・・・。

まぁなんとか動くようになったので、プリスケーラも追加した。
当初オーバーレンジ設定周波数で自動的にプリスケーラをON/OFFするようにしたが、不安定な発振回路でオーバーレンジ設定周波数付近の信号を入れてやるとプリスケーラがONしたりOFFしたりするのでそのたびに表示が乱れる。
プリスケーラは手動でコントロールした方がいいようだ。

このままではプリスケーラON時に表示が1/10になる、そこでプリスケーラONをtiny2313カウンタに知らせて表示を10倍させるようにプログラムを追加した。

TINY2313カウンタ
関連記事
スポンサーサイト

コメント

コメントの投稿

管理者にだけ表示を許可する

トラックバック

この記事へのトラックバックURL
http://edycube.blog.fc2.com/tb.php/625-3e717d11

 | HOME | 

文字サイズの変更

プロフィール

edy

最新記事一覧(サムネイル画像付き)

DABP発振回路を使ってキャパシタのESRを測定する構想(2)断念 2018/02/15
Androidアプリ:Resonance Calculator LC共振回路の計算に便利 2018/02/03
DABP発振回路を使ってキャパシタのESRを測定する構想(1)追記あり 2018/01/27
スマホとmicro:bitをBluetoothでつなぎたいのだが・・・。 2018/01/27
Androidアプリ:Signal Generator 2017/12/31
エレコム EHP-AHR192 を試す。(1) 2017/12/17
AliExpressでお買い物:TPS60403テスト 2017/12/02
AliExpressでお買い物:スイッチトキャパシタ電圧コンバータ三種(1) 2017/11/29
ATmega328 Maximum Frequency vs. VCC 2017/11/26
AC電力計(2) 2017/11/19

全記事表示リンク

全ての記事を表示する

リンク

このブログをリンクに追加する

月別アーカイブ

02  01  12  11  10  09  08  07  06  05  04  03  02  01  12  11  10  09  08  07  06  05  04  03  02  01  12  11  10  09  08  07  06  05  04  03  02  01  12  11  10  09  08  07  06  05  04  03  02  12  11  10  09  07  05  04  03  04  03  01  12  11  10  08  07  06  05  03  02  01  12  11  10  09  08  07  06  05  04  03  02  01  12  11  10  09  08  07  06  05  04  02  01  12  10  09  08  07  06  05  04  03  02  01  12  11  10  09  08  07  06  05  03  02  01  12  11  10  09  08  07  06  05  04  03  02  01  12  10  09  08  07  06  05  04  03  02  01 

カテゴリ

プログラミング (0)
freescale (1)
AVR (3)
テルミン (16)
緊急警報放送 (3)
78K (1)
PSoC (295)
地上デジタル放送 (2)
電子工作 (434)
HX711 (2)
ACS712 (6)
数学 (6)
パソコン (12)
PLC (14)
未分類 (39)
ブログ関係 (20)
スカイプ (37)
ロボット (1)
LTSpice (8)
OCXO (0)
arduino (32)
maxima (1)
フランクリン発振回路 (3)
GPS (3)
DTMF (1)
Linux (1)
KOMAINO (7)
Android (1)

タグリスト

最近のコメント

最近のトラックバック

メールフォーム

名前:
メール:
件名:
本文:

検索フォーム

アクセス

RSSリンクの表示

ブログリンク

FC2Ad

まとめ

Template by たけやん