Go to file
2013-12-06 00:44:04 +01:00
examples Reorganizing project folder 2013-08-01 18:46:40 +02:00
Live player Live player in python added 2013-12-06 00:44:04 +01:00
.gitignore Reorganizing project folder 2013-08-01 18:46:40 +02:00
generateur_partition.py Add support for english notations 2013-08-15 17:50:56 +02:00
generateur.c Now using getopt for options parsing 2013-08-15 17:50:13 +02:00
makefile Initial commit 2013-07-28 15:20:57 +02:00
README.md Live player in python added 2013-12-06 00:44:04 +01:00
wave_stuff.c Initial commit 2013-07-28 15:20:57 +02:00
wave_stuff.h Initial commit 2013-07-28 15:20:57 +02:00

(Bad) Artificial Song Generator

This is just a simple C code to handle wave files (see files wave_stuf.* for the functions) and a simple application to generate purely artificial sounds (just by creating a wave file with values from a sine wave at the good frequency to make a note).

Included files are :

  • examples folder with some examples music sheets and the resulting generated wave files
  • generateur.c which is the main program
  • generateur_musicsheet.py which is just a simple program to generate basic music sheet to use with the main program
  • wave_stuff.* which are the functions to handle wave files
  • Live_player/* : a python script to play music in live, using a, b, c, d, e, f and g keys on your keyboard.

Usage of the main program

The main program should be compiled using the makefile.

To use it, just run from command line : ./generateur.out options where

options are amongst :

  • -m (or --musicsheet) file where file is the path to the music sheet you want to generate. [mandatory argument]
  • -o (or --output) file where file is the resulting wave file. [mandatory argument]
  • -b (or --bpm) bpm where bpm is the speed of the song (in bpm). [mandatory argument]
  • -s (or --silence) to add silences between notes. [optional argument]
  • -h (or --help) to display an help message.

Usage of the basic music sheet generator

This program allows you to write a simple music sheet without always looking for the correspondance between note and frequency. It is very basic and only allows you to use notes amongst :

  • RE, MI, FA, SOL, LA, SI, DO (where LA is 440Hz)
  • RE2, MI2, FA2, SOL2, LA2, SI2, DO2 (where LA is 880Hz).

or the english corresponding notations :

  • D0, E0, F0, G0, A, B, C (where A is 440Hz)
  • D, E, F, G, A2, B2, C2 (where A2 is 880Hz)

Length is any integer you want. It will define the length of the note (play with both length and bpm (during playback) params to get what you want).

You can use the -o (--output) option with a filename as argument to store the generated music sheet to this specific file.

License

TLDR;

I don't give a damn to anything you can do using this code. It would just be nice to
quote where the original code comes from.

"THE NO-ALCOHOL BEER-WARE LICENSE" (Revision 42):

Phyks (phyks@phyks.me) wrote this file. As long as you retain this notice you
 can do whatever you want with this stuff (and you can also do whatever you want
 with this stuff without retaining it, but that's not cool... :/ ). If we meet some 
 day, and you think this stuff is worth it, you can buy me a <del>beer</del> soda 
 in return.
																		Phyks