45

是否有可能让 python 产生像正弦波一样的简单声音?

有可用的模块吗?如果没有,您将如何创建自己的?

此外,您是否需要某种主机环境来运行 python 才能播放声音,或者仅通过从终端拨打电话就可以实现?

如果答案取决于操作系统,我使用的是 Mac。

4

7 回答 7

38

我一直在寻找同样的东西,最后,我编写了这个运行良好的代码。

import math        #import needed modules
import pyaudio     #sudo apt-get install python-pyaudio

PyAudio = pyaudio.PyAudio     #initialize pyaudio

#See https://en.wikipedia.org/wiki/Bit_rate#Audio
BITRATE = 16000     #number of frames per second/frameset.      

FREQUENCY = 500     #Hz, waves per second, 261.63=C4-note.
LENGTH = 1     #seconds to play sound

if FREQUENCY > BITRATE:
    BITRATE = FREQUENCY+100

NUMBEROFFRAMES = int(BITRATE * LENGTH)
RESTFRAMES = NUMBEROFFRAMES % BITRATE
WAVEDATA = ''    

#generating wawes
for x in xrange(NUMBEROFFRAMES):
 WAVEDATA = WAVEDATA+chr(int(math.sin(x/((BITRATE/FREQUENCY)/math.pi))*127+128))    

for x in xrange(RESTFRAMES): 
 WAVEDATA = WAVEDATA+chr(128)

p = PyAudio()
stream = p.open(format = p.get_format_from_width(1), 
                channels = 1, 
                rate = BITRATE, 
                output = True)

stream.write(WAVEDATA)
stream.stop_stream()
stream.close()
p.terminate()
于 2015-11-23T20:41:08.710 回答
17

我知道我在这个游戏上有点晚了,但这是一个非常棒的用于合成和音频合成的 python 项目:https ://github.com/hecanjog/pippi

它仍在积极开发中,但已经持续了一段时间。

于 2013-12-06T15:53:03.970 回答
7

在一些无法编译或不存在的项目上浪费时间之后,我发现了 python 模块wavebender,它可以生成单个或多个正弦波、方波和组合波的通道。结果可以写入波形文件或写入sys.stdout,从那里它们可以直接由aplay实时解释。此处解释了一些有用的示例,并包含在项目的github 页面中。

于 2013-12-17T08:11:43.007 回答
5

Python In Music wiki 页面并没有得到很好的维护,但它是一个很好的起点。 http://wiki.python.org/moin/PythonInMusic

于 2013-04-26T22:21:55.383 回答
5

我正在用python开发一个强大的合成器。我使用自定义函数直接写入 .wav 文件。有可用于此目的的内置函数。您将需要修改 .wav 标头以反映采样率、每个样本的位数、通道数和合成持续时间。

这是一个早期版本的正弦波发生器,它输出一个值列表,在应用 bytearray 后,这些值适合写入波形文件的数据参数。[编辑]在应用字节数组之前,转换函数需要将列表转换为小端十六进制值。有关 .wav 规范的详细信息,请参阅下面的 WAVE PCM 声音文件格式链接。[/编辑]

def sin_basic(freq, time=1, amp=1, phase=0, samplerate=44100, bitspersample=16):
    bytelist = []
    import math
    TwoPiDivSamplerate = 2*math.pi/samplerate
    increment = TwoPiDivSamplerate * freq
    incadd = phase*increment
    for i in range(int(samplerate*time)):
        if incadd > (2**(bitspersample - 1) - 1):
            incadd = (2**(bitspersample - 1) - 1) - (incadd - (2**(bitspersample - 1) - 1))
        elif incadd < -(2**(bitspersample - 1) - 1):
            incadd = -(2**(bitspersample - 1) - 1) + (-(2**(bitspersample - 1) - 1) - incadd)
        bytelist.append(int(round(amp*(2**(bitspersample - 1) - 1)*math.sin(incadd))))
        incadd += increment
    return bytelist

较新的版本可以使用波形来调制波形参数的频率、幅度和相位。数据格式使得将波混合和连接在一起变得微不足道。如果这似乎是您的小菜一碟,请查看WAVE PCM 声音文件格式

于 2015-08-12T22:48:30.273 回答
3

我喜欢PyAudiere,它可以让你播放 numpy 数组作为声音......我想它与我的 Matlab 背景很相配。我相信它是跨平台的。我认为scikits.audiolab做同样的事情,并且可能更新/更好的支持......对我来说似乎比尝试将内容保存为 wavfile 或将它们写入缓冲区并使用 Python 的内置声音库更容易。

于 2012-03-19T19:41:43.673 回答
3

我发现这两个 python 存储库非常有用,可能想看看它......

python https://github.com/JeremyCCHsu/Python-Wrapper-for-World-Vocoder

ipythonhttps ://timsainb.github.io/spectrograms-mfccs-and-inversion-in-python.html

[编辑] 正如所指出的,这里是两个链接的解释

python one似乎有错误,但很多人都能让它运行,所以我不确定。ipython 就像一个魅力,所以我希望你能运行它。

这两个链接都应该将音频作为输入,最好是.wav文件。将其特征化(使用 FFT:512,步长 = 512/8)以获得频谱图(您甚至可以将其可视化),它是一个 2D 矩阵,然后训练您的机器学习对象或使用代表原始矩阵的任何您想做的事情声音的。如果你想,在任何时候,这些向量代表什么,你也可以重新合成音频。

于 2017-06-28T20:58:48.867 回答