본문 바로가기

개발자/Raspberry Pi3

미세먼지 측정 센서 Nova PM sensor SDS011 공기 품질 센서 사용법

반응형




미세먼지 측정 센서 Nova  PM sensor SDS011 공기 품질 센서


서울 디지털 재단에서 실행하는 메이커 프로젝트 진행할때 센서 질문해서 알아낸 것 정리.


[서울디지털재단] 도시 미세먼지 측정 공유를 위한 ‘메이커 혁신가’를 모집합니다 

- 모집인원 : 시민 60명! 

- 교육장소 : 개포디지털혁신파크 상상공작소

- 교육기간 : 클래스별 각 6회과정, 수업내용 동일하게 진행

ㆍA class 매주 금요일 (10.27 개강, 19:00~22:00)

ㆍB class 매주 토요일 (10.28 개강, 14:00~17:00)


개요


다 SDS011 사용하여 원리 레이저 산란 얻을 수 있습니다, 입자 농도 0.3 사이의 10μm 공기. 그것은 디지털 출력 내장 팬 안정적인.


특성


1. 정확한 신뢰할: 레이저 감지, 안정적인, 좋은 일관성;

2. 빠른 응답: 응답 시간 10 초 변정경;

3. 쉽게 통합: UART 출력 (또는 IO 출력 사용자), 팬 내장;

4. 높은 해상도: 해상도 0.3 μg/m3이다.


범위


감지기 PM2.5 의;.


작동 원리


사용하여 레이저 산란 원리:

빛 산란 유도 수 때 입자를 통해 검출 영역. 흩어져 빛 변신 전기 신호를 이러한 신호를 증폭 것입니다 처리됩니다. 번호 직경 입자 분석 의해 얻을 수있다 때문에 신호 파형 특정 관계를 입자 직경.


기술적 인 매개 변수


약 수명


수명 키 매개 변수 레이저 먼지 센서. 레이저 다이오드 센서 높은 품질과 서비스 수명을 8000 시간. 당신이 실시간 데이터 (감지기) 당신은 기본 구성 동시에 측정 주파수 1 시간. On 행사는 실시간 수요가 높은 (필터, 공기 품질 모니터링, 등) 당신은 불연속 작동 방법 수명을 연장. 들어용 당신은 시작 센서 30 초 당. 다른 요구, 문의드립니다, 우리는 제조 업체 및 개발자가 봉사.


제품 사양




제품 크기

* W * H = 71*70*23 미리메터


인터페이스 사양




PS:각 핀 2.54 사이의 거리를 미리메터.


다 UART 통신 프로토콜

비트 속도 : 9600

데이터: 8

패리티 비트:

정지 비트: 1

데이터 패킷 주파수: 1 헤르쯔




체크 합: 합 = DATA1 + DATA2 +... + DATA6.

PM2.5 값: PM2.5 (μg/m3) = ((PM2.5 높은 바이트 * 256) + PM2.5 낮은 바이트)/10

PM10 값: PM10 (μg/m3) = ((PM10 높은 바이트 * 256) + PM10 낮은 바이트)/10


PWM 출력 설명











자료 출처는 알리익스프레스 https://ko.aliexpress.com/ 에서 검색 - https://ko.aliexpress.com/store/product/nova-PM-sensor-SDS011-High-precision-laser-pm2-5-air-quality-detection-sensor-module-Super-dust/421570_32317805049.html


사용법은 다음 출처를 참고한다.


아두이노 라이브러리 Arduino library for SDS011 dust sensor  https://github.com/ricki-z/SDS011


사용법은 아래와 같다.


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
SDS011
 
Arduino library for dust Sensor SDS011 (Nova Fitness Co.,Ltd)
This library uses SoftSerial to connect to the SDS011.
 
Usage
 
Define SDS object:
 
SDS011(uint8_t pin_rx, uint8_t pin_tx);
i.e. SDS011 mySDS(pinRX,pinTX);
 
Start object:
void begin(void);
i.e. mySDS.begin();
 
Read values:
int read(float *p25, float *p10);
i.e. error = mySDS(pm25,pm10);
 
Reads the PM2.5 and PM10 values, return code is 0if new values were read, and 1 if there were no new values.
cs


다른 센서 라이브러리 참고 : http://www.arduinolibraries.info/libraries/sds011-sensor-library


라이브러리를 카피한 후 아래의 소스코드를 참고한다. 출처 : http://www.instructables.com/id/Make-one-PM25-monitor-with-Arduino-UNO/



1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
const unsigned char dofly_DuanMa[10]={
  0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};
//位码
unsigned char const dofly_WeiMa[]={
  0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};
long previousMillis = 0
const int analogInPin = A0;
int latch = 8;
int srclk = 9;
int ser = 10;
 
unsigned char displayTemp[8];
unsigned int Pm25 = 0;
unsigned int Pm10 = 0;
 
