電子發(fā)燒友App

硬聲App

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

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

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>電子資料>用藥溫度監(jiān)測系統(tǒng)

用藥溫度監(jiān)測系統(tǒng)

2023-07-03 | zip | 0.18 MB | 次下載 | 免費

資料介紹

描述

介紹

該項目監(jiān)控平板電腦存儲冷卻室的溫度。它檢查溫度是否在指定的范圍內(nèi),并在溫度有任何偏差時通知用戶。

它基本上分3個階段實施-

  • 第 1 階段 - 記錄室中的溫度值幾個小時。實施多項式回歸的機器學習算法,用于預測未來值并確定室內(nèi)溫度的邊界。
  • 第 2 階段 - 每 10 秒獲取溫度值,如果溫度超過溫度閾值(我們在第 1 階段設置),則向用戶發(fā)送通知(通過電子郵件)。
  • 第 3 階段 - 使系統(tǒng)“自力更生” - 使用 z 分數(shù)分析,檢測任何異常并通知用戶。

保護藥物和藥片免受設備故障或故障的影響對于維持合規(guī)性和質(zhì)量標準至關(guān)重要。

階段1

在這個階段,我們將記錄溫度傳感器的值約 2 小時。我們還將實施多項式回歸模型,以預測未來一些點的溫度讀數(shù)。根據(jù)結(jié)果??,我們將找到溫度的閾值邊界值。

1.1 構(gòu)建電路

LM35傳感器是一種常用的溫度讀數(shù)傳感器。隨著溫度升高,傳感器兩端的電壓升高,反之亦然。

T = r / 10.24,r-> LM35 傳感器讀數(shù),T-> 溫度(攝氏度)

下面給出了LM35-溫度傳感器與螺栓模塊的電路連接。

poYBAGOYQUOARDx9AAzVEaWpJQs170.jpg
LDR 連接到 Bolt IoT Wifi 模塊
?

將 LM35 連接到螺栓模塊-

1)拿著LM35,這樣你就可以看到上面寫的LM35。

2)從這個位置最左邊的引腳連接到Vcc(螺栓模塊上的+5v)。

3)中間引腳連接到輸出(即螺栓模塊上的A0)

4)最右邊的引腳接地(螺栓模塊上的GND)

通過 Micro USB 電纜將 Bolt Wifi 模塊連接到電源。

1.2 創(chuàng)建產(chǎn)品并將其鏈接到我們的設備

轉(zhuǎn)到https://cloud.boltiot.com/ ,然后按照以下步驟操作:

?

1.3 實現(xiàn)多項式回歸算法

  • 多項式回歸是一種機器學習算法,我們在其中找到一個最能模擬數(shù)據(jù)集的多項式方程。

多項式方程的形式是-

y = f(x),其中 f(x) 是 x 的不同冪次之和的函數(shù)。
pYYBAGOYQUeAKoAkAAAP5RI8tks381.png
我們試圖找到最適合給定數(shù)據(jù)集的多項式方程。
?

在這里,我們使用“時間”作為 x 坐標。然后我們可以使用獲得的多項式方程來預測未來的溫度值。

  • 步驟- 1. 單擊配置此產(chǎn)品。
poYBAGOYQUyAKKbHAAEg3brA1w0176.jpg
?

2. 點擊 A0 引腳并給它一個名字——“temp”。(因為該引腳將溫度作為輸入)

根據(jù)您的要求選擇數(shù)據(jù)收集率。(我選擇了 5 分鐘)

pYYBAGOYQVCATS1pAAF8drVVZJA948.png
?

3. 單擊代碼。選擇.js作為擴展文件,編寫如下代碼。

setChartLibrary('google-chart')
setChartTitle('Polynomial Regression')
setChartType('predictionGraph')
setAxisName('time_stamp','temp')
mul(0.0977)
plotChart('time_stamp','temp')

注意-a)我使用谷歌圖表庫來實現(xiàn)多項式回歸。

