当前位置:首页 » 编程语言 » 信号转换器c语言
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

信号转换器c语言

发布时间: 2022-06-15 06:19:45

❶ 用89S51单片机设计低频函数信号发生器,能产生方波、正弦波、三角波等信号波形的电路原理图和c语言程序

给你发一个参考电路图

❷ stc15f2k60s2单片机如何用c语言将一个模拟信号转换成数字信号

你可以查询51单片机的AD信号采集程序,也就是说,你是使用ADC芯片采集到的信号送到单片机里提取的。

❸ hd74ls164的输入和输出信号是如何转换的即如何用c语言编程实现

是串并转换吧。下面是送i串行信号里的一个信号的操作:
先置clear 为1
置CLK为0
再送A B 信号(一般会有一个固定为1)
再让CLK置1,产生低-高的跳变,然后置回0,准备输入下一个信号
上面每一个名字都对应了一个管脚

❹ 单片机C语言版信号发生器

单片机信号发生器,一般是通过控制单片机的IO的高低电平来实现的,具体为
1,可以通过先配置一个管脚为输出,然后给这个管脚写0,输出就为低电平,然后写1,这个管脚就输出为高电平。如果你的单片机是3.3v供电的话,那么高电平一般为3.3V,低电平一般为0v。
2,如果要产生一个方波的话,需要先输出1,然后延迟一段时间,然后再输出0,然后再延迟一段时间,然后输出1.... 要如此反复的话,可以用while(1), 然后在while(1)里面写入你的置高,延迟,置低的代码,具体伪代码可以为
配置对应输出管脚为输出; //因为管脚可以配置为输出和输入,所以需要先配置为输出
while(1)
{
对对应输出管脚置高;
sleep(半个周期的时间);
对对应输出管脚置低;
sleep(半个周期的时间);
}
3, 如果你牵涉到高级应用的话,比如要输出一个正弦波,那么需要外加信号产生芯片,比如DDS芯片。
4,如果还需要更加复杂的信号,任意波形的,可以用一个片内DA按照你的意思输出对应的电平,或者片外DA来输出。

❺ 单片机C语言版正弦波信号发生器怎么做

#include<at89x51.h>
//unsigned char TIME0_H=0xec,TIME0_L=0x78; //定时器0的初值设置;全局变量
#include<sinx.h>
#include<0832.h>
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 ty_u=P1^3;
sbit ty_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(+\-)n*2Hz.
{
temp=0xffff-3906/FREQ; //方波,三角波默认为100hz,切换后频率也为50HZ 65336-10^6/(256*FREQ)
TIME0_H=temp/256;
TIME0_L=temp%256;
}
else if(cho==0|cho==3){ //正弦波 三角波默认周期50hz 65536-10^6//(512*FREQ)
temp=0xffff-1953/FREQ;
TIME0_H=temp/256;
TIME0_L=temp%256;
}
}
//调节部分——方波的占空比
void ty_ud(void) //方波也采用512次中断构成一个周期。
{
if(ty_d==0&sqar_num>0)
sqar_num--;
else if(ty_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&(ty_d==0|ty_u==0))
{ty_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)/2.0*255;
//%uint32(y)%强制类型转换。
//%fprintf('%.f\n',uint32(y));%控制输出类型
//round(y)%四舍五入函数

❻ 我要用C语言实现A/D转换(即把传感器测到的土壤模拟信号转化为数字信号),请高手帮忙编写一下程序段

A/D转换是由硬件芯片完成的。
程序的作用是控制A/D转换芯片,读取A/D转换芯片输出的结果。然后将A/D转换芯片直接输出的值换算为你需要的结果。

❼ 简易函数信号发生器C语言编写

我没做过正弦波和三角波,我认为正弦波做的话用带DA功能的单片机,但是你没说正弦波的频率和赋值,三角波也可以用DA做,方波就很简单了用拉高活拉低口线就可以了。你直接用单片机做,不用外围电路吗??

❽ 求高手把这些汇编语言转成c语言,51单片机数字信号发生器-串行通讯软件设计

帮助你改变
#包括

无符号字符型吨= 0;

SBIT P3_7 = P3 ^ 7;

无效的主要()

{

TMOD = 0X01 ;/ /设置T0定时1

TH0 =值0x3c ;/ /设置初始值的计时器100ms的

TL0 = 0XB0; /> EA = 1 ;/ / CPU开中断

ET0 = 1 ;/ /定时器0中断使能

P3 = 0X00 ;/ /设置正常状态P3口

P1 = 0X00 ;/ / VD1VD6发红外光

{(1)

(P3! = 0X00)/ /显示器,如果有人闯入

{

TR0 = 1 ;/ /启动T0定时

}

}

}

无效定时器0()中断1 / /定时器0中断子程序

{

TH0 =值0x3c ;/ /重新设置初始值

TL0 = 0XB0;

+ +;

(== 10)/ / 1S,1S尚未返回

{

T = 0 ;/ /重置计数器的初始值

P3_7 =! P3_7 ;/ / P3.7端口否定}
}

❾ 用c语言写的信号发生器程序

个值做下处理,这样就可以生成随机数了。

延时函数可试下sleep函数
另外,团IDC网上有许多产品团购,便宜有口碑

❿ 急!!用ADC0809做A/D转换器,编制C程序,将正弦信号转换成数字信号输送给单片机,出来电信号,是led灯亮

#include<reg52.h> //包含单片机寄存器的头文件
#include<intrins.h> //包含_nop_()函数定义的头文件

//AD端口定义
sbit CLK=P3^4;
sbit start=P3^0;
sbit oe=P3^1;
sbit eoc=P3^2;

#define uchar unsigned char
#define uint unsigned int

/*********初始化***********/
void sysinit()
{

TMOD = 0x20; //设定定时器T1工作方式 T0 工作方式1
TH1=0xfe; //利用T1中断产生CLK信号
TL1=0xfe;//
EA = 1; //开总中断

ET1=1;
TR1=1; //启动定时器T1

start=0; // START: A/D转换启动信号,输入,高电平有效。
oe=0; //数据输出允许信号,输入,高电平有效。当A/D转换结束时,此端输入一个高电平,才能打开输出三态门,输出数字量。
}

void t1(void) interrupt 3
{
ET1=0;
CLK=~CLK;
ET1=1;
}

//adc0800数据采集

unsigned char adc()

{
unsigned char Temp;
start=1;

start=0; //启动信号
while (!eoc);// A/D转换结束信号
P1=0xff;
oe=1;

Temp=P1;//读取采集数据
oe=0;
return(Temp);//返回采集数据

}

void main()
{
uchar a;
sysinit();
while(1)
{
a=adc();//AD转换,转换后将数据存入变量a中
}

}