電子發(fā)燒友App

硬聲App

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>電子資料>Arduino氣象浮標(biāo)

Arduino氣象浮標(biāo)

2023-06-14 | zip | 0.00 MB | 次下載 | 免費(fèi)

資料介紹

描述

的背景

在春天,我們附近的湖泊是一個(gè)誘人的重現(xiàn)場(chǎng)所,但水溫并不總是像看起來那么受歡迎。在季節(jié)初期,冷空氣和水溫的結(jié)合有時(shí)會(huì)導(dǎo)致體溫過低。經(jīng)驗(yàn)法則是:如果水溫和氣溫的總和低于 120 華氏度,則不要下水。即使是訓(xùn)練有素的游泳運(yùn)動(dòng)員,在寒冷的天氣里也面臨著巨大的風(fēng)險(xiǎn)。如果不滿足此條件,劃船或劃獨(dú)木舟等水上活動(dòng)也可能很危險(xiǎn),因?yàn)閮A覆和意外游泳的可能性很小。

目標(biāo)

該項(xiàng)目的目標(biāo)是建造一個(gè)氣象浮標(biāo),它可以指示出水是否安全。浮標(biāo)將使用 Oplà IoT 套件中包含的 Arduino MKR WiFi 1010 讀取防水溫度傳感器,MKR IoT Carrier 上的大氣傳感器將檢索大氣條件。MKR IoT Carrier 上的 IMU 將用于確定當(dāng)前的波浪狀況。

安全用水

浮標(biāo)代碼的核心很簡(jiǎn)單,它已經(jīng)為我們形成了偽代碼!

if ( Water Temperature + Air Temperature < 120) { 
//
}

而已!對(duì)于水溫,我們有兩種選擇,因?yàn)樗婧蛶子⒊咭韵碌乃疁赝ǔ2煌?/font>在這種情況下,我編寫了腳本,因此它使用這兩個(gè)溫度的平均值。我使用的水溫傳感器是不銹鋼外殼中的通用 DS18b20 傳感器。這些是您搜索“防水溫度傳感器”時(shí)出現(xiàn)的最常見選項(xiàng)。這些將需要 Dallas Temperature 庫和 One Wire 庫。我遵循這些傳感器的標(biāo)準(zhǔn)接線,用一個(gè) 4.7 kΩ 電阻橋接 Vcc 和數(shù)據(jù)線。我有兩個(gè)傳感器,但因?yàn)樗鼈兪?DS18b20,它們使用 MKR WIFi 1010 的相同數(shù)字引腳。這意味著當(dāng)我們想要傳感器的溫度時(shí),我們必須在代碼中指定哪一個(gè)。

其他功能

除了水安全之外,如果可以的話,我們還想增加一些額外的功能,尤其是利用 MKR IoT Carrier 上已有的傳感器。氣溫、濕度和壓力非常簡(jiǎn)單,所以我們將它們添加到我們的主循環(huán)中。MKR IoT Carrier 還有一個(gè)慣性測(cè)量單元 (IMU),內(nèi)部有一個(gè)陀螺儀和加速度計(jì)。我想用IMU來看看水有多粗糙。為了了解波浪狀況,我確定了兩個(gè)指標(biāo);波周期和波強(qiáng)度。

波周期是波峰之間的時(shí)間。波強(qiáng)度是波的強(qiáng)度。我們不能依靠來自 IMU 的單個(gè)數(shù)據(jù)集來測(cè)量波浪的周期和強(qiáng)度,因?yàn)槲覀儫o法知道 IMU 在波浪周期中測(cè)量的位置。代替瞬時(shí)測(cè)量,我們可以在短時(shí)間內(nèi)快速采樣 IMU 數(shù)據(jù),然后對(duì)其進(jìn)行分析。這是我正在使用的方法。

IMU 采樣

要如上所述對(duì) IMU 進(jìn)行采樣,我們將需要兩個(gè)參數(shù)。我們希望多久收集一次數(shù)據(jù),以及每次收集需要多長(zhǎng)時(shí)間。在我的代碼中,我在腳本開頭使用變量設(shè)置了這些值。如果我決定對(duì)他們不滿意,這可以很容易地在以后進(jìn)行更改。

