Skip to main content

一个用numpy实现的8bit音乐生成器

Project description

一个用numpy实现的8bit音乐生成器

功能特性

  • MIDI 音符映射:通过枚举类将 MIDI 缺陷值与音名绑定。
  • 多种波形支持:包括正弦波、方波、三角波、锯齿波和白噪声。
  • 基本鼓组支持:Kick、Snare、Hi-hat 等常见打击乐器模拟。
  • 通道生成器:支持旋律和鼓声分别生成独立通道。
  • 后处理与播放:混音、音量控制、裁剪与播放功能。
  • ️参数配置系统:灵活定义采样率、BPM 和时长等音频参数。

安装方式

pip install chippymu

示例用法

播放一段旋律

from chippymu.models import Note, WaveType
from chippymu.configs import BasicParams
from chippymu.channelgen import generate_wave
from chippymu.sound import post_processing, play

params = BasicParams(sample_rate=16000, bpm=90, length=4)

melody = [(0.0, Note.C1, 1.0), (2.0, Note.E1, 1.0), (3.0, Note.G1, 1.0)]
wave = generate_wave(melody=melody, wave_type=WaveType.SINE, params=params)
mixed = post_processing([wave], volumes=[0.8])
play(mixed, params)

播放一段鼓点

from chippymu.models import DrumType
from chippymu.channelgen import generate_drums
from chippymu.sound import post_processing, play

params = BasicParams(sample_rate=16000, bpm=90, length=4)

drums = [(0.0, DrumType.KICK, 0.1), (1.0, DrumType.HIHAT, 0.2), (2.0, DrumType.SNARE, 0.2)]
drum_audio = generate_drums(drums=drums, params=params)
mixed = post_processing([drum_audio], volumes=[0.8])
play(mixed, params)

核心模块说明

  1. models 模块:定义了 MIDI 音符映射、波形类型和鼓点类型。

    • WaveType:波形类型,包括 SINESQUARESAWTOOTHTRIANGLE
    • DrumType:鼓点类型,包括 KICKHIHATSNAREPERC
    • Note:音符对象,包含音符的起始时间、持续时间、音高和音量等信息。
  2. configs 模块:定义了参数配置,包括采样率、每分钟节拍数、总时长。

    • sample_rate:采样率,默认为 16000 Hz。
    • bpm:每分钟节拍数,默认为 90。
    • length:总时长(以拍数为单位)。
  3. utils 模块:工具函数集合。

    • note_to_freq:将音符对象转换为频率。
    • basic_wave_gen:生成基本波形。
    • basic_drum_gen:生成基本鼓声。
  4. channelgen模块:通道生成器。

    • generate_wave: 生成波形通道。
    • generate_drum: 生成鼓声通道。
  5. sound模块:后处理与播放。

    • post_processing: 混音、裁剪、量化等。
    • play: 使用sounddevice播放音频。

更新记录

0.3.0

  • 将noice从波形移动至鼓声,保持一致的创建方式。
  • 更新README.md以符合类型标注。

0.3.1

  • 修复了音符与midi音符的映射错误。

0.3.2

  • 修改了混音基准长度的计算方法。
  • 将sound模块的函数改为不能传位置参数

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

chippymu-0.3.2.tar.gz (10.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

chippymu-0.3.2-py3-none-any.whl (7.0 kB view details)

Uploaded Python 3

File details

Details for the file chippymu-0.3.2.tar.gz.

File metadata

  • Download URL: chippymu-0.3.2.tar.gz
  • Upload date:
  • Size: 10.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.13

File hashes

Hashes for chippymu-0.3.2.tar.gz
Algorithm Hash digest
SHA256 22f6073f5241c3a9fcb72eb478a36bfdaafe1ec846fee6594863c9fdecf0ff7a
MD5 c6114899801af429a2bbca34c2e2fc68
BLAKE2b-256 5f282a4cd318b04f266c9a9e29e64910aefbfaec842a7fde247a52be09db2cee

See more details on using hashes here.

File details

Details for the file chippymu-0.3.2-py3-none-any.whl.

File metadata

  • Download URL: chippymu-0.3.2-py3-none-any.whl
  • Upload date:
  • Size: 7.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.13

File hashes

Hashes for chippymu-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 527a8d969d315bab7f00d775a9c57c355d01770904c6c775755352019f50994f
MD5 e6f50da3e82298ac8d0dbc6eb8ea2935
BLAKE2b-256 a2da1d29788450ccda9096141b2693216dbf98e942a2102bad0dc456f8930674

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page