一、模块来源
二、规格参数
工作电压:5-7V
消耗电流:最大20mA
最小粒子检出值:0.8微米
灵敏度:0.5V(0.1mg/m3)
清洁空气中电压:0.9V (典型)
重量:15g
尺寸大小:46x30x17.6mm
以上信息见厂家资料文件
三、移植过程
我们的目标是将例程移植至MSPM0G3507开发板上【能够判断粉尘浓度的功能】。首先要获取资料,查看数据手册应如何实现读取数据,再移植至我们的工程。
1、查看资料
GP2Y1014AU粉尘传感器在其中间有一个洞,空气可以自由流通,传感器内部邻角位置安装有红外发光二极管和光电晶体管,红外发光二极管定向发送红外光,当空气中有颗粒物阻碍红外线时,红外线发生漫反射,光电晶体管接收到红外光线,信号输出引脚电压会随之发生变化。该电压值在一定范围内与灰尘浓度成线性关系,因此在使用过程中,需要使用 ADC 采集该电压信号,并通过该电压值计算出空气中的灰尘浓度。
2、引脚选择
当前只有AO引脚需要使用到ADC接口,所以DO引脚可以使用开发板上其他的GPIO。这里选择使用PA27的附加ADC功能。
蓝线 | 3V3 |
绿线 | GND |
LED-白线 | PA26 |
黄线 | GND |
VO-黑线 | PA27 |
红线 | 5V0 |
接下来我们配置 SYSCONFIG
- 双击 empty.syscfg 文件,打开它。
- 点击 ADD 添加GPIO配置
- 配置GPIO
- 添加ADC
- 配置ADC
Ctrl + S
保存配置文件然后点击编译(可能会报错,我们不用管!)
- 然后我们所有设定的引脚和功能就会在 ti_msp_dl_config.h 中定义。因为这个文件我们包含进了 board.h 所以我们只需要引用 board.h 即可。【这里的 board.h 就充当了芯片头文件的作用】
3、代码编写
我们在 BSP文件夹
中新建inc和src文件夹,新建两个文件 bsp_dust.c
和 bsp_dust.h
,并且将头文件路径添加到编译器中。
在文件bsp_dust.c中,编写如下代码。
c
/*
* 立创开发板软硬件资料与相关扩展板软硬件资料官网全部开源
* 开发板官网:www.lckfb.com
* 文档网站:wiki.lckfb.com
* 技术支持常驻论坛,任何技术问题欢迎随时交流学习
* 嘉立创社区问答:https://www.jlc-bbs.com/lckfb
* 关注bilibili账号:【立创开发板】,掌握我们的最新动态!
* 不靠卖板赚钱,以培养中国工程师为己任
*/
#include "bsp_dust.h"
#include "stdio.h"
/**********************************************************
* 函 数 名 称:ADC_GET
* 函 数 功 能:读取一次ADC数据
* 传 入 参 数:无
* 函 数 返 回:无
* 作 者:LCKFB
* 备 注:LP
**********************************************************/
static uint32_t ADC_GET(void)
{
unsigned int gAdcResult = 0;
//使能ADC转换
DL_ADC12_enableConversions(ADC12_0_INST);
//软件触发ADC开始转换
DL_ADC12_startConversion(ADC12_0_INST);
//如果当前状态 不是 空闲状态
while (DL_ADC12_getStatus(ADC12_0_INST) != DL_ADC12_STATUS_CONVERSION_IDLE );
//清除触发转换状态
DL_ADC12_stopConversion(ADC12_0_INST);
//失能ADC转换
DL_ADC12_disableConversions(ADC12_0_INST);
//获取数据
gAdcResult = DL_ADC12_getMemResult(ADC12_0_INST, ADC12_0_ADCMEM_CH0);
return gAdcResult;
}
/******************************************************************
* 函 数 名 称:Get_ADC_Value
* 函 数 说 明:对ADC值进行平均值计算后输出
* 函 数 形 参:num采集次数
* 函 数 返 回:对应扫描的ADC值
* 作 者:LCKFB
* 备 注:无
******************************************************************/
unsigned int Get_ADC_Value(void)
{
uint32_t Data = 0;
for(int i = 0; i < SAMPLES; i++)
{
Data += ADC_GET();
delay_ms(2);
}
Data = Data / SAMPLES;
return Data;
}
int Filter(int m)
{
static int flag_first = 0, _buff[10], sum;
const int _buff_max = 10;
int i;
if (flag_first == 0)
{
flag_first = 1;
for (i = 0, sum = 0; i < _buff_max; i++)
{
_buff[i] = m;
sum += _buff[i];
}
return m;
}
else
{
sum -= _buff[0];
for (i = 0; i < (_buff_max - 1); i++)
{
_buff[i] = _buff[i + 1];
}
_buff[9] = m;
sum += _buff[9];
i = sum / 10.0;
return i;
}
}
/******************************************************************
* 函 数 名 称:Read_dust_concentration
* 函 数 说 明:读取粉尘浓度
* 函 数 形 参:无
* 函 数 返 回:粉尘浓度
* 作 者:LCKFB
* 备 注:无
******************************************************************/
float Read_dust_concentration(void)
{
unsigned int value=0;
float f_value = 0;
DL_GPIO_clearPins(GPIO_PORT,GPIO_LED1_PIN);
delay_us(280);
value = Get_ADC_Value();
delay_us(40);
DL_GPIO_setPins(GPIO_PORT,GPIO_LED1_PIN);
delay_us(9680);
value = Filter(value);
f_value = 0.17*value-0.1; //转换公式
return f_value;
}
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
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
在文件bsp_dust.h中,编写如下代码。
c
/*
* 立创开发板软硬件资料与相关扩展板软硬件资料官网全部开源
* 开发板官网:www.lckfb.com
* 文档网站:wiki.lckfb.com
* 技术支持常驻论坛,任何技术问题欢迎随时交流学习
* 嘉立创社区问答:https://www.jlc-bbs.com/lckfb
* 关注bilibili账号:【立创开发板】,掌握我们的最新动态!
* 不靠卖板赚钱,以培养中国工程师为己任
*/
#ifndef __BSP_DUST_H__
#define __BSP_DUST_H__
#include "board.h"
//采样次数
#define SAMPLES 30
float Read_dust_concentration(void);
#endif
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
四、移植验证
在empty.c中输入代码如下:
c
#include "ti_msp_dl_config.h"
#include "board.h"
#include "bsp_dust.h"
int main(void)
{
SYSCFG_DL_init();
lc_printf("\nGP2Y1014AU Demo Start.....\r\n");
while (1)
{
lc_printf("dust concentration = [ %.2f ]\r\n",Read_dust_concentration());
delay_ms(500);
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
【代码下载】
- 跳转到
下载中心
去下载CCS模块移植代码:【点击跳转🚀】