土壤湿度传感器详解(STM32)

目录

一、介绍

二、传感器原理

1.原理图

2.引脚描述

三、程序设计

main.c文件

TS.h文件

TS.c文件

四、实验效果 

五、资料获取

项目分享


一、介绍

        传感器适用于土壤的湿度检测,模块中蓝色的电位器是用于土壤湿度的阈值调节,数字量输出DO可以与单片机直接相连,通过单片机来检测高低电平,由此来检测土壤湿度。模拟量输出AO可以和AD模块相连,通过AD转换,可以获得土壤湿度更精确的数值;

以下是土壤湿度传感器的参数:

工作电压

3.3~5V

阈值调节

电位器调节

尺寸

14mm×32mm

输出方式

模拟量(AO)与数字量(DO

比较器

LM393

哔哩哔哩视频链接:

土壤湿度传感器详解(STM32)

(资料分享见文末) 

二、传感器原理

1.原理图

2.引脚描述

引脚名称

描述

VCC

供给电压3~5V

GND

地线

DO

开关信号

AO

模拟信号

三、程序设计

1.使用STM32F103C8T6读取土壤湿度传感器采集的数据,通过串口发送至电脑

2.将读取得到的数据同时在OLED上显示

土壤湿度(AO

PA0

OLED_SCL

PB11

OLED_SDA

PB10

串口

串口1

main.c文件

#include "stm32f10x.h"
#include "led.h"
#include "usart.h"
#include "delay.h"
#include "oled.h"
#include "TS.h"
#include "adcx.h"

/*****************辰哥单片机设计******************
											STM32
 * 项目			:	土壤湿度传感器实验                     
 * 版本			: V1.0
 * 日期			: 2024.8.12
 * MCU			:	STM32F103C8T6
 * 接口			:	参看TS.h							
 * BILIBILI	:	辰哥单片机设计
 * CSDN			:	辰哥单片机设计
 * 作者			:	辰哥 

**********************BEGIN***********************/

u16 value;

int main(void)
{ 
	
  SystemInit();//配置系统时钟为72M	
	delay_init(72);
	LED_Init();
	LED_On();
	TS_Init();
	USART1_Config();//串口初始化
	
	OLED_Init();
	printf("Start \n");
	delay_ms(1000);
	
	OLED_Clear();
	//显示“土壤湿度:”
	OLED_ShowChinese(0,0,8,16,1);
	OLED_ShowChinese(16,0,9,16,1);
	OLED_ShowChinese(32,0,10,16,1);
	OLED_ShowChinese(48,0,11,16,1);
	OLED_ShowChar(64,0,':',16,1);
	

  while (1)
  {
		LED_Toggle();
		value = TS_GetData();
		printf("土壤湿度: %d\r\n",value);
		OLED_ShowNum(80,0,value,2,16,1);
		
		delay_ms(200);
  }
}

TS.h文件

#ifndef __TS_H
#define	__TS_H
#include "stm32f10x.h"
#include "adcx.h"
#include "delay.h"
#include "math.h"

/*****************辰哥单片机设计******************
											STM32
 * 文件			:	土壤湿度传感器h文件                   
 * 版本			: V1.0
 * 日期			: 2024.8.12
 * MCU			:	STM32F103C8T6
 * 接口			:	见代码							
 * BILIBILI	:	辰哥单片机设计
 * CSDN			:	辰哥单片机设计
 * 作者			:	辰哥

**********************BEGIN***********************/

#define TS_READ_TIMES	10  //土壤湿度ADC循环读取次数


/***************根据自己需求更改****************/
// TS GPIO宏定义

#define		TS_GPIO_CLK								RCC_APB2Periph_GPIOA
#define 	TS_GPIO_PORT							GPIOA
#define 	TS_GPIO_PIN								GPIO_Pin_0
#define   ADC_CHANNEL               ADC_Channel_0	// ADC 通道宏定义

/*********************END**********************/


void TS_Init(void);
uint16_t TS_GetData(void);

#endif /* __ADC_H */

TS.c文件

#include "TS.h"


/*****************辰哥单片机设计******************
											STM32
 * 文件			:	土壤湿度传感器c文件                   
 * 版本			: V1.0
 * 日期			: 2024.8.12
 * MCU			:	STM32F103C8T6
 * 接口			:	见代码							
 * BILIBILI	:	辰哥单片机设计
 * CSDN			:	辰哥单片机设计
 * 作者			:	辰哥

**********************BEGIN***********************/

void TS_Init(void)
{
		GPIO_InitTypeDef GPIO_InitStructure;
		
		RCC_APB2PeriphClockCmd (TS_GPIO_CLK, ENABLE );	// 打开 ADC IO端口时钟
		GPIO_InitStructure.GPIO_Pin = TS_GPIO_PIN;					// 配置 ADC IO 引脚模式
		GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;		// 设置为模拟输入
		
		GPIO_Init(TS_GPIO_PORT, &GPIO_InitStructure);				// 初始化 ADC IO

		ADCx_Init();
}

uint16_t TS_ADC_Read(void)
{
	//设置指定ADC的规则组通道,采样时间
	return ADC_GetValue(ADC_CHANNEL, ADC_SampleTime_55Cycles5);
}

uint16_t TS_GetData(void)
{
	uint32_t  tempData = 0;
	for (uint8_t i = 0; i < TS_READ_TIMES; i++)
	{
		tempData += TS_ADC_Read();
		delay_ms(5);
	}

	tempData /= TS_READ_TIMES;
	return 100 - (float)tempData/40.96;
}



四、实验效果 

五、资料获取

项目分享

### 土壤湿度检测传感器的计算公式与数据处理方法 土壤湿度检测传感器的核心在于通过物理参数的变化来反映土壤中的含水量。以下是关于如何基于引用内容以及专业知识进行数据处理和公式的说明。 #### 1. 数据采集原理 土壤湿度传感器通常通过测量电阻或电容变化来间接表示土壤湿度水平[^1]。由于不同类型的土壤具有不同的导电性和介电常数,因此原始读数可能无法直接对应于实际的土壤湿度值。为了提高准确性,需要对传感器进行校准并采用适当的数据处理算法。 #### 2. 温度补偿公式 对于某些高级传感器(如DHT系列),提供了内置温度补偿功能以减少环境因素的影响。具体而言,在一定范围内调整湿度读数时会考虑当前温度条件下的偏差修正因子: ```plaintext Hc = Hm ± (T × Kt) ``` 其中: - `Hc` 表示经过温度补偿后的相对湿度; - `Hm` 是未加任何矫正前由设备测得的实际数值; - `T` 则代表实时监测到的大气温度; - 而系数 `Kt` 取决于制造商给出的技术规格书或者实验测定结果[^2]。 #### 3. 数字化转换函数 当使用微控制器(例如Arduino)连接模拟信号输入端口时,需调用类似如下定义的功能实现模数变换过程: ```c++ uint16_t Get_Adc(uint8_t ch){ ADMUX=(ADMUX & 0xF0)|ch; ADCSRA|=(1<<ADSC); while(!(ADCSRA&(1<<ADIF))); ADCSRA|=(1<<ADIF); return ADCW; } ``` 此代码片段展示了如何配置AVR架构内部ADC模块完成一次通道切换操作,并返回最终量化之后的结果作为后续分析依据[^3]。 #### 4. 单位换算关系 如果目标是以摄氏度以外的形式展示,则可运用国际通用标准Fahrenheit scale来进行单位互转运算: ```python def celsius_to_fahrenheit(c): f = c * 9 / 5 + 32 return round(f, 2) temperature_c = 25 # Example value in Celsius degrees print("Temperature:", temperature_c,"°C =", celsius_to_fahrenheit(temperature_c),"°F") ``` 上述Python脚本演示了一个简单的摄氏至华氏转变逻辑,适用于那些希望同时获得两种表述形式的应用场景下。 --- ### 数据处理建议 考虑到自然环境中存在诸多干扰源可能导致误差累积现象发生,故推荐采取以下几种策略优化整体性能表现: - **多点平均法**: 对同一位置重复采样多次后再求取均值得到更加稳定可靠的估计值。 - **滑动窗口滤波器**: 应用低通性质的时间序列模型平抑短期波动效应从而提升长期趋势预测能力。 - **非线性映射拟合曲线构建**: 鉴于理论预期同实测反馈之间可能存在复杂关联结构特点,尝试借助多项式回归或者其他机器学习技术建立精确匹配关系表达式供进一步深入探讨研究之用。 ---
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值