b) setChartLibrary() - 選擇 google 圖表庫 setChartTitle() - 設置圖表的標題 setChartType() - 將圖表類型設置為預測圖(即它選擇多項式回歸) setAxisName() - 將名稱設置為 x 和 y軸(分別是時間和溫度值) mul(0.0977)- 將溫度值乘以 0.0977,將溫度傳感器讀數(shù)轉(zhuǎn)換為以攝氏度為單位的溫度。 plotChart() - 最后繪制圖表。

4. 保存配置。

poYBAGOYQVWAduOEAAFFU7uRYlg239.png
保存配置。
?

5. 部署硬件配置并單擊“查看此設備”。

pYYBAGOYQWCAUzwoAAEfzOb3me4678.jpg
?

6. 現(xiàn)在將傳感器在冷卻室中放置約 2 小時(蓋上蓋子)并記錄數(shù)值。(PS - 我使用了一個封閉的托盤,里面有一些冰塊作為房間,但你可以把設置放在冰箱里)。

pYYBAGOYQYeAXy5PAAc7OrTFsBk001.jpg
冷卻室托盤,里面有一些冰塊。
?
  • 了解預測模型-
poYBAGOYQZuASkfYAAQR61F66II411.jpg
當您單擊預測按鈕時,除了顯示的數(shù)據(jù)圖之外,還有 2 個圖。這些圖表是預測歷史和預測數(shù)據(jù)。
?

預測點:這個數(shù)字告訴 Visualizer 需要預測多少未來數(shù)據(jù)點。因此,如果您將產(chǎn)品設置為每 5 分鐘收集一次數(shù)據(jù),并選擇 4 個預測點,Visualizer 將預測趨勢并在未來 30 分鐘內(nèi)顯示 4 個點。

No. 多項式系數(shù):Polynomial Visualizer 處理給定的輸入時間相關(guān)數(shù)據(jù),并輸出以下形式的函數(shù)的系數(shù):

pYYBAGOYQZ6ATt_sAAA8w2hRdKQ274.png
?

最接近輸入數(shù)據(jù)的趨勢。這個數(shù)字告訴 Visualizer 函數(shù)中應該存在多少元素,即 n 的值。

幀大?。?/font>這些是 Visualizer 將用于預測數(shù)據(jù)趨勢的先前數(shù)據(jù)點的數(shù)量。例如,如果將此值設置為 3,Visualizer 將使用前 3 個點來預測趨勢。

預測歷史圖表可幫助您調(diào)整機器學習模型。您必須更改以下參數(shù),以使該圖表最接近實際數(shù)據(jù)。當這種情況發(fā)生時,預測數(shù)據(jù)或預測的未來溫度將是最準確的。

這在有特定要求時很有用,例如 - 片劑的溫度不得一次保持在 -33 到 -30 度之間超過 20 分鐘。使用預測數(shù)據(jù),只要圖表預測溫度將保持在 -33 和 -30 攝氏度范圍內(nèi)超過 20 分鐘,我們就可以及早采取行動。

1.4設置室內(nèi)溫度邊界

poYBAGOYQbyAVTyIAALEB0it2k0310.png
從云端下載數(shù)據(jù)
?

通過查看數(shù)據(jù),我們可以將閾值設置為26*C 傳感器值 - 277)和34*C (傳感器值 - 351)

第二階段

我們將編寫一個 python 代碼來獲取溫度數(shù)據(jù),每 10 秒,如果溫度超過我們在 1.4 部分中確定的溫度閾值,則發(fā)送電子郵件警報(通過 Mailgun)。

因此,如果腔室中出現(xiàn)任何問題(由于溫度變化),可以很容易地檢測到并進行修復。

2.1 設置 Mailgun

使用過 Mailgun——它是一個電子郵件自動化服務。它有一套非常強大的用于發(fā)送電子郵件的內(nèi)置功能。開發(fā)人員可以在 Mailgun API 的幫助下處理他們的電子郵件。

第 1 步 - 打開https://www.mailgun.com/并注冊免費試用帳戶。

第 2 步 - 遵循以下步驟 -

?

2.2 服務器和SSH終端軟件

在這個項目中使用了數(shù)字海洋云服務。

