资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

c语言中pulse函数 c语言put函数

c语言如何中断函数控制脉冲

外部中断的常用功能

为企业提供成都做网站、成都网站建设、网站优化、全网营销推广、竞价托管、品牌运营等营销获客服务。成都创新互联公司拥有网络营销运营团队,以丰富的互联网营销经验助力企业精准获客,真正落地解决中小企业营销获客难题,做到“让获客更简单”。自创立至今,成功用技术实力解决了企业“网站建设、网络品牌塑造、网络营销”三大难题,同时降低了营销成本,提高了有效客户转化率,获得了众多企业客户的高度认可!

外部中断经常用来记录外部脉冲的个数,也就是当我们使用外部中断1时,如果想记录自身单片机的某个引脚的下降沿个数,只需用杜邦线把这个引脚和P3.3连接即可。

比如P2.3引脚产生这样的电平无规律跳转,则下降沿的个数为5

所以我们就用外部中断1来实现记录K4按键从按下到松手的抖动过程中经历了多少个下降沿,把下降沿的个数显示在数码管上。

2.程序思路

我们定义一个16位的全局变量pulse用来记录P2.3下降沿的个数,在中断函数中的任务就是简单的pulse自加,因为引脚遇到下降沿就会进入中断函数。

在主函数里就是负责数码管显示即可。

3.代码#include 

#include //详见第六章第8讲

u16 pulse=0;

void main()

{

u16 x,PULSE_buf;

IT1 = 1;   //下降沿触发模式

EX1 = 1;

EA  = 1;

LED_Init();//初始化LED硬件模块

KEY_Init();//初始化按键功能模块

ShowNumber(pulse);

while(1)

{

SEG_Scan();

if(PULSE_buf!=pulse)ShowNumber(pulse);//pulse不再是前一次的值,也就是pulse数值更新了,所以数码管缓存区也要更新pulse的数值以便显示出来

x++;

if(x=50)//隔一段时间过来记录此时的pulse数值

{

x=0;

PULSE_buf=pulse;

}

}

}

//请把P3.3和P2.3用杜邦线连接起来

void EXTI1_IRQHandler() interrupt 2

{

pulse++;

}

大家多按几次K4,发现按下后松手的一个动作里有时pulse就自加了几次,显示在数码管上的数加了好几下。

在80C51单片机系统中,已知时钟频率为6MHz。请利用定时器T1编程P3.1口输出频率为10KHz的方波(用c语言)

#include reg51.h

sbit pulse = P3^1;

void main (void)

{

P3=0xFF;

EA=1;

ET1=1;

TMOD =0x10;

TH1 = 0xFFH;

TL1 = 0xFFH;

TR1=1;

for(;;);

}

void intserv 3 (void) interrupt 3 using1

{

TH1 = 0xFFH;

TL1 = 0xFFH;

pulse=!pulse;

}

c语言关于if结构的问题?

#include stdio.h

int main()

{

int breathe, pulse;

printf("Breathe: ");

scanf("%d", breathe);

printf("Pulse: ");

scanf("%d", pulse);

if (15 = breathe breathe =20

50 = pulse pulse = 70)

printf("sleeping\n");

else

printf("pretend\n");

return 0;

}

谁有pulsesensor心率传感器 的c语言程序,带注释的。在线等挺急的

这个是主程序和部分代码由于字数限制所以你还是留个邮箱吧

void main(void)

