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 可视化生成的音频信号。

执行结果:

相关推荐
清水迎朝阳3 分钟前
火山RTC 6 自定义视频
音视频·实时音视频·火山rtc·自定义视频
旋风小飞棍12 分钟前
如何在sheel中运行spark
大数据·开发语言·scala
xinxiyinhe21 分钟前
内存泄漏与OOM崩溃根治方案:JVM与原生内存池差异化排查手册
java·开发语言·jvm
愚润求学30 分钟前
【Linux】基础 IO(一)
linux·运维·服务器·开发语言·c++·笔记
oliveira-time38 分钟前
ArrayList和LinkedList区别
java·开发语言
yutian06061 小时前
C语言中的宏
c语言·开发语言
红衣小蛇妖1 小时前
Python基础学习-Day23
开发语言·python·学习
孞㐑¥1 小时前
Linux之进程控制
linux·开发语言·c++·经验分享·笔记
Akiiiira1 小时前
【日撸 Java 300行】Day 14(栈)
java·开发语言
景天科技苑1 小时前
【Rust泛型】Rust泛型使用详解与应用场景
开发语言·后端·rust·泛型·rust泛型