Arduino连接夏普GP2Y1010AU0F空气质量传感器检测PM2.5

作者:楚风狂 | 更新时间:2016-06-01 | 浏览量:7164


夏普GP2Y1010AU0F图片



GP2Y1010AU0F引脚图

序号名称作用
1V-LEDLED供电
2LED-GNDLED GND
3LEDLED控制
4S-GND传感器GND
5VO检测结果电压模拟量输出
6VCC供电


GP2Y1010AU0F接线图



接线图.jpg



程序代码


/*
   Arduino连接夏普GP2Y1010AU0F空气质量传感器检测PM2.5
   些程序也适用于用 Arduino IDE 开发 ESP8266
*/

/* 定义引脚 */

 #define PIN_DATA_OUT A0 //连接空气质量传感器模拟量输出的IO口


 #define PIN_LED_VCC 2 //空气质量传感器中为内部Led供电的引脚

 /* 定义时间 */
 const int DELAY_BEFORE_SAMPLING = 280; //采样前等待时间
 const int DELAY_AFTER_SAMPLING = 40; //采样后等待时间
 const int DELAY_LED_OFF = 9680; //间隔时间

/**
   读取输出电压
*/
double getOutputV() {
  digitalWrite(PIN_LED_VCC, LOW);
  delayMicroseconds(DELAY_BEFORE_SAMPLING);
  double analogOutput = analogRead(PIN_DATA_OUT);
  delayMicroseconds(DELAY_AFTER_SAMPLING);
  digitalWrite(PIN_LED_VCC, HIGH);
  delayMicroseconds(DELAY_LED_OFF);
  //Arduino模拟量读取值的范围为0~1023,以下换算为0~5v
  double outputV = analogOutput / 1024 * 5;
  return outputV;
}

/**
   根据输出电压计算灰尘密度
*/
double getDustDensity(double outputV) {
  //输出电压和灰尘密度换算公式: ug/m3 = (V - 0.9) / 5 * 1000
  double ugm3 = (outputV - 0.9) / 5 * 1000;
  //去除检测不到的范围
  if (ugm3 < 0) {
    ugm3 = 0;
  }
  return ugm3;
}

/**
   根据灰尘密度计算AQI
   环境空气质量指数(AQI)技术规定(试行)](http://kjs.mep.gov.cn/hjbhbz/bzwb/dqhjbh/jcgfffbz/201203/t20120302_224166.htm
*/
double getAQI(double ugm3) {
  double aqiL = 0;
  double aqiH = 0;
  double bpL = 0;
  double bpH = 0;
  double aqi = 0;
  //根据pm2.5和aqi对应关系分别计算aqi
  if (ugm3 >= 0 && ugm3 <= 35) {
    aqiL = 0;
    aqiH = 50;
    bpL = 0;
    bpH = 35;
  } else if (ugm3 > 35 && ugm3 <= 75) {
    aqiL = 50;
    aqiH = 100;
    bpL = 35;
    bpH = 75;
  } else if (ugm3 > 75 && ugm3 <= 115) {
    aqiL = 100;
    aqiH = 150;
    bpL = 75;
    bpH = 115;
  } else if (ugm3 > 115 && ugm3 <= 150) {
    aqiL = 150;
    aqiH = 200;
    bpL = 115;
    bpH = 150;
  } else if (ugm3 > 150 && ugm3 <= 250) {
    aqiL = 200;
    aqiH = 300;
    bpL = 150;
    bpH = 250;
  } else if (ugm3 > 250 && ugm3 <= 350) {
    aqiL = 300;
    aqiH = 400;
    bpL = 250;
    bpH = 350;
  } else if (ugm3 > 350) {
    aqiL = 400;
    aqiH = 500;
    bpL = 350;
    bpH = 500;
  }
  //公式aqi = (aqiH - aqiL) / (bpH - bpL) * (desity - bpL) + aqiL;
  aqi = (aqiH - aqiL) / (bpH - bpL) * (ugm3 - bpL) + aqiL;
  return aqi;
}

