北京迪阳世纪科技有限责任公司---是国内做虚拟仪器的厂家,他们所产销的
虚拟仪器,组合仪器,行销全球50多个国家,其虚拟仪器产品是将仪器技术、计算机技术、总线技术和软件技术紧密的融合在一起,利用计算机强大的数字处理能力实现仪器的大部分功能,打破了传统仪器的框架,形成的一种新测量模式,同时代理荷兰泰普,台湾克拉克,一及其它欧美国家的虚拟示波器。
典型型号有。
DSO2090/32K , USB, 2通道100MHz示波器+频谱仪+频率计 40MHz带宽
DSO2150/32K , USB, 2通道150MHz示波器+频谱仪+频率计 60MHz带宽
DSO2250/32K , USB, 2通道250MHz示波器+频谱仪+频率计 60MHz带宽
DSO5200/14K , USB, 2通道200MHz示波器+频谱仪+频率计 100MHz带宽
DSO5200a/512K,USB, 2通道250MHz示波器+频谱仪+频率计 200MHz带宽
DSO-2902AM2/512K USB,2通道500MHz示波器+16通道逻辑分析仪+频谱仪+频率计125MHz带宽
DSO-2902AG2/1M, USB,2通道1GHz示波器+16通道逻辑分析仪+频谱仪+频率计170MHz带宽
DSO-2904AM2/512K, USB,4通道500MHz示波器+16通道逻辑分析仪+频谱仪+频率计125MHz带宽
DSO-2904AG2/1M, USB,4通道1GHz示波器+32通道逻辑分析仪+频谱仪+频率计170MHz带宽
HS3 2通道100MHz示波器+频谱仪+频率计 40MHz带宽
HS4 4通道50MHz示波器+频谱仪+频率计 20MHz带宽
HS5 2通道500MHz示波器+频谱仪+频率计 200MHz带宽
楼主:是不是可以这样理解,通过单片机一个IO口输出一个时钟信号,然后用示波器去测量。
例子:下面是一个89C51为例输出矩形波代码
sbit SCLK P1^0;
while(1){
unsingned int i;
SCLK=0;
for(i=0;i<20000;i++);//波形宽度
SCLK=1;
for(i=0;i<20000;i++);
}
你放到你的程序里,然后用示波器测量第一脚,肯定有波形
如有问题,请再问,呵呵!
单片机和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)%四舍五入函数
在实际问题中,经常会遇到同一个质点同时参与两个不同方向的振动。这时质点的合位移是两个分振动的矢量和。其中,相互垂直的两个简谐振动的合成,就是我准备讨论的李萨如图的基础本质。
我认为编辑程序的前提,就是要将所用到的量和公式进行变量式处理,也可以说是数字化处理。所以,在进行程序说明以前,先对李萨如图合成原理进行分析。
李萨如图上的每一个点都可以用以下的公式进行表示:
X=A1Cos(ω1t+ψ1)
Y=A2Cos(ω2t+ψ2)
从这里可以看出,李萨如图实际上是一个质点同时在X轴和Y轴上振动形成的。但是,如果这两个相互垂直的振动的频率为任意值,那么它们的合成运动就会比较复杂,而且轨迹是不稳定的。然而,如果两个振动的频率成简单的整数比,这样就能合成一个稳定、封闭的曲线图形,这就是李萨如图。
下面我介绍一下我是如何在程序中实现这一目的的。在程序中,我将公式稍加改动,成为:
X
=
Sin
(at)
Y
=
-
Sin
(bt+ψ)
其中,a和b是变量,用于获取外界输入的数值,为了保证频率成简单的整数比,所以a和b只能取个位整数。ψ是用来获取外界输入的初始相差的值,ψ=ψ2-ψ1。先前公式中的A1和A2,只关系到绘制出的图形的最高最低点和最左最右点的位置,对图形的实质没有影响,所以我将其简化为1∶1。
以上这些就是我所制作的程序的理论基础。如果将t作为可以不断自动变化一个微小量的变量,再依靠VB提供的功能就能将点(X,Y)逐一绘制在屏幕上,这样就形成了一个绘制李萨如图的过程。如果将ψ作为一个不断自动变化的变量,那么就可以使李萨如图“动”起来,即绘制出频率比相同,但初始相差不同各个图形。当这些图形一幅接着一幅出现在眼前时,就有了动的效果,这也可以模拟示波器上得到的李萨如图形。
在对李萨如图合成原理进行分析,并且对VB程序相关内容的做了仔细研究之后,终于编出了名为“李萨如图绘制程序”的应用程序。下面我就来简单介绍一下这个程序所具有的特点,也可以说是我制作得比较得意的地方。
一、可以变换绘制图线的颜色。这样的好处就是可以看清李萨如图绘制的全过程。因为李萨如图在绘制过程中会有和原图线重合的时候,这时换一种颜色,就可以知道图线仍然在绘制只不过是和原图线重合而已,并不是已停止绘制。
二、可以自定初始相差。本程序提供了八种初始相差值,这样便可以更清楚地了解李萨如图在不同初始相差下的不同形式了。
三、可以手动控制绘图速度。在一个水平滚动轴上,左右移动滑块便可以实现对绘图速度的控制。
制作这个程序,要先对李萨如图进行研究,了解其形成原理,然后再要对VB进行研究,想方设法把对李萨如图的理解用计算机语言表达出来。这个过程不仅让我对李萨如图有了更深的理解,而且也帮助我更快地掌握VB这门语言,从中还是收获不少的。如果已知一个振动的周期,就可以根据李萨如图求出另一个振动的周期,这是一种比较方便也是比较常用的测定频率的方法。因此,李萨如图有着较为广泛的应用。也希望这个程序能对李萨如图的研究有所帮助。
恩,这个我记得我做过啊,不难就是LCD要有打点的,我可以发你一个。原理就是点x,y,x是横的,就是一个for循环啊,然后y把他根据电压的数值对应比例转换为64高度上的数值啊,比如1v对应y=30,处理好这个数据就在刚才的for里面显示就行,关键是打点哦
可以直接连接。
1
打开matlab,这里我以我自己的为例
2
打开你的程序或者simulink仿真图,这两个都可以设置示波器输出
3
运行程序或者仿真图,得到一个波形,如下示波器的设置是系统默认设置,下面我们就对其进行修改
4
回到“Command Window”,输入
set(0,'ShowHiddenHandles','On')
set(gcf,'menubar','figure')
并按回车键
5
此时,你再点击示波器,你会发现,示波器上多了一行工具栏
6
选择“Insert”下的“Axes”
7
双击示波器的任意地方,当然不能是“关闭”按钮
8
现在你就可以对示波器进行设置了,这里我将背景换成白的
9
也可以对线型设置,我将线换成蓝的
10
最终得到这样的一个波形以及背景,当然还有更多设置,根据自己需求进行设置吧。
以上就是关于PC示波器,自制虚拟示波器,哪家公司是做适合科研的全部的内容,包括:PC示波器,自制虚拟示波器,哪家公司是做适合科研的、求单片机51的c语言程序,要求用单片机调示波器的,要能正确显示波形。急用。、利用单片机和DAC0832控制输出方形波,锯齿波,三角波,并通过示波器显示 程序如下等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)