int T=1000;
創(chuàng)新互聯(lián)建站主要為客戶提供服務(wù)項(xiàng)目涵蓋了網(wǎng)頁(yè)視覺設(shè)計(jì)、VI標(biāo)志設(shè)計(jì)、成都營(yíng)銷網(wǎng)站建設(shè)、網(wǎng)站程序開發(fā)、HTML5響應(yīng)式成都網(wǎng)站建設(shè)公司、移動(dòng)網(wǎng)站建設(shè)、微商城、網(wǎng)站托管及網(wǎng)站維護(hù)、WEB系統(tǒng)開發(fā)、域名注冊(cè)、國(guó)內(nèi)外服務(wù)器租用、視頻、平面設(shè)計(jì)、SEO優(yōu)化排名。設(shè)計(jì)、前端、后端三個(gè)建站步驟的完善服務(wù)體系。一人跟蹤測(cè)試的建站服務(wù)標(biāo)準(zhǔn)。已經(jīng)為成都邊坡防護(hù)網(wǎng)行業(yè)客戶提供了網(wǎng)站營(yíng)銷服務(wù)。
主要算法:
double time=(1/fs)/T;
double d[1000];
for(int i=1;i=1000;i++)
{
time*=i;
d[i]=sin(2*PI*fs*time);
}
把fs換成f0就可得第二個(gè)波形數(shù)組。
#includeat89x51.h
//unsigned char TIME0_H=0xec,TIME0_L=0x78; //定時(shí)器0的初值設(shè)置;全局變量
#includesinx.h
#include0832.h
void main()
{
TMOD=0X01;
TH0=0xff;
TL0=0xd9;
IT0=1; //設(shè)置中斷觸發(fā)方式,下降沿
EA=1;
EX0=1;
ET0=1;
IP=0X01; //鍵盤中斷級(jí)別高
TR0=1;
while(1)
{
// square();
;
}
}
#ifndef __0832_h__
#define __0832_h__
//#define INPUT XBYTE[0xbfff] //即cs 與xfer 輪流低電平。
//#define DACR XBYTE[0x7fff] //單通道輸出,單緩沖就行了。
unsigned char i,sqar_num=128; //最大值100,默認(rèn)值50
unsigned char cho=0; //0:正弦波。1:方波。2:三角波。3:鋸齒波。
unsigned char num=0;
unsigned char TIME0_H=0xff,TIME0_L=0xd9; //定時(shí)器0的初值設(shè)置;全局變量.對(duì)應(yīng)正弦波,鋸齒波50HZ
sbit chg= P1^0; //三角波100Hz.
sbit freq_u=P1^1;
sbit freq_d=P1^2;
sbit duty_u=P1^3;
sbit duty_d=P1^4;
sbit cs =P3^7;
bit flag=0;
unsigned int FREQ=50;//初始化頻率,50HZ
//調(diào)節(jié)部分——頻率
void freq_ud(void)
{
unsigned int temp;
if(freq_d==0)
{ FREQ--; }
else if(freq_u==0)
{ FREQ++; }
if(cho==1|cho==3) //鋸齒波256次中斷一周期,特殊處理下。否則他的頻率是100(+\-)n*2Hz.
{
temp=0xffff-3906/FREQ; //方波,三角波默認(rèn)為100hz,切換后頻率也為50HZ 65336-10^6/(256*FREQ)
TIME0_H=temp/256;
TIME0_L=temp%256;
}
else if(cho==0|cho==3){ //正弦波 三角波默認(rèn)周期50hz 65536-10^6//(512*FREQ)
temp=0xffff-1953/FREQ;
TIME0_H=temp/256;
TIME0_L=temp%256;
}
}
//調(diào)節(jié)部分——方波的占空比
void duty_ud(void) //方波也采用512次中斷構(gòu)成一個(gè)周期。
{
if(duty_d==0sqar_num0)
sqar_num--;
else if(duty_u==0sqar_num255)
sqar_num++;
}
//波形發(fā)生函數(shù)
void sint(void)
{
if(!flag)
{
cs=0;P2=sin_num[num++];cs=1;
if(num==0){num=255;flag=1;}
}
else if(flag)
{
cs=0;P2=sin_num[num--];cs=1;
if(num==255){num=0;flag=0;}
}
}
void square(void)
{
if(i++sqar_num) {cs=0;P2=0XFF;cs=1;}
else{cs=0;P2=0X00;cs=1;}
}
void triangle(void)
{
cs=0;P2=num++;cs=1;
}
void stw(void)
{
if(~flag)
{
cs=0;P2=num++;cs=1;
if(num==0){num=255;flag=1;}
}
else if(flag)
{
cs=0;P2=num--;cs=1;
if(num==255){num=1;flag=0;}
}
}
//按鍵中斷處理程序。
void it0() interrupt 0
{
if(chg==0) { if(++cho==4) {cho=0;num=0;} } //num=0;所有數(shù)據(jù)從新開始,保證波形的完整性
else if(freq_u==0|freq_d==0)
{freq_ud();}
else if (cho==1(duty_d==0|duty_u==0))
{duty_ud();}
else ;
}
//定時(shí)器中斷處理程序。
void intt0() interrupt 1
{
//TH0=0x00;TL0=0x00;sinx();
switch(cho)
{
case 0:{TH0=TIME0_H;TL0=TIME0_L;sint() ;break;} //正弦波//每半周期256取樣。
case 1:{TH0=TIME0_H;TL0=TIME0_L;square(); break;} //方波 //為了提高方波的最高頻率,只有犧牲占空比的最小可調(diào)值。分100份 每次1%。
case 2:{TH0=TIME0_H;TL0=TIME0_L;triangle();break;} //三角波
case 3:{TH0=TIME0_H;TL0=TIME0_L;stw(); break;} //鋸齒波
default: ;
}
}
#endif
//正弦表;每半個(gè)周期256個(gè)取值,最大限度保證波形不失真。
//各個(gè)值通過MATLAB算出,并四設(shè)五如取整。具體程序如下
#ifndef __sinx_h__
#define __sinx_h__
unsigned char code sin_num[]={
0,0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 2, 2, 2,
2, 3, 3, 4, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9,
10, 10, 11, 12, 12, 13, 14, 15, 15, 16, 17, 18, 18, 19, 20, 21,
22, 23, 24, 25, 25, 26, 27, 28, 29, 30, 31, 32, 34, 35, 36, 37,
38, 39, 40, 41, 42, 44, 45, 46, 47, 49, 50, 51, 52, 54, 55, 56,
57, 59, 60, 61, 63, 64, 66, 67, 68, 70, 71, 73, 74, 75, 77, 78,
80, 81, 83, 84, 86, 87, 89, 90, 92, 93, 95, 96, 98, 99, 101,102,
104, 106, 107, 109, 110, 112, 113, 115, 116, 118, 120, 121, 123, 124, 126, 128,
129, 131, 132, 134, 135, 137, 139, 140, 142, 143, 145, 146, 148, 149, 151, 153,
154, 156, 157, 159, 160, 162, 163, 165, 166, 168, 169, 171, 172, 174, 175, 177,
178, 180, 181, 182, 184, 185, 187, 188, 189, 191, 192, 194, 195, 196, 198, 199,
200, 201, 203, 204, 205, 206, 208, 209, 210, 211, 213, 214, 215, 216, 217, 218,
219, 220, 221, 223, 224, 225, 226, 227, 228, 229, 230, 230, 231, 232, 233, 234,
235, 236, 237, 237, 238, 239, 240, 240, 241, 242, 243, 243, 244, 245, 245, 246,
246, 247, 247, 248, 248, 249, 249, 250, 250, 251, 251, 251, 252, 252, 253, 253,
253, 253, 254, 254, 254, 254, 254, 255, 255, 255, 255, 255, 255, 255, 255, 255
};
#endif
//MATLAB程序:
//x=linspace(-pi/2,pi/2,255);%如果過采用1位采用,很多值是重的。雖然實(shí)際中并不會(huì)。
//y=(sin(x)+1)/2.0*255;
//%uint32(y)%強(qiáng)制類型轉(zhuǎn)換。
//%fprintf('%.f\n',uint32(y));%控制輸出類型
//round(y)%四舍五入函數(shù)
/**************************************/
/* 信號(hào)發(fā)生器 (正弦波,方波,三角波) */
/*************************************/
#includereg52.h
#include intrins.h
#define uchar unsigned char
#define uint unsigned int
sbit cs=P2^0; //tlc5615片選端口
sbit clk=P2^1; //tlc5615時(shí)鐘線
sbit din=P2^2; //tlc5615傳輸端口
sbit key1=P1^0;
sbit key2=P1^1; //按鍵的單片機(jī)接口
uchar keydat;
uchar flag; //波形發(fā)生終止信號(hào)的標(biāo)志位 一旦被置零立馬停止發(fā)信號(hào)
uchar flagsqu; //方波高低電平控制為(運(yùn)用定時(shí)器1中斷控制)
uchar m,num;
uchar dat=0xff;
uchar code tosin[141]={ //正弦波的編碼
0x00,0x01,0x02,0x02,0x03,0x04,0x05,0x06,0x07,0x08,
0x09,0x0a,0x0b,0x0d,0x0e,0x10,0x11,0x13,0x15,0x16,
0x18,0x1a,0x1c,0x1e,0x20,0x22,0x25,0x27,0x29,0x2b,
0x2e,0x30,0x33,0x35,0x38,0x3a,0x3d,0x40,0x43,0x45,
0x48,0x4c,0x4e,0x51,0x55,0x57,0x5a,0x5d,0x60,0x63,
0x66,0x69,0x6c,0x6f,0x70,0x71,0x72,0x73,0x74,0x75,
0x76,0x77,0x78,0x79,0x7a,0x7b,0x7c,0x7d,0x7e,0x7e,
0x7f,0x80,0x7f,0x7e,0x7e,0x7d,0x7c,0x7b,0x7a,0x79,
0x78,0x77,0x76,0x75,0x74,0x73,0x72,0x6f,0x6c,0x69,
0x66,0x63,0x60,0x5d,0x5a,0x57,0x55,0x51,0x4e,0x4c,
0x48,0x45,0x43,0x40,0x3d,0x3a,0x38,0x35,0x33,0x30,
0x2e,0x2b,0x29,0x27,0x25,0x22,0x20,0x1e,0x1c,0x1a,
0x18,0x16,0x15,0x13,0x11,0x10,0x0e,0x0d,0x0b,0x0a,
0x09,0x08,0x07,0x06,0x05,0x04,0x03,0x02,0x02,0x01,
0x00};
void delay(uchar z) //延時(shí)函數(shù)
{
uchar x,y;
for(x=0;x110;x++)
for(y=z;y0;y--);
}
void prepare() //tlc5615的初始化
{
cs=1;
din=1;
clk=0;
cs=0; //cs的上升沿和下降沿必須在clk為低時(shí)進(jìn)?
}
/* 用中斷來(lái)產(chǎn)生方波
void Squtranslator()
{
TR1=1; //啟動(dòng)定時(shí)器1 控制高低電平的持續(xù)時(shí)間 占空比
do{
do{
_wave=0;
}while((!flagsqu) flag==1);//如果一旦終止信號(hào)的
//產(chǎn)生可以立馬退出循環(huán)
flagsqu=0;
do{
_wave=1;
}while((!flagsqu) flag==1);
flagsqu=0;
}while(flag);
flag=1;
TR1=0;
}
*/
void Squtranslator() //方波函數(shù)
{
uchar j;
uchar dat1=0x7f;
while(flag)
{
do{
prepare();
dat=dat1;
for(j=0;j12;j++)
{
din=(bit)(dat7); //將數(shù)據(jù)的最高位賦給din
clk=1;
dat=dat1; //一位位的傳輸
clk=0;
}
cs=1; //cs的上升沿和下降沿必須在clk為低時(shí)進(jìn)行
delay(200); //使高低電平持續(xù)一段時(shí)間
if(dat1==0)
dat1=0x7f; //完成了0和0x7f之間的替換
else
dat1=0;
}while(flag);
}
}
void Tratranslator() //鋸齒波的發(fā)生函數(shù)
{
uchar j;
uchar dat1=0x7f;
while(flag)
{
do{
prepare();
dat=dat1;
for(j=0;j12;j++)
{
din=(bit)(dat7); //將數(shù)據(jù)的最高位賦給din
clk=1;
dat=dat1; //一位位的傳輸
clk=0;
}
cs=1; //cs的上升沿和下降沿必須在clk為低時(shí)進(jìn)行
delay(2); //稍加延時(shí)
dat1--;
}while(flag dat1); //一旦有終止信號(hào)就可以停止
do{
prepare();
dat=dat1;
for(j=0;j12;j++)
{
din=(bit)(dat7); //將數(shù)據(jù)的最高位賦給din
clk=1;
dat=dat1; //一位位的傳輸
clk=0;
}
cs=1; //cs的上升沿和下降沿必須在clk為低時(shí)進(jìn)行
delay(2); //稍加延時(shí)
dat1++;
}while(flag (!(dat1==0x7f)));
}
}
void Sintranslator(uchar wave[],uchar num )//正弦波的轉(zhuǎn)換函數(shù)
{
uchar i,j;
uchar dat1;
do{
for(i=0;inum;i++)
{
prepare();
dat1=wave[i]; //打開片選 開始工作
for(j=0;j12;j++)
{
din=(bit)(dat17); //將數(shù)據(jù)的最高位賦給din
clk=1;
dat1=dat11; //一位位的傳輸
clk=0;
if(flag==0)break;
}
cs=1; //cs的上升沿和下降沿必須在clk為低時(shí)進(jìn)行
delay(1); //稍加延時(shí)
if(flag==0)break;
}
}while(flag); //等待控制鍵的暫停
}
void keyscan() //切換功能按鍵返回鍵值函數(shù)
{
uchar i;
for(i=0;i4;i++)
{
if(key1==0)
{
delay(10);
if(key1==0)
{
keydat++;
do{}while(!key1); //松手檢測(cè)
if(keydat==4)keydat=1;//加滿回零處理
}
}
}
}
void keycountrl() //切斷輸出控制函數(shù)
{
if(key2==0)
{
delay(10);
if(key2==0)
{
flag=0;
do{}while(!key2); //松手檢測(cè)
}
}
}
void main ()
{
uchar temp;
TMOD=0x01; //確定定時(shí)器的工作方式
TH0=(65536-50000)/256; //給定時(shí)器0賦予初值
TL0=(65536-50000)%256;
EA=1; //開總中斷
ET0=1; //開啟定時(shí)器0中斷
TR0=1;
while(1)
{
do{
switch(keydat)
{
case
分享文章:波形產(chǎn)生函數(shù)c語(yǔ)言程序 梯形波c語(yǔ)言程序
文章地址:http://www.muchs.cn/article12/hphigc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)公司、微信小程序、品牌網(wǎng)站制作、標(biāo)簽優(yōu)化、網(wǎng)站改版
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
網(wǎng)頁(yè)設(shè)計(jì)公司知識(shí)