📄 main.c
字号:
/*Main.c*/ //2006.11.15
/*AD采样基本程序,并带有排队滤波函数
采样结果的精度与稳定性与基准源和信号源有关
请在项目开发的时候选择稳定的电压基准源*/
#include "global.c"
#include "math.h"
//#include "ioports.h"
//ioport unsigned port1000;
void SystemInit();
void Timer1Init();
void KickDog();
//void SPI_Init();
//void DA_OUT(unsigned CHANNEL,unsigned int RNG,unsigned int SPI_DATA);
void AD_Sample();
void pn(void);
unsigned int v,i,j,k;
unsigned int sendbuff[48] ,sendbuff1[48];
unsigned char m[511];
void main(void)
{
// pi=3.1415926;
SystemInit(); //系统初始化
pn();
v=50;
for(i=0;i<16*3;i++) //m/f=1/3
{ sendbuff[i]=v*sin(2*3.1415926*i/16)+70;
}
for(i=0;i<16*3;i++) //m/f=1/3
{ sendbuff[i]=0xFF00^sendbuff[i];
}
for(i=0;i<16*3;i++) //m/f=1/3
{ sendbuff1[i]=140-sendbuff[i];
}
for(i=0;i<16*3;i++) //m/f=1/3
{ sendbuff1[i]=0xFF00^sendbuff1[i];
}
PFDATDIR=PFDATDIR &0x0100; //=0
// _EINT(); // Enable interrupts
while(1)
{
// PFDATDIR=0x0101; //IOPA3=1;LED亮
// PFDATDIR=0x0100; //IOPA3=0;LED灭
for(j=0;j<511;j++) //BPSK
{ // PFDATDIR=0xffff; //IOPA3=1;LED亮
// PFDATDIR=0xff00; //IOPA3=0;LED灭
for(i=0;i<48;i++)
{
if(m[j]==1)
{ PEDATDIR=sendbuff[i];
// PFDATDIR=0x0101; //IOPA3=1;LED亮
// PFDATDIR=0x0100; //IOPA3=0;LED灭
}
if(m[j]==0)
{PEDATDIR=sendbuff[i];
// PFDATDIR=0x0101; //IOPA3=1;LED亮
// PFDATDIR=0x0100; //IOPA3=0;LED灭
}
PFDATDIR=0x0101; //IOPA3=1;LED亮
PFDATDIR=0x0100; //IOPA3=0;LED灭
}
}
}
}
void c_int2() /*定时器1中断服务程序*/
{
/* if(PIVR!=0x27)
{ asm(" CLRC INTM ");
return;
}
T1CNT=0;
t0++;
numled0--;
if(numled0==0)
{
numled0=200;
if((PBDATDIR & 0x0001)==0x0001)
PBDATDIR=PBDATDIR & 0xFFFE; //IOPB0=0;LED灭
else
PBDATDIR=PBDATDIR |0x0101; //IOPB0=1;LED亮
}
if((AD_FLAG==0)&((t0%100)==0)) //定时AD采样
{
AD_FLAG=1;
}*/
// AD_Sample();
// AD0[i++]=RESULT_0;
T1CNT=0;
EVAIFRA=0x80;
// asm(" CLRC INTM ");
}
void SystemInit()
{
asm(" SETC INTM "); /* 关闭总中断 */
asm(" CLRC SXM "); /* 禁止符号位扩展 */
asm(" CLRC CNF "); /* B0块映射为 on-chip DARAM*/
asm(" CLRC OVM "); /* 累加器结果正常溢出*/
// SCSR1=0x87FE; /* 系统时钟CLKOUT=20*2=40M */PLL=1*clk
SCSR1=0x83FE; /* 系统时钟CLKOUT=20*2=40M */
// SCSR1=0x81FE; /* 系统时钟CLKOUT=6*4=40M */
/* 打开ADC,EVA,EVB,CAN和SCI的时钟*/
WDCR=0x006F; /* 禁止看门狗,看门狗时钟64分频 */
// KickDog(); /* 初始化看门狗 */
IFR=0xFFFF; /* 清除中断标志 */
// IMR=0x0002; /* 打开中断2*/
}
void Timer1Init()
{
EVAIMRA=0x0080; // 定时器1周期中断使能
EVAIFRA=0xFFFF; // 清除中断标志
GPTCONA=0x0000;
// T1PR=2500; // 定时器1初值,定时0.4us*2500=1ms
T1PR=40;
T1CNT=0; //clear T1
// T1CON=0x144E; //增模式, TPS系数40M/16=2.5M,T1使能
T1CON=0x144E; //增模式, TPS系数20M/1=20M,T1使能
// KickDog(); /* 初始化看门狗 */
}
void KickDog() /*踢除看门狗 */
{
WDKEY=0x5555;
WDKEY=0xAAAA;
}
void pn(void) //local m FFT m=511
{
unsigned char m0=1,m1=0,m2=0,m3=0,m4=0,m5=0,m6=0,m7=0,m8=0,m9=0;
for ( i=0;i<511;i++) // m (1021)
{
//m0=(m0 ^ m1 ^ m4 ^ m5) || ( ! (m0 || m1 || m2 || m3 || m4 || m5 )) ;
m[i]=m9; //keep from m0=m1=m2=m3=m4=m5=0;
m9=m8;
m8=m7;
m7=m6;
m6=m5;
m5=m4;
m4=m3;
m3=m2;
m2=m1;
m1=m0;
m0=m4^m9;//(1021)
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -