注釈

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

参加する理由は?

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

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

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

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

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

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

2.2.8 超音波センサモジュール

はじめに

このプロジェクトでは、超音波を使用して物体を精度よく検出し、距離を測定する超音波センサを利用します。超音波波を発信し、それらを電子信号に変換します。

必要な部品

このプロジェクトには以下のコンポーネントが必要です。

../_images/list_2.2.5.png

一式をまとめて購入すると便利です、リンクはこちらです:

名前

このキットのアイテム

リンク

Raphael Kit

337

Raphael Kit

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

コンポーネントの紹介

購入リンク

GPIO拡張ボード

購入

ブレッドボード

購入

ジャンパーワイヤー

購入

超音波モジュール

購入

回路図

../_images/image329.png

実験手順

ステップ1: 回路を作成する。

../_images/image220.png

ステップ2: コードが保存されているフォルダに移動する。

cd ~/raphael-kit/python/

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

sudo python3 2.2.8_Ultrasonic.py

コードを実行すると、超音波センサモジュールが障害物とモジュール自体との距離を検出し、その距離値が画面に表示されます。

コード

注釈

以下のコードは 編集/リセット/コピー/実行/停止 が可能です。それに先立ち、 raphael-kit/python のようなソースコードのパスに移動する必要があります。コードを修正した後は、直接実行して効果を確認できます。

import RPi.GPIO as GPIO
import time

TRIG = 16
ECHO = 18

def setup():
    GPIO.setmode(GPIO.BOARD)
    GPIO.setup(TRIG, GPIO.OUT)
    GPIO.setup(ECHO, GPIO.IN)

def distance():
    GPIO.output(TRIG, 0)
    time.sleep(0.000002)

    GPIO.output(TRIG, 1)
    time.sleep(0.00001)
    GPIO.output(TRIG, 0)

    while GPIO.input(ECHO) == 0:
        a = 0
    time1 = time.time()
    while GPIO.input(ECHO) == 1:
        a = 1
    time2 = time.time()

    during = time2 - time1
    return during * 340 / 2 * 100

def loop():
    while True:
        dis = distance()
        print ('Distance: %.2f' % dis )
        time.sleep(0.3)

def destroy():
    GPIO.cleanup()

if __name__ == "__main__":
    setup()
    try:
        loop()
    except KeyboardInterrupt:
        destroy()

コード説明

def distance():

この関数は、返された検出距離を計算することで超音波センサの機能を実現します。

GPIO.output(TRIG, 1)
time.sleep(0.00001)
GPIO.output(TRIG, 0)

これは10usの超音波パルスを発信しています。

while GPIO.input(ECHO) == 0:
    a = 0
time1 = time.time()

この空のループは、トリガーシグナルが送信されたときに、干渉するエコーシグナルがないことを確認し、現在の時間を取得するために使用されます。

while GPIO.input(ECHO) == 1:
    a = 1
time2 = time.time()

この空のループは、エコーシグナルが受信されるまで次のステップに進まないようにし、現在の時間を取得するために使用されます。

during = time2 - time1

時間間隔の計算を実行します。

return during * 340 / 2 * 100

時間間隔と音の速度に基づいて距離を計算します。空気中の音の速度:340m/s。

現象の画像

../_images/image221.jpeg