
A=[...
11000 6 8 29 21 0 9 47 147
11001 6 8 29 21 0 10 89 149
11002 6 8 29 21 0 12 31 142
11003 6 8 29 21 0 13 71 146
11004 6 8 29 21 0 15 12 149
11005 6 8 29 21 0 16 52 151
11006 6 8 29 21 0 17 92 146
11007 6 8 29 21 0 19 32 144
11008 6 8 29 21 0 20 73 148
11009 6 8 29 21 0 22 14 148]
t=A(:,7)*1000+A(:,8) %ms
I=A(:,9)
[Imax,idmax]=max(I)
[Imin,idmin]=min(I)
plot(t,I,'o-')
给你一个51单片机读取模拟信号并转换成数字信号的例程,峰峰值什么的自己再根据需求自己加条件判断吧。
#include<reg51.h>#include <intrins.h>
#define uint unsigned int
#define uchar unsigned char
sbit adrd=P3^7 //IO口定义
sbit adwr=P3^6
sbit diola=P2^5
sbit dula=P2^6
sbit wela=P2^7
unsigned char j,k,adval
void delay(unsigned char i) //延时程序
{
for(j=ij>0j--)
for(k=125k>0k--)
}
uchar code table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d, //数码管编码
0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71}
void display(uchar bai_c,uchar sh_c,uchar g_c) //显示程序
{
P0=table[bai_c] //显示百位
dula=1
dula=0
P0=0xfe
wela=1
wela=0
delay(5)
dula=0
P0=table[sh_c] //显示十位
dula=1
dula=0
wela=0
P0=0xfd
wela=1
wela=0
delay(5)
P0=table[g_c] //显示个位
dula=1
dula=0
P0=0xfb
wela=1
wela=0
delay(5)
}
void main() // 主程序
{
uchar a,A1,A2,A2t,A3
while(1)
{
wela=1
P0=0 //选通ADCS
adwr=0 //AD写入(随便写个什么都行,主要是为了启动AD转换)
_nop_()
adwr=1
P0=0xff //关闭ADCS
delay(10)
wela=0 //关闭有AD片选信号锁存器的锁存端以防止在 *** 作数码管时使AD的片选发生变化
for(a=20a>0a--) //需要注意的是ADC0804在写和读之间的时间间隔要足够长否则无法读出数据
{ //这里把显示部分放这里的原因也是为了增加写读之间的时间间隔
display(A1,A2,A3)
} //送去显示各位。
wela=1 //重新打开有AD片选信号锁存器的锁存端
P1=0xff //读取P1口之前先给其写全1
P0=0 //选通ADCS
adrd=0 //AD读使能
adval=P1 //AD数据读取赋给P1口
adrd=1
P0=0xff //关闭ADCS
adwr=0
P1=adval //同时把AD的值送八个发光二极显示
A1=adval/100 //分出百,十,和个位
A2t=adval%100
A2=A2t/10
A3=A2t%10
}
}
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)