首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

树莓派综合项目3:AI视觉机械臂小车(一)蜂鸣器

一、介绍

  树莓派综合项目2:智能小车(六)黑线循迹

  树莓派基础实验

  在树莓派项目2中,我学到了很多东西,主要是通过实践掌握了树莓派小车的无线电控制和自动化避障控制,虽然不是特别的高深和难懂,但是增强了我学习的动力和信心,万丈高楼平地起,2018年6月买的小车现在才学习吸收完,原因还是先学完基础实验内容后,才能学懂项目2,推及以后更难的内容,若没有项目2做铺垫,估计也学不来,更不用说自己创作了。

  目前我仍处于学习的初级阶段,正向学习的中级阶段迈进。项目2学习完后,下一步做什么呢?我有两个想法:

一是学物联网的自动化控制。我对农业很感兴趣,也喜欢养花种菜,想做智能温室的树莓派物联网,但是我家里没有院子,房间也小,做个mini的都困难;

二是AI视觉和机械臂。在各类树莓派创客书籍中发现,视觉识别是一个主要内容,是信息输入的重要方式,而机械臂是机器人输出、工作的重要方式,比如农业采摘机器人。

  于是我选择了继续做机器人,在网上慢慢选了一个月的时间,终于找到一款适合我现在的套件。

  做视觉处理对硬件的计算力有要求,为了让运行更流畅,我选择了树莓派4B 8G版本,整个套件花了我1777大洋,虽然有点心疼,但是投资学习是不会亏的。

如果不是4B8G的主板,价格会少很多的,同学们可以自己选择。或者看我的文章就可以了,欢迎大家关注我,点赞哦!我会把这套学习资料吃透后分享给大家,如果能再开发,做一个草莓采摘机器人就更棒了!

与项目2的小车做对比要大许多,操作升级、再开发的空间很大。

二、组件

三、实验原理

看过我项目2的同学,相信对小车控制这部分已经很熟悉了,但项目2中的python代码都是我自己写的,在这个套件中我们来学习下专业人士的代码是怎么写的。

这个课程的第一个实验就是蜂鸣器实验,作为开局实验是比较基础的,就是不知道后面的复杂实验里是否会用到蜂鸣器。

我的基础实验里做过有源蜂鸣器和无源蜂鸣器,它的基础原理大家可以点击参考:

树莓派基础实验9:蜂鸣器实验

本实验中使用的是无源蜂鸣器,和电磁扬声器一样,需要接在音频输出电路中才能周期性地振动发声。只要输出不同频率的PWM波,即可发出不同的音符,不同的音符组合起来就是一个曲子了。

树莓派功能转接板

在树莓派功能转接板上看到,蜂鸣器是直接焊接在板子上的,连接的板载模式第11针,不用像基础实验中一样去接线,但初学者最好看一下基础实验9,学习下基本接线方法。

四、实验步骤

第1步: 蜂鸣器焊接在板子上,不用连接电路。这里说下树莓派4B8G是64位的操作系统,与4G、2G版本不能混用。

第2步: 编写程序。原始代码为python2版本,为适应发展,我还是转换成了python3版本,并有中文注释,更详细讲解请参考树莓派基础实验9:蜂鸣器实验

代码语言:txt
复制
#!/usr/bin/env python
# -*- coding: utf-8 -*-

import RPi.GPIO as GPIO
import time

Buzzer = 11

CL = [0, 131, 147, 165, 175, 196, 211, 248]     # 低音C调音符对应的频率

CM = [0, 262, 294, 330, 350, 393, 441, 495]     # 中音C调音符对应的频率

CH = [0, 525, 589, 661, 700, 786, 882, 990]     # 高音C调音符对应的频率

song_1 = [  CM[3], CM[5], CM[6], CM[3], CM[2], CM[3], CM[5], CM[6], # 歌曲1的音符
            CH[1], CM[6], CM[5], CM[1], CM[3], CM[2], CM[2], CM[3], 
            CM[5], CM[2], CM[3], CM[3], CL[6], CL[6], CL[6], CM[1],
            CM[2], CM[3], CM[2], CL[7], CL[6], CM[1], CL[5] ]

beat_1 = [  1, 1, 3, 1, 1, 3, 1, 1,             # 歌曲1的节拍, 1 指 1/8 拍
            1, 1, 1, 1, 1, 1, 3, 1, 
            1, 3, 1, 1, 1, 1, 1, 1, 
            1, 2, 1, 1, 1, 1, 1, 1, 
            1, 1, 3 ]

song_2 = [  CM[1], CM[1], CM[1], CL[5], CM[3], CM[3], CM[3], CM[1], # 歌曲2的音符
            CM[1], CM[3], CM[5], CM[5], CM[4], CM[3], CM[2], CM[2], 
            CM[3], CM[4], CM[4], CM[3], CM[2], CM[3], CM[1], CM[1], 
            CM[3], CM[2], CL[5], CL[7], CM[2], CM[1]    ]

beat_2 = [  1, 1, 2, 2, 1, 1, 2, 2,             # 歌曲2的节拍, 1 指 1/8 拍
            1, 1, 2, 2, 1, 1, 3, 1, 
            1, 2, 2, 1, 1, 2, 2, 1, 
            1, 2, 2, 1, 1, 3 ]

def setup():
    GPIO.setwarnings(False)
    GPIO.setmode(GPIO.BOARD)        # 根据物理位置对gpio进行编号
    GPIO.setup(Buzzer, GPIO.OUT)    # 设置引脚模式为输出
    global Buzz                     # 指定一个全局变量来替换GPIO.PWM
    Buzz = GPIO.PWM(Buzzer, 440)    # 440 是初始频率
    Buzz.start(50)                  # 启动蜂鸣器PWM50%的占空比

def loop():
    while True:
        print('\n    Playing song 1...')
        for i in range(1, len(song_1)):     # 播放歌曲1
            Buzz.ChangeFrequency(song_1[i]) # 沿着歌曲的音符改变频率
            time.sleep(beat_1[i] * 0.5)     # 一个节拍为0.5s的时长
        time.sleep(1)                       # 

        print('\n\n    Playing song 2...')
        for i in range(1, len(song_2)):     
            Buzz.ChangeFrequency(song_2[i]) 
            time.sleep(beat_2[i] * 0.5)     

def destory():
    Buzz.stop()                 # 停止PWM
    GPIO.output(Buzzer, 1)      # 将蜂鸣器引脚设置为输出高电平
    GPIO.cleanup()              # 释放资源

if __name__ == '__main__':      # 程序从这里开始
    setup()
    try:
        loop()
    except KeyboardInterrupt:   # 当输入'Ctrl+C'时, 函数destroy()会被执行
        destory()
下一篇
举报
领券