- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试以低功耗模式从一个 ESP32 LoRa 节点传输到另一个节点,并符合欧洲法规。
ESP32 板:TTGO LoRa32 OLED 板 V1.0(here 和 here)。
/*
* LoRa (low-power) sender for IoT projects
*
* Tested on a TTGO LoRa32 OLED Board V1.0
*
* Based on the LoRa examples and the board
* documentation
*
* More on the deep sleep with timer wake up:
*
* Examples > ESP32 > Deep Sleep > TimerWakeUp sketch
*
*
* ERC Recommendation
* h1.4 frequency band requires <= 1% duty cycle and 25mW (14 db) maximum power
* => 36 seconds every hour (so: 1 sec transmitting, 99 secs idle)
*
*
* Created 11 June 2019
* by DP
*
*/
#include <SPI.h> // allows communication with SPI devices
#include <LoRa.h>
#include <SSD1306.h> // provides API to work with OLED displays
// defines the pins used by the transceiver module
#define SS 18 // GPIO18 - SX1278's CS - LoRa radio chip select
#define RST 14 // GPIO14 - SX1278's RESET - LoRa radio reset
#define DI0 26 // GPIO26 - SX1278's IRQ - IRQ pin
#define BAND 868E6 // EU - Italy
// deep sleep
#define uS_TO_S_FACTOR 1000000 // conversion factor for micro seconds to seconds
#define TIME_TO_SLEEP 5 // time ESP32 will go to sleep (in seconds) - 99 for (about) 1% duty cycle
// an object of class SSD1306
// first parameter: the I2C address of the display
// second parameter: the number of the SDA
// third parameter: the SCL pin
SSD1306 display(0x3c, 4, 15);
// stores the data on the RTC memory so that it will not be deleted during the deep sleep
RTC_DATA_ATTR int bootCount = 0;
RTC_DATA_ATTR int pckCounter = 0; // sending packet number...
void setup() {
Serial.begin(115200); // initializes serial data transmission
while(!Serial); // waits for serial port to connect
Serial.println("LoRa low-power Sender");
pinMode(16, OUTPUT);
digitalWrite(16, LOW); // sets GPIO16 low to reset the OLED
delay(50);
digitalWrite(16, HIGH); // while the OLED is running, GPIO16 must go to high
pinMode(2, OUTPUT);
digitalWrite(2, LOW); // sets the onboard LED low
// LoRa transceiver module setup
LoRa.setPins(SS, RST, DI0); // overrides the default CS, reset, and IRQ pins used by the library
// initializes the transceiver module with a specified frequency
while (!LoRa.begin(BAND)) { // LoRa.begin returns 1 on success, 0 on failure
Serial.println(".");
}
// changes the spreading factor to 12 -> slower speed but better noise immunity
LoRa.setSpreadingFactor(12); // ranges from 6-12, default is 7
// changes the sync word (0xF3) to match the receiver
// the sync word assures you don't get LoRa messages from other LoRa transceivers
LoRa.setSyncWord(0xF3); // ranges from 0-0xFF
// LoRa.setTxPower(txPower); // defaults to 17
// initializes the display by calling the init method of the display object
display.init(); // receives no arguments and returns void
// display.flipScreenVertically(); // LCD is broken!
display.setFont(ArialMT_Plain_16); // sets the current font
display.drawString(0, 0, "Initialization"); // x, y, message to show
display.drawString(0, 16, "completed");
display.display();
delay(1500); // small delay so that the user can read it
Serial.println("LoRa init completed");
//Increments boot number and prints it every reboot
bootCount++;
Serial.println("Boot number: " + String(bootCount));
sendData(); // sends the data...
// deep sleep
esp_sleep_enable_timer_wakeup(TIME_TO_SLEEP * uS_TO_S_FACTOR);
Serial.println("Setup ESP32 to sleep for every " + String(TIME_TO_SLEEP) + " Seconds");
Serial.println("Going to sleep now");
Serial.flush(); // waits for the transmission of outgoing serial data to complete
esp_deep_sleep_start(); // enters deep sleep with the configured wakeup options
}
void loop(){
// this is not going to be called
}
// sends the data to the receiver
void sendData() {
Serial.print("Sending packet: ");
Serial.println(pckCounter);
display.clear(); // clears the display
display.setTextAlignment(TEXT_ALIGN_LEFT);
display.drawString(0, 0, "Sending ");
display.drawString(0, 16, "packet: " + String(pckCounter, DEC));
display.display();
digitalWrite(2, HIGH); // LED is ON during transmission
// sends the LoRa packet to the receiver
LoRa.beginPacket();
LoRa.print("hello ");
LoRa.print(pckCounter);
LoRa.endPacket();
digitalWrite(2, LOW); // turns the LED off after transmission
pckCounter++;
}
草图运行没有错误(商店页面上的代码包含一些错误,所以我鼓励您使用这个只是为了玩一玩)。我的问题:
我忘了初始化 SPI 通信:
SPI.begin(SCK、MISO、MOSI、SS);
尽管如此,它还是奏效了。我没想到。我的第一个问题是:我错过了什么?
我住在欧洲。 ERC 推荐文件说 h1.4 频段(我以 868 Mhz 传输)需要 <=1% 的占空比和 25mW (14db) 的最大功率。这意味着我每小时可以传输 36 秒(假设我传输 1 秒,然后 ESP32“休眠”99 秒)。我可以实现这种写作(这不是更准确的方法,但它应该有效):
#define TIME_TO_SLEEP 99
erp 呢?假设天线有 2db 增益,所以我可以将发射功率设置为 12db(12db + 2db -> 14db,很好。没关系!):
LoRa.setTxPower(12);
我的第二个问题:我(关于这两种设置)是否正确?我错过了什么吗?
最后一个问题:请随时给我任何(如果您有)反馈/建议以改进此草图!
最佳答案
看起来不错,你测试过深度 sleep 时的功耗吗?我有相同的板(带 OLED 的 TTGO ESP32 LORA),清醒时电流约为 38-50mA, sleep 时电流为 10mA。发送完毕后可以试试LoRa.end()
和LoRa.sleep()
让芯片休眠,不过不知道功率有多大这节省了。
有一些讨论going on here关于进一步降低功率的方法,但我无法将 TTGO 的电流降至 10mA 以下。
关于c++ - 具有深度 sleep 模式的低功耗ESP32 + LoRa (TTGO LoRa32 OLED Board V1.0),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56548700/
对此感到疯狂,真的缺少一些东西。 我有webpack 4.6.0,webpack-cli ^ 2.1.2,所以是最新的。 在文档(https://webpack.js.org/concepts/mod
object Host "os.google.com" { import "windows" address = "linux.google.com" groups = ["linux"] } obj
每当我安装我的应用程序时,我都可以将数据库从 Assets 文件夹复制到 /data/data/packagename/databases/ .到此为止,应用程序工作得很好。 但 10 或 15 秒后
我在 cc 模式缓冲区中使用 hideshow.el 来折叠我不查看的文件部分。 如果能够在 XML 文档中做到这一点就好了。我使用 emacs 22.2.1 和内置的 sgml-mode 进行 xm
已结束。此问题不符合 Stack Overflow guidelines .它目前不接受答案。 我们不允许提出有关书籍、工具、软件库等方面的建议的问题。您可以编辑问题,以便用事实和引用来回答它。 关闭
根据java: public Scanner useDelimiter(String pattern) Sets this scanner's delimiting pattern to a patt
我读过一些关于 PRG 模式以及它如何防止用户重新提交表单的文章。比如this post有一张不错的图: 我能理解为什么在收到 2xx 后用户刷新页面时不会发生表单提交。但我仍然想知道: (1) 如果
看看下面的图片,您可能会清楚地看到这一点。 那么如何在带有其他一些 View 的简单屏幕中实现没有任何弹出/对话框/模式的微调器日期选择器? 我在整个网络上进行了谷歌搜索,但没有找到与之相关的任何合适
我不知道该怎么做,我一直遇到问题。 以下是代码: rows = int(input()) for i in range(1,rows): for j in range(1,i+1):
我想为重写创建一个正则表达式。 将所有请求重写为 index.php(不需要匹配),它不是以/api 开头,或者不是以('.html',或'.js'或'.css'或'.png'结束) 我的例子还是这样
MVC模式代表 Model-View-Controller(模型-视图-控制器) 模式 MVC模式用于应用程序的分层开发 Model(模型) - 模型代表一个存取数据的对象或 JAVA PO
我想为组织模式创建一个 RDF 模式世界。您可能知道,组织模式文档基于层次结构大纲,其中标题是主要的分组实体。 * March auxiliary :PROPERTIES: :HLEVEL: 1 :E
我正在编写一个可以从文件中读取 JSON 数据的软件。该文件包含“person”——一个值为对象数组的对象。我打算使用 JSON 模式验证库来验证内容,而不是自己编写代码。符合代表以下数据的 JSON
假设我有 4 张 table 人 公司 团体 和 账单 现在bills/persons和bills/companys和bills/groups之间是多对多的关系。 我看到了 4 种可能的 sql 模式
假设您有这样的文档: doc1: id:1 text: ... references: Journal1, 2013, pag 123 references: Journal2, 2014,
我有这个架构。它检查评论,目前工作正常。 var schema = { id: '', type: 'object', additionalProperties: false, pro
这可能很简单,但有人可以解释为什么以下模式匹配不明智吗?它说其他规则,例如1, 0, _ 永远不会匹配。 let matchTest(n : int) = let ran = new Rand
我有以下选择序列作为 XML 模式的一部分。理想情况下,我想要一个序列: 来自 my:namespace 的元素必须严格解析。 来自任何其他命名空间的元素,不包括 ##targetNamespace和
我希望编写一个 json 模式来涵盖这个(简化的)示例 { "errorMessage": "", "nbRunningQueries": 0, "isError": Fals
首先,我是 f# 的新手,所以也许答案很明显,但我没有看到。所以我有一些带有 id 和值的元组。我知道我正在寻找的 id,我想从我传入的三个元组中选择正确的元组。我打算用两个 match 语句来做到这
我是一名优秀的程序员,十分优秀!