// How long to wait between IMU collections (seconds)
int collectionInterval = 900;  // 15 minutes is 900 seconds
// How long do you want to wait between datapoints (milliseconds)
int imuDelay = 100; 
// How many data points to collect during each period
const int collectionTarget = 200;  // This should take ~20 seconds overall

收集數(shù)據(jù)點(diǎn)后,我們必須對(duì)它們進(jìn)行解碼。如果 MKR IoT Carrier 平行于水面安裝,我發(fā)現(xiàn) Z 加速度可以作為波浪強(qiáng)度的粗略估計(jì)。波前越尖銳,垂直加速度就越高。

在同一方向,Z 陀螺儀在每個(gè)波期間都經(jīng)過零。我們只需計(jì)算數(shù)據(jù)從正數(shù)變?yōu)樨?fù)數(shù)的次數(shù),然后將收集時(shí)間(我們測(cè)量的時(shí)間)除以該數(shù)字。這為我們提供了波峰之間的近似平均時(shí)間。

void readIMU() {
 unsigned long startCollecting = millis(); // Record the start time
 int indexG = 0;
 int indexA = 0;
 int crossings = 0;
 float lastGZ = 0;
 float highA = 0;
 int updateOn = 10;
 updateDisplayIMU(0);
 // Continue collecting as long as you haven't reached the target
 while ((indexG < collectionTarget) || (indexA < collectionTarget)) {
   if (carrier.IMUmodule.gyroscopeAvailable()) {
     carrier.IMUmodule.readGyroscope(gyroX, gyroY, gyroZ);
     if ((lastGZ > 0 && gyroZ < 0) || (lastGZ > 0 && gyroZ < 0)) { 
       // Has the Z gyroscope crossed zero?
       crossings++; // If so, increment the counter
     }
     lastGZ = gyroZ; // Replace the last number
     indexG++; // Increment the index counter
   }
   if (carrier.IMUmodule.accelerationAvailable()) {
     carrier.IMUmodule.readAcceleration(acelX, acelY, acelZ);
     if (acelZ > highA) { // Is the Z component the highest recorded?
       highA = acelZ; // If so, replace it
     }
     indexA++; // Increment the index conter
   }
   if ((indexA == updateOn) || (indexG == updateOn)) { 
     // If 10 samples have passed
     updateDisplayIMU(updateOn); 
     // update the display with the remaining samples
     updateOn = updateOn + 10; // Increment the counter
   }
   ArduinoCloud.update();
   delay(imuDelay);
 }
 unsigned long stopCollecting = millis();
 // Use the collected data to find the wave characteristics
 float dT = (stopCollecting - startCollecting)/millisCorrection;
 waveIntensity = highA; 
 if (crossings > 0) { // Avoid dividing by zero 
   wavePeriod = dT/crossings;
 }
 else { // Make it an obviously wrong value 
   wavePeriod = -100;
 }
}

物聯(lián)網(wǎng)連接

我定期編寫的代碼包含ArduinoCloud.update();此函數(shù)是 ArduinoIoTCloud 庫的一部分,它會(huì)更新您在 IOT 云中設(shè)置項(xiàng)目期間定義的任何云連接變量。您可以在下面完整代碼的開頭看到我選擇連接到云的變量。我設(shè)置了一個(gè)簡(jiǎn)單的儀表板來監(jiān)控這些變量,如下所示。

pYYBAGNYt72AESnrAADv-Jwi1No211.png
儀表板變量
?

我設(shè)置了一個(gè)名為 unitSelector 的云連接布爾(真/假)變量,它連接到儀表板右下角的開關(guān)。默認(rèn)情況下,該變量設(shè)置為 true,當(dāng)浮標(biāo)通電或重置時(shí),單位為公制。當(dāng)代碼讀取傳感器時(shí)檢查選擇器。

