㈠ 如何用單片機識別這樣一個波形
單片機是識別 不了的,這個是脈沖,幅值不是二值的,也就是不是0或者1。單片機只能識別0或1。如果你真的想識別的話建議你用AD晶元採集,但是我不知道你的波形的頻率是多少,如果不是很高,那麼用性能強的單片機和采樣速率高點的AD晶元就能。如果頻率很高的話只能用AD加FPGA了。
㈡ 如何用51單片機設計出一個任意波形信號發生器
這個需要DA轉換晶元,將要產生的波形數字化,存入數組中,由單片機按順序依次送往DA晶元進行轉換,例如產生正弦波,頻率50HZ,可以用100個點來描述,每隔200uS送1個數據,100個數據花20ms.數字化點越多,波形越完美,但也與你的DA晶元精度有關,8位DA只能輸入256個數字量,很難得到很好的波形
㈢ 單片機有哪些主要應用
單片機從她誕生之日起,永葆青春,令我們電子工程師們一代接一代的時刻暗戀著她。以致單片機被廣泛應用於儀器儀表、工業自動控制、家用電器、醫用設備、辦公自動化設備、安全監控等領域,涵蓋了人類生活的方方面面。單片機的應用,使電路設計重心由硬體設計(傳統電路設計)向軟體設計(微控制技術)轉移。傳統電路設計的缺點在於,設計比較復雜的控制電路時,其硬體電路非常復雜,開發周期長,消耗較大的人力、物力和財力,有些智能控制電路用傳統電路設計根本無法實現,特別是直觀的人機交互界面。現在用單片機通過軟體編程就能輕而易舉實現了。電路簡單、功能強大、質量可靠,這就是單片機被廣泛是使用的根本原因。在我們的生活里,電器更新換代頻繁、體積越來越小巧、控制越來越智能、功能越來越強大、質量越來越可靠,這都是單片機嵌入應用的結果。
一、在智能儀器儀表上的應用
單片機廣泛應用於儀器儀表中,實現模擬量和數字量的轉換和處理。通過感測器,可實現諸如電壓、功率、頻率、濕度、溫度、流量、速度、厚度、角度、長度、距離、硬度、元素、壓力、重力、音量、光亮、波形、磁感應等物理量的測量。採用單片機控制使得儀器儀表數字化、智能化、微型化、直觀化,還能通過單片機串口通信實現遠程測量和數據採集。
二、工業自動化領域的應用
在工業控制中,如工業過程自動控制、過程自動監測、過程數據採集、工業控制器、工業現場聯網通信及機電一體化自動控制系統等,都離不開單片機。在比較復雜的大型工業控制系統中,用單片機可以實現智能控制、智能數據採集、遠程自動控制,現場自動管理,真正實現工業自動化。如工業機器人的控制系統是由中央控制器、感覺系統、行走系統、擒拿系統等節點構成的多機網路系統,而其中每一個小系統都是由單片微機進行控制的。
三、在家用電器的應用
四、在計算機通信領域和安全監控系統中的應用
單片機普遍具備通信介面,可以很方便地與計算機進行數據通信,為在計算機和設備的通信提供了技術條件。如電話機及其監控設備,樓宇自動通信呼叫系統、煙火報警系統和攝像監控系統,無線有線對講系統等等。
五、在醫用設備領域中的應用
單片機在醫用設備中的用途亦相當廣泛,例如醫用呼吸機、分析儀、監護儀、診斷設備及病床呼叫系統等等。
六、在汽車電子產品中的應用
現代汽車的集中顯示系統、動力、速度、壓力監測控制系統、自動駕駛系統、導航系統、安全保護系統、通信系統和運行監視器(黑匣子)等都是單片機的功勞。
七、在辦公自動化設備中的應用
現代辦公室使用的大量通信和辦公設備多數嵌入了單片機。如列印機、復印機、傳真機、繪圖機、考勤機、電話以及通用計算機中的鍵盤解碼、磁碟驅動等。
八、在商業營銷設備中的應用
在商業營銷系統中已廣泛使用的led信息顯示屏、電子稱、收款機、條形碼閱讀器、ic卡刷卡機、計程車計價器以及倉儲安全監測系統、商場保安系統、空氣調節系統、冷凍保險系統等都採用了單片機控制。
此外,單片機在工商、金融、科研、教育、國防、航空航天等領域也有著廣泛的應用。
單片機的廣泛應用不僅讓我們享受到新型電子產品和新技術帶來的貼心服務,也使我們的生活環境變得安全、舒適、便捷;有了單片機作主控,我們的生產生活工具更加先進和智能,減輕勞動強度的同時提高了工作效率和安全系數。
可見,我們的生活離不開單片機,單片機也正在改變我們的生活。
㈣ 如何使用單片機控制輸出波形,是否需要特定模塊
單片機控制輸出波形,不用模塊;可以通過編寫程序進行控制;輸出你想要的波形!
㈤ 怎麼在proteus中用示波器模擬單片機的輸出波形
單片機的P10引腳接到示波器的一個通道埠上就可以,然後運行模擬後,會自動打開示波器界面。如果界面沒有打開,可以自己手動打開。
㈥ 怎樣藉助單片機做一個信號發生器,可以產生任意波形
這個需要da轉換晶元,將要產生的波形數字化,存入數組中,由單片機按順序依次送往da晶元進行轉換,例如產生正弦波,頻率50hz,可以用100個點來描述,每隔200us送1個數據,100個數據花20ms.數字化點越多,波形越完美,但也與你的da晶元精度有關,8位da只能輸入256個數字量,很難得到很好的波形
㈦ 單片機波形發生器的設計,請大家提供思路
#include "reg52.h"
#define uchar unsigned char
#define uint unsigned int
unsigned char code table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0x00}; //共陰極0~9對應16進制數
//=============正弦波數據====================
uchar code sin_tab[256]=
{
0x80, 0x83, 0x86, 0x89, 0x8c, 0x8f, 0x92, 0x95, 0x98, 0x9c, 0x9f, 0xa2, 0xa5, 0xa8, 0xab, 0xae,
0xb0, 0xb3, 0xb6, 0xb9, 0xbc, 0xbf, 0xc1, 0xc4, 0xc7, 0xc9, 0xcc, 0xce, 0xd1, 0xd3, 0xd5, 0xd8,
0xda, 0xdc, 0xde, 0xe0, 0xe2, 0xe4, 0xe6, 0xe8, 0xea, 0xec, 0xed, 0xef, 0xf0, 0xf2, 0xf3, 0xf4,
0xf6, 0xf7, 0xf8, 0xf9, 0xfa, 0xfb, 0xfc, 0xfc, 0xfd, 0xfe, 0xfe, 0xff, 0xff, 0xff, 0xff, 0xff,
0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0xfe, 0xfd, 0xfc, 0xfc, 0xfb, 0xfa, 0xf9, 0xf8, 0xf7,
0xf6, 0xf5, 0xf3, 0xf2, 0xf0, 0xef, 0xed, 0xec, 0xea, 0xe8, 0xe6, 0xe4, 0xe3, 0xe1, 0xde, 0xdc,
0xda, 0xd8, 0xd6, 0xd3, 0xd1, 0xce, 0xcc, 0xc9, 0xc7, 0xc4, 0xc1, 0xbf, 0xbc, 0xb9, 0xb6, 0xb4,
0xb1, 0xae, 0xab, 0xa8, 0xa5, 0xa2, 0x9f, 0x9c, 0x99, 0x96, 0x92, 0x8f, 0x8c, 0x89, 0x86, 0x83,
0x80, 0x7d, 0x79, 0x76, 0x73, 0x70, 0x6d, 0x6a, 0x67, 0x64, 0x61, 0x5e, 0x5b, 0x58, 0x55, 0x52,
0x4f, 0x4c, 0x49, 0x46, 0x43, 0x41, 0x3e, 0x3b, 0x39, 0x36, 0x33, 0x31, 0x2e, 0x2c, 0x2a, 0x27,
0x25, 0x23, 0x21, 0x1f, 0x1d, 0x1b, 0x19, 0x17, 0x15, 0x14, 0x12, 0x10, 0xf, 0xd, 0xc, 0xb ,
0x9, 0x8, 0x7, 0x6, 0x5, 0x4, 0x3, 0x3, 0x2, 0x1, 0x1, 0x0, 0x0, 0x0, 0x0, 0x0 ,
0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x1, 0x1, 0x2, 0x3, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8 ,
0x9, 0xa, 0xc, 0xd, 0xe, 0x10, 0x12, 0x13, 0x15, 0x17, 0x18, 0x1a, 0x1c, 0x1e, 0x20, 0x23,
0x25, 0x27, 0x29, 0x2c, 0x2e, 0x30, 0x33, 0x35, 0x38, 0x3b, 0x3d, 0x40, 0x43, 0x46, 0x48, 0x4b,
0x4e, 0x51, 0x54, 0x57, 0x5a, 0x5d, 0x60, 0x63, 0x66, 0x69, 0x6c, 0x6f, 0x73, 0x76, 0x79, 0x7c,
};
//三角波信號數據表
uchar code thr_tab[32]=
{
0x00,0x0f,0x1f,0x2f,0x3f,0x4f,0x5f,0x6f,0x7f,0x8f,0x9f,0xaf,0xbf,0xcf,0xdf,0xef,
0xff,0xef,0xdf,0xcf,0xbf,0xaf,0x9f,0x8f,0x7f,0x6f,0x5f,0x4f,0x3f,0x2f,0x1f,0x0f
};
//-------------------------------------------------------------------------------------------------------
//鋸齒波信號數據表
uchar code jc_tab[33]=
{
0x00,0x08,0x0f,0x18,0x1f,0x28,0x2f,0x38,0x3f,0x48,0x4f,0x58,0x5f,0x68,0x6f,0x78,
0x7f,0x88,0x8f,0x98,0x9f,0xa8,0xaf,0xb8,0xbf,0xc8,0xcf,0xd8,0xdf,0xe8,0xef,0xf8,0xff
};
//數碼管位選控制口定義
sbit LED4=P2^7;
sbit LED3=P2^6;
sbit LED2=P2^5;
sbit LED1=P2^4;
//按鍵口申明
sbit S1=P2^3;
sbit S2=P2^2;
sbit S3=P2^1;
unsigned char tabArry[4]; //保存顯示數據
char flag=1; //按鍵標志,當flag=1時表示沒有按下,當flag=0時表示有按鍵按下
int keycount=0; //按鍵計數
unsigned char waveth,wavetl; //用於對定時器付值
unsigned int frecount=100; //頻率計數
unsigned int mbjs; //碼表計數,共采32個點
//毫秒延時程序
void delayms(int ms)
{
uchar i;
while(ms--)
{
for(i=250;i>0;i--);
}
}
//鍵盤掃描
void keyscan()
{
if(flag==1)
{
if(S3==0) //用S3切換波形
{
delayms(2); //延時去抖
if(S3==0) //按鍵計數,便於切換波形
{
flag=0;
keycount++;
if(keycount>=4) keycount=0; //四種波形計數4次
}
}
if(S2==0) //頻率加1 處理
{
delayms(2);
if(S2==0)
{
flag=0;
switch(keycount)
{
case 0: //正弦波頻率加1
frecount++;
if(frecount>1000) frecount=0;
break;
case 1: //三角波頻率加1
frecount++;
if(frecount>1000) frecount=0;
break;
case 2: //鋸齒波頻率加1
frecount++;
if(frecount>1000) frecount=0;
break;
case 3: //方波頻率加1
frecount++;
if(frecount>1000) frecount=0;
break;
}
waveth=(65536-57603/frecount)/256; //重新計算初值
wavetl=(65536-57603/frecount)%256;
}
}
if(S1==0) //頻率減1 處理
{
delayms(2);
if(S1==0)
{
flag=0;
switch(keycount)
{
case 0: //正弦波頻率減1
frecount--;
if(frecount<0) frecount=999;
break;
case 1: //三角波頻率減1
frecount--;
if(frecount<0) frecount=999;
break;
case 2: //鋸齒波頻率減1
frecount--;
if(frecount<0) frecount=999;
break;
case 3: //方波頻率減1
frecount--;
if(frecount<0) frecount=999;
break;
}
waveth=(65536-57603/frecount)/256; //重新計算初值
wavetl=(65536-57603/frecount)%256;
}
}
}
if(S1!=0 && S2!=0 && S3!=0) flag=1; //判斷按鍵是否彈起
}
//數據分位
void change(char wavetype,unsigned int frequency)
{
tabArry[0]=wavetype; //顯示字母,表示波形類型
tabArry[1]=frequency%1000/100; //百位
tabArry[2]=frequency%100/10; //十位
tabArry[3]=frequency%10; //個位
}
//顯示函數
void display()
{
switch(keycount)
{
case 0: //顯示A和正弦波的頻率
change(0x0a,frecount);
break;
case 1: //顯示b和三角波的頻率
change(0x0b,frecount);
break;
case 2: //顯示C和鋸齒波的頻率
change(0x0c,frecount);
break;
case 3: //顯示d和方波的頻率
change(0x0d,frecount);
break;
}
P0 = table[tabArry[0]]; //送最高位段碼
LED1=0; //打開對應的位選控制口
delayms(2); //顯示延時
LED1=1; //關閉對應的位選控制後顯示下一位
P0 = table[tabArry[1]];
LED2=0;
delayms(2);
LED2=1;
P0 = table[tabArry[2]];
LED3=0;
delayms(2);
LED3=1;
P0 = table[tabArry[3]];
LED4=0;
delayms(2);
LED4=1;
}
void Timerinit()
{
TMOD=0x01; //定時器0方式1
//定時器初值計算公式:X=65536-(T/T0)=65536-(f0/f/32)
TH0=waveth=(65536-57603/frecount)/256; //定時器初值 22.1184MHz
TL0=wavetl=(65536-57603/frecount)%256;
EA=1; //開總中斷
ET0=1; //開定時器0中斷
TR0=1; //定時器0開始計數
}
//主函數
void main()
{
Timerinit(); //定時器初始化
while(1)
{
keyscan(); //掃描按鍵
display(); //顯示程序
}
}
void Timer0() interrupt 1
{
TH0=waveth; //重新賦初值
TL0=wavetl;
if (keycount==0) //輸出正弦波
{
P1 = sin_tab[mbjs];
mbjs+=8; //256點,每隔8點輸出一個數據
if(mbjs>=256)
{
mbjs=0;
}
}
else if(keycount==1) //輸出三角波
{
P1 = thr_tab[mbjs];
mbjs++;
if(mbjs>=32)
{
mbjs=0;
}
}
else if(keycount==2) //輸出鋸齒波
{
P1 = jc_tab[mbjs];
mbjs++;
if(mbjs>=32)
{
mbjs=0;
}
}
else if(keycount==3) //輸出方波
{
mbjs++;
if(mbjs>=32)
{
mbjs=0;
}
else if(mbjs<16) P1=0xff;
else P1=0x00;
}
}