注釈

こんにちは、SunFounderのRaspberry Pi & Arduino & ESP32愛好家コミュニティへようこそ!Facebook上でRaspberry Pi、Arduino、ESP32についてもっと深く掘り下げ、他の愛好家と交流しましょう。

参加する理由は?

  • エキスパートサポート:コミュニティやチームの助けを借りて、販売後の問題や技術的な課題を解決します。

  • 学び&共有:ヒントやチュートリアルを交換してスキルを向上させましょう。

  • 独占的なプレビュー:新製品の発表や先行プレビューに早期アクセスしましょう。

  • 特別割引:最新製品の独占割引をお楽しみください。

  • 祭りのプロモーションとギフト:ギフトや祝日のプロモーションに参加しましょう。

👉 私たちと一緒に探索し、創造する準備はできていますか?[ここ]をクリックして今すぐ参加しましょう!

2.2.2 サーミスタ

注釈

../_images/mcp3008_and_adc0834.jpg

キットのバージョンによって、 ADC0834 または MCP3008 が含まれています。 該当するセクションを選択してください。

はじめに

フォトレジスタが光を検知できるように、サーミスタは温度に反応する電子デバイスであり、熱警報のような温度制御機能を実現できます。

必要な部品

このプロジェクトに必要な部品は次のとおりです。

../_images/list_2.2.2_thermistor.png

一式を購入することで手間が省けます、リンクはこちらです:

名前

このキットのアイテム

リンク

Raphael Kit

337

Raphael Kit

以下のリンクから個別にも購入可能です。

コンポーネントの紹介

購入リンク

GPIO拡張ボード

購入

ブレッドボード

購入

ジャンパーワイヤー

購入

抵抗器

購入

サーミスター

購入

ADC0834

-

回路図

../_images/image323.png ../_images/image324.png

実験手順

ステップ 1: 回路を組む。

../_images/image202.png

ステップ 2: コードがあるフォルダに移動する。

cd ~/raphael-kit/python/

ステップ 3: 実行ファイルを起動する

sudo python3 2.2.2_Thermistor.py

コードが実行された後、サーミスタが周囲の温度を検知し、プログラム計算が完了すると画面に表示されます。

コード

注釈

以下のコードは 修正/リセット/コピー/実行/停止 ができます。ただし、その前に、 raphael-kit/python などのソースコードパスに移動する必要があります。コードを修正した後は、その効果を直接確認することができます。

#!/usr/bin/env python3
# -*- coding: utf-8 -*-

import RPi.GPIO as GPIO
import ADC0834
import time
import math

def init():
    ADC0834.setup()

def loop():
    while True:
        analogVal = ADC0834.getResult()
        Vr = 5 * float(analogVal) / 255
        Rt = 10000 * Vr / (5 - Vr)
        temp = 1/(((math.log(Rt / 10000)) / 3950) + (1 / (273.15+25)))
        Cel = temp - 273.15
        Fah = Cel * 1.8 + 32
        print ('Celsius: %.2f °C  Fahrenheit: %.2f ℉' % (Cel, Fah))
        time.sleep(0.2)

if __name__ == '__main__':
    init()
    try:
        loop()
    except KeyboardInterrupt:
        ADC0834.destroy()

コード説明

import math

このライブラリは、一般的な数学的操作や変換を計算する一連の関数を定義しています。

analogVal = ADC0834.getResult()

この関数はサーミスタの値を読み取るために使用されます。

Vr = 5 * float(analogVal) / 255
Rt = 10000 * Vr / (5 - Vr)
temp = 1/(((math.log(Rt / 10000)) / 3950) + (1 / (273.15+25)))
Cel = temp - 273.15
Fah = Cel * 1.8 + 32
print ('Celsius: %.2f °C  Fahrenheit: %.2f ℉' % (Cel, Fah))

これらの計算は、サーミスタの値を摂氏と華氏に変換します。

Vr = 5 * float(analogVal) / 255
Rt = 10000 * Vr / (5 - Vr)

この2行のコードは、読み取られたアナログ値を用いてRt(サーミスタの抵抗値)を求めるための電圧分布を計算しています。

temp = 1/(((math.log(Rt / 10000)) / 3950) + (1 / (273.15+25)))

このコードは、ケルビン温度を求めるための公式 TK=1/(ln(RT/RN)/B+1/TN) にRtを代入しています。

temp = temp - 273.15

ケルビン温度を摂氏温度に変換します。

Fah = Cel * 1.8 + 32

摂氏温度を華氏温度に変換します。

print ('Celsius: %.2f °C  Fahrenheit: %.2f ℉' % (Cel, Fah))

表示に摂氏度、華氏度、およびそれらの単位を出力します。

現象の画像

../_images/image203.jpeg