【ブルーブリッジカップ単片モジュール】10、NE 555モジュール
3279 ワード
積もらずに千里も歩かず、小流を積もらずに川の海になることはない.
2018年3月29日(さらに)
555周波数測定
理論的に実現可能な周波数測定範囲:
原理も簡単で、
ところで、カウンタとしてタイマーとして使用するタイマーは、タイマーのように割り込みに値を繰り返す必要はありません.つまり、初期値は1つだけでいいということです.
私たちは以下を実現します.
もちろん、上記の考え方は、タイマ0をカウンタとして使用し、その後、
同じように、
今日は以前葛藤していた
そうです.
2018年3月29日(さらに)
555周波数測定
理論的に実現可能な周波数測定範囲:
500Hz - 20KHz
以前はタイマーで試したことがなく、青い橋に出会って、いいチャンスです.T0(P34)
を例にとると、一発.原理も簡単で、
TMOD
のC/T
ビットを1
にし、カウンタモードで動作することを示すだけです.このときのTMOD
に対応する取値は0x04
であり、これによりP34
ピンからのパルスが実現する、T0
のカウンタには1
が加算されます.この場合、そのカウンタの初期値をFF
、すなわちTH0=0xFF; TL0=0xFF
に設定するだけでいいです.その後、カウントを中断し、1s
(1 sのタイミングはT1
で処理)のカウント個数が周波数です.ところで、カウンタとしてタイマーとして使用するタイマーは、タイマーのように割り込みに値を繰り返す必要はありません.つまり、初期値は1つだけでいいということです.
私たちは以下を実現します.
#include
typedef unsigned char u8;
typedef unsigned int u16;
typedef unsigned long u32;
u8 LedChar[] = {
0xC0, 0xF9, 0xA4, 0xB0, 0x99, 0x92, 0x82, 0xF8, 0x80, 0x90
};
u8 LedBuff[] = {
0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF
};
u32 cnt = 0;
u8 T1RH, T1RL;
bit flag1s = 0;
void CloseFucker();
void ConfigTimer0();
void ConfigTimer1(u16 ms);
void ShowNumber(u32 num);
void main()
{
EA = 1;
CloseFucker();
ConfigTimer0();
ConfigTimer1(1);
while(1)
{
if(flag1s)
{
flag1s = 0;
ShowNumber(cnt);
cnt = 0;
}
}
}
void CloseFucker()
{
P2 = (P2&0x1F)|0xA0;
P0 = P0&0xAF;
P2 = P2&0x1F;
}
void ConfigTimer0()
{
TH0 = 0xFF;
TL0 = 0xFF;
TMOD &= 0xF0;
TMOD |= 0x04;
ET0 = 1;
TR0 = 1;
}
void ConfigTimer1(u16 ms)
{
u32 tmp;
tmp = 11059200/12;
tmp = (tmp*ms)/1000;
tmp = 65536 - tmp;
T1RH = (u8)(tmp>>8);
T1RL = (u8)tmp;
TMOD &= 0x0F;
TMOD |= 0x10;
TH1 = T1RH;
TL1 = T1RL;
ET1 = 1;
TR1 = 1;
}
void LedScan()
{
static u8 index = 0;
P2 = (P2&0x1F)|0xE0;
P0 = 0xFF;
P2 = P2&0x1F;
P2 = (P2&0x1F)|0xC0;
P0 = 0x80>>index;
P2 = P2&0x1F;
P2 = (P2&0x1F)|0xE0;
P0 = LedBuff[index];
P2 = P2&0x1F;
index++;
index &= 0x07;
}
void ShowNumber(u32 num)
{
u8 buf[8];
char i;
for(i=0; i<8; i++)
{
buf[i] = num%10;
num /= 10;
}
for(i=7; i>0; i--)
{
if(buf[i] == 0)
{
LedBuff[i] = 0xFF;
}
else
{
break;
}
}
for( ; i>=0; i--)
{
LedBuff[i] = LedChar[buf[i]];
}
}
void InterruptTimer0() interrupt 1
{
cnt++;
}
void InterruptTimer1() interrupt 3
{
static u16 tmr1s = 0;
TH1 = T1RH;
TL1 = T1RL;
tmr1s++;
if(tmr1s == 1000)
{
tmr1s = 0;
flag1s = 1;
}
LedScan();
}
もちろん、上記の考え方は、タイマ0をカウンタとして使用し、その後、
Cnt
変数をカウンタの割り込みでカウントし、T1
の1s
を表示してクリアすることである.よく考えてみるとT0
のTH0
とTL0
をそのまま使えば、計のパルス数を表すことができるようですが、節約したようです.実際には、T1
を使用して1S
の監視を行う必要があります.同じように、
T1
はP35
のピンに交換されたにすぎない.今日は以前葛藤していた
TMOD
のGATE
ドアの空きスペースも解決しました.そうです.
GATE
ビットは0
で、TR
セットさえあればタイマーを起動できます.GATE
ビットは1
であり、対応するINT×
はハイレベルであってこそタイマカウントを開始することができ、外部入力信号のパルス幅を測定できることもよく理解されている.