void readSensors() {
  // Humidity is the same in metric and imperial, so read it first
  airHumidity = carrier.Env.readHumidity();
  if (unitSelector) { // If reading metric units
    airTemp = carrier.Env.readTemperature();
    airPressure = carrier.Pressure.readPressure();
    deepWaterTemp = tempSensors.getTempCByIndex(deepwaterProbe);
    surfaceWaterTemp = tempSensors.getTempCByIndex(surfacewaterProbe);
  }
  else { // If reading imperial units
    airTemp = carrier.Env.readTemperature(FAHRENHEIT);
    airPressure = carrier.Pressure.readPressure(PSI);
    deepWaterTemp = tempSensors.getTempFByIndex(deepwaterProbe);
    surfaceWaterTemp = tempSensors.getTempFByIndex(surfacewaterProbe);
  }
  // Take the average water temperature
  avgWater = (deepWaterTemp + surfaceWaterTemp)/2;
}

unitSelector 還將安全水溫重新定義為適當(dāng)?shù)膯挝唬?9C 或 120F)。

最后的想法

教程到此結(jié)束。浮標(biāo)可以安裝在任何東西中,從帶有熱膠的特百惠到定制的 3D 打印外殼。我住的地方現(xiàn)在是冬天,所以我還沒有機(jī)會(huì)制作外殼的原型。希望它很快就會(huì)變暖,可以讓它徹底運(yùn)行。


下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評(píng)論

查看更多

下載排行

本周

  1. 1山景DSP芯片AP8248A2數(shù)據(jù)手冊(cè)
  2. 1.06 MB  |  532次下載  |  免費(fèi)
  3. 2RK3399完整板原理圖(支持平板,盒子VR)
  4. 3.28 MB  |  339次下載  |  免費(fèi)
  5. 3TC358743XBG評(píng)估板參考手冊(cè)
  6. 1.36 MB  |  330次下載  |  免費(fèi)
  7. 4DFM軟件使用教程
  8. 0.84 MB  |  295次下載  |  免費(fèi)
  9. 5元宇宙深度解析—未來的未來-風(fēng)口還是泡沫
  10. 6.40 MB  |  227次下載  |  免費(fèi)
  11. 6迪文DGUS開發(fā)指南
  12. 31.67 MB  |  194次下載  |  免費(fèi)
  13. 7元宇宙底層硬件系列報(bào)告
  14. 13.42 MB  |  182次下載  |  免費(fèi)
  15. 8FP5207XR-G1中文應(yīng)用手冊(cè)
  16. 1.09 MB  |  178次下載  |  免費(fèi)

本月

  1. 1OrCAD10.5下載OrCAD10.5中文版軟件
  2. 0.00 MB  |  234315次下載  |  免費(fèi)
  3. 2555集成電路應(yīng)用800例(新編版)
  4. 0.00 MB  |  33566次下載  |  免費(fèi)
  5. 3接口電路圖大全
  6. 未知  |  30323次下載  |  免費(fèi)
  7. 4開關(guān)電源設(shè)計(jì)實(shí)例指南
  8. 未知  |  21549次下載  |  免費(fèi)
  9. 5電氣工程師手冊(cè)免費(fèi)下載(新編第二版pdf電子書)
  10. 0.00 MB  |  15349次下載  |  免費(fèi)
  11. 6數(shù)字電路基礎(chǔ)pdf(下載)
  12. 未知  |  13750次下載  |  免費(fèi)
  13. 7電子制作實(shí)例集錦 下載
  14. 未知  |  8113次下載  |  免費(fèi)
  15. 8《LED驅(qū)動(dòng)電路設(shè)計(jì)》 溫德爾著
  16. 0.00 MB  |  6656次下載  |  免費(fèi)

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935054次下載  |  免費(fèi)
  3. 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
  4. 78.1 MB  |  537798次下載  |  免費(fèi)
  5. 3MATLAB 7.1 下載 (含軟件介紹)
  6. 未知  |  420027次下載  |  免費(fèi)
  7. 4OrCAD10.5下載OrCAD10.5中文版軟件
  8. 0.00 MB  |  234315次下載  |  免費(fèi)
  9. 5Altium DXP2002下載入口
  10. 未知  |  233046次下載  |  免費(fèi)
  11. 6電路仿真軟件multisim 10.0免費(fèi)下載
  12. 340992  |  191187次下載  |  免費(fèi)
  13. 7十天學(xué)會(huì)AVR單片機(jī)與C語言視頻教程 下載
  14. 158M  |  183279次下載  |  免費(fèi)
  15. 8proe5.0野火版下載(中文版免費(fèi)下載)
  16. 未知  |  138040次下載  |  免費(fèi)