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以符合类型标注。

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.0.tar.gz (9.8 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.0-py3-none-any.whl (6.8 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for chippymu-0.3.0.tar.gz
Algorithm Hash digest
SHA256 54c22cebd2937bb14b74f96a465e02f97e66b76db2a01b57ecb24166c8299d9e
MD5 14ce91c78df9393715f2f3bf76ad345c
BLAKE2b-256 ae5d39792c4ed5dcdaa0e63212fc2f47aaab4884125a327f36a6d8cb04fae102

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for chippymu-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ae095b028ff53266dbd708d0090f9e588b92a906025d6b0aeec3f8389d732441
MD5 850b3b4e06e21eb9bf99e7bdd209a8ec
BLAKE2b-256 98dfa8f10733c3a2eeb080980fb0a41f3d6ec3e52a8fa00244d1eff4f50d8088

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