第一步,打开Simulink
第二步,新建一个空白工程(或直接在已有工程里边修改)
第三步,添加示波器模块。
第四步,添加信号源并连接,本文选择阶跃信号。
第五步,设置阶跃信号从0s开始出现。
第六步,双击示波器打开设置。
第七步,设置采样时间,点击OK。
第八步,运行程序。
第七步,设置采样时间,点击OK。
恩,这个我记得我做过啊,不难就是LCD要有打点的,我可以发你一个。原理就是点x,y,x是横的,就是一个for循环啊,然后y把他根据电压的数值对应比例转换为64高度上的数值啊,比如1v对应y=30,处理好这个数据就在刚才的for里面显示就行,关键是打点哦
单片机和DAC0832控制输出方波,锯齿波,三角波,正弦波。
#include<at89x51h>
//unsigned char TIME0_H=0xec,TIME0_L=0x78; //定时器0的初值设置;全局变量
#include<sinxh>
#include<0832h>
void main()
{
TMOD=0X01;
TH0=0xff;
TL0=0xd9;
IT0=1; //设置中断触发方式,下降沿
EA=1;
EX0=1;
ET0=1;
IP=0X01; //键盘中断级别高
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,默认值50
unsigned char cho=0; //0:正弦波。1:方波。2:三角波。3:锯齿波。
unsigned char num=0;
unsigned char TIME0_H=0xff,TIME0_L=0xd9; //定时器0的初值设置;全局变量对应正弦波,锯齿波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
//调节部分——频率
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(+\-)n2Hz
{
temp=0xffff-3906/FREQ; //方波,三角波默认为100hz,切换后频率也为50HZ 65336-10^6/(256FREQ)
TIME0_H=temp/256;
TIME0_L=temp%256;
}
else if(cho==0|cho==3){ //正弦波 三角波默认周期50hz 65536-10^6//(512FREQ)
temp=0xffff-1953/FREQ;
TIME0_H=temp/256;
TIME0_L=temp%256;
}
}
//调节部分——方波的占空比
void duty_ud(void) //方波也采用512次中断构成一个周期。
{
if(duty_d==0&sqar_num>0)
sqar_num--;
else if(duty_u==0&sqar_num<255)
sqar_num++;
}
//波形发生函数
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;所有数据从新开始,保证波形的完整性
else if(freq_u==0|freq_d==0)
{freq_ud();}
else if (cho==1&(duty_d==0|duty_u==0))
{duty_ud();}
else ;
}
//定时器中断处理程序。
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;} //方波 //为了提高方波的最高频率,只有牺牲占空比的最小可调值。分100份 每次1%。
case 2:{TH0=TIME0_H;TL0=TIME0_L;triangle();break;} //三角波
case 3:{TH0=TIME0_H;TL0=TIME0_L;stw(); break;} //锯齿波
default: ;
}
}
#endif
//正弦表;每半个周期256个取值,最大限度保证波形不失真。
//各个值通过MATLAB算出,并四设五如取整。具体程序如下
#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位采用,很多值是重的。虽然实际中并不会。
//y=(sin(x)+1)/20255;
//%uint32(y)%强制类型转换。
//%fprintf('%f\n',uint32(y));%控制输出类型
//round(y)%四舍五入函数
我们先来看看说明书上是怎么说的:
只有受过专业培训的人员才能执行维修程序
避免起火和人身伤害
使用合适的电源线。请使用本产品专用并经所在国家/地区认证的电源线
正确连接和断开探头。正确连接仪器探头,探头的接地端为地相位。当探头或测试端连接到电压源上时请勿插拔;将探头与测试仪器断开前,请将探头输入和探头基准导线与电路断开
将产品接地。为避免电击,必须将仪器通过接地导线与大地相连
查看所有终端额定值。为避免起火和过大电流的冲击,请查看产品上所有的额定值和标记说明。在连接产品前,请先查看产品手册,了解额定值的详细信息
使用正确的探头。为避免过大电流的冲击,请使用正确的额定探头进行测量
断开交流电源。适配器可以断开交流电源,用户必须能随时触及适配器
请勿拆机运行。如外盖或面板已卸下,请勿 *** 作
怀疑产品出现故障时,请勿进行 *** 作。如果怀疑本产品损坏,请让指定的维修人员进行检查
正确对电池进行充电。按指定的电源适配器和推荐的充电周期对电池进行充电
避免接触裸露电路。产品接通电源时,请勿接触任何裸露的接点和部件
保持良好的通风
请勿在潮湿的环境下使用
请勿在易燃易爆的环境下使用
请保持产品表面的清洁和干燥
在示波器通道口附近,写有ALL INPUTS 1MΩ//14pF 300Vrms CAT I
他的含义是所有通道输入阻抗是1MΩ,输入电容是14pF,最大输入电压有效值为300V,CAT是安全等级分类,根据国际电子电工委员会IEC1010-1的定义,把工业工作的区域分为四个等级,分别是CATI,CATII ,CATIII ,CATIV,每个等级定义不同。
测量类别
CAT I 电子设备负载
CAT II 单项接收的负载,电气设备负载
CAT III 三相电的配电,分配端,包括单项照明电
CAT IV 三相电落地的总输入/接入端口,任何在户外的导体
在CAT I,CAT II区域里,最高受到600V的电压冲击,仪器不会对人体安全产生威胁。
300Vrms也意味着在 IEC 类别 I 安装条件下,可以将输入终端连接到其线电压最大值为 300Vrms 的电路接线端。为避免电击的危险,请不要将输入端连接到线电压超过 300Vrms 的电路。
何为IEC 类别 I设备?
这类设备具有金属外壳,但它除靠一层基本绝缘来防电击外还另有补充措施,即它具有经PE线接地的手段。这样当基本绝缘损坏带电导体碰设备金属外壳时,外壳电位因接地而大大降低,同时经PE线构成的接地通路也可使产生的接地故障电流返回电源,这时回路上的防护电器即可检测出故障电流而及时切断电源。这类设备具有机械强度高的金属外壳和简单有效的防电击措施,它有较大的适用范围,额定功率不受限制,得到广泛应用。
实际上,示波器能测多大电压往往取决于用什么探头,如下图示波器配合标配的10X探头最高可以测600V pk,选配的100X高压探头T3100C, 耐压可达2KV pk。600V的电压经过10倍衰减输入示波器后,只剩60V,因此不会对示波器造成伤害。
所以,在测试的时候,还要检查探头衰减与示波器通道衰减倍数设置是否一致,否则会引起读数错误。
除了在进行测试前,应估算被测信号的幅度大小之外,我们也应确认示波器的量程范围和示波器的基线是否对齐零点。如图可知,在1X档位下,最大垂直档位是10V,示波器纵坐标上一共是10格,所以此时最大量程是100V,其他档位下同理。而如果示波器的基线没有对齐零点,则需要对示波器进行自校准,这种情况一般出现在长时间没有使用示波器,或者所处环境温度、海拔高度出现了比较大的变化时候。
示波器可在没有直接连接到主电源市电的电路上进行测量。例如,没有从主电源引出的电路, 或者虽然从市电引出,但经过了特殊保护(内部)的电路。在后一种情况下,瞬间应力会发生变化;因此,用户应了解设备的瞬间承受能力。瞬间过电压在与主电源隔离的电路中存在。麦科信STO系列数字示波器的设计可安全地承受偶发的最大1000Vpk的瞬间过电压。不要使用示波器在瞬间过电压超过这个值的电路中测量。
采用示波器测试高压电路时,要特别注意安全。要站在绝缘物上,单手 *** 作,不要触及设备和其他接地物体,更不要接触高压测试点。接探头时,先切断高压测试电路电源,接好后,再进行测试。示波器安全使用中最重要的一点毫无疑问当属可靠的接地,可靠接地可以有效避免示波器外壳金属部分带电(如BNC接口),同时在测量时也更加安全。
示波器通道的探头地,从安全考虑,最好只接一个,因为示波器通道之间往往不是隔离的,示波器内部通道往往共地,并且接在地电平上。如测量高频信号的时候如果确实需使用两个地线夹,则一定要保证两个地线夹连的都是地电平。
如下图所示测量市电的时候,就会造成对地线的短路,从而引发跳闸等问题。
有些工程师在测量高压信号时,往往习惯性地把电源插头的保护地断开,然后使用普通无源探头直接进行测量,也就是我们所说的浮地测量方式。但这种测量方式其实存在安全隐患,可能会使得示波器外壳金属部分带电,人体不小心触碰到有触电危险。如果要用示波器探头测量浮地信号,最好当然是是采用差分探头,如果没有条件可以用两探头信号相减的办法。而示波器探头不接地可能会导致电路错误或短路。
如下图通道一(**)和通道二(蓝色)分别测量的是零线和火线,通道三(粉色)是直接采用差分探头测出的市电波形,通过示波器数学通道(红色)相减后也可以得出市电波形。
◆李萨如图形是当在示波器的X轴输入一个波形,用它作为扫描信号(而不是用示波器本身的锯齿波来扫描!),同时在Y轴输入另一个信号,当两个信号的频率之比正好形成整数比时产生的图样。
◆比个设想的简单例子:如果你一边在荡秋千,一边拿着一个长把扫帚在地上左右摆动。仍你左右摆动的周期或频率正好等于秋千前后摆动的周期或频率的话,那就会在地面上画出一个封闭的图形。如果你是按照正弦波的规律摆动扫帚的话,那画出来的图形将是椭圆。如果你扫帚的摆幅正好等于秋千的摆幅时,画出来的一定会是个圆圈!如果你晃动扫把的频率比秋千块一倍,则会画出一个8字。
示波器上的X轴信号就相当于例子中的秋千,Y轴的信号就相当于例子中的扫帚。
◆因此,用构成李萨如图形的方法就可以比较两个信号间的频率比,当一个信号的频率为已知时,就可测出另一个信号的频率。
◆所以要观察李萨如图形,首先将示波器的X输入端设置到外部扫描方式上,再将一个信号送入X轴输入端,另一个信号送入Y轴输入端,然后改变一个信号的频率,并将信号幅度适当衰减就行了。
以上就是关于matlab示波器怎么在一秒采样全部的内容,包括:matlab示波器怎么在一秒采样、如何将AD0832等采集的数据转换为LCD12864对应的坐标值呢想制作一个单片机控制的简易示波器、利用单片机和DAC0832控制输出方形波,锯齿波,三角波,并通过示波器显示 程序如下等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)