Arduino + ESP32-C3 + TFT(1.8‘ ST7735S)基础平台(实验九)ADS1115

更多内容,请访问我的网站:https://jiangge12.github.io/

ADS1115 是一个廉价16位ADC,也很容易买到模块,这样不用打板即可开始实验。

更有意思的是 ADS1115 4个输入端可以组成两个差分输入,这样就可以直接采集交流信号了。

在线安装 Adafruit_ADS1X15.h 即可使用,不过默认128 Sa/s 对付50Hz交流电有些不够,仔细看pdf 可以看到 ADS1115 最大支持 860 Sa/s.

例程里并没有直接改 采样率 的语句, 于是再仔细看 Adafruit_ADS1X15.h 有提到 采样率,具体更改在 Adafruit_ADS1X15.cpp 里, 可以改为 860,就是下面这里:

Adafruit_ADS1115::Adafruit_ADS1115() {
  m_bitShift = 0;
  m_gain = GAIN_TWOTHIRDS; /* +/- 6.144V range (limited to VDD +0.3V max!) */
  m_dataRate = RATE_ADS1115_860SPS; 
}

虽然改为了860Sa/s,不知道为什么实测只有420 Sa/s, 但总也比默认128 Sa/s 好多了。

下面例程是1000次采样的时间测试:

#include "Adafruit_ADS1X15.h"
Adafruit_ADS1115 ads;  /* Use this for the 16-bit version */
int results;
float multiplier = 0.1875F; /* ADS1115  @ +/- 6.144V gain (16-bit results) */
long ADC_start;
long ADC_stop;
long ADC_elapse;  

void setup(void)
{
  Serial.begin(115200);
  Serial.println("Getting differential reading from AIN0 (P) and AIN1 (N)");
  Serial.println("ADC Range: +/- 6.144V (1 bit = 3mV/ADS1015, 0.1875mV/ADS1115)");

  if (!ads.begin( 0x48 )) { Serial.println("Failed to initialize ADS."); while (1); }

  ADC_start  = millis();
  for(int i=0;i<1000;i++) { results = ads.readADC_Differential_0_1(); Serial.println(results*multiplier); }
  ADC_stop   = millis();
  ADC_elapse = ADC_stop - ADC_start;
  Serial.println(ADC_elapse);                  // 2438 ms  410 Sa/s

  ADC_start  = millis();
  for(int i=0;i<1000;i++) {results = ads.readADC_Differential_0_1();}
  ADC_stop   = millis();
  ADC_elapse = ADC_stop - ADC_start;
  Serial.println(ADC_elapse);                  // 2348 ms  425 Sa/s
}

void loop(void)
{    
}

.以下例程可以直接由“串口绘图器”持续查看采集到的波形:

#include "Adafruit_ADS1X15.h"
Adafruit_ADS1115 ads;  /* Use this for the 16-bit version */
int results;
float multiplier = 0.1875F; /* ADS1115  @ +/- 6.144V gain (16-bit results) */
  
void setup(void)
{
  Serial.begin(115200);
  Serial.println("Getting differential reading from AIN0 (P) and AIN1 (N)");
  Serial.println("ADC Range: +/- 6.144V (1 bit = 3mV/ADS1015, 0.1875mV/ADS1115)");

  if (!ads.begin( 0x48 )) { Serial.println("Failed to initialize ADS."); while (1); }
}

void loop(void)
{
  results = ads.readADC_Differential_0_1();
  Serial.println(results*multiplier); 
}

Arduino ESP32-C3板(ESP32-C3 DevKitM)有多个硬件定时器,可以用来生成精确定时的信号,例如PWM信号、定时采样等。在这里,我们将介绍如何在Arduino ESP32-C3板上使用硬件定时器来生成PWM信号。 步骤1:引入头文件 首先,需要在Arduino IDE中引入ESP32-C3的头文件,其中包含了定时器相关的函数和常量。 #include <esp32-hal-timer.h> 步骤2:配置定时器 在Arduino ESP32-C3板上,有四个硬件定时器可供使用,分别为TIMER0、TIMER1、TIMER2和TIMER3。在使用定时器之前,需要先进行配置。以下是一个示例代码段,用于配置TIMER0。 void initTimer0() { // 配置TIMER0为PWM模式 timerAttach(TIMER0, 0, true); timerSetMode(TIMER0, TIMER_PWM_MODE, 1); timerSetFrequency(TIMER0, 1000); timerSetDuty(TIMER0, 0, 50); // 开始TIMER0 timerAlarmEnable(TIMER0); } 在上述代码中,我们首先使用timerAttach()函数将TIMER0与GPIO0引脚绑定,然后使用timerSetMode()函数将其设置为PWM模式。接下来,使用timerSetFrequency()函数设置PWM频率为1000Hz,然后使用timerSetDuty()函数设置PWM占空比为50%。最后,使用timerAlarmEnable()函数启动TIMER0。 步骤3:控制PWM输出 完成定时器的配置后,可以使用timerWrite()函数来控制PWM输出。以下是一个示例代码段,用于控制TIMER0输出PWM信号。 void loop() { for (int i = 0; i <= 100; i++) { timerWrite(TIMER0, i); delay(10); } } 在上述代码中,我们使用一个for循环来逐步增加PWM占空比,从0到100。每次循环使用timerWrite()函数来设置PWM占空比,然后使用delay()函数延时10毫秒。 总结 在Arduino ESP32-C3板上使用硬件定时器可以生成精确的PWM信号,用于控制各种设备和传感器。在使用定时器时,需要注意配置定时器的模式、频率和占空比。同时,也需要注意控制PWM输出的时序,以保证信号的稳定性和准确性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值