音樂製做模塊

本人雖然五音不全,可是聽歌仍是很喜歡的。但願能利用機器自動製做音樂,本我發現了一個比較適合入門的有趣的開源音樂生成模塊PySynth,文咱們主要講解下如何Python3使用PySynth製做音樂。linux

樂理

  • 聲音:物體振動產生,振動次數越多,音越高;振動次數越少,音越低
  • 可聞:人耳能夠聽到的聲音在每秒16-2000此左右
  • 樂音:振動規則產生,聽起來高低明顯
  • 噪音:振動不規則產生,聽起來高低不明顯
  • 音樂:將聲音經過藝術形象表達人們的思想感情
  • 音階:do、re、mi、sol、la、(do)
  • 調性:C、D、E、F、G、A、B

安裝git

pip3 install pysynthgithub

示例app

import pysynthdom

# 例1:C大調google

song1 = [
['c',4],['d',4],['e',4],['f',4],['g',4],['a',4],['b',4],['c5',2],['r',1],
['c3',4],['d3',4],['e3',4],['f3',4],['g3',4],['a3',4],['b3',4],['c4',2],['r',1],
['c1*', 1], ['c2*', 1], ['c3*', 1], ['c4*', 1], ['c5*', 1], ['c6*', 1], ['c7*', 1], ['c8*', 1],
]spa

pysynth.make_wav(song1, fn = "linuxidc.com.wav")orm

在當前目錄下生成linuxidc.com.wav文件。htm

 Python3使用PySynth製做音樂

在Linux終端輸入如下命令試聽一下ip

[linuxidc@localhost www.linuxidc.com]$ aplay -D plughw:0,0 linuxidc.com.wav

Python3使用PySynth製做音樂

試下週杰倫的晴天,bmp是67下每分鐘:

import pysynth

songx=(('e3',8),('d3',8),('f3',8),('e3',4),('c3',8),('g3',8),('b3',8),('c4',8),('b3',8),('c3',8),('c3',4),('c3',8),('a3',8),('a3',8),
      ('r',16),('a3',16),('g3',8),('g3',4),('g3',8),('f3',8),('e3',8),('d3',8),('e3',8),('f3',8),('e3',2.25),('e3',8),('f#3',8),('g#3',8),
      ('e3',4),('f3',8),('g3',8),('b3',8),('d4',8),('b3',8),('c4',8),('c4',6),('c4',16),('c4',8),('g3',8),('g3',8),('a3',8),('g3',8),('f3',8),
      ('a2',8),('b2',8),('c3',8),('d3',8),('e3',8),('d3',3),('e3',8),('c3',2))
pysynth.make_wav(songx, bpm=67, repeat=0, fn="linuxidc.wav")

Python3使用PySynth製做音樂

隨機生成中國風音樂旋律

import pysynth
import numpy as np
import re

#先限定音符12356 中國風五聲調式 這樣聽起來比較天然
notes=np.array(["c4","d4","e4","g4","a4",])
#音符時值
durations=np.array([1,2,4,-2,-4,-8])

#隨機生成音符 重音穿插其中
sn=[]
for t in range(16):
    n=np.random.randint(0,len(notes))
    note=notes[n]+"*"
    sn.append(note)

 

    for i in range(np.random.randint(3,5)):
        note0=notes[np.random.randint(0,len(notes))]
        sn.append(note0)
       
#隨機生成音符時值序列 造成長短參差變幻的節奏
dn=[]
for i in range(len(sn)):
    duration=durations[np.random.randint(0,len(durations))]
    nn=sn[i]
    dn.append(duration)

#將音符和時值合併成旋律
melody=tuple(zip(sn,dn))
print(melody)

#將曲譜合成到聲音文件
pysynth.make_wav(melody,fn =r"linuxmi.com.wav")

print("ok")

備註:

'song' 是一個被定義的列表或元組,格式是這樣 ['音', 長度]

音符是'a','g'這些; 升半音以 '#' 表示,降半音以 'b' 表示;以octave 結束 (默認爲四分音符);asterisk 在最後表明重音; 'r' 是空.

音的長度用數字表示:1=全音符; 2=二分音符; 4=四分音符, 等.
浮點音符寫法:
 1.33 = -2 = 二分浮點音符
 2.66 = -4 = 四分浮點音符
 5.33 = -8 = 八分浮點音符

 一些參數:
 節奏:每分鐘節拍數;  bpm = 95
 八度轉變 (neg. 降八度; pos. 升八度); transpose = 0
 音符間停頓 (0. = 連音 ;  0.5 = 斷音); pause = 0.05
 Volume boost:音量變高 (1. = 音量無變化);  boost = 1.2
 Output file name 輸出文件名;fn = 'pysynth_output.wav'

 其餘參數:
 Influences the decay of harmonics over frequency. Lowering the value eliminates even more harmonics at high frequencies.
 Suggested range: between 3. and 5., depending on the frequency response  of speakers/headphones used
harm_max = 4.

Linux公社的RSS地址https://www.linuxidc.com/rssFeed.aspx

本文永久更新連接地址https://www.linuxidc.com/Linux/2019-09/160567.htm

linux
相關文章
相關標籤/搜索