创意发明:自制小型PM2.5环境检测系,实测效果还可以,赶快一起学起来!

最近比较忙,可能更新的文章比较少,疫情期间请大家多多注意身体,尽量减少外出,在家学习。
这段时间由于疫情影响不能出去,看着家对面空气检测系统的大屏幕上各种数据不断变化,于是突发奇想,能不能自己也做一个PM2.5测试系统呢,想到就要做。
老规矩废话不多说,先上实物图:
实物图1
在这里插入图片描述
实物图2
在这里插入图片描述
在这里插入图片描述
实测测量精度和准确率还是可以的。

PM2.5检测系统参考代码如下:

#include<reg52.h>
#include “delay.h”
#include “LCD12864.h”
#include “PM2_5.h”
#include “BMP180.h”
#include “DHT11.h”
#define uint unsigned int
#define uchar unsigned char

sbit waring=P1^3;
void main()
{
lcd_init();
Init_BMP085();
Init_PM2_5();

    while(1)
    {
    bmp085Convert();
    RH();
    
    lcd_pos(0,0);
    display_string("pm2.5:");
    if(read_pm()>5)
    display_num(read_pm());
    else
    display_num(5);
    display_string("ug/m3");
    display_string("    ");

    lcd_pos(1,0);
    display_string("T:");
    display_num(temperature/10);
    display_string(".");
    display_num(temperature%10);
    display_string("'C");
    display_string("  ");
     
    display_string("H:");
    display_num(RHdataH);
    display_string("%");

    lcd_pos(2,0);
    display_string("pre:");
    display_num(pressure/1000);
display_string(".");
    display_num(pressure%1000);
    display_string("kpa");

    lcd_pos(3,0);
    display_string("smo:");
    if(read_pm()>200)
    {
            display_string("High");        
            waring=0;
    }
    else
    {
            display_string("low");
            display_string(" ");
            waring=1;
    }
    display_string("Al:");        
    display_num(Altitude);
    display_string("m");
    display_string(" ");
    delay_ms(200);
    }

}

PM2.5
#include<reg52.h>
#define uint unsigned int
#define uchar unsigned char
#define K_PM 820
void senddata(uchar dat);
uint read_pm();
uchar cal[7]={0};
// cal[0]:起始位 0xAA
// cal[1]:Vout(H)
// cal[2]:Vout(L)
// cal[3]:Vref(H)
// cal[4]:Vref(L)
// cal[5]:校验位
// cal[6]:结束位0xFF

uchar buf;
uchar sum;
int i=0;
float Vo;
void Init_PM2_5()
{
SCON=0x50;
PCON=0x00;

    TMOD=0x20;
    EA=1;
    ES=1;
    TL1=0xF4;
    TH1=0xF4;
    TR1=1;        

}

uint read_pm()
{
return (uint)(K_PM*Vo);
}

void serial() interrupt 4
{
ES=0;
RI=0;
buf=SBUF;
senddata(buf);
ES=1;
}

void senddata(uchar dat)
{

if(dat0xAA)
{
i=0;
cal[i]=dat;
}
else
{
i=i+1;
cal[i]=dat;
if(i
6)
{
sum=cal[1]+cal[2]+cal[3]+cal[4];
if(sum==cal[5]&&cal[6]==0xFF)
{

// for(i=0;i<=6;i++)
// {
// SBUF=cal[i];
// while(!TI);
// TI=0;
// }
Vo=(cal[1]256+cal[2])/1024.05;
// SBUF=cal[1];
// while(!TI);
// TI=0;
//
//
// SBUF=cal[2];
// while(!TI);
// TI=0;

                    }
            }
    }

}

鉴于篇幅有限,只能写这么多了。
最后,如果有什么意见或者建议欢迎您留言给我,让我们共同学习一起进步,
如果需要完整代码或设计文件,请私信我或者直接给简介里的邮箱发邮件,看到后会第一时间回复。
谢谢!

发布了97 篇原创文章 · 获赞 200 · 访问量 8万+

猜你喜欢

转载自blog.csdn.net/weixin_44212493/article/details/105564472