//把数据用串行转并行输出到595
void SendByte(unsigned char dat)
{    
  static unsigned char i; 
        
   for(i=0;i<8;i++)
    {
     digitalWrite(srclk,0);
     digitalWrite(ser,bitRead(dat,7-i));//这里也可以用arduino自带的函数操作,主用于595类型的输出,自查帮助文件。
     digitalWrite(srclk,1);
     }
}
//德飞莱的模块是2个595级联,段码和位码都是用折3根线控制,所以需要连续2个字节
void Send2Byte(unsigned char dat1,unsigned char dat2)
{    
   SendByte(dat1);
   SendByte(dat2);      
}
//锁存输出
void Out595(void)
{
        digitalWrite(latch,1);
        digitalWrite(latch,0);
}
void DisPm25data(unsigned int value)
{
  int i;
  if(value/1000)
  {
    displayTemp[0]=dofly_DuanMa[value/1000%10];//这里最后是加小数点,共阳和共阴是相反的。
    displayTemp[1]=dofly_DuanMa[value/100%10];
    displayTemp[2]=dofly_DuanMa[value/10%10];
  }
  else
  {
    if((value/100!= 0)
    displayTemp[0]=dofly_DuanMa[value/100%10];//这里最后是加小数点,共阳和共阴是相反的。
    displayTemp[1]=dofly_DuanMa[value/10%10]|0x80;
    displayTemp[2]=dofly_DuanMa[value%10];    
  }
  for(i=0;i<8;i++)
  {
    Send2Byte(dofly_WeiMa[i],displayTemp[i]);
    Out595();
  }
}
void DisPm10data(unsigned int value)
{
  int i;
  if(value/1000)
  {
    displayTemp[4]=dofly_DuanMa[value/1000%10];//这里最后是加小数点,共阳和共阴是相反的。
    displayTemp[5]=dofly_DuanMa[value/100%10];
    displayTemp[6]=dofly_DuanMa[value/10%10];
  }
  else
  {
    if((value/100!= 0)
    displayTemp[4]=dofly_DuanMa[value/100%10];//这里最后是加小数点,共阳和共阴是相反的。
    displayTemp[5]=dofly_DuanMa[value/10%10]|0x80;
    displayTemp[6]=dofly_DuanMa[value%10];    
  }
  for(i=0;i<8;i++)
  {
    Send2Byte(dofly_WeiMa[i],displayTemp[i]);
    Out595();
  }
}
void Display()
{
  int i;
  for(i=0;i<8;i++)
     displayTemp[i]=0
     DisPm25data(Pm25);
     DisPm10data(Pm10);
}
void ProcessSerialData()
{
  uint8_t mData = 0;
  uint8_t i = 0;
  uint8_t mPkt[10= {0};
  uint8_t mCheck = 0;
 while (Serial.available() > 0
  {  
    // from www.inovafitness.com
    // packet format: AA C0 PM25_Low PM25_High PM10_Low PM10_High 0 0 CRC AB
     mData = Serial.read();     delay(2);//wait until packet is received
    if(mData == 0xAA)//head1 ok
     {
        mPkt[0=  mData;
        mData = Serial.read();
        if(mData == 0xc0)//head2 ok
        {
          mPkt[1=  mData;
          mCheck = 0;
          for(i=0;i < 6;i++)//data recv and crc calc
          {
             mPkt[i+2= Serial.read();
             delay(2);
             mCheck += mPkt[i+2];
          }
          mPkt[8= Serial.read();
          delay(1);
      mPkt[9= Serial.read();
          if(mCheck == mPkt[8])//crc ok
          {
            Serial.flush();
            //Serial.write(mPkt,10);
 
            Pm25 = (uint16_t)mPkt[2| (uint16_t)(mPkt[3]<<8);
            Pm10 = (uint16_t)mPkt[4| (uint16_t)(mPkt[5]<<8);
            if(Pm25 > 9999)
             Pm25 = 9999;
            if(Pm10 > 9999)
             Pm10 = 9999;            
            //get one good packet
             return;
          }
        }      
     }
   } 
}
 
void setup() {
  // 循环设置,把对应的端口都设置成输出
  // 这里使用德飞莱串口数码管模块,595芯片控制
    pinMode(latch, OUTPUT); 
    pinMode(ser, OUTPUT); 
    pinMode(srclk, OUTPUT);
    Serial.begin(9600,SERIAL_8N1);
    Pm25=0;
    Pm10=0;
    Display();
}
// 主循环
void loop() {
  ProcessSerialData();
  Display();
}
cs





반응형

캐어랩 고객 지원

취업, 창업의 막막함, 외주 관리, 제품 부재!

당신의 고민은 무엇입니까? 현실과 동떨어진 교육, 실패만 반복하는 외주 계약, 아이디어는 있지만 구현할 기술이 없는 막막함.

우리는 알고 있습니다. 문제의 원인은 '명확한 학습, 실전 경험과 신뢰할 수 있는 기술력의 부재'에서 시작됩니다.

이제 고민을 멈추고, 캐어랩을 만나세요!

코딩(펌웨어), 전자부품과 디지털 회로설계, PCB 설계 제작, 고객(시장/수출) 발굴과 마케팅 전략으로 당신을 지원합니다.

제품 설계의 고수는 성공이 만든 게 아니라 실패가 만듭니다. 아이디어를 양산 가능한 제품으로!

귀사의 제품을 만드세요. 교육과 개발 실적으로 신뢰할 수 있는 파트너를 확보하세요.

지난 30년 여정, 캐어랩이 얻은 모든 것을 함께 나누고 싶습니다.

카카오 채널 추가하기

카톡 채팅방에서 무엇이든 물어보세요

당신의 성공을 위해 캐어랩과 함께 하세요.

캐어랩 온라인 채널 바로가기

캐어랩