{

unsigned char i;

sys_init();

beep = 1;

LCD12864_DisplayOneLine(0x80,ucStr1); //显示信息1

LCD12864_DisplayOneLine(0x90,ucStr2); //显示信息2

LCD12864_DisplayOneLine(0x88,ucStr3); //显示信息3

LCD12864_DisplayOneLine(0x98,ucStr4); //显示信息4

while(1)

{

sendDataToProcessing('S', Signal); // 发送并处理原始脉搏传感器数据

if (QS == true){ // 确定发现一个心跳

fadeRate = 255; // Set 'fadeRate' Variable to 255 to fade LED with pulse

sendDataToProcessing('B',BPM); // 发送一个'B'和心率

sendDataToProcessing('Q',IBI); // send time between beats with a 'Q' prefix

QS = false; // reset the Quantified Self flag for next time

LCD_disp_list_char(2,4,DisBuff);//在LCD12864上显示BPM

}

delay(138); // 延时 19.6ms

LCD_disp_list_char(4,4,DisBuff2);

//ledFadeToBeat();

if(Pressure100){

for(i=0;i8;i++){

delay(1000);}

if (Pressure100){

beep = 0;}}

if(BPM60|BPM100){

for(i=0;i9;i++){

delay(1000);}

if(BPM60|BPM100){

beep = 0;}

for(i = 0;i16;i++) //依次执行写入操作

{

putchar(ucStr1[i]);

}

for(i = 0;i16;i++) //依次执行写入操作

{

putchar(ucStr2[i]);

}

for(i=0;i3;i++)

{

putchar(DisBuff[i]);}

for(i = 0;i16;i++) //依次执行写入操作

{

putchar(ucStr3[i]);

}

for(i = 0;i16;i++) //依次执行写入操作

{

putchar(ucStr4[i]);

}

for(i=0;i4;i++)

{

putchar(DisBuff2[i]);}

}

}

//void ledFadeToBeat(){

// fadeRate -= 15; // set LED fade value

// fadeRate = constrain(fadeRate,0,255); // keep LED fade value from going into negative numbers!

// analogWrite(fadePin,fadeRate); // fade LED

// }

/******************************************************************************

函数名称:GetADCResult

函数功能:获取AD转换结果函数

入口参数:BYTE ch(通道选择)

返回值:result(A/D转换结果)

备注:无

*******************************************************************************/

unsigned int GetADCResult(BYTE ch)

{ unsigned int result; //AD转换结果result

ADC_CONTR=0xf8; //清除ADC控制寄存器ADC CONTR的CHS2、CHS1、CHS0(清除通道选择)

_nop_(); //设置ADC CONTR控制寄存器后,要加4个空操作延时才可以正确读到ADC CONTR寄存器的值

_nop_();

_nop_();

_nop_();

ADC_CONTR = ADC_POWER | ADC_SPEEDLL | ch | ADC_START; //开ADC电源,选择AD转换速率,并选择AD通道,开始AD转换

_nop_(); //设置ADC CONTR控制寄存器后,要加4个空操作延时才可以正确读到ADC CONTR寄存器的值

_nop_();

_nop_();

_nop_();

while (!(ADC_CONTR ADC_FLAG));//等待AD转换结束

ADC_CONTR = ~ADC_FLAG; //关闭ADC

result=ADC_RES; //将AD转换结果的高两位赋给result

result=result8; //将result循环左移8位

result+=ADC_RESL; //将AD转换结果的底8位加高两位共10位给result

return result; //返回10位AD转换结果

}

void sendDataToProcessing(char symbol, int dat ){

putchar(symbol); // symbol prefix tells Processing what type of data is coming

printf("%d\r\n",dat); // the data to send culminating in a carriage return

}

void UART_init(void)

{

TMOD = 0x20; //定时器工作在定时器1的方式2

PCON = 0x00; //不倍频

SCON = 0x50; //串口工作在方式1,并且启动串行接收

TH1 = 0xFd; //设置波特率 9600

TL1 = 0xFd;

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

}

char putchar(unsigned char dat)

{

TI=0;

SBUF=dat;

while(!TI);

TI=0;

return SBUF;

}

void _nop_ (void)

{}

void T0_init(void){

// Initializes Timer0 to throw an interrupt every 2mS.

TMOD |= 0x01; //16bit TIMER

TL0=T0MS;

TH0=T0MS8;

TR0=1; //start Timer 0

ET0=1; //enable Timer Interrupt

EA=1; // MAKE SURE GLOBAL INTERRUPTS ARE ENABLED

}

void T1_init(void){

// Initializes Timer0 to throw an interrupt every 2mS.

TMOD |= 0x01; //16bit TIMER

TL1=T0MS2;

TH1=T0MS28;

TR1=1; //start Timer 0

ET1=1; //enable Timer Interrupt

EA=1; // MAKE SURE GLOBAL INTERRUPTS ARE ENABLED

}

void ADC_init(unsigned char channel)

{

P1ASF=ADC_MASKchannel; //选择P1. channel作为A/D输入来用

ADC_RES=0; //清除ADC结果寄存器RES

ADC_RESL=0; //清除ADC结果寄存器RESL

AUXR1 |= 0x04; //调整ADC格式的结果

}

void Timer1_rountine(void) interrupt 1

{}

unsigned int analogRead(unsigned char channel)

{

unsigned int result;

while (!(ADC_CONTR ADC_FLAG));//Wait complete flag

ADC_CONTR =!ADC_FLAG; //clear ADC FLAG

result=ADC_RES;

result=result8;

result+=ADC_RESL;

// ADC_CONTR|=channel|ADC_POWER|ADC_SPEEDLL|ADC_START;

return result;

}

// Timer 0中断子程序,每2MS中断一次,读取AD值,计算心率值

void Timer0_rountine(void) interrupt 1

{

int N;

unsigned char i;

// keep a running total of the last 10 IBI values

unsigned int runningTotal = 0; // clear the runningTotal variable

EA=0; // 关定时器中断

TL0=T0MS;

TH0=T0MS8; //重装16位定时器初值

Pressure = (GetADCResult(PressurePin)); //****************

DisBuff2[3] = Pressure%10+48;//取个位数

DisBuff2[2] = Pressure%100/10+48; //取十位数

DisBuff2[1] = Pressure%1000/100+48; //百位数 ***************

DisBuff2[0] = Pressure/1000+48;//取千位数

Signal = GetADCResult(PulsePin); // 读脉搏传感器

sampleCounter += 2; // 使用这个值跟踪记录脉搏时间间隔在ms级

N = sampleCounter - lastBeatTime; // 减上个节拍的时间来避免噪声

// 找到脉搏波的波峰和波谷

if(Signal thresh N (IBI/5)*3){ // 如果脉搏传感器输出小于电源电压一半 并且 消除噪声时间小于 3/5个脉搏时间间隔

if (Signal Trough){ // 如果脉搏传感器输出小于波谷

Trough = Signal; // 跟踪脉搏波的最低点

}

}

if(Signal thresh Signal Peak){ // 如果输出大于电源电压一半并且大于波峰

Peak = Signal; // 将新值设为波峰

} // 跟踪脉搏波的波峰

if (N 250){ // 避免高频噪声

if ( (Signal thresh) (Pulse == false) (N (IBI/5)*3) ){

Pulse = true; // 当检测到一个脉搏时将脉搏标志设为真

blinkPin=0; // 点亮脉搏灯

IBI = sampleCounter - lastBeatTime; // 测量两个脉搏的时间in mS

lastBeatTime = sampleCounter; // 跟踪脉搏时间

if(secondBeat){ // 如果这是第二个脉搏

secondBeat = false; // 清除标识

for(i=0; i=9; i++){ // 全部的数据作为真实脉搏BMP

rate[i] = IBI;

}

}

if(firstBeat){ // 如果是第一个脉搏

firstBeat = false; // 清除标志

secondBeat = true; // 设置第二脉搏标志

EA=1; //开中断

return; // IBI 值是不可靠的所以抛弃

}

for(i=0; i=8; i++){ // 移动数据在rate数组中

rate[i] = rate[i+1]; // 顶替旧值

runningTotal += rate[i]; // 加上第九个新值

}

rate[9] = IBI; // 加最后的IBI到rate数组中

runningTotal += rate[9]; // 加上一个IBI到runningTotal

runningTotal /= 10; // 取平均值

BPM = 60000/runningTotal; // 一分钟可以检测到多少个心跳及 BPM!

if(BPM200)BPM=200; //限制BPM最高显示值

if(BPM30)BPM=30; //限制BPM最低显示值

DisBuff[2] = BPM%10+48;//取个位数

DisBuff[1] = BPM%100/10+48; //取十位数

DisBuff[0] = BPM/100+48; //百位数

if(DisBuff[0]==48)

DisBuff[0]=32;

QS = true; // 设置QS标志

// QS FLAG IS NOT CLEARED INSIDE THIS ISR

}

}

if (Signal thresh Pulse == true){ // 当电压归零节拍结束

blinkPin=1; // 熄灭脉搏灯

Pulse = false; // 重置脉搏标识我们可以重新测

amp = Peak - Trough; // 得到脉搏波的峰峰值

thresh = amp/2 + Trough; // 设置thresh位脉搏峰峰值的一半

Peak = thresh; // 为下一次测试重置波峰

Trough = thresh;

}

if (N 2500){ //如果超过2.5秒没有检测到一个脉搏

thresh = 512; // 重新设置波谷

Peak = 512; // 重新设置波峰

Trough = 512; // 重新设置间隔

lastBeatTime = sampleCounter; // 把最后的节拍时间更新

firstBeat = true; // 重新设置标志避免噪声

secondBeat = false; // 当我们得到心跳的时候

}

EA=1; // 开中断

}// end isr


网站标题:c语言中pulse函数 c语言put函数
本文URL:http://cdkjz.cn/article/doedcjp.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

大客户专线   成都:13518219792   座机:028-86922220