DigitalOcean 是一家云計算供應商,為軟件開發(fā)人員提供基礎(chǔ)設施即服務 (IaaS) 平臺。

  • 單擊此鏈接- https://www.digitalocean.com/并創(chuàng)建一個帳戶并進行驗證。創(chuàng)建一個 Droplet。(確保選擇離您最近的數(shù)據(jù)中心
  • 您將通過郵件獲得登錄憑據(jù)和服務器 IP。

我使用“putty”軟件通過 SSH 連接到服務器。SSH 是一種網(wǎng)絡協(xié)議,它允許我們通過 Internet 遠程訪問計算機。

  • 單擊 - https://www.chiark.greenend.org.uk/~sgtatham/putty/latest.html并根據(jù)您的 Windows 體系結(jié)構(gòu)從包文件列表中選擇 Windows 安裝程序。
  • 安裝膩子后,通過郵件接收到的droplet的憑據(jù)和IP地址登錄。更改新密碼并設置新密碼。

看看,在膩子中登錄。

?
?
?
pYYBAGOYQb-AMA67AACfYEl60_I240.jpg
?
1 / 4 ?寫出droplet的ip地址
?

2.3 配置文件

我們必須創(chuàng)建一個文件來存儲 Mailgun 和 Bolt IoT 的所有憑據(jù)。

Bolt 模塊的 API 密鑰和設備 ID 可以如下確定:

pYYBAGOYQcGAYKBLAAECSCHsTLM833.jpg
?
  • 轉(zhuǎn)到 API 部分以了解 API 密鑰。
poYBAGOYQcaAK8o9AAEIpbLaTag142.png
?

2.4 編寫最終的python代碼

代碼算法——

  • 從 Bolt 設備中獲取最新的傳感器值。
?

收到郵件截圖——

poYBAGOYQd6AZX30AAKEga0QCJs000.jpg
?

階段 - 3

在階段 -2 中,我手動設置了溫度傳感器的閾值范圍。但在這個階段,我將使用Z-score算法來動態(tài)更改發(fā)送警報的范圍。

這個階段的要點是——

當腔室工作正常時,溫度變化會很慢,系統(tǒng)的界限會隨著這種變化而變化。但是當出現(xiàn)任何系統(tǒng)故障或任何問題時,房間內(nèi)的溫度會突然發(fā)生變化。因此,系統(tǒng)將檢測到異常并迅速提醒用戶存在問題。

3.1 Z分數(shù)分析

Z-score 分析是一種用于異常檢測的算法。在這里,溫度的突然變化超出(閾值)范圍值,是一種異常情況。值的范圍稱為界限(上限和下限)。這些界限是使用輸入值、幀大小和乘法因子計算的。幀大小是 Z 分數(shù)分析所需的最小輸入值數(shù)量,乘法因子確定邊界與輸入值曲線的接近程度。

pYYBAGOYQeGAb4QUAAAiMnhydlM277.png
?

上面給出的是計算邊界的公式。這里輸入表示為“Vi”,“r”表示幀大小,“C”是乘法因子。首先,我們計算輸入值的平均值(Mn)(對于每個新輸入,再次計算平均值)。每個輸入值的變化(來自平均值)為 (Vi - Mn)^2。Z 分數(shù) (Zn) 的計算如上所示(每個輸入值的變化平均值的平方根乘以乘法因子)。界限表示為“Tn”,上限計算為 (Vi + Zn),下限計算為 (Vi - Zn)。

幀大小和倍增因子是使用試錯法確定的。

3.2 修改配置文件

MAILGUN_API_KEY = 'This is the private API key which you can find on your Mailgun Dashboard' 
SANDBOX_URL= 'You can find this on your Mailgun Dashboard' 
SENDER_EMAIL = 'This would be test@your SANDBOX_URL'
RECIPIENT_EMAIL = 'Enter your Email ID Here'
API_KEY = 'This is your Bolt Cloud account API key'
DEVICE_ID = 'This is the ID of your Bolt device'
FRAME_SIZE = 10
MUL_FACTOR = 6

幀大小和倍增因子猜測為 10 和 6,然后根據(jù)要求進行調(diào)整。

