❶ 脉搏计数器的程序(用c语言编写程序)
#include <reg51.h>
unsigned char i,j,t,m,DelayTime,DispBuf[3];
unsigned int n,mb;
unsigned char code
BitTab[3]={0xf7,0xef,0xdf};//位驱动码
unsigned char code
DispTab[10]={0x81,0xcf,0x92,0x86,0xcc,0xa4,0xa0,0x8f,0x80,0x84};//字形码
sbit P3_0=P3^0;
void delay(DelayTime);
main() //主程序
{
TMOD=0x01; //定时器T0工作于方式1
TH0=0xec;
TL0=0x78; //T0定时时间为5ms
IE=0X83; //开中断
IT0=1; //外部中断0为边沿触发方式
TR0=1; //开定时器T0
for(;;) //脉搏指示灯控制
{
if(P3_0==0)
{
delay(200);
P3_0=1;
}
}
}
external0() interrupt 0//外部中断服务程序
{
P3_0=0; //点亮指示灯
if(n==0)
mb=0;
else
mb=12000/n; //计算每分钟脉搏数
DispBuf[2]=mb%10;//取个位数
mb=mb/10;
DispBuf[1]=mb%10;//取十位数
DispBuf[0]=mb/10;//取百位数
n=0;
}
Timer0() interrupt 1//定时中断服务程序
{
TH0=0xec;
TL0=0x78;
t=BitTab[j];//取位值
P3=P3|0x38;//P3.3-P3.5送1
P3=P3&t; //P3.3-P3.5输出取出的位值
t=DispBuf[j];//取出待显示的数
t=DispTab[t];//取字形码
P1=t; //字型码由P3输出显示
j++; //j作为数码管的计数器,取值0-2,显示程序通过它确认显示哪个数码管
if(j==3)
j=0;
n++;
if(n==2000)//10秒钟测不到心率,n复位
n=0;
}
void delay(DelayTime)//延时子程序
{
for(;DelayTime>0;DelayTime--)
{
for(i=0;i<250;i++)
;
}
}
❷ 谁有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(Pressure<100){
for(i=0;i<8;i++){
delay(1000);}
if (Pressure<100){
beep = 0;}}
if(BPM<60|BPM>100){
for(i=0;i<9;i++){
delay(1000);}
if(BPM<60|BPM>100){
beep = 0;}
for(i = 0;i<16;i++) //依次执行写入操作
{
putchar(ucStr1[i]);
}
for(i = 0;i<16;i++) //依次执行写入操作
{
putchar(ucStr2[i]);
}
for(i=0;i<3;i++)
{
putchar(DisBuff[i]);}
for(i = 0;i<16;i++) //依次执行写入操作
{
putchar(ucStr3[i]);
}
for(i = 0;i<16;i++) //依次执行写入操作
{
putchar(ucStr4[i]);
}
for(i=0;i<4;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=result<<8; //将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=T0MS>>8;
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=T0MS2>>8;
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_MASK<<channel; //选择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=result<<8;
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=T0MS>>8; //重装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(BPM>200)BPM=200; //限制BPM最高显示值
if(BPM<30)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语言做的读心术代码每步都代表什么
#include<bits/stdc++.h>
using namespace std;
int main(void)
{
int i,a[4],ans;
string t[4];
t[0]="1,2,3,4,5,6,7";
t[1]="1,3,5,7";
t[2]="2,3,6,7";
t[3]="4,5,6,7";
cout<<"读心术猜数"<<endl;
cout<<"请你从下面7个数中,选一个并记在心里。"<<endl;
cout<<t[0]<<endl;
system("pause");
for(i=1;i<=3;i++)
{
system("cls");
cout<<i<<"问:下面的数中有吗?0:没有,1:有"<<endl;
cout<<t[i]<<endl;
do
{
cin>>a[i];
}while(a[i]<0||a[i]>1);
}
ans=4*a[3]+2*a[2]+a[1];
system("cls");
cout<<"你心中想的数是:";
cout<<ans<<endl;
return 0;
}
❹ C语言编写闪烁的红心的程序
1、首先第一步要用在一个项目的spalsh界面,进入应用后弹出这个界面,闪烁完毕后跳入主界面,比纯粹的设置背景图片的splash好看炫酷很多。
❺ 求linux c语言的心跳包程序
首先,心跳包一般是30秒或者1分钟一次才正常,3秒一次太频繁,耗损资源,降低效率,心跳包其实就是你自己定义一条数据send给服务器,服务器recv到这条数据做下判断就行了,如果1分钟没收到这条数据,就断开此客户端的socket连接,返回socket值,根据返回的值确定此客户端掉线了.
❻ 用c语言写一个程序,要求实现心跳计数,甚至输出阶跃波形
搞笑,这个跟你的硬件有关系,怎么能写,理论还没有搞通,回家好好看书吧,不要想着在这投机取巧
❼ 心跳包。如何发送TCP空帧的心跳包,它的格式是什么最好用c语言实现,因为我是在ARM上实现tcp协议
一字节对齐
struct heartbeat_req{
short reqNum;
}
struct heartbeat_rcv{
short reqNum;
}
你所有的包都有一个公用的报文头吧,报文头里面定义一个字段记录请求类型,一个字段记录数据部分长度,要空帧的心跳包就发一个没数据部分的报文头,请求类型字段填心跳包类型,数据部分长度填0就行了
❽ C语言基本代码,求详细解释,越详细越好。
解释如下:
#include"stdio.h"//头文件
#include"math.h"//数学库函数
double pcos(double a);//声明子函数
main()//主函数
{
double x,y;//定义x,y这两个双精度数据
printf("please input one number:");
//输出please input one number:
scanf("%lf",&x);//出入一个数据并赋值给x
y=pcos(x);//把x传入pcos函数,返回值赋值给y
printf("cos of %lf is %lf ",x,y);//输出cos of x is y
}
double pcos(double a)//定义子函数名,形式参数
{
double b;//定义双精度数据b
b=cos(a);//计算cos(a),并赋值给b
return b;//返回b的值
}
(8)c语言心跳代码扩展阅读:
注释就是对代码的解释和说明,其目的是让人们能够更加轻松地了解代码。注释是编写程序时,写程序的人给一个语句、程序段、函数等的解释或提示,能提高程序代码的可读性。
注释就是对代码的解释和说明。目的是为了让别人和自己很容易看懂。为了让别人一看就知道这段代码是做什么用的。
正确的程序注释一般包括序言性注释和功能性注释。序言性注释的主要内容包括模块的接口、数据的描述和模块的功能。模块的功能性注释的主要内容包括程序段的功能、语句的功能和数据的状态。
❾ c语言问题:求大神帮忙看一眼这个程序哪里有问题
这个问题关键在于计算闰年的个数,闰年比普通年份多了一天,所以最后天数直接加上闰年数就行了。(注意在循环时控制条件不用算当年是否为闰年,因为当年还没开始)以下是具体代码:
#include<stdio.h>
#include<stdlib.h>
main()
{
inti,by,ty,r=0;
longunsignedmin;
printf("Inputyourbirthyear:");
scanf("%d",&by);
printf("Inputthisyear:");
scanf("%d",&ty);
for(i=by;i<ty;i++){
if(i%400==0||i%100!=0&&i%4==0)
r++;
}
min=((ty-by)*365+r)*24*60;
printf("Theheartbeatsinyourlife:%lu",min*75);
system("pause");
}
❿ c语言编程,一个应用程序如何判断另外一个被监控的应用程序的存活与否若用心跳实现,如何设置心跳机制
APP-2每1分钟发一个心跳包给APP-1。APP-1如果超过1分钟没收到,可以累计记录x++,收到心跳包x清零。当x=2时,可以发送一个ack包给APP-2,如果APP-2还是没有回应,即x=3时,可以确定APP-2down掉。x在1~3直接时是网络阻塞。具体操作时间还需要自行确定。