Python生成432Hz音频

使用 numpy 来生成信号,

使用 matplotlib 可视化信号,

使用 sounddevice 播放声音。

以下生成和播放 432 Hz 的正弦波信号:

python 复制代码
import numpy as np
import sounddevice as sd
import matplotlib.pyplot as plt


# 生成单音函数
def generate_tone(frequency, duration, sampling_rate):
    t = np.linspace(0, duration, int(sampling_rate * duration), endpoint=False)
    return 0.5 * np.sin(2 * np.pi * frequency * t)

# 生成和弦(多个频率同时播放)
def generate_chord(frequencies, duration, sampling_rate):
    chord = np.zeros(int(sampling_rate * duration))
    for freq in frequencies:
        chord += generate_tone(freq, duration, sampling_rate)
    return chord / len(frequencies)  # 归一化

def fun_music(frequency = 432, sampling_rate = 44100, duration = 2):

    # 参数设置
    frequency = 432  # 频率(赫兹)
    sampling_rate = 44100  # 采样率(赫兹)
    duration = 2  # 持续时间(秒)

    # 时间轴
    t = np.linspace(0, duration, int(sampling_rate * duration), endpoint=False)

    # 生成正弦波信号
    signal = 0.5 * np.sin(2 * np.pi * frequency * t)

    # 播放声音
    sd.play(signal, samplerate=sampling_rate)
    sd.wait() # 等待声音播放完成


    # 绘制信号
    plt.plot(t[:1000], signal[:1000])  # 只绘制前1000个点
    plt.title(f'Sine Wave - {frequency} Hz')
    plt.xlabel('Time [s]')
    plt.ylabel('Amplitude')
    plt.show()


fun_music()
  1. 参数设置:定义了频率为 432 Hz、采样率为 44100 Hz 和持续时间为 2 秒。
  2. 生成时间轴 :使用 numpy.linspace 创建时间轴。
  3. 生成正弦波信号 :使用 numpy.sin 生成 432 Hz 的正弦波信号。
  4. 播放声音 :使用 sounddevice 库的 play 函数播放生成的音频信号。
  5. 绘制信号 :使用 matplotlib 可视化生成的音频信号。

执行结果:

相关推荐
weixin_3875342212 分钟前
Ownership - Rust Hardcore Head to Toe
开发语言·后端·算法·rust
csdn_zhangchunfeng41 分钟前
Qt之slots和Q_SLOTS的区别
开发语言·qt
计算机安禾42 分钟前
【C语言程序设计】第35篇:文件的打开、关闭与读写操作
c语言·开发语言·c++·vscode·算法·visual studio code·visual studio
kishu_iOS&AI1 小时前
Python - 链表浅析
开发语言·python·链表
m0_733612211 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法
大连好光景1 小时前
conda管理包还是pip管理包
python·conda·pip
m0_730115111 小时前
自动化机器学习(AutoML)库TPOT使用指南
jvm·数据库·python
luffy54591 小时前
Rust语言入门-变量篇
开发语言·后端·rust
FreakStudio2 小时前
MicroPython+PycoClaw,3 分钟搞定 ESP32 跑上 OpenClaw!
python·单片机·嵌入式·电子diy