3.3異常檢測的Python代碼

import email_conf   #import the configuration file
from boltiot import Email, Bolt   #import the boltiot module from the Bolt python library
import json, time, math, statistics #import various python libraries

#//---------FUNCTION TO COMPUTE BOUNDS OR Z SCORE ANALYSIS------------//
def compute_bounds(history_data,frame_size,factor):
#//Function to compute bounds
    if len(history_data)        return None

    if len(history_data)>frame_size :
        del history_data[0:len(history_data)-frame_size]
    Mn=statistics.mean(history_data)
    Variance=0
    for data in history_data :
        Variance += math.pow((data-Mn),2)
    Zn = factor * math.sqrt(Variance / frame_size)
    High_bound = history_data[frame_size-1]+Zn
    Low_bound = history_data[frame_size-1]-Zn
    return [High_bound,Low_bound]  # //Returns Low Bound and High Bound

mybolt = Bolt(email_conf.API_KEY, email_conf.DEVICE_ID) # //To identify your bolt device
mailer = Email(email_conf.MAILGUN_API_KEY, email_conf.SANDBOX_URL, email_conf.SENDER_EMAIL, email_conf.RECIPIENT_EMAIL)    # //To identify Mailgun account
history_data=[]    # //Array of input values from LM35
#//---------------------READ INPUT FROM LM35--------------------------//
while True:
    response = mybolt.analogRead('A0')  #//Read input from LM35 at A0 pin
    data = json.loads(response) # //Retrieve the input data in json format
    if data['success'] != 1:
        print("There was an error while retriving the data.")
        print("This is the error:"+data['value'])
        time.sleep(10)
        continue

    print ("This is the value "+data['value'])
    sensor_value=0
    try:
        sensor_value = int(data['value']) # //store current input value in variable
    except e:
        print("There was an error while parsing the response: ",e)
        continue
#//----------------PERFORMING Z SCORE ANALYSIS--------------------------//
    bound = compute_bounds(history_data,email_conf.FRAME_SIZE,email_conf.MUL_FACTOR)
    if not bound:
        required_data_count=email_conf.FRAME_SIZE-len(history_data)
        print("Not enough data to compute Z-score. Need ",required_data_count," more data points")
        history_data.append(int(data['value']))
        time.sleep(10)
        continue
#//-----------DETECTING ANOMALY AND SENDING ALERTS--------------//
    try:
        if sensor_value > bound[0] :  # //If input crosses upper bound
            print ("The temperature has increased suddenly. Sending an E-mail.")
            response = mailer.send_email("Alert", "The temperature has suddenly increased! ")
            print("This is the response ",response)
        elif sensor_value < bound[1]:   # //If input crosses lower bound
            print ("The light level decreased suddenly. Sending an Email.")
            response = mailer.send_email("Alert", "The temperature has suddenly decreased! ")
            print("This is the response ",response)
        history_data.append(sensor_value);   # //Append each new input to array history_data[]
    except Exception as e:
        print ("Error",e)
    time.sleep(10)     # //Wait for 10 seconds

3.4 演示

當一杯熱水靠近傳感器時,溫度突然變化,檢測到溫度值異常。幀大小和倍增因子已經(jīng)以這種方式進行了調(diào)整。

?

3.5 輸出說明

由于我已將幀大小設置為 10,因此在獲取 10 個傳感器值之前,它不會計算 z 分數(shù)。

poYBAGOYQeOANuaeAAD-dfQ9T-o412.png
膩子輸出截圖
?

100 秒后(10 幀延遲 10 秒),它會開始計算 z-score 并檢查是否有異常。帶上一杯熱水后,當溫度突然變化時,異常是檢測到。

poYBAGOYQeeACIJCAADaCsfs9KE765.png
膩子輸出截圖
?

收到郵件截圖——

pYYBAGOYQfaAMcVRAAHrqjFYkXY978.png
?

因此,這是一種異常檢測中的自力更生系統(tǒng)。

?

?

?

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

評論

查看更多

下載排行

本周

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

本月

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

總榜

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