/**
   根据aqi获取级别描述
*/
String getGradeInfo(double aqi) {
  String gradeInfo;
  if (aqi >= 0 && aqi <= 50) {
    gradeInfo = String("Perfect");
  } else if (aqi > 50 && aqi <= 100) {
    gradeInfo = String("Good");
  } else if (aqi > 100 && aqi <= 150) {
    gradeInfo = String("Mild polluted");
  } else if (aqi > 150 && aqi <= 200) {
    gradeInfo = String("Medium polluted");
  } else if (aqi > 200 && aqi <= 300) {
    gradeInfo = String("Heavily polluted");
  } else if (aqi > 300 && aqi <= 500) {
    gradeInfo = String("Severely polluted");
  } else {
    gradeInfo = String("Broken roof!!!");
  }
  return gradeInfo;
}

void setup() {
  Serial.begin(115200);
  pinMode(PIN_DATA_OUT, INPUT); //定义为输入(ADC读取模拟量)
  pinMode(PIN_LED_VCC, OUTPUT); //定义为输出
}

void loop() {
  double outputV = getOutputV(); //采样获取输出电压
  double ugm3 = getDustDensity(outputV); //计算灰尘浓度
  double aqi = getAQI(ugm3); //计算aqi
  String gradeInfo = getGradeInfo(aqi); //计算级别

  //打印到串口
  Serial.println(String("outputV=") + outputV + "\tug/m3=" + ugm3 + "\tAQI=" + aqi + "\tgradeInfo=" + gradeInfo);

  //间隔1秒执行下次检测
  delay(1000);
}


输出结果


outputV=1.05	ug/m3=29.96	AQI=42.80	gradeInfo=Perfect
outputV=1.36	ug/m3=92.46	AQI=121.83	gradeInfo=Mild polluted
outputV=1.29	ug/m3=77.81	AQI=103.52	gradeInfo=Mild polluted
outputV=1.16	ug/m3=51.45	AQI=70.56	gradeInfo=Good
outputV=1.12	ug/m3=43.63	AQI=60.79	gradeInfo=Good
outputV=1.26	ug/m3=72.93	AQI=97.41	gradeInfo=Good


本文大多摘自http://blog.fantasymaker.cn/2016/01/10/pm25-aqi-detector-based-on-nodemcu/

更多信息请自行查看


关于联网请参考网站文档,这里不在重复。


关于数据上传这里给大家分享一个函数格式供大家参考


void update1(int did, int inputid1, int inputid2,int inputid3,float value1 ,float value2,float value3) // 定义一次传递3个参数的函数

{

String str1="{\"M\":\"update\",\"ID\":\"";

str1+=did;

str1+="\",\"V\":{\"";

str1+=inputid1;

str1+="\":\"";

str1+=value1;

str1+="\",\"" ;

str1+=inputid2;

str1+="\":\"";

str1+=value2;

str1+="\",\"" ;

str1+=inputid3;

str1+="\":\"";

str1+=value3;

str1+="\"" ;

str1+="}}\n";

 client.print(str1);  

//下面是串口打印 传递到服务器的信息,以便调试

  Serial.print("update:");   

  Serial.print(inputid1);   

  Serial.print("->");   

  Serial.println(value1);   

   Serial.print("update:");   

  Serial.print(inputid2);   

  Serial.print("->");   

  Serial.println(value2); 

   Serial.print("update:");   

  Serial.print(inputid3);   

  Serial.print("->");   

  Serial.println(value3); 

}


此函数出自网友 疯狂的小车 借鉴网友 在路上 的劳动成果并发表的 ”用ESP8266传递BMP180的温度的气压到贝壳“一文


*所有图片和程序均来源于互连网,本人只是重新整理发布。如有侵权请及时联系网站管理员或作者。谢谢







评论:共5条

z494627 评论于:2016-06-01 16:17:26
不错!谢谢分享!
楚风狂 回复于:2016-06-01 16:34:49
回复 @z494627:谢谢!还要多向你学习
贝壳物联 回复于:2016-06-02 18:45:21
回复 @楚风狂:不错的教程。
activemee 评论于:2016-12-29 23:47:42
我最近在实验这个传感器, 按照你的接线,AQI基本都是0,后来我把C1的位置挪到R1后面, 这样能测出数值,但是感觉还是很不准。
出门看天下 评论于:2017-03-21 18:34:36
感谢分享
返回顶部