O Midifile é uma biblioteca de classes C ++ para ler/escrever arquivos MIDI padrão. A biblioteca consiste em 6 classes:
| Midifile | A principal interface para lidar com arquivos MIDI. A classe Midifile aparece como uma matriz bidimensional de Midiencents: a primeira dimensão é uma lista de faixas e a segunda dimensão é uma lista de Midievents. |
| MidieVentlist | Uma estrutura de dados que gerencia a lista de Midievents para uma faixa de arquivo MIDI. |
| Midievent | A unidade de armazenamento primária para as medidas intermediárias em um meio. A classe consiste em um timestamp de carrapato (delta ou absoluto) e um vetor de bytes de mensagem MIDI (ou mensagens de meta de arquivo MIDI padrão). |
| Midimessage | A classe base para os Midievents. Este é um vetor STL de bytes não assinados, representando uma mensagem MIDI (ou meta). |
| BINASC | Uma classe auxiliar para Midifile que permite a leitura/gravação de arquivos MIDI em um formato ASCII descrevendo os bytes dos arquivos MIDI padrão binários. |
| Opções | Uma classe de conveniência opcional usada para analisar as opções da linha de comando nos programas de exemplo. Esta classe pode ser removida da biblioteca, pois não é necessária para o uso da classe Midifile. |
Aqui está um esquema de como as classes são usadas juntas:

A classe MidiFile contém um vetor de faixas armazenadas em objetos MidiEventList . A MidiEventList é em si um vetor de MidiEvent S, que armazena cada evento MIDI na pista. MidiEvent S contém um registro de data e hora e uma MidiMessage que é um vetor de valores de char não assinados, armazenando os bytes brutos de uma mensagem MIDI (ou meta-mensagem).
A documentação está em construção em http://midifile.sapp.org. Exemplos essenciais para leitura e gravação de arquivos MIDI são fornecidos abaixo.
Você pode baixar como um arquivo zip da página do Github para a biblioteca Midifile ou, se usar o Git, faça o download com este comando:
git clone https://github.com/craigsapp/midifile Isso criará o diretório midifile com o código -fonte da biblioteca.
A biblioteca pode ser compilada com o comando:
make library Isso criará o arquivo lib/libmidifile.a que pode ser usado para vincular -se a programas que usam a biblioteca. Exemplo de programas podem ser compilados com o comando:
make programs Isso compilará todos os programas de exemplo no diretório de ferramentas. Os programas de exemplo compilados serão armazenados no diretório bin . Para compilar a biblioteca e os programas de exemplo, tudo em uma etapa, digite:
make Para compilar apenas um único programa, como createmidifile , tipo:
make createmidifile Você também pode colocar seus próprios programas em tools , como myprogram.cpp e para compilar o tipo:
make myprogram O programa compilado será bin/myprogram .
A maneira mais fácil de usar a biblioteca Midifile em seu próprio projeto é copiar os arquivos de cabeçalho no diretório include e os arquivos de código de origem no diretório src em seu próprio projeto. Você não precisa copiar Options.h ou Options.cpp pois a classe MidiFile não depende deles. Os projetos do Verovio e Midiroll no GitHub usam esse método para usar a biblioteca Midifile. Como alternativa, você pode gastar o repositório Midifile e criar um arquivo de biblioteca compilado do código -fonte que pode ser copiado com o conteúdo do diretório include em seu projeto.
O programa a seguir lista todos os Midievents em um arquivo MIDI. O programa itera em cada faixa, imprimindo uma lista de todos os eventos MIDI na pista. Para cada evento, o timestamp absoluto para o tempo de desempenho da mensagem MIDI é dado, seguido pela própria mensagem como uma lista de bytes hexadecimais.
Você pode executar a função MidiFile::doTimeAnalysis() para converter os registros de data e hora absolutos em segundos, de acordo com quaisquer meta-mensagens de ritmo no arquivo (usando um ritmo padrão de 120 notas de quarto por minuto, se não houver meta-mensagens de tempo). O tempo de início absoluto do evento é mostrado na segunda coluna da saída do programa.
A função MidiFile::linkNotePairs() pode ser usada para corresponder ao anotações e anotações. Quando isso for feito, você pode acessar a duração da nota com MidiEvent::getDurationInSeconds() para obter mensagens de anotação. As durações das notas são mostradas na terceira coluna da saída do programa.
Observe que as classes de biblioteca Midifile estão no espaço para nome smf , portanto, using namespace smf; ou smf:: Prefixos são necessários para acessar as classes.
# include " MidiFile.h "
# include " Options.h "
# include < iostream >
# include < iomanip >
using namespace std ;
using namespace smf ;
int main ( int argc, char ** argv) {
Options options;
options. process (argc, argv);
MidiFile midifile;
if (options. getArgCount () == 0 ) midifile. read (cin);
else midifile. read (options. getArg ( 1 ));
midifile. doTimeAnalysis ();
midifile. linkNotePairs ();
int tracks = midifile. getTrackCount ();
cout << " TPQ: " << midifile. getTicksPerQuarterNote () << endl;
if (tracks > 1 ) cout << " TRACKS: " << tracks << endl;
for ( int track= 0 ; track<tracks; track++) {
if (tracks > 1 ) cout << " n Track " << track << endl;
cout << " Tick t Seconds t Dur t Message " << endl;
for ( int event= 0 ; event<midifile[track]. size (); event++) {
cout << dec << midifile[track][event]. tick ;
cout << ' t ' << dec << midifile[track][event]. seconds ;
cout << ' t ' ;
if (midifile[track][event]. isNoteOn ())
cout << midifile[track][event]. getDurationInSeconds ();
cout << ' t ' << hex;
for ( int i= 0 ; i<midifile[track][event]. size (); i++)
cout << ( int )midifile[track][event][i] << ' ' ;
cout << endl;
}
}
return 0 ;
} O programa de exemplo acima lerá o primeiro nome do arquivo que encontra na linha de comando, ou será lido a partir da entrada padrão se nenhum argumento for encontrado. Os arquivos MIDI padrão binários e as representações ASCII dos arquivos MIDI podem ser inseridos no programa. Por exemplo, salve o texto a seguir em um arquivo chamado twinkle.txt para usar como dados de entrada. Esse conteúdo representa os bytes hexadecimais para um arquivo MIDI padrão, que será analisado automaticamente pela classe MidiFile .
4d 54 68 64 00 00 00 06 00 01 00 03 00 78 4d 54 72 6b 00 00 00 04 00 ff 2f
00 4d 54 72 6b 00 00 00 76 00 90 48 40 78 80 48 40 00 90 48 40 78 80 48 40
00 90 4f 40 78 80 4f 40 00 90 4f 40 78 80 4f 40 00 90 51 40 78 80 51 40 00
90 51 40 78 80 51 40 00 90 4f 40 81 70 80 4f 40 00 90 4d 40 78 80 4d 40 00
90 4d 40 78 80 4d 40 00 90 4c 40 78 80 4c 40 00 90 4c 40 78 80 4c 40 00 90
4a 40 78 80 4a 40 00 90 4a 40 78 80 4a 40 00 90 48 40 81 70 80 48 40 00 ff
2f 00 4d 54 72 6b 00 00 00 7d 00 90 30 40 78 80 30 40 00 90 3c 40 78 80 3c
40 00 90 40 40 78 80 40 40 00 90 3c 40 78 80 3c 40 00 90 41 40 78 80 41 40
00 90 3c 40 78 80 3c 40 00 90 40 40 78 80 40 40 00 90 3c 40 78 80 3c 40 00
90 3e 40 78 80 3e 40 00 90 3b 40 78 80 3b 40 00 90 3c 40 78 80 3c 40 00 90
39 40 78 80 39 40 00 90 35 40 78 80 35 40 00 90 37 40 78 80 37 40 00 90 30
40 81 70 80 30 40 00 ff 2f 00
Abaixo está a saída do programa de exemplo, dados os dados de entrada acima. O valor TPQ é o valor de ticks por nota do trimestre do cabeçalho MIDI. Neste exemplo, cada nota de trimestre tem uma duração de 120 ticks de arquivo MIDI. O arquivo MIDI acima contém três faixas, com a primeira faixa (a faixa de expressão, sem conteúdo além da meta mensagem de fim de pista, ff 2f 00 em bytes hexadecimais. A segunda faixa começa com uma mensagem MIDI-ON 90 48 40 (em hex) que começará a tocar Midi Note 72 (uma oitava em uma oitava acima do meio-médio) com uma sonoridade média (40.
TPQ: 120 Faixas: 3 Faixa 0 Tick segundos durante a mensagem 0 0 ff 2f 0 Faixa 1 Tick segundos durante a mensagem 0 0 0,5 90 48 40 120 0,5 80 48 40 120 0,5 0,5 90 48 40 240 1 80 48 40 240 1 0,5 90 4f 40 360 1,5 80 4f 40 360 1,5 0,5 90 4f 40 480 2 80 4f 40 480 2 0,5 90 51 40 600 2,5 80 51 40 600 2,5 0,5 90 51 40 720 3 80 51 40 720 3 1 90 4f 40 960 4 80 4f 40 960 4 0,5 90 4d 40 1080 4,5 80 4d 40 1080 4,5 0,5 90 4d 40 1200 5 80 4D 40 1200 5 0,5 90 4C 40 1320 5,5 80 4c 40 1320 5,5 0,5 90 4C 40 1440 6 80 4C 40 1440 6 0,5 90 4A 40 1560 6,5 80 4A 40 1560 6,5 0,5 90 4A 40 1680 7 80 4A 40 1680 7 1 90 48 40 1920 8 80 48 40 1920 8 ff 2f 0 Faixa 2 Tick segundos durante a mensagem 0 0 0,5 90 30 40 120 0,5 80 30 40 120 0,5 0,5 90 3C 40 240 1 80 3C 40 240 1 0,5 90 40 40 360 1,5 80 40 40 360 1,5 0,5 90 3c 40 480 2 80 3C 40 480 2 0,5 90 41 40 600 2,5 80 41 40 600 2,5 0,5 90 3C 40 720 3 80 3C 40 720 3 0,5 90 40 40 840 3,5 80 40 40 840 3,5 0,5 90 3C 40 960 4 80 3C 40 960 4 0,5 90 3e 40 1080 4,5 80 3e 40 1080 4,5 0,5 90 3b 40 1200 5 80 3b 40 1200 5 0,5 90 3C 40 1320 5,5 80 3c 40 1320 5,5 0,5 90 39 40 1440 6 80 39 40 1440 6 0,5 90 35 40 1560 6.5 80 35 40 1560 6,5 0,5 90 37 40 1680 7 80 37 40 1680 7 1 90 30 40 1920 8 80 30 40 1920 8 ff 2f 0
O comportamento padrão da classe MidiFile é armazenar os tempos de ticks absolutos dos eventos MIDI, disponíveis no MidiEvent::tick , que é a hora do tique -taque desde o início do arquivo até o evento atual. Nos arquivos MIDI padrão, o Tick são armazenados como valores delta, onde o tick indica a duração a ser esperado desde a mensagem anterior em uma faixa. Para acessar os valores do Tick Delta, você pode (1) subtrair o horário atual do tique -taque a partir do horário anterior da lista ou ligar para MidiFile::makeDeltaTime() para converter os valores absolutos do Tick em valores do Tick Delta.
A função MidiFile::joinTracks() pode ser usada para converter dados de várias faixas em uma única sequência de tempo. A operação joinTrack() pode ser revertida chamando a função MidiFile::splitTracks() . Aqui está uma amostra de programa que se junta aos MidiEvents em uma única faixa para que os dados possam ser processados em um único loop:
# include " MidiFile.h "
# include " Options.h "
# include < iostream >
# include < iomanip >
using namespace std ;
using namespace smf ;
int main ( int argc, char ** argv) {
Options options;
options. process (argc, argv);
MidiFile midifile;
if (options. getArgCount () > 0 ) midifile. read (options. getArg ( 1 ));
else midifile. read (cin);
cout << " TPQ: " << midifile. getTicksPerQuarterNote () << endl;
cout << " TRACKS: " << midifile. getTrackCount () << endl;
midifile. joinTracks ();
// midifile.getTrackCount() will now return "1", but original
// track assignments can be seen in .track field of MidiEvent.
cout << " TICK DELTA TRACK MIDI MESSAGE n " ;
cout << " ____________________________________ n " ;
MidiEvent* mev;
int deltatick;
for ( int event= 0 ; event < midifile[ 0 ]. size (); event++) {
mev = &midifile[ 0 ][event];
if (event == 0 ) deltatick = mev-> tick ;
else deltatick = mev-> tick - midifile[ 0 ][event- 1 ]. tick ;
cout << dec << mev-> tick ;
cout << ' t ' << deltatick;
cout << ' t ' << mev-> track ;
cout << ' t ' << hex;
for ( int i= 0 ; i < mev-> size (); i++)
cout << ( int )(*mev)[i] << ' ' ;
cout << endl;
}
return 0 ;
}Abaixo está a nova saída de faixa única. A primeira coluna é o timestamp absoluto da mensagem; A segunda coluna é o valor do Tick Delta; A terceira coluna é o valor da faixa original; e a última coluna contém a mensagem MIDI (em bytes hexadecimais).
TPQ: 120 Faixas: 3 Tick Delta Track Midi Mensagem ____________________________________ 0 0 1 90 48 40 0 0 2 90 30 40 0 0 0 ff 2f 0 120 120 1 80 48 40 120 0 2 80 30 40 120 0 2 90 3C 40 120 0 1 90 48 40 240 120 2 80 3C 40 240 0 1 80 48 40 240 0 2 90 40 40 240 0 1 90 4f 40 360 120 2 80 40 40 360 0 1 80 4f 40 360 0 1 90 4f 40 360 0 2 90 3C 40 480 120 2 80 3C 40 480 0 1 80 4F 40 480 0 2 90 41 40 480 0 1 90 51 40 600 120 2 80 41 40 600 0 1 80 51 40 600 0 1 90 51 40 600 0 2 90 3C 40 720 120 1 80 51 40 720 0 2 80 3C 40 720 0 2 90 40 40 720 0 1 90 4F 40 840 120 2 80 40 40 840 0 2 90 3C 40 960 120 2 80 3C 40 960 0 1 80 4f 40 960 0 2 90 3e 40 960 0 1 90 4D 40 1080 120 1 80 4D 40 1080 0 2 80 3E 40 1080 0 2 90 3b 40 1080 0 1 90 4D 40 1200 120 1 80 4D 40 1200 0 2 80 3b 40 1200 0 2 90 3C 40 1200 0 1 90 4C 40 1320 120 1 80 4C 40 1320 0 2 80 3C 40 1320 0 1 90 4C 40 1320 0 2 90 39 40 1440 120 1 80 4C 40 1440 0 2 80 39 40 1440 0 1 90 4A 40 1440 0 2 90 35 40 1560 120 1 80 4A 40 1560 0 2 80 35 40 1560 0 2 90 37 40 1560 0 1 90 4A 40 1680 120 1 80 4A 40 1680 0 2 80 37 40 1680 0 2 90 30 40 1680 0 1 90 48 40 1920 240 1 80 48 40 1920 0 2 80 30 40 1920 0 1 ff 2f 0 1920 0 2 ff 2f 0
Abaixo está um programa de exemplo para criar um arquivo MIDI. Este programa gerará uma sequência aleatória de notas e as anexará ao final da faixa. Por padrão, um objeto MidiFile contém uma única faixa e será escrito como um arquivo MIDI tipo 0, a menos que mais faixas sejam adicionadas. Depois de adicionar notas à faixa, ela deve ser classificada na sequência do tempo antes de ser gravada em um arquivo.
# include " MidiFile.h "
# include " Options.h "
# include < random >
# include < iostream >
using namespace std ;
using namespace smf ;
int main ( int argc, char ** argv) {
Options options;
options. define ( " n|note-count=i:10 " , " How many notes to randomly play " );
options. define ( " o|output-file=s " , " Output filename (stdout if none) " );
options. define ( " i|instrument=i:0 " , " General MIDI instrument number " );
options. define ( " x|hex=b " , " Hex byte-code output " );
options. process (argc, argv);
random_device rd;
mt19937 mt ( rd ());
uniform_int_distribution< int > starttime ( 0 , 100 );
uniform_int_distribution< int > duration ( 1 , 8 );
uniform_int_distribution< int > pitch ( 36 , 84 );
uniform_int_distribution< int > velocity ( 40 , 100 );
MidiFile midifile;
int track = 0 ;
int channel = 0 ;
int instr = options. getInteger ( " instrument " );
midifile. addTimbre (track, 0 , channel, instr);
int tpq = midifile. getTPQ ();
int count = options. getInteger ( " note-count " );
for ( int i= 0 ; i<count; i++) {
int starttick = int ( starttime (mt) / 4.0 * tpq);
int key = pitch (mt);
int endtick = starttick + int ( duration (mt) / 4.0 * tpq);
midifile. addNoteOn (track, starttick, channel, key, velocity (mt));
midifile. addNoteOff (track, endtick, channel, key);
}
midifile. sortTracks (); // Need to sort tracks since added events are
// appended to track in random tick order.
string filename = options. getString ( " output-file " );
if (filename. empty ()) {
if (options. getBoolean ( " hex " )) midifile. writeHex (cout);
else cout << midifile;
} else
midifile. write (filename);
return 0 ;
}Se nenhum arquivo de saída for especificado, o conteúdo do arquivo MIDI será impresso no formato BINASC na saída padrão, que pode ser lida de volta em um objeto médio e convertida em um arquivo MIDI padrão (consulte o exemplo de leitura/gravação mais adiante na página para fazer isso):
"MThd" ; MIDI header chunk marker
4'6 ; bytes to follow in header chunk
2'0 ; file format: Type-0 (single track)
2'1 ; number of tracks
2'120 ; ticks per quarter note
;;; TRACK 0 ----------------------------------
"MTrk" ; MIDI track chunk marker
4'89 ; bytes to follow in track chunk
v30 90 '74 '72 ; note-on D5
v150 90 '68 '88 ; note-on G#4
v0 90 '79 '83 ; note-on G5
v60 90 '74 '0 ; note-off D5
v150 90 '79 '0 ; note-off G5
v30 90 '68 '0 ; note-off G#4
v990 90 '60 '100 ; note-on C4
v90 90 '60 '0 ; note-off C4
v630 90 '83 '69 ; note-on B5
v60 90 '83 '0 ; note-off B5
v30 90 '56 '51 ; note-on G#3
v90 90 '56 '0 ; note-off G#3
v390 90 '78 '46 ; note-on F#5
v30 90 '60 '78 ; note-on C4
v90 90 '78 '0 ; note-off F#5
v0 90 '70 '56 ; note-on A#4
v60 90 '76 '100 ; note-on E5
v90 90 '60 '0 ; note-off C4
v30 90 '76 '0 ; note-off E5
v60 90 '70 '0 ; note-off A#4
v0 ff 2f v0 ; end-of-track
Aqui estão os dados MIDI visualizados com o programa de exemplo Mid2Svg:

A opção -x pode ser usada para gerar os dados como codos de bytes hexadecimal, a opção -n controla o número de notas e -i # especifica o número do instrumento a ser usado:
myprogram -n 100 -x -i 24Produz o arquivo MIDI do código de bytes hexadecimal:
4d 54 68 64 00 00 00 06 00 00 00 01 00 78 4d 54 72 6b 00 00 03 27 00 c0 18
1e 90 4d 2f 1e 90 31 5e 00 90 40 42 1e 90 47 55 1e 90 47 00 00 90 31 00 00
90 32 62 1e 90 43 2d 1e 90 43 00 00 90 3f 5f 1e 90 32 00 1e 90 4d 00 00 90
47 38 1e 90 51 33 1e 90 40 00 00 90 31 31 00 90 35 3a 1e 90 24 41 00 90 4d
4f 00 90 4e 32 1e 90 31 00 00 90 51 00 1e 90 4e 00 00 90 48 51 1e 90 3f 00
00 90 24 00 1e 90 47 00 1e 90 35 00 00 90 2c 61 1e 90 4d 63 3c 90 4d 00 00
90 48 00 00 90 33 30 1e 90 2c 00 00 90 4d 00 00 90 40 5f 00 90 45 5f 00 90
3e 58 00 90 3f 45 00 90 24 4a 1e 90 33 00 00 90 3c 3c 1e 90 32 38 1e 90 39
40 1e 90 53 43 1e 90 40 00 00 90 3f 00 00 90 3e 00 00 90 45 00 00 90 4d 62
1e 90 24 00 00 90 32 00 00 90 30 42 00 90 2d 28 1e 90 3c 00 00 90 4d 00 00
90 53 00 00 90 2a 45 3c 90 36 51 1e 90 39 00 00 90 2a 00 00 90 36 4b 3c 90
36 00 00 90 3e 5c 1e 90 2d 00 1e 90 30 00 00 90 3e 00 3c 90 41 48 00 90 37
3f 00 90 36 3a 00 90 41 51 00 90 46 38 3c 90 36 00 1e 90 36 00 00 90 46 00
00 90 36 58 1e 90 41 00 00 90 32 44 00 90 47 2a 1e 90 37 00 00 90 45 2b 1e
90 41 53 00 90 3e 2d 1e 90 3e 00 00 90 33 28 00 90 29 4b 1e 90 41 00 00 90
41 00 1e 90 29 00 00 90 49 51 1e 90 47 00 00 90 35 49 00 90 49 43 1e 90 35
00 00 90 45 00 00 90 36 00 00 90 27 5c 1e 90 32 00 1e 90 49 00 00 90 28 4d
1e 90 49 00 00 90 33 00 00 90 2e 44 1e 90 29 2b 3c 90 27 00 00 90 24 3e 00
90 28 53 00 90 52 51 1e 90 4d 4f 00 90 26 5c 1e 90 28 00 00 90 29 00 00 90
27 32 1e 90 28 00 00 90 2e 00 00 90 4d 00 1e 90 2f 28 1e 90 4a 5a 00 90 47
43 1e 90 4a 00 00 90 52 00 00 90 24 00 00 90 34 2f 1e 90 2f 00 00 90 3c 5e
00 90 28 4f 00 90 32 2d 1e 90 26 00 00 90 3c 00 00 90 27 00 00 90 53 63 1e
90 47 00 1e 90 32 00 00 90 44 5d 00 90 32 40 1e 90 28 00 00 90 46 46 1e 90
34 00 1e 90 2a 3e 1e 90 53 00 00 90 3a 3f 00 90 53 31 1e 90 28 5f 1e 90 28
00 00 90 46 00 00 90 53 00 00 90 2a 00 1e 90 32 00 00 90 3a 00 00 90 44 00
3c 90 33 4d 1e 90 53 57 00 90 54 30 1e 90 38 45 1e 90 2f 46 1e 90 2f 00 00
90 33 00 1e 90 3a 61 00 90 38 40 1e 90 54 00 00 90 27 37 1e 90 3a 00 00 90
53 00 00 90 32 29 1e 90 38 00 00 90 40 2b 00 90 36 41 1e 90 38 00 00 90 34
46 1e 90 27 00 5a 90 36 00 00 90 32 00 00 90 40 00 00 90 48 4a 5a 90 34 00
00 90 48 00 1e 90 29 62 00 90 3e 4d 1e 90 39 3e 00 90 4a 2d 00 90 40 2d 3c
90 39 00 00 90 4a 00 00 90 25 58 1e 90 29 00 00 90 41 37 00 90 45 4c 00 90
4d 64 1e 90 41 00 00 90 3e 00 1e 90 4d 00 3c 90 40 00 00 90 25 00 00 90 39
4a 3c 90 32 43 1e 90 45 4a 1e 90 45 00 3c 90 45 00 3c 90 32 00 00 90 39 00
00 ff 2f 00
Visualização com bin/mid2svg -s 6 -a 12 -v :

Aqui está um exemplo de programa mínimo que converte os códigos de byte hexadecimal acima em um arquivo MIDI padrão:
# include " MidiFile.h "
# include < iostream >
using namespace std ;
using namespace smf ;
int main ( int argc, char ** argv) {
if (argc != 3 ) return 1 ;
MidiFile midifile;
midifile. read (argv[ 1 ]);
if (midifile. status ()) midifile. write (argv[ 2 ]);
else cerr << " Problem reading MIDI file " << argv[ 1 ] << endl;
} A função MidiFile::read() identificará automaticamente se a entrada é um arquivo MIDI padrão binário, uma representação de código de bytes hexadecimal ou um arquivo de sintaxe de binasc generalizado (que inclui códigos de bytes). A função MidiFile::status() pode ser verificada após a leitura de um arquivo MIDI para determinar se o arquivo foi lido sem problemas.
Este exemplo usa o MidiFile::getFileDurationInSeconds() para calcular a duração de um arquivo MIDI. Além disso, este exemplo mostra como processar vários arquivos de entrada ao usar a classe Options.
# include " MidiFile.h "
# include " Options.h "
# include < iostream >
using namespace std ;
using namespace smf ;
int main ( int argc, char ** argv) {
Options options;
options. process (argc, argv);
MidiFile midifile;
if (options. getArgCount () == 0 ) {
midifile. read (cin);
cout << midifile. getFileDurationInSeconds () << " seconds " << endl;
} else {
int count = options. getArgCount ();
for ( int i= 0 ; i<count; i++) {
string filename = options. getArg (i+ 1 );
if (count > 1 ) cout << filename << " t " ;
midifile. read (filename);
cout << midifile. getFileDurationInSeconds () << " seconds " << endl;
}
}
return 0 ;
} A função MidiMessage::isText() retornará verdadeira se a mensagem for uma meta-mensagem de texto. O programa a seguir mescla todas as faixas em uma única lista e faz uma verificação de um loop quanto a meta-mensagens de texto, imprimindo-as quando encontradas. A função MidiMessage::getMetaContent() extrai a sequência de texto da mensagem dos bytes de arquivo MIDI bruto.
# include " MidiFile.h "
# include < iostream >
using namespace std ;
using namespace smf ;
int main ( int argc, char ** argv) {
MidiFile midifile;
if (argc == 1 ) midifile. read (cin);
else midifile. read (argv[ 1 ]);
if (!midifile. status ()) {
cerr << " Problem reading MIDI file " << endl;
return 1 ;
}
midifile. joinTracks ();
for ( int i= 0 ; i<midifile[ 0 ]. getEventCount (); i++) {
if (midifile[ 0 ][i]. isText ()) {
string content = midifile[ 0 ][i]. getMetaContent ();
cout << content << endl;
}
}
return 0 ;
} Extrair as letras funcionariam da mesma forma usando .isLyricText() em vez de .isText() , e uma meta-mensagem de nome de faixa é identificada por .isTrackName() .
Aqui está uma demonstração de converter um arquivo MIDI de várias faixas em um arquivo MIDI de faixa única:
# include " MidiFile.h "
# include < iostream >
using namespace std ;
using namespace smf ;
int main ( int argc, char ** argv) {
if (argc != 3 ) {
cerr << " Usage: " << argv[ 0 ] << " input output " << endl;
return 1 ;
}
MidiFile midifile;
midifile. read (argv[ 1 ]);
if (!midifile. status ()) {
cerr << " Problem reading MIDI file " << endl;
return 1 ;
}
midifile. joinTracks ();
midifile. write (argv[ 2 ]);
return 0 ;
}
A função .joinTracks() mescla todas as faixas em uma única faixa. E se um objeto MidiFile tiver apenas uma faixa quando estiver sendo gravada, ele será escrito como um arquivo MIDI do tipo 0 (faixa única).
Nos arquivos MIDI em geral, a faixa da bateria está no 10º canal, que é representado pelo número inteiro 9. O exemplo a seguir pesquisam os eventos MIDI em cada faixa até encontrar uma nota no canal 9:
# include " MidiFile.h "
# include < iostream >
using namespace std ;
using namespace smf ;
int main ( int argc, char ** argv) {
MidiFile midifile;
if (argc == 1 ) midifile. read (cin);
else midifile. read (argv[ 1 ]);
if (!midifile. status ()) {
cerr << " Problem reading MIDI file " << endl;
return 1 ;
}
bool found = false ;
for ( int i= 0 ; i<midifile. getTrackCount (); i++) {
for ( int j= 0 ; j<midifile[i]. getEventCount (); j++) {
if (midifile[i][j]. isNote ()) {
int channel = midifile[i][j]. getChannelNibble ();
if (channel == 9 ) {
found = true ;
break ;
}
}
}
if (found == true ) break ;
}
if (found) cout << " Has a percussion part. " << endl;
else cout << " Does not have a percussion part. " << endl;
return 0 ;
}Para alguns aplicativos de análise musical, é útil remover as notas de percussão de um arquivo MIDI. Aqui está um exemplo de como isso pode ser feito com a biblioteca Midifile.
# include " MidiFile.h "
# include < iostream >
using namespace std ;
using namespace smf ;
int main ( int argc, char ** argv) {
if (argc != 3 ) {
cerr << " Usage: " << argv[ 0 ] << " input output " << endl;
return 1 ;
}
MidiFile midifile;
midifile. read (argv[ 1 ]);
if (!midifile. status ()) {
cerr << " Problem reading MIDI file " << endl;
return 1 ;
}
for ( int i= 0 ; i<midifile. getTrackCount (); i++) {
for ( int j= 0 ; j<midifile[i]. getEventCount (); j++) {
if (midifile[i][j]. isNote ()) {
int channel = midifile[i][j]. getChannelNibble ();
if (channel == 9 ) {
midifile[i][j]. clear ();
}
}
}
}
midifile. removeEmpties (); // optional
midifile. write (argv[ 2 ]);
return 0 ;
} Para excluir uma mensagem MIDI, limpe sua classe base de vetores. Isso deixará um MidiEvent vazio na pista, mas a função MidiFile::write() ignorará qualquer MidiMessage vazio. A função MidiFile::removeEmpties() pode ser chamada para remover explicitamente qualquer MidiEvents vazio da pista.
Este exemplo mostra como transpor notas em um arquivo MIDI. Deve -se tomar cuidado para evitar a transposição do canal 10 em General Midi, pois isso é reservado para a faixa de bateria (e a maioria dos arquivos MIDI usa a Convenção Midi em geral).
# include " MidiFile.h "
# include " Options.h "
# include < iostream >
using namespace std ;
using namespace smf ;
int main ( int argc, char ** argv) {
Options options;
options. define ( " t|transpose=i:0 " , " Semitones to transpose by " );
options. process (argc, argv);
MidiFile midifile;
if (options. getArgCount () == 0 ) midifile. read (cin);
else midifile. read (options. getArg ( 1 ));
if (!midifile. status ()) {
cerr << " Could not read MIDI file " << endl;
return 1 ;
}
int transpose = options. getInteger ( " transpose " );
for ( int i= 0 ; i<midifile. getTrackCount (); i++) {
for ( int j= 0 ; j<midifile[i]. getEventCount (); j++) {
if (!midifile[i][j]. isNote ()) continue ;
if (midifile[i][j]. getChannel () == 9 ) continue ;
int newkey = transpose + midifile[i][j]. getP1 ();
midifile[i][j]. setP1 (newkey);
}
}
if (options. getArgCount () < 2 ) cout << midifile;
else midifile. write (options. getArg ( 2 ));
return 0 ;
}O exemplo a seguir lista todos os números de instrumentos usados em um arquivo MIDI. Ele não analisa a pista de bateria.
# include " MidiFile.h "
# include " Options.h "
# include < set >
# include < utility >
# include < iostream >
using namespace std ;
using namespace smf ;
int main ( int argc, char ** argv) {
Options options;
options. process (argc, argv);
MidiFile midifile;
if (options. getArgCount () == 0 ) midifile. read (cin);
else midifile. read (options. getArg ( 1 ));
if (!midifile. status ()) {
cerr << " Could not read MIDI file " << endl;
return 1 ;
}
pair< int , int > trackinst;
set<pair< int , int >> iset;
for ( int i= 0 ; i<midifile. getTrackCount (); i++) {
for ( int j= 0 ; j<midifile[i]. getEventCount (); j++) {
if (midifile[i][j]. isTimbre ()) {
trackinst. first = i;
trackinst. second = midifile[i][j]. getP1 ();
iset. insert (trackinst);
}
}
}
for ( auto it : iset)
cout << " Track: " << it. first << " t Instrument: " << it. second << endl;
return 0 ;
}Se você deseja simular o temperamento em um arquivo MIDI padrão sem um sintetizador que conhece especificamente sobre o temperamento, este exemplo é útil. Cada classe de inclinação é colocada em uma pista separada e canal MIDI. Uma mensagem de inclinação é então adicionada ao início de cada faixa em cada canal para controlar o temperamento. É tomado cuidado para evitar o canal 10 do MIDI, que é reservado para timbres de percussão em geral MIDI.
# include " MidiFile.h "
# include < iostream >
using namespace std ;
using namespace smf ;
int main ( int argc, char ** argv) {
if (argc != 3 ) {
cerr << " Usage: " << argv[ 0 ] << " input output " << endl;
return 1 ;
}
MidiFile midifile;
midifile. read (argv[ 1 ]);
if (!midifile. status ()) {
cerr << " Problem reading MIDI file " << endl;
return 1 ;
}
midifile. joinTracks ();
for ( int i= 0 ; i<midifile[ 0 ]. getEventCount (); i++) {
midifile[ 0 ][i]. seq = 2 ;
if (!midifile[ 0 ][i]. isNote ()) {
midifile[ 0 ][i]. track = 0 ;
continue ;
}
int pc = midifile[ 0 ][i]. getP1 () % 12 ;
int channel = midifile[ 0 ][i]. getChannelNibble ();
if (channel != 9 ) {
midifile[ 0 ][i]. track = pc + 1 ;
if (pc >= 9 ) pc++;
midifile[ 0 ][i]. setChannelNibble (pc);
} else midifile[ 0 ][i]. track = 13 ;
}
midifile. splitTracks ();
double maxbend = 200.0 ; // typical pitch-bend depth in cents on synthesizers
// pythagorean tuning deviations from equal temperament in cents.
vector< double > pythagorean = {- 3.91 , 9.78 , 0.00 , - 9.78 , 3.91 , - 5.87 , 7.82 ,
- 1.96 , - 11.73 , 1.96 , - 7.82 , 5.87 };
for ( int i= 0 ; i< 12 ; i++) {
int maxtrack = midifile. getTrackCount ();
int track = i+ 1 ;
if (track >= maxtrack) break ;
int channel = i;
if (i >= 9 ) channel++;
double bend = pythagorean[i] / maxbend;
MidiEvent* me = midifile. addPitchBend (track, 0 , channel, bend);
me-> seq = 1 ;
}
midifile. sortTracks ();
midifile. write (argv[ 2 ]);
return 0 ;
} A função MidiFile::splitTracks() gerará 13 ou 14 faixas. A faixa 0 conterá todas as mensagens MIDI não notas do arquivo original, enquanto as faixas de 1 a 12 conterão notas de uma classe específica nos canais MIDI 1-12, pulando o canal 10 (o canal de percussão geral do MIDI). As notas de percussão serão colocadas na faixa 13, mas permanecerão no canal 10.
O uso de MidiEvent::seq está sendo definido como 1 e 2 no programa é usado para forçar as primeiras notas no horário de tick 0 a serem colocadas após as mensagens de curvatura inseridas no mesmo registro de data e hora quando MidiFile::sortTracks() é chamado (eventos com um número de sequência mais baixo serão colocados antes daqueles com um número mais alto. As mensagens de curvatura provavelmente seriam classificadas antes das notas de qualquer maneira, mas o uso seq deve garantir que elas sejam colocadas antes das primeiras notas.
Experimente este programa no bem-humorado Clavier de Bach, Livro I, Fugue No. 4 em C-Sharp Minor:
4d 54 68 64 00 00 00 06 00 01 00 06 00 78 4d 54 72 6b 00 00 00 13 00 ff 51 03 08 8e 6c 00 ff 58 04 02 01 30 08 00 ff 2f
00 4d 54 72 6b 00 00 09 bd b2 50 90 49 40 81 70 80 49 40 00 90 48 40 81 70 80 48 40 00 90 4c 40 81 70 80 4c 40 00 90 4b
40 83 60 80 4b 40 00 90 49 40 82 68 80 49 40 00 90 4b 40 78 80 4b 40 00 90 4c 40 78 80 4c 40 00 90 4b 40 78 80 4b 40 00
90 49 40 81 70 80 49 40 00 90 47 40 81 70 80 47 40 00 90 49 40 81 70 80 49 40 00 90 4b 40 81 70 80 4b 40 82 68 90 4c 40
78 80 4c 40 00 90 4b 40 78 80 4b 40 00 90 49 40 78 80 49 40 00 90 47 40 78 80 47 40 00 90 4b 40 78 80 4b 40 00 90 50 40
82 68 80 50 40 00 90 4e 40 78 80 4e 40 00 90 50 40 78 80 50 40 00 90 51 40 78 80 51 40 00 90 53 40 84 58 80 53 40 00 90
51 40 78 80 51 40 00 90 50 40 78 80 50 40 00 90 4e 40 78 80 4e 40 00 90 50 40 3c 80 50 40 00 90 4e 40 3c 80 4e 40 00 90
4c 40 3c 80 4c 40 00 90 4b 40 3c 80 4b 40 00 90 49 40 83 60 80 49 40 00 90 47 40 82 68 80 47 40 00 90 49 40 78 80 49 40
00 90 47 40 78 80 47 40 00 90 45 40 78 80 45 40 00 90 44 40 81 70 80 44 40 00 90 46 40 78 80 46 40 00 90 47 40 78 80 47
40 00 90 49 40 81 70 80 49 40 00 90 47 40 83 60 80 47 40 00 90 46 40 81 70 80 46 40 00 90 47 40 84 58 80 47 40 00 90 49
40 78 80 49 40 00 90 4b 40 78 80 4b 40 00 90 4c 40 78 80 4c 40 00 90 4c 40 81 70 80 4c 40 00 90 4b 40 81 70 80 4b 40 00
90 4c 40 78 80 4c 40 00 90 4b 40 78 80 4b 40 00 90 4c 40 78 80 4c 40 00 90 4e 40 78 80 4e 40 00 90 50 40 3c 80 50 40 00
90 4e 40 3c 80 4e 40 00 90 50 40 3c 80 50 40 00 90 51 40 3c 80 51 40 00 90 50 40 3c 80 50 40 00 90 4e 40 3c 80 4e 40 00
90 4c 40 3c 80 4c 40 00 90 50 40 3c 80 50 40 00 90 4e 40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 4e 40 3c 80 4e 40 00
90 50 40 3c 80 50 40 00 90 4e 40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 4b 40 3c 80 4b 40 00 90 4e 40 3c 80 4e 40 00
90 4c 40 3c 80 4c 40 00 90 4b 40 3c 80 4b 40 00 90 4c 40 3c 80 4c 40 00 90 4e 40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00
90 4b 40 3c 80 4b 40 00 90 49 40 3c 80 49 40 00 90 4c 40 3c 80 4c 40 00 90 4b 40 3c 80 4b 40 00 90 49 40 3c 80 49 40 00
90 4b 40 3c 80 4b 40 00 90 4c 40 3c 80 4c 40 00 90 4b 40 3c 80 4b 40 00 90 49 40 3c 80 49 40 00 90 47 40 3c 80 47 40 00
90 4b 40 3c 80 4b 40 00 90 49 40 3c 80 49 40 00 90 47 40 3c 80 47 40 00 90 49 40 3c 80 49 40 00 90 4b 40 3c 80 4b 40 00
90 49 40 3c 80 49 40 00 90 47 40 3c 80 47 40 00 90 46 40 3c 80 46 40 00 90 49 40 3c 80 49 40 00 90 47 40 82 2c 80 47 40
00 90 49 40 3c 80 49 40 00 90 4b 40 3c 80 4b 40 00 90 47 40 3c 80 47 40 00 90 49 40 82 68 80 49 40 00 90 4c 40 78 80 4c
40 00 90 4b 40 82 68 80 4b 40 00 90 4e 40 78 80 4e 40 00 90 4c 40 84 58 80 4c 40 00 90 4b 40 81 70 80 4b 40 00 90 49 40
81 70 80 49 40 00 90 48 40 3c 80 48 40 00 90 46 40 3c 80 46 40 00 90 48 40 78 80 48 40 00 90 4b 40 78 80 4b 40 00 90 50
40 3c 80 50 40 00 90 4e 40 3c 80 4e 40 00 90 50 40 3c 80 50 40 00 90 51 40 3c 80 51 40 00 90 50 40 3c 80 50 40 00 90 4e
40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 50 40 3c 80 50 40 00 90 4e 40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 4e
40 3c 80 4e 40 00 90 50 40 3c 80 50 40 00 90 4e 40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 4b 40 3c 80 4b 40 00 90 4e
40 3c 80 4e 40 00 90 4d 40 81 70 80 4d 40 00 90 51 40 81 70 80 51 40 00 90 50 40 84 58 80 50 40 00 90 4e 40 3c 80 4e 40
00 90 4c 40 3c 80 4c 40 00 90 4a 40 81 70 80 4a 40 78 90 49 40 78 80 49 40 00 90 4e 40 78 80 4e 40 00 90 4e 40 78 80 4e
40 00 90 4e 40 78 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 4a 40 3c 80 4a 40 00 90 4c 40 82 68 80 4c 40 00 90 4a 40 3c 80
4a 40 00 90 49 40 3c 80 49 40 00 90 4a 40 83 60 80 4a 40 00 90 49 40 81 70 80 49 40 00 90 4e 40 81 70 80 4e 40 00 90 4c
40 81 70 80 4c 40 00 90 4c 40 81 34 80 4c 40 00 90 4e 40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 4a 40 3c 80 4a 40 00
90 49 40 3c 80 49 40 00 90 4c 40 3c 80 4c 40 00 90 4a 40 3c 80 4a 40 00 90 49 40 3c 80 49 40 00 90 4a 40 3c 80 4a 40 00
90 4c 40 3c 80 4c 40 00 90 4a 40 3c 80 4a 40 00 90 49 40 3c 80 49 40 00 90 47 40 3c 80 47 40 00 90 4a 40 3c 80 4a 40 00
90 49 40 83 60 80 49 40 00 90 48 40 81 70 80 48 40 00 90 4c 40 81 70 80 4c 40 00 90 4b 40 84 58 80 4b 40 00 90 44 40 78
80 44 40 00 90 49 40 78 80 49 40 00 90 49 40 78 80 49 40 00 90 49 40 78 80 49 40 00 90 47 40 3c 80 47 40 00 90 45 40 3c
80 45 40 00 90 47 40 83 60 80 47 40 00 90 45 40 81 70 80 45 40 00 90 44 40 81 70 80 44 40 81 70 90 4b 40 83 60 80 4b 40
00 90 4a 40 81 70 80 4a 40 00 90 4e 40 81 70 80 4e 40 00 90 4d 40 81 70 80 4d 40 00 90 4c 40 81 70 80 4c 40 00 90 4b 40
3c 80 4b 40 00 90 49 40 3c 80 49 40 00 90 4b 40 3c 80 4b 40 00 90 4c 40 3c 80 4c 40 00 90 4b 40 3c 80 4b 40 00 90 49 40
3c 80 49 40 00 90 47 40 3c 80 47 40 00 90 4b 40 3c 80 4b 40 00 90 49 40 3c 80 49 40 00 90 47 40 3c 80 47 40 00 90 49 40
3c 80 49 40 00 90 4b 40 3c 80 4b 40 00 90 49 40 3c 80 49 40 00 90 4c 40 3c 80 4c 40 00 90 4b 40 3c 80 4b 40 00 90 49 40
3c 80 49 40 00 90 48 40 81 70 80 48 40 00 90 47 40 81 70 80 47 40 00 90 46 40 81 70 80 46 40 00 90 45 40 81 70 80 45 40
00 90 44 40 81 70 80 44 40 89 30 90 49 40 83 60 80 49 40 00 90 48 40 81 70 80 48 40 00 90 4c 40 81 70 80 4c 40 00 90 4b
40 85 50 80 4b 40 00 90 49 40 83 60 80 49 40 00 90 48 40 81 70 80 48 40 78 90 49 40 3c 80 49 40 00 90 4b 40 3c 80 4b 40
00 90 4c 40 78 80 4c 40 00 90 4e 40 78 80 4e 40 00 90 50 40 3c 80 50 40 00 90 4e 40 3c 80 4e 40 00 90 50 40 3c 80 50 40
00 90 51 40 3c 80 51 40 00 90 50 40 3c 80 50 40 00 90 4e 40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 50 40 3c 80 50 40
00 90 4e 40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 4e 40 3c 80 4e 40 00 90 50 40 3c 80 50 40 00 90 4e 40 3c 80 4e 40
00 90 4c 40 3c 80 4c 40 00 90 4b 40 3c 80 4b 40 00 90 4e 40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 4b 40 3c 80 4b 40
00 90 4c 40 3c 80 4c 40 00 90 4e 40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 4a 40 3c 80 4a 40 00 90 49 40 3c 80 49 40
00 90 4c 40 3c 80 4c 40 00 90 4a 40 3c 80 4a 40 00 90 49 40 3c 80 49 40 00 90 4a 40 3c 80 4a 40 00 90 4c 40 3c 80 4c 40
00 90 4a 40 3c 80 4a 40 00 90 49 40 3c 80 49 40 00 90 47 40 3c 80 47 40 00 90 4a 40 3c 80 4a 40 00 90 49 40 3c 80 49 40
00 90 47 40 3c 80 47 40 00 90 49 40 3c 80 49 40 00 90 4a 40 3c 80 4a 40 00 90 49 40 3c 80 49 40 00 90 47 40 3c 80 47 40
00 90 45 40 3c 80 45 40 00 90 49 40 3c 80 49 40 00 90 47 40 3c 80 47 40 00 90 45 40 3c 80 45 40 00 90 47 40 3c 80 47 40
00 90 49 40 3c 80 49 40 00 90 47 40 3c 80 47 40 00 90 45 40 3c 80 45 40 00 90 44 40 3c 80 44 40 00 90 47 40 3c 80 47 40
00 90 45 40 81 70 80 45 40 81 70 90 49 40 83 60 80 49 40 00 90 48 40 81 70 80 48 40 00 90 4c 40 81 70 80 4c 40 00 90 4b
40 84 58 80 4b 40 00 90 49 40 78 80 49 40 00 90 50 40 78 80 50 40 00 90 50 40 78 80 50 40 00 90 50 40 78 80 50 40 00 90
4e 40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 4e 40 81 70 80 4e 40 00 90 4c 40 83 60 80 4c 40 00 90 4b 40 81 70 80 4b
40 00 90 4f 40 81 70 80 4f 40 00 90 4e 40 81 70 80 4e 40 00 90 42 40 81 70 80 42 40 00 90 41 40 81 70 80 41 40 00 90 45
40 81 70 80 45 40 00 90 44 40 78 80 44 40 83 60 90 48 40 78 80 48 40 00 90 4e 40 78 80 4e 40 00 90 4e 40 78 80 4e 40 00
90 4e 40 78 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 4b 40 3c 80 4b 40 00 90 4c 40 78 80 4c 40 00 90 4b 40 3c 80 4b 40 00
90 49 40 3c 80 49 40 00 90 4b 40 78 80 4b 40 00 90 48 40 78 80 48 40 00 90 49 40 85 50 80 49 40 00 90 48 40 81 70 80 48
40 00 90 47 40 81 70 80 47 40 00 90 46 40 81 70 80 46 40 00 90 45 40 81 70 80 45 40 00 90 44 40 83 60 80 44 40 00 90 46
40 81 70 80 46 40 00 90 48 40 81 70 80 48 40 00 90 49 40 83 60 80 49 40 00 90 48 40 81 70 80 48 40 00 90 4c 40 83 60 80
4c 40 00 90 4b 40 78 80 4b 40 00 90 49 40 78 80 49 40 00 90 48 40 81 70 80 48 40 00 90 49 40 83 60 80 49 40 00 90 48 40
81 70 80 48 40 00 90 49 40 8f 00 80 49 40 77 90 00 00 00 ff 2f 00 4d 54 72 6b 00 00 09 40 ab 10 91 44 40 81 70 81 44 40
00 91 41 40 81 70 81 41 40 00 91 45 40 81 70 81 45 40 00 91 44 40 81 70 81 44 40 00 91 42 40 83 60 81 42 40 00 91 49 40
83 60 81 49 40 00 91 47 40 83 60 81 47 40 00 91 45 40 81 70 81 45 40 00 91 44 40 81 70 81 44 40 00 91 45 40 82 68 81 45
40 00 91 44 40 78 81 44 40 00 91 42 40 78 81 42 40 00 91 40 40 78 81 40 40 00 91 3f 40 81 70 81 3f 40 00 91 44 40 81 70
81 44 40 00 91 44 40 81 70 81 44 40 00 91 43 40 81 70 81 43 40 00 91 44 40 81 70 81 44 40 00 91 3b 40 81 70 81 3b 40 00
91 3d 40 82 68 81 3d 40 00 91 3d 40 78 81 3d 40 00 91 3f 40 78 81 3f 40 00 91 3d 40 78 81 3d 40 00 91 3f 40 78 81 3f 40
00 91 41 40 78 81 41 40 00 91 42 40 81 70 81 42 40 00 91 45 40 81 70 81 45 40 00 91 44 40 81 70 81 44 40 3c 91 47 40 3c
81 47 40 00 91 45 40 3c 81 45 40 00 91 44 40 3c 81 44 40 00 91 42 40 78 81 42 40 00 91 45 40 78 81 45 40 00 91 44 40 78
81 44 40 00 91 42 40 78 81 42 40 00 91 41 40 81 70 81 41 40 00 91 42 40 82 68 81 42 40 00 91 40 40 84 58 81 40 40 00 91
3f 40 81 70 81 3f 40 00 91 40 40 84 58 81 40 40 00 91 3f 40 78 81 3f 40 00 91 40 40 78 81 40 40 00 91 42 40 3c 81 42 40
00 91 44 40 3c 81 44 40 00 91 42 40 81 70 81 42 40 00 91 47 40 82 68 81 47 40 00 91 49 40 78 81 49 40 00 91 47 40 78 81
47 40 00 91 45 40 78 81 45 40 00 91 44 40 81 70 81 44 40 a1 60 91 49 40 81 70 81 49 40 00 91 48 40 81 70 81 48 40 00 91
4c 40 81 70 81 4c 40 00 91 4b 40 85 50 81 4b 40 00 91 49 40 83 60 81 49 40 00 91 48 40 78 81 48 40 00 91 47 40 81 34 81
47 40 00 91 47 40 3c 81 47 40 00 91 49 40 3c 81 49 40 00 91 4a 40 3c 81 4a 40 00 91 49 40 3c 81 49 40 00 91 47 40 3c 81
47 40 00 91 45 40 3c 81 45 40 00 91 49 40 3c 81 49 40 00 91 47 40 3c 81 47 40 00 91 45 40 3c 81 45 40 00 91 47 40 3c 81
47 40 00 91 49 40 3c 81 49 40 00 91 47 40 3c 81 47 40 00 91 45 40 3c 81 45 40 00 91 44 40 3c 81 44 40 00 91 47 40 3c 81
47 40 00 91 45 40 82 2c 81 45 40 00 91 49 40 3c 81 49 40 00 91 47 40 3c 81 47 40 00 91 45 40 3c 81 45 40 00 91 44 40 81
70 81 44 40 87 40 91 45 40 81 70 81 45 40 00 91 44 40 81 70 81 44 40 00 91 49 40 81 70 81 49 40 00 91 47 40 84 58 81 47
40 00 91 40 40 78 81 40 40 00 91 45 40 78 81 45 40 00 91 45 40 78 81 45 40 00 91 45 40 78 81 45 40 00 91 44 40 3c 81 44
40 00 91 42 40 3c 81 42 40 00 91 44 40 82 68 81 44 40 00 91 3d 40 3c 81 3d 40 00 91 3f 40 3c 81 3f 40 00 91 40 40 78 81
40 40 00 91 42 40 78 81 42 40 00 91 44 40 3c 81 44 40 00 91 42 40 3c 81 42 40 00 91 44 40 3c 81 44 40 00 91 45 40 3c 81
45 40 00 91 44 40 3c 81 44 40 00 91 42 40 3c 81 42 40 00 91 40 40 3c 81 40 40 00 91 44 40 3c 81 44 40 00 91 42 40 3c 81
42 40 00 91 40 40 3c 81 40 40 00 91 42 40 3c 81 42 40 00 91 44 40 3c 81 44 40 00 91 42 40 3c 81 42 40 00 91 40 40 3c 81
40 40 00 91 3f 40 3c 81 3f 40 00 91 42 40 3c 81 42 40 00 91 40 40 3c 81 40 40 00 91 3f 40 3c 81 3f 40 00 91 40 40 3c 81
40 40 00 91 42 40 3c 81 42 40 00 91 40 40 3c 81 40 40 00 91 3f 40 3c 81 3f 40 00 91 3d 40 3c 81 3d 40 00 91 40 40 3c 81
40 40 00 91 3f 40 3c 81 3f 40 00 91 3d 40 3c 81 3d 40 00 91 3f 40 3c 81 3f 40 00 91 40 40 3c 81 40 40 00 91 3e 40 3c 81
3e 40 00 91 3d 40 3c 81 3d 40 00 91 3b 40 3c 81 3b 40 00 91 3e 40 3c 81 3e 40 00 91 3d 40 3c 81 3d 40 00 91 3b 40 3c 81
3b 40 00 91 3d 40 3c 81 3d 40 00 91 3e 40 3c 81 3e 40 00 91 3d 40 3c 81 3d 40 00 91 40 40 3c 81 40 40 00 91 3f 40 3c 81
3f 40 00 91 3d 40 3c 81 3d 40 00 91 48 40 81 70 81 48 40 00 91 3d 40 81 70 81 3d 40 00 91 3f 40 78 81 3f 40 00 91 3f 40
78 81 3f 40 00 91 44 40 3c 81 44 40 00 91 46 40 3c 81 46 40 00 91 47 40 81 70 81 47 40 00 91 46 40 78 81 46 40 00 91 4b
40 78 81 4b 40 00 91 4b 40 78 81 4b 40 00 91 4b 40 78 81 4b 40 00 91 49 40 3c 81 49 40 00 91 48 40 3c 81 48 40 00 91 49
40 83 60 81 49 40 00 91 47 40 81 70 81 47 40 00 91 46 40 81 70 81 46 40 00 91 45 40 82 68 81 45 40 00 91 3f 40 78 81 3f
40 00 91 44 40 78 81 44 40 00 91 44 40 81 70 81 44 40 00 91 42 40 3c 81 42 40 00 91 41 40 3c 81 41 40 00 91 42 40 83 60
81 42 40 00 91 40 40 81 70 81 40 40 00 91 3f 40 81 70 81 3f 40 00 91 3d 40 81 70 81 3d 40 00 91 3f 40 83 60 81 3f 40 84
58 91 44 40 78 81 44 40 00 91 49 40 78 81 49 40 00 91 49 40 78 81 49 40 00 91 49 40 78 81 49 40 00 91 48 40 3c 81 48 40
00 91 46 40 3c 81 46 40 00 91 48 40 3c 81 48 40 00 91 49 40 3c 81 49 40 00 91 4b 40 3c 81 4b 40 00 91 48 40 3c 81 48 40
00 91 44 40 3c 81 44 40 00 91 42 40 3c 81 42 40 00 91 44 40 3c 81 44 40 00 91 45 40 3c 81 45 40 00 91 44 40 3c 81 44 40
00 91 42 40 3c 81 42 40 00 91 40 40 3c 81 40 40 00 91 44 40 3c 81 44 40 00 91 42 40 3c 81 42 40 00 91 40 40 3c 81 40 40
00 91 42 40 3c 81 42 40 00 91 44 40 3c 81 44 40 00 91 42 40 3c 81 42 40 00 91 40 40 3c 81 40 40 00 91 3f 40 3c 81 3f 40
00 91 42 40 3c 81 42 40 00 91 40 40 3c 81 40 40 00 91 44 40 3c 81 44 40 00 91 45 40 3c 81 45 40 00 91 47 40 3c 81 47 40
00 91 49 40 3c 81 49 40 00 91 4b 40 3c 81 4b 40 00 91 48 40 3c 81 48 40 00 91 49 40 3c 81 49 40 00 91 4b 40 78 81 4b 40
8b 20 91 42 40 78 81 42 40 00 91 47 40 78 81 47 40 00 91 47 40 78 81 47 40 00 91 47 40 78 81 47 40 00 91 45 40 3c 81 45
40 00 91 44 40 3c 81 44 40 00 91 45 40 81 70 81 45 40 00 91 44 40 84 1c 81 44 40 00 91 44 40 3c 81 44 40 00 91 42 40 3c
81 42 40 00 91 41 40 3c 81 41 40 00 91 42 40 81 70 81 42 40 00 91 44 40 82 2c 81 44 40 00 91 44 40 3c 81 44 40 00 91 42
40 3c 81 42 40 00 91 40 40 3c 81 40 40 00 91 3f 40 3c 81 3f 40 00 91 45 40 3c 81 45 40 00 91 44 40 3c 81 44 40 00 91 42
40 3c 81 42 40 00 91 40 40 3c 81 40 40 00 91 44 40 3c 81 44 40 00 91 49 40 3c 81 49 40 00 91 47 40 3c 81 47 40 00 91 45
40 3c 81 45 40 00 91 44 40 3c 81 44 40 00 91 45 40 3c 81 45 40 00 91 42 40 3c 81 42 40 00 91 44 40 82 68 81 44 40 00 91
49 40 3c 81 49 40 00 91 48 40 3c 81 48 40 00 91 49 40 82 68 81 49 40 00 91 46 40 78 81 46 40 00 91 4b 40 78 81 4b 40 00
91 4b 40 78 81 4b 40 00 91 4b 40 78 81 4b 40 00 91 49 40 3c 81 49 40 00 91 47 40 3c 81 47 40 00 91 49 40 81 70 81 49 40
00 91 47 40 81 70 81 47 40 00 91 47 40 81 70 81 47 40 00 91 46 40 81 70 81 46 40 00 91 4a 40 81 70 81 4a 40 00 91 49 40
83 60 81 49 40 78 91 44 40 78 81 44 40 00 91 49 40 78 81 49 40 00 91 49 40 78 81 49 40 00 91 49 40 78 81 49 40 00 91 48
40 3c 81 48 40 00 91 46 40 3c 81 46 40 00 91 48 40 3c 81 48 40 00 91 49 40 3c 81 49 40 00 91 4b 40 81 70 81 4b 40 00 91
49 40 3c 81 49 40 00 91 48 40 3c 81 48 40 00 91 49 40 81 70 81 49 40 00 91 42 40 81 70 81 42 40 00 91 44 40 83 60 81 44
40 00 91 42 40 82 68 81 42 40 82 68 91 44 40 78 81 44 40 00 91 42 40 3c 81 42 40 00 91 40 40 3c 81 40 40 00 91 42 40 78
81 42 40 00 91 42 40 78 81 42 40 00 91 42 40 78 81 42 40 00 91 40 40 3c 81 40 40 00 91 3f 40 3c 81 3f 40 00 91 40 40 82
68 81 40 40 00 91 42 40 3c 81 42 40 00 91 44 40 3c 81 44 40 00 91 45 40 78 81 45 40 00 91 44 40 81 70 81 44 40 00 91 40
40 78 81 40 40 00 91 45 40 78 81 45 40 00 91 45 40 78 81 45 40 00 91 45 40 78 81 45 40 00 91 44 40 3c 81 44 40 00 91 42
40 3c 81 42 40 00 91 44 40 78 81 44 40 00 91 46 40 3c 81 46 40 00 91 48 40 3c 81 48 40 00 91 49 40 81 70 81 49 40 00 91
46 40 81 70 81 46 40 00 91 44 40 81 70 81 44 40 00 91 44 40 85 50 81 44 40 00 91 44 40 81 70 81 44 40 00 91 42 40 81 70
81 42 40 00 91 41 40 81 70 81 41 40 00 91 45 40 81 70 81 45 40 00 91 44 40 87 40 81 44 40 77 90 00 00 00 ff 2f 00 4d 54
72 6b 00 00 08 ba 98 30 92 3d 40 81 70 82 3d 40 00 92 3c 40 81 70 82 3c 40 00 92 40 40 81 70 82 40 40 00 92 3f 40 83 60
82 3f 40 00 92 3d 40 81 70 82 3d 40 00 92 42 40 82 68 82 42 40 00 92 40 40 78 82 40 40 00 92 3f 40 78 82 3f 40 00 92 3d
40 78 82 3d 40 00 92 3d 40 81 70 82 3d 40 00 92 3b 40 81 70 82 3b 40 00 92 3d 40 81 70 82 3d 40 00 92 42 40 82 68 82 42
40 00 92 40 40 78 82 40 40 00 92 3f 40 78 82 3f 40 00 92 3d 40 78 82 3d 40 00 92 3f 40 81 70 82 3f 40 00 92 44 40 81 70
82 44 40 78 92 45 40 78 82 45 40 00 92 44 40 78 82 44 40 00 92 42 40 78 82 42 40 00 92 41 40 78 82 41 40 00 92 3d 40 78
82 3d 40 00 92 42 40 81 70 82 42 40 00 92 40 40 85 50 82 40 40 00 92 44 40 81 70 82 44 40 00 92 46 40 81 70 82 46 40 92
60 92 3d 40 81 70 82 3d 40 00 92 3c 40 81 70 82 3c 40 00 92 40 40 81 70 82 40 40 00 92 3f 40 83 60 82 3f 40 00 92 3d 40
87 40 82 3d 40 00 92 36 40 78 82 36 40 00 92 38 40 78 82 38 40 00 92 3a 40 78 82 3a 40 00 92 3b 40 78 82 3b 40 00 92 3d
40 83 60 82 3d 40 81 70 92 40 40 81 70 82 40 40 00 92 3f 40 81 70 82 3f 40 00 92 44 40 81 70 82 44 40 00 92 42 40 83 60
82 42 40 00 92 40 40 81 70 82 40 40 8b 20 92 44 40 81 70 82 44 40 00 92 43 40 81 70 82 43 40 00 92 47 40 81 70 82 47 40
00 92 46 40 84 58 82 46 40 00 92 3f 40 78 82 3f 40 00 92 44 40 82 68 82 44 40 00 92 42 40 3c 82 42 40 00 92 40 40 3c 82
40 40 00 92 42 40 82 68 82 42 40 00 92 40 40 3c 82 40 40 00 92 42 40 3c 82 42 40 00 92 44 40 89 30 82 44 40 8c 18 92 3d
40 78 82 3d 40 00 92 42 40 78 82 42 40 00 92 42 40 78 82 42 40 00 92 42 40 78 82 42 40 00 92 41 40 3c 82 41 40 00 92 3f
40 3c 82 3f 40 00 92 41 40 81 70 82 41 40 00 92 42 40 78 82 42 40 00 92 36 40 3c 82 36 40 00 92 38 40 3c 82 38 40 00 92
39 40 78 82 39 40 00 92 3b 40 78 82 3b 40 00 92 3d 40 3c 82 3d 40 00 92 3b 40 3c 82 3b 40 00 92 3d 40 3c 82 3d 40 00 92
3e 40 3c 82 3e 40 00 92 3d 40 3c 82 3d 40 00 92 3b 40 3c 82 3b 40 00 92 39 40 3c 82 39 40 00 92 3d 40 3c 82 3d 40 00 92
3b 40 3c 82 3b 40 00 92 39 40 3c 82 39 40 00 92 3b 40 3c 82 3b 40 00 92 3d 40 3c 82 3d 40 00 92 3b 40 3c 82 3b 40 00 92
39 40 3c 82 39 40 00 92 38 40 3c 82 38 40 00 92 3b 40 3c 82 3b 40 00 92 39 40 3c 82 39 40 00 92 38 40 3c 82 38 40 00 92
39 40 3c 82 39 40 00 92 3b 40 3c 82 3b 40 00 92 39 40 3c 82 39 40 00 92 3b 40 3c 82 3b 40 00 92 3d 40 3c 82 3d 40 00 92
3e 40 3c 82 3e 40 00 92 40 40 3c 82 40 40 00 92 3e 40 3c 82 3e 40 00 92 40 40 3c 82 40 40 00 92 42 40 3c 82 42 40 00 92
40 40 3c 82 40 40 00 92 3e 40 3c 82 3e 40 00 92 3d 40 3c 82 3d 40 00 92 40 40 3c 82 40 40 00 92 3e 40 3c 82 3e 40 00 92
3d 40 3c 82 3d 40 00 92 3e 40 3c 82 3e 40 00 92 40 40 3c 82 40 40 00 92 3e 40 3c 82 3e 40 00 92 3d 40 3c 82 3d 40 00 92
3b 40 3c 82 3b 40 00 92 3e 40 3c 82 3e 40 00 92 3d 40 3c 82 3d 40 00 92 3b 40 3c 82 3b 40 00 92 3d 40 3c 82 3d 40 00 92
3e 40 3c 82 3e 40 00 92 3d 40 3c 82 3d 40 00 92 3b 40 3c 82 3b 40 00 92 39 40 3c 82 39 40 00 92 3d 40 3c 82 3d 40 00 92
3b 40 83 60 82 3b 40 00 92 39 40 3c 82 39 40 00 92 38 40 3c 82 38 40 00 92 36 40 3c 82 36 40 00 92 34 40 3c 82 34 40 00
92 33 40 3c 82 33 40 00 92 31 40 3c 82 31 40 00 92 30 40 3c 82 30 40 00 92 31 40 3c 82 31 40 00 92 33 40 81 70 82 33 40
8e 08 92 31 40 78 82 31 40 00 92 36 40 78 82 36 40 00 92 36 40 78 82 36 40 00 92 36 40 78 82 36 40 00 92 34 40 3c 82 34
40 00 92 33 40 3c 82 33 40 00 92 34 40 81 70 82 34 40 00 92 37 40 81 70 82 37 40 00 92 38 40 81 70 82 38 40 00 92 35 40
78 82 35 40 87 40 92 33 40 78 82 33 40 00 92 38 40 78 82 38 40 00 92 38 40 78 82 38 40 00 92 38 40 78 82 38 40 00 92 36
40 3c 82 36 40 00 92 34 40 3c 82 34 40 00 92 36 40 82 2c 82 36 40 00 92 39 40 3c 82 39 40 00 92 38 40 3c 82 38 40 00 92
36 40 3c 82 36 40 00 92 35 40 3c 82 35 40 00 92 33 40 3c 82 33 40 00 92 35 40 3c 82 35 40 00 92 31 40 3c 82 31 40 00 92
36 40 3c 82 36 40 00 92 35 40 3c 82 35 40 00 92 36 40 3c 82 36 40 00 92 38 40 3c 82 38 40 00 92 39 40 3c 82 39 40 00 92
38 40 3c 82 38 40 00 92 39 40 3c 82 39 40 00 92 3b 40 3c 82 3b 40 00 92 3d 40 3c 82 3d 40 00 92 3c 40 3c 82 3c 40 00 92
3d 40 3c 82 3d 40 00 92 3f 40 3c 82 3f 40 00 92 40 40 3c 82 40 40 00 92 3f 40 3c 82 3f 40 00 92 40 40 3c 82 40 40 00 92
42 40 3c 82 42 40 00 92 44 40 3c 82 44 40 00 92 42 40 3c 82 42 40 00 92 44 40 3c 82 44 40 00 92 45 40 3c 82 45 40 00 92
44 40 3c 82 44 40 00 92 42 40 3c 82 42 40 00 92 40 40 3c 82 40 40 00 92 44 40 3c 82 44 40 00 92 42 40 3c 82 42 40 00 92
40 40 3c 82 40 40 00 92 42 40 3c 82 42 40 00 92 44 40 3c 82 44 40 00 92 42 40 3c 82 42 40 00 92 40 40 3c 82 40 40 00 92
3f 40 3c 82 3f 40 00 92 42 40 3c 82 42 40 00 92 40 40 3c 82 40 40 00 92 3f 40 3c 82 3f 40 00 92 40 40 3c 82 40 40 00 92
42 40 3c 82 42 40 00 92 40 40 3c 82 40 40 00 92 3f 40 3c 82 3f 40 00 92 3d 40 3c 82 3d 40 00 92 40 40 3c 82 40 40 00 92
3f 40 81 70 82 3f 40 91 68 92 38 40 78 82 38 40 00 92 3d 40 78 82 3d 40 00 92 3d 40 78 82 3d 40 00 92 3d 40 78 82 3d 40
00 92 3c 40 3c 82 3c 40 00 92 3a 40 3c 82 3a 40 00 92 3c 40 81 70 82 3c 40 00 92 3d 40 83 60 82 3d 40 00 92 3b 40 82 68
82 3b 40 00 92 42 40 78 82 42 40 00 92 41 40 81 70 82 41 40 00 92 42 40 81 70 82 42 40 00 92 3b 40 81 70 82 3b 40 00 92
3d 40 84 1c 82 3d 40 00 92 3d 40 3c 82 3d 40 00 92 3b 40 3c 82 3b 40 00 92 39 40 3c 82 39 40 00 92 38 40 83 60 82 38 40
93 58 92 3b 40 78 82 3b 40 00 92 40 40 78 82 40 40 00 92 40 40 78 82 40 40 00 92 40 40 78 82 40 40 00 92 3e 40 3c 82 3e
40 00 92 3d 40 3c 82 3d 40 00 92 3b 40 81 70 82 3b 40 78 92 3d 40 78 82 3d 40 00 92 42 40 78 82 42 40 00 92 42 40 78 82
42 40 00 92 42 40 78 82 42 40 00 92 40 40 3c 82 40 40 00 92 3f 40 3c 82 3f 40 00 92 40 40 81 70 82 40 40 00 92 42 40 83
24 82 42 40 00 92 44 40 3c 82 44 40 00 92 45 40 78 82 45 40 00 92 44 40 3c 82 44 40 00 92 42 40 3c 82 42 40 00 92 44 40
78 82 44 40 00 92 42 40 3c 82 42 40 00 92 40 40 3c 82 40 40 00 92 3f 40 81 70 82 3f 40 00 92 40 40 83 60 82 40 40 00 92
3f 40 78 82 3f 40 00 92 3d 40 78 82 3d 40 00 92 3f 40 78 82 3f 40 00 92 41 40 3c 82 41 40 00 92 42 40 3c 82 42 40 00 92
44 40 78 82 44 40 00 92 44 40 78 82 44 40 78 92 3d 40 78 82 3d 40 00 92 3f 40 78 82 3f 40 00 92 3d 40 78 82 3d 40 00 92
3c 40 81 70 82 3c 40 00 92 3d 40 83 60 82 3d 40 00 92 3f 40 81 70 82 3f 40 00 92 3d 40 78 82 3d 40 00 92 3d 40 78 82 3d
40 00 92 42 40 78 82 42 40 00 92 42 40 78 82 42 40 00 92 42 40 78 82 42 40 00 92 40 40 3c 82 40 40 00 92 3f 40 3c 82 3f
40 00 92 40 40 78 82 40 40 00 92 42 40 3c 82 42 40 00 92 44 40 3c 82 44 40 00 92 46 40 81 70 82 46 40 00 92 3f 40 83 60
82 3f 40 00 92 40 40 81 70 82 40 40 00 92 3f 40 82 68 82 3f 40 00 92 40 40 3c 82 40 40 00 92 42 40 3c 82 42 40 00 92 41
40 78 82 41 40 00 92 3d 40 83 60 82 3d 40 00 92 3d 40 78 82 3d 40 00 92 42 40 78 82 42 40 00 92 42 40 78 82 42 40 00 92
42 40 81 70 82 42 40 00 92 41 40 78 82 41 40 00 92 3f 40 78 82 3f 40 00 92 41 40 83 60 82 41 40 77 90 00 00 00 ff 2f 00
4d 54 72 6b 00 00 07 ac 8b 20 93 38 40 83 60 83 38 40 00 93 37 40 81 70 83 37 40 00 93 3b 40 81 70 83 3b 40 00 93 3a 40
83 60 83 3a 40 00 93 38 40 81 70 83 38 40 00 93 39 40 82 68 83 39 40 00 93 38 40 3c 83 38 40 00 93 36 40 3c 83 36 40 00
93 38 40 78 83 38 40 00 93 3d 40 78 83 3d 40 00 93 36 40 78 83 36 40 00 93 38 40 3c 83 38 40 00 93 39 40 3c 83 39 40 00
93 3b 40 82 68 83 3b 40 00 93 39 40 78 83 39 40 00 93 38 40 78 83 38 40 00 93 36 40 78 83 36 40 00 93 38 40 81 70 83 38
40 00 93 36 40 78 83 36 40 00 93 34 40 78 83 34 40 00 93 33 40 82 68 83 33 40 00 93 32 40 78 83 32 40 00 93 31 40 87 40
83 31 40 90 70 93 38 40 81 70 83 38 40 00 93 37 40 81 70 83 37 40 00 93 3b 40 81 70 83 3b 40 00 93 3a 40 83 60 83 3a 40
00 93 38 40 78 83 38 40 00 93 39 40 78 83 39 40 00 93 38 40 78 83 38 40 00 93 36 40 78 83 36 40 00 93 35 40 81 70 83 35
40 00 93 39 40 81 70 83 39 40 00 93 38 40 83 60 83 38 40 00 93 36 40 84 58 83 36 40 00 93 38 40 3c 83 38 40 00 93 36 40
3c 83 36 40 00 93 34 40 78 83 34 40 00 93 36 40 3c 83 36 40 00 93 38 40 3c 83 38 40 00 93 39 40 78 83 39 40 00 93 36 40
78 83 36 40 00 93 38 40 81 70 83 38 40 00 93 31 40 89 30 83 31 40 00 93 36 40 81 70 83 36 40 00 93 34 40 78 83 34 40 00
93 33 40 78 83 33 40 00 93 34 40 78 83 34 40 00 93 36 40 78 83 36 40 00 93 38 40 78 83 38 40 00 93 36 40 78 83 36 40 00
93 38 40 78 83 38 40 00 93 39 40 78 83 39 40 00 93 3b 40 89 30 83 3b 40 00 93 3d 40 81 70 83 3d 40 00 93 3c 40 81 70 83
3c 40 00 93 40 40 81 70 83 40 40 00 93 3f 40 83 60 83 3f 40 00 93 3d 40 84 58 83 3d 40 00 93 3b 40 78 83 3b 40 00 93 3a
40 78 83 3a 40 00 93 38 40 81 70 83 38 40 00 93 37 40 3c 83 37 40 00 93 35 40 3c 83 35 40 00 93 37 40 81 70 83 37 40 00
93 38 40 3c 83 38 40 00 93 3a 40 3c 83 3a 40 00 93 38 40 3c 83 38 40 00 93 37 40 3c 83 37 40 00 93 38 40 3c 83 38 40 00
93 3a 40 3c 83 3a 40 00 93 3b 40 3c 83 3b 40 00 93 38 40 3c 83 38 40 00 93 39 40 3c 83 39 40 00 93 3b 40 3c 83 3b 40 00
93 39 40 3c 83 39 40 00 93 38 40 3c 83 38 40 00 93 3a 40 3c 83 3a 40 00 93 3b 40 3c 83 3b 40 00 93 3d 40 3c 83 3d 40 00
93 3a 40 3c 83 3a 40 00 93 3b 40 3c 83 3b 40 00 93 3d 40 3c 83 3d 40 00 93 3b 40 3c 83 3b 40 00 93 3a 40 3c 83 3a 40 00
93 3c 40 3c 83 3c 40 00 93 3d 40 3c 83 3d 40 00 93 3f 40 3c 83 3f 40 00 93 3c 40 3c 83 3c 40 00 93 3d 40 83 60 83 3d 40
98 30 93 36 40 81 70 83 36 40 00 93 35 40 81 70 83 35 40 00 93 39 40 81 70 83 39 40 00 93 38 40 83 60 83 38 40 00 93 36
40 83 60 83 36 40 93 58 93 38 40 78 83 38 40 00 93 3d 40 78 83 3d 40 00 93 3d 40 78 83 3d 40 00 93 3d 40 78 83 3d 40 00
93 3c 40 3c 83 3c 40 00 93 3a 40 3c 83 3a 40 00 93 3c 40 81 70 83 3c 40 00 93 3d 40 81 70 83 3d 40 00 93 39 40 81 70 83
39 40 00 93 36 40 81 70 83 36 40 00 93 38 40 81 70 83 38 40 00 93 35 40 81 70 83 35 40 00 93 36 40 81 70 83 36 40 00 93
38 40 83 60 83 38 40 00 93 33 40 83 60 83 33 40 9b 18 93 2c 40 78 83 2c 40 00 93 31 40 78 83 31 40 00 93 31 40 78 83 31
40 00 93 31 40 78 83 31 40 00 93 30 40 3c 83 30 40 00 93 2e 40 3c 83 2e 40 00 93 30 40 81 70 83 30 40 00 93 31 40 81 70
83 31 40 90 70 93 31 40 83 60 83 31 40 00 93 30 40 81 70 83 30 40 00 93 34 40 81 70 83 34 40 00 93 33 40 83 60 83 33 40
00 93 31 40 78 83 31 40 00 93 34 40 78 83 34 40 00 93 39 40 78 83 39 40 00 93 39 40 78 83 39 40 00 93 39 40 78 83 39 40
00 93 38 40 3c 83 38 40 00 93 36 40 3c 83 36 40 00 93 38 40 83 60 83 38 40 00 93 36 40 81 70 83 36 40 00 93 38 40 83 60
83 38 40 00 93 39 40 81 70 83 39 40 00 93 36 40 82 2c 83 36 40 00 93 36 40 3c 83 36 40 00 93 34 40 3c 83 34 40 00 93 33
40 3c 83 33 40 00 93 34 40 78 83 34 40 00 93 31 40 78 83 31 40 00 93 38 40 83 60 83 38 40 00 93 36 40 81 70 83 36 40 00
93 33 40 81 70 83 33 40 00 93 34 40 3c 83 34 40 00 93 33 40 3c 83 33 40 00 93 34 40 3c 83 34 40 00 93 36 40 3c 83 36 40
00 93 34 40 3c 83 34 40 00 93 33 40 3c 83 33 40 00 93 31 40 3c 83 31 40 00 93 34 40 3c 83 34 40 00 93 33 40 3c 83 33 40
00 93 31 40 3c 83 31 40 00 93 33 40 3c 83 33 40 00 93 34 40 3c 83 34 40 00 93 33 40 3c 83 33 40 00 93 31 40 3c 83 31 40
00 93 30 40 3c 83 30 40 00 93 33 40 3c 83 33 40 00 93 31 40 78 83 31 40 00 93 34 40 78 83 34 40 00 93 39 40 78 83 39 40
00 93 39 40 78 83 39 40 00 93 39 40 78 83 39 40 00 93 37 40 3c 83 37 40 00 93 36 40 3c 83 36 40 00 93 34 40 81 70 83 34
40 78 93 36 40 78 83 36 40 00 93 3b 40 78 83 3b 40 00 93 3b 40 78 83 3b 40 00 93 3b 40 78 83 3b 40 00 93 39 40 3c 83 39
40 00 93 38 40 3c 83 38 40 00 93 39 40 3c 83 39 40 00 93 38 40 3c 83 38 40 00 93 36 40 3c 83 36 40 00 93 34 40 3c 83 34
40 00 93 33 40 81 70 83 33 40 78 93 38 40 78 83 38 40 00 93 3f 40 78 83 3f 40 00 93 3f 40 78 83 3f 40 00 93 3f 40 78 83
3f 40 00 93 3d 40 3c 83 3d 40 00 93 3c 40 3c 83 3c 40 00 93 3d 40 83 60 83 3d 40 00 93 3c 40 81 70 83 3c 40 00 93 40 40
82 68 83 40 40 00 93 31 40 78 83 31 40 00 93 36 40 78 83 36 40 00 93 36 40 78 83 36 40 00 93 36 40 78 83 36 40 00 93 35
40 3c 83 35 40 00 93 33 40 3c 83 33 40 00 93 31 40 83 60 83 31 40 00 93 33 40 82 68 83 33 40 00 93 33 40 78 83 33 40 00
93 38 40 78 83 38 40 00 93 38 40 78 83 38 40 00 93 38 40 78 83 38 40 00 93 36 40 3c 83 36 40 00 93 34 40 3c 83 34 40 00
93 36 40 78 83 36 40 00 93 36 40 78 83 36 40 00 93 36 40 78 83 36 40 00 93 34 40 3c 83 34 40 00 93 33 40 3c 83 33 40 00
93 34 40 78 83 34 40 00 93 33 40 3c 83 33 40 00 93 31 40 3c 83 31 40 00 93 33 40 78 83 33 40 00 93 2c 40 78 83 2c 40 00
93 31 40 78 83 31 40 00 93 31 40 78 83 31 40 00 93 31 40 78 83 31 40 00 93 2f 40 3c 83 2f 40 00 93 2e 40 3c 83 2e 40 00
93 33 40 82 2c 83 33 40 00 93 34 40 3c 83 34 40 00 93 36 40 81 34 83 36 40 00 93 34 40 3c 83 34 40 00 93 33 40 3c 83 33
40 00 93 31 40 3c 83 31 40 00 93 38 40 83 60 83 38 40 00 93 39 40 82 68 83 39 40 00 93 38 40 3c 83 38 40 00 93 39 40 3c
83 39 40 00 93 3b 40 78 83 3b 40 00 93 39 40 78 83 39 40 00 93 38 40 78 83 38 40 00 93 36 40 78 83 36 40 00 93 3d 40 78
83 3d 40 00 93 3b 40 3c 83 3b 40 00 93 39 40 3c 83 39 40 00 93 38 40 78 83 38 40 00 93 36 40 78 83 36 40 00 93 38 40 83
60 83 38 40 77 90 00 00 00 ff 2f 00 4d 54 72 6b 00 00 07 cd 00 90 31 40 83 60 80 31 40 00 90 30 40 81 70 80 30 40 00 90
34 40 81 70 80 34 40 00 90 33 40 83 60 80 33 40 00 90 31 40 78 80 31 40 00 90 33 40 78 80 33 40 00 90 34 40 82 68 80 34
40 00 90 33 40 3c 80 33 40 00 90 31 40 3c 80 31 40 00 90 33 40 78 80 33 40 00 90 38 40 78 80 38 40 00 90 31 40 78 80 31
40 00 90 33 40 3c 80 33 40 00 90 34 40 3c 80 34 40 00 90 36 40 82 68 80 36 40 00 90 34 40 78 80 34 40 00 90 33 40 78 80
33 40 00 90 31 40 78 80 31 40 00 90 33 40 81 70 80 33 40 00 90 31 40 82 68 80 31 40 00 90 2f 40 78 80 2f 40 00 90 2d 40
78 80 2d 40 00 90 2c 40 78 80 2c 40 00 90 2d 40 81 70 80 2d 40 00 90 2e 40 81 70 80 2e 40 00 90 30 40 81 70 80 30 40 00
90 31 40 81 70 80 31 40 00 90 2c 40 78 80 2c 40 00 90 2d 40 78 80 2d 40 00 90 2f 40 82 68 80 2f 40 00 90 2d 40 78 80 2d
40 00 90 2c 40 78 80 2c 40 00 90 2a 40 78 80 2a 40 00 90 31 40 81 70 80 31 40 00 90 2d 40 82 68 80 2d 40 00 90 2c 40 78
80 2c 40 00 90 2a 40 78 80 2a 40 00 90 28 40 78 80 28 40 00 90 2a 40 81 70 80 2a 40 00 90 2c 40 81 70 80 2c 40 00 90 2d
40 78 80 2d 40 00 90 2c 40 78 80 2c 40 00 90 2d 40 78 80 2d 40 00 90 2f 40 78 80 2f 40 00 90 31 40 78 80 31 40 00 90 2f
40 78 80 2f 40 00 90 31 40 78 80 31 40 00 90 33 40 78 80 33 40 00 90 34 40 81 70 80 34 40 00 90 31 40 82 68 80 31 40 00
90 2f 40 78 80 2f 40 00 90 2e 40 78 80 2e 40 00 90 2c 40 78 80 2c 40 00 90 31 40 81 70 80 31 40 00 90 33 40 81 70 80 33
40 00 90 2c 40 81 70 80 2c 40 9a 20 90 2f 40 81 70 80 2f 40 00 90 2e 40 81 70 80 2e 40 00 90 33 40 81 70 80 33 40 00 90
31 40 83 60 80 31 40 00 90 2f 40 84 58 80 2f 40 00 90 38 40 78 80 38 40 00 90 36 40 78 80 36 40 00 90 34 40 78 80 34 40
00 90 3b 40 81 70 80 3b 40 00 90 2f 40 81 70 80 2f 40 00 90 34 40 81 70 80 34 40 00 90 39 40 81 70 80 39 40 00 90 38 40
81 70 80 38 40 00 90 3d 40 83 60 80 3d 40 00 90 3c 40 81 70 80 3c 40 00 90 3d 40 81 70 80 3d 40 95 48 90 31 40 3c 80 31
40 00 90 33 40 3c 80 33 40 00 90 34 40 78 80 34 40 00 90 36 40 78 80 36 40 00 90 38 40 3c 80 38 40 00 90 36 40 3c 80 36
40 00 90 38 40 3c 80 38 40 00 90 39 40 3c 80 39 40 00 90 38 40 3c 80 38 40 00 90 36 40 3c 80 36 40 00 90 34 40 3c 80 34
40 00 90 38 40 3c 80 38 40 00 90 36 40 3c 80 36 40 00 90 34 40 3c 80 34 40 00 90 36 40 3c 80 36 40 00 90 38 40 3c 80 38
40 00 90 36 40 3c 80 36 40 00 90 34 40 3c 80 34 40 00 90 33 40 3c 80 33 40 00 90 36 40 3c 80 36 40 00 90 34 40 3c 80 34
40 00 90 33 40 3c 80 33 40 00 90 34 40 3c 80 34 40 00 90 36 40 3c 80 36 40 00 90 34 40 3c 80 34 40 00 90 39 40 3c 80 39
40 00 90 38 40 3c 80 38 40 00 90 39 40 3c 80 39 40 00 90 33 40 3c 80 33 40 00 90 31 40 3c 80 31 40 00 90 33 40 3c 80 33
40 00 90 34 40 3c 80 34 40 00 90 33 40 3c 80 33 40 00 90 38 40 3c 80 38 40 00 90 36 40 3c 80 36 40 00 90 38 40 3c 80 38
40 00 90 31 40 81 70 80 31 40 95 48 90 34 40 78 80 34 40 00 90 39 40 78 80 39 40 00 90 39 40 78 80 39 40 00 90 39 40 78
80 39 40 00 90 38 40 3c 80 38 40 00 90 36 40 3c 80 36 40 00 90 38 40 81 70 80 38 40 00 90 39 40 81 70 80 39 40 00 90 36
40 81 70 80 36 40 00 90 2f 40 81 70 80 2f 40 00 90 34 40 81 70 80 34 40 00 90 2d 40 83 60 80 2d 40 00 90 2c 40 81 70 80
2c 40 91 68 90 2c 40 78 80 2c 40 00 90 31 40 78 80 31 40 00 90 31 40 78 80 31 40 00 90 31 40 78 80 31 40 00 90 2f 40 3c
80 2f 40 00 90 2e 40 3c 80 2e 40 00 90 2f 40 3c 80 2f 40 00 90 2e 40 3c 80 2e 40 00 90 2c 40 3c 80 2c 40 00 90 2f 40 3c
80 2f 40 00 90 2e 40 3c 80 2e 40 00 90 2c 40 3c 80 2c 40 00 90 2e 40 3c 80 2e 40 00 90 2f 40 3c 80 2f 40 00 90 2e 40 3c
80 2e 40 00 90 2c 40 3c 80 2c 40 00 90 2a 40 3c 80 2a 40 00 90 2e 40 3c 80 2e 40 00 90 2c 40 3c 80 2c 40 00 90 2a 40 3c
80 2a 40 00 90 2c 40 3c 80 2c 40 00 90 2e 40 3c 80 2e 40 00 90 2c 40 3c 80 2c 40 00 90 2f 40 3c 80 2f 40 00 90 2e 40 3c
80 2e 40 00 90 2c 40 3c 80 2c 40 00 90 2b 40 81 70 80 2b 40 00 90 2c 40 81 70 80 2c 40 00 90 2e 40 81 70 80 2e 40 00 90
33 40 81 70 80 33 40 00 90 2c 40 81 70 80 2c 40 85 50 90 25 40 83 60 80 25 40 00 90 30 40 81 70 80 30 40 00 90 28 40 81
70 80 28 40 00 90 27 40 83 60 80 27 40 00 90 25 40 78 80 25 40 00 90 25 40 3c 80 25 40 00 90 27 40 3c 80 27 40 00 90 28
40 78 80 28 40 00 90 2a 40 78 80 2a 40 00 90 2c 40 3c 80 2c 40 00 90 2a 40 3c 80 2a 40 00 90 2c 40 3c 80 2c 40 00 90 2d
40 3c 80 2d 40 00 90 2c 40 3c 80 2c 40 00 90 2a 40 3c 80 2a 40 00 90 28 40 3c 80 28 40 00 90 2c 40 3c 80 2c 40 00 90 2a
40 3c 80 2a 40 00 90 28 40 3c 80 28 40 00 90 2a 40 3c 80 2a 40 00 90 2c 40 3c 80 2c 40 00 90 2a 40 3c 80 2a 40 00 90 28
40 3c 80 28 40 00 90 27 40 3c 80 27 40 00 90 2a 40 3c 80 2a 40 00 90 28 40 78 80 28 40 00 90 34 40 78 80 34 40 00 90 39
40 78 80 39 40 00 90 39 40 78 80 39 40 00 90 39 40 78 80 39 40 00 90 38 40 3c 80 38 40 00 90 36 40 3c 80 36 40 00 90 38
40 78 80 38 40 00 90 2c 40 78 80 2c 40 00 90 31 40 78 80 31 40 00 90 2f 40 78 80 2f 40 00 90 2d 40 81 70 80 2d 40 00 90
2c 40 78 80 2c 40 8f 00 90 31 40 78 80 31 40 00 90 36 40 78 80 36 40 00 90 36 40 78 80 36 40 00 90 36 40 78 80 36 40 00
90 35 40 3c 80 35 40 00 90 33 40 3c 80 33 40 00 90 35 40 81 70 80 35 40 00 90 36 40 81 70 80 36 40 86 48 90 2c 40 78 80
2c 40 00 90 31 40 78 80 31 40 00 90 31 40 78 80 31 40 00 90 31 40 78 80 31 40 00 90 30 40 3c 80 30 40 00 90 2e 40 3c 80
2e 40 00 90 30 40 3c 80 30 40 00 90 31 40 3c 80 31 40 00 90 33 40 3c 80 33 40 00 90 30 40 3c 80 30 40 00 90 28 40 81 70
80 28 40 78 90 2d 40 78 80 2d 40 00 90 27 40 81 70 80 27 40 78 90 2c 40 78 80 2c 40 00 90 25 40 78 80 25 40 8c 18 90 31
40 81 70 80 31 40 00 90 30 40 81 70 80 30 40 00 90 34 40 81 70 80 34 40 00 90 33 40 83 60 80 33 40 00 90 31 40 78 80 31
40 00 90 34 40 78 80 34 40 00 90 39 40 78 80 39 40 00 90 39 40 78 80 39 40 00 90 39 40 78 80 39 40 00 90 38 40 3c 80 38
40 00 90 36 40 3c 80 36 40 00 90 34 40 3c 80 34 40 00 90 33 40 3c 80 33 40 00 90 31 40 3c 80 31 40 00 90 2f 40 3c 80 2f
40 00 90 2e 40 81 70 80 2e 40 00 90 2d 40 82 68 80 2d 40 00 90 2c 40 3c 80 2c 40 00 90 2a 40 3c 80 2a 40 00 90 29 40 81
70 80 29 40 00 90 2a 40 83 60 80 2a 40 00 90 2c 40 8f 00 80 2c 40 00 90 2b 40 83 60 80 2b 40 00 90 2c 40 87 40 80 2c 40
00 90 31 40 8f 00 80 31 40 77 90 00 00 00 ff 2f 00
O programa a seguir leva um arquivo MIDI de várias faixas com três ou mais faixas e divide cada faixa em um arquivo MIDI separado. A faixa de expressão do arquivo MIDI original é copiada para a 0ª faixa dos novos arquivos MIDI, e as faixas individuais do primeiro arquivo MIDI são copiadas para a 1ª faixa dos arquivos MIDI de saída.
# include " MidiFile.h "
# include < iostream >
# include < vector >
using namespace std ;
using namespace smf ;
int main ( int argc, char ** argv) {
if (argc != 3 ) {
cerr << " Usage: " << argv[ 0 ] << " input output " << endl;
return 1 ;
}
MidiFile midifile (argv[ 1 ]);
if (!midifile. status ()) {
cerr << " Problem reading input " << endl;
return 1 ;
}
if (midifile. getTrackCount () < 3 ) {
cerr << " Not enough tracks to split " << endl;
return 1 ;
}
string basename = argv[ 2 ];
if (basename. substr (basename. size () - 4 ) == " .mid " )
basename = basename. substr ( 0 , basename. size () - 4 );
int outcount = midifile. getTrackCount () - 1 ;
vector<MidiFile> outputs (outcount);
for ( int i= 0 ; i<outcount; i++) {
outputs[i]. addTrack ();
for ( int j= 0 ; j<midifile[ 0 ]. getEventCount (); j++)
outputs[i]. addEvent (midifile[ 0 ][j]);
for ( int j= 0 ; j<midifile[i+ 1 ]. getEventCount (); j++)
outputs[i]. addEvent ( 1 , midifile[i+ 1 ][j]);
}
for ( int i= 0 ; i<outcount; i++)
outputs[i]. write (basename + " - " + to_string (i+ 1 ) + " .mid " );
return 0 ;
}Aqui está o primeiro arquivo extraído da entrada do arquivo MIDI para o exemplo do temperamento:
4d 54 68 64 00 00 00 06 00 01 00 02 00 78 4d 54 72 6b 00 00 00 13 00 ff 51
03 08 8e 6c 00 ff 58 04 02 01 30 08 00 ff 2f 00 4d 54 72 6b 00 00 09 bd b2
50 90 49 40 81 70 80 49 40 00 90 48 40 81 70 80 48 40 00 90 4c 40 81 70 80
4c 40 00 90 4b 40 83 60 80 4b 40 00 90 49 40 82 68 80 49 40 00 90 4b 40 78
80 4b 40 00 90 4c 40 78 80 4c 40 00 90 4b 40 78 80 4b 40 00 90 49 40 81 70
80 49 40 00 90 47 40 81 70 80 47 40 00 90 49 40 81 70 80 49 40 00 90 4b 40
81 70 80 4b 40 82 68 90 4c 40 78 80 4c 40 00 90 4b 40 78 80 4b 40 00 90 49
40 78 80 49 40 00 90 47 40 78 80 47 40 00 90 4b 40 78 80 4b 40 00 90 50 40
82 68 80 50 40 00 90 4e 40 78 80 4e 40 00 90 50 40 78 80 50 40 00 90 51 40
78 80 51 40 00 90 53 40 84 58 80 53 40 00 90 51 40 78 80 51 40 00 90 50 40
78 80 50 40 00 90 4e 40 78 80 4e 40 00 90 50 40 3c 80 50 40 00 90 4e 40 3c
80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 4b 40 3c 80 4b 40 00 90 49 40 83 60
80 49 40 00 90 47 40 82 68 80 47 40 00 90 49 40 78 80 49 40 00 90 47 40 78
80 47 40 00 90 45 40 78 80 45 40 00 90 44 40 81 70 80 44 40 00 90 46 40 78
80 46 40 00 90 47 40 78 80 47 40 00 90 49 40 81 70 80 49 40 00 90 47 40 83
60 80 47 40 00 90 46 40 81 70 80 46 40 00 90 47 40 84 58 80 47 40 00 90 49
40 78 80 49 40 00 90 4b 40 78 80 4b 40 00 90 4c 40 78 80 4c 40 00 90 4c 40
81 70 80 4c 40 00 90 4b 40 81 70 80 4b 40 00 90 4c 40 78 80 4c 40 00 90 4b
40 78 80 4b 40 00 90 4c 40 78 80 4c 40 00 90 4e 40 78 80 4e 40 00 90 50 40
3c 80 50 40 00 90 4e 40 3c 80 4e 40 00 90 50 40 3c 80 50 40 00 90 51 40 3c
80 51 40 00 90 50 40 3c 80 50 40 00 90 4e 40 3c 80 4e 40 00 90 4c 40 3c 80
4c 40 00 90 50 40 3c 80 50 40 00 90 4e 40 3c 80 4e 40 00 90 4c 40 3c 80 4c
40 00 90 4e 40 3c 80 4e 40 00 90 50 40 3c 80 50 40 00 90 4e 40 3c 80 4e 40
00 90 4c 40 3c 80 4c 40 00 90 4b 40 3c 80 4b 40 00 90 4e 40 3c 80 4e 40 00
90 4c 40 3c 80 4c 40 00 90 4b 40 3c 80 4b 40 00 90 4c 40 3c 80 4c 40 00 90
4e 40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 4b 40 3c 80 4b 40 00 90 49
40 3c 80 49 40 00 90 4c 40 3c 80 4c 40 00 90 4b 40 3c 80 4b 40 00 90 49 40
3c 80 49 40 00 90 4b 40 3c 80 4b 40 00 90 4c 40 3c 80 4c 40 00 90 4b 40 3c
80 4b 40 00 90 49 40 3c 80 49 40 00 90 47 40 3c 80 47 40 00 90 4b 40 3c 80
4b 40 00 90 49 40 3c 80 49 40 00 90 47 40 3c 80 47 40 00 90 49 40 3c 80 49
40 00 90 4b 40 3c 80 4b 40 00 90 49 40 3c 80 49 40 00 90 47 40 3c 80 47 40
00 90 46 40 3c 80 46 40 00 90 49 40 3c 80 49 40 00 90 47 40 82 2c 80 47 40
00 90 49 40 3c 80 49 40 00 90 4b 40 3c 80 4b 40 00 90 47 40 3c 80 47 40 00
90 49 40 82 68 80 49 40 00 90 4c 40 78 80 4c 40 00 90 4b 40 82 68 80 4b 40
00 90 4e 40 78 80 4e 40 00 90 4c 40 84 58 80 4c 40 00 90 4b 40 81 70 80 4b
40 00 90 49 40 81 70 80 49 40 00 90 48 40 3c 80 48 40 00 90 46 40 3c 80 46
40 00 90 48 40 78 80 48 40 00 90 4b 40 78 80 4b 40 00 90 50 40 3c 80 50 40
00 90 4e 40 3c 80 4e 40 00 90 50 40 3c 80 50 40 00 90 51 40 3c 80 51 40 00
90 50 40 3c 80 50 40 00 90 4e 40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90
50 40 3c 80 50 40 00 90 4e 40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 4e
40 3c 80 4e 40 00 90 50 40 3c 80 50 40 00 90 4e 40 3c 80 4e 40 00 90 4c 40
3c 80 4c 40 00 90 4b 40 3c 80 4b 40 00 90 4e 40 3c 80 4e 40 00 90 4d 40 81
70 80 4d 40 00 90 51 40 81 70 80 51 40 00 90 50 40 84 58 80 50 40 00 90 4e
40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 4a 40 81 70 80 4a 40 78 90 49
40 78 80 49 40 00 90 4e 40 78 80 4e 40 00 90 4e 40 78 80 4e 40 00 90 4e 40
78 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 4a 40 3c 80 4a 40 00 90 4c 40 82
68 80 4c 40 00 90 4a 40 3c 80 4a 40 00 90 49 40 3c 80 49 40 00 90 4a 40 83
60 80 4a 40 00 90 49 40 81 70 80 49 40 00 90 4e 40 81 70 80 4e 40 00 90 4c
40 81 70 80 4c 40 00 90 4c 40 81 34 80 4c 40 00 90 4e 40 3c 80 4e 40 00 90
4c 40 3c 80 4c 40 00 90 4a 40 3c 80 4a 40 00 90 49 40 3c 80 49 40 00 90 4c
40 3c 80 4c 40 00 90 4a 40 3c 80 4a 40 00 90 49 40 3c 80 49 40 00 90 4a 40
3c 80 4a 40 00 90 4c 40 3c 80 4c 40 00 90 4a 40 3c 80 4a 40 00 90 49 40 3c
80 49 40 00 90 47 40 3c 80 47 40 00 90 4a 40 3c 80 4a 40 00 90 49 40 83 60
80 49 40 00 90 48 40 81 70 80 48 40 00 90 4c 40 81 70 80 4c 40 00 90 4b 40
84 58 80 4b 40 00 90 44 40 78 80 44 40 00 90 49 40 78 80 49 40 00 90 49 40
78 80 49 40 00 90 49 40 78 80 49 40 00 90 47 40 3c 80 47 40 00 90 45 40 3c
80 45 40 00 90 47 40 83 60 80 47 40 00 90 45 40 81 70 80 45 40 00 90 44 40
81 70 80 44 40 81 70 90 4b 40 83 60 80 4b 40 00 90 4a 40 81 70 80 4a 40 00
90 4e 40 81 70 80 4e 40 00 90 4d 40 81 70 80 4d 40 00 90 4c 40 81 70 80 4c
40 00 90 4b 40 3c 80 4b 40 00 90 49 40 3c 80 49 40 00 90 4b 40 3c 80 4b 40
00 90 4c 40 3c 80 4c 40 00 90 4b 40 3c 80 4b 40 00 90 49 40 3c 80 49 40 00
90 47 40 3c 80 47 40 00 90 4b 40 3c 80 4b 40 00 90 49 40 3c 80 49 40 00 90
47 40 3c 80 47 40 00 90 49 40 3c 80 49 40 00 90 4b 40 3c 80 4b 40 00 90 49
40 3c 80 49 40 00 90 4c 40 3c 80 4c 40 00 90 4b 40 3c 80 4b 40 00 90 49 40
3c 80 49 40 00 90 48 40 81 70 80 48 40 00 90 47 40 81 70 80 47 40 00 90 46
40 81 70 80 46 40 00 90 45 40 81 70 80 45 40 00 90 44 40 81 70 80 44 40 89
30 90 49 40 83 60 80 49 40 00 90 48 40 81 70 80 48 40 00 90 4c 40 81 70 80
4c 40 00 90 4b 40 85 50 80 4b 40 00 90 49 40 83 60 80 49 40 00 90 48 40 81
70 80 48 40 78 90 49 40 3c 80 49 40 00 90 4b 40 3c 80 4b 40 00 90 4c 40 78
80 4c 40 00 90 4e 40 78 80 4e 40 00 90 50 40 3c 80 50 40 00 90 4e 40 3c 80
4e 40 00 90 50 40 3c 80 50 40 00 90 51 40 3c 80 51 40 00 90 50 40 3c 80 50
40 00 90 4e 40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 50 40 3c 80 50 40
00 90 4e 40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 4e 40 3c 80 4e 40 00
90 50 40 3c 80 50 40 00 90 4e 40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90
4b 40 3c 80 4b 40 00 90 4e 40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 4b
40 3c 80 4b 40 00 90 4c 40 3c 80 4c 40 00 90 4e 40 3c 80 4e 40 00 90 4c 40
3c 80 4c 40 00 90 4a 40 3c 80 4a 40 00 90 49 40 3c 80 49 40 00 90 4c 40 3c
80 4c 40 00 90 4a 40 3c 80 4a 40 00 90 49 40 3c 80 49 40 00 90 4a 40 3c 80
4a 40 00 90 4c 40 3c 80 4c 40 00 90 4a 40 3c 80 4a 40 00 90 49 40 3c 80 49
40 00 90 47 40 3c 80 47 40 00 90 4a 40 3c 80 4a 40 00 90 49 40 3c 80 49 40
00 90 47 40 3c 80 47 40 00 90 49 40 3c 80 49 40 00 90 4a 40 3c 80 4a 40 00
90 49 40 3c 80 49 40 00 90 47 40 3c 80 47 40 00 90 45 40 3c 80 45 40 00 90
49 40 3c 80 49 40 00 90 47 40 3c 80 47 40 00 90 45 40 3c 80 45 40 00 90 47
40 3c 80 47 40 00 90 49 40 3c 80 49 40 00 90 47 40 3c 80 47 40 00 90 45 40
3c 80 45 40 00 90 44 40 3c 80 44 40 00 90 47 40 3c 80 47 40 00 90 45 40 81
70 80 45 40 81 70 90 49 40 83 60 80 49 40 00 90 48 40 81 70 80 48 40 00 90
4c 40 81 70 80 4c 40 00 90 4b 40 84 58 80 4b 40 00 90 49 40 78 80 49 40 00
90 50 40 78 80 50 40 00 90 50 40 78 80 50 40 00 90 50 40 78 80 50 40 00 90
4e 40 3c 80 4e 40 00 90 4c 40 3c 80 4c 40 00 90 4e 40 81 70 80 4e 40 00 90
4c 40 83 60 80 4c 40 00 90 4b 40 81 70 80 4b 40 00 90 4f 40 81 70 80 4f 40
00 90 4e 40 81 70 80 4e 40 00 90 42 40 81 70 80 42 40 00 90 41 40 81 70 80
41 40 00 90 45 40 81 70 80 45 40 00 90 44 40 78 80 44 40 83 60 90 48 40 78
80 48 40 00 90 4e 40 78 80 4e 40 00 90 4e 40 78 80 4e 40 00 90 4e 40 78 80
4e 40 00 90 4c 40 3c 80 4c 40 00 90 4b 40 3c 80 4b 40 00 90 4c 40 78 80 4c
40 00 90 4b 40 3c 80 4b 40 00 90 49 40 3c 80 49 40 00 90 4b 40 78 80 4b 40
00 90 48 40 78 80 48 40 00 90 49 40 85 50 80 49 40 00 90 48 40 81 70 80 48
40 00 90 47 40 81 70 80 47 40 00 90 46 40 81 70 80 46 40 00 90 45 40 81 70
80 45 40 00 90 44 40 83 60 80 44 40 00 90 46 40 81 70 80 46 40 00 90 48 40
81 70 80 48 40 00 90 49 40 83 60 80 49 40 00 90 48 40 81 70 80 48 40 00 90
4c 40 83 60 80 4c 40 00 90 4b 40 78 80 4b 40 00 90 49 40 78 80 49 40 00 90
48 40 81 70 80 48 40 00 90 49 40 83 60 80 49 40 00 90 48 40 81 70 80 48 40
00 90 49 40 8f 00 80 49 40 77 90 00 00 00 ff 2f 00
Este exemplo demonstra a geração de um vibrato constante para anotações em um arquivo MIDI (em um canal específico). O programa adiciona uma faixa extra no final do arquivo para armazenar as curvas de arremesso. A taxa de vibrato é constante, independentemente da configuração do ritmo do arquivo MIDI, pois o vibrato é calculado no tempo físico, em vez do tempo de carrapato. A função MidiFile::getAbsoluteTickTime() calcula a conversão entre o tempo físico em segundos e o horário de marque no arquivo MIDI.
# include " MidiFile.h "
# include " Options.h "
# include < iostream >
# include < utility >
# include < cmath >
using namespace std ;
using namespace smf ;
int main ( int argc, char ** argv) {
Options options;
options. define ( " f|frequency=d:4.0 " , " vibrato frequency " );
options. define ( " d|depth=d:20.0 " , " vibrato depth in cents " );
options. define ( " b|bend-max=d:200.0 " , " pitch bend depth " );
options. define ( " s|sample-rate=d:100.0 " , " sample rate " );
options. define ( " o|output-file=s " , " output filename " );
options. define ( " c|channel=i:0 " , " output channel " );
options. process (argc, argv);
MidiFile midifile;
if (options. getArgCount () == 0 ) midifile. read (cin);
else midifile. read (options. getArg ( 1 ));
if (!midifile. status ()) {
cerr << " Problem reading file " << endl;
return 1 ;
}
string filename = options. getString ( " output-file " );
int channel = options. getInteger ( " channel " );
double freq = options. getDouble ( " frequency " );
double depth = options. getDouble ( " depth " );
double bend = options. getDouble ( " bend-max " );
double srate = options. getDouble ( " sample-rate " );
double phase = 0.0 ;
double twopi = 2.0 * M_PI;
double increment = twopi * freq / srate;
double maxtime = midifile. getFileDurationInSeconds ();
midifile. addTrack (); // store vibrato in separate track
pair< int , double > tickbend;
vector<pair< double , double >> storage;
int count = maxtime * srate;
storage. reserve (maxtime * srate + 1000 );
for ( int i= 0 ; i<count; i++) {
tickbend. first = int (midifile. getAbsoluteTickTime (i/srate) + 0.5 );
tickbend. second = depth/bend * sin (phase);
if ((storage. size () > 0 ) && (tickbend. first == 0 )) break ;
storage. push_back (tickbend);
phase += increment;
if (phase > twopi) phase -= twopi;
}
int track = midifile. getTrackCount () - 1 ;
for ( int i= 0 ; i<( int )storage. size (); i++)
midifile. addPitchBend (track, storage[i]. first , channel, storage[i]. second );
if (filename. empty ()) cout << midifile;
else midifile. write (filename);
return 0 ;
}Aqui está um programa que gera padrões de polirritmo. As opções de linha de comando são:
| opção | valor padrão | significado |
|---|---|---|
-a | 2 | Divisão do Ciclo do primeiro instrumento |
-b | 3 | Divisão do Ciclo do primeiro instrumento |
-c | 10 | Número de ciclos |
-d | 2.0 | duração de cada ciclo |
--key1 | 76 | Número da chave de percussão para o primeiro instrumento |
--key2 | 77 | Número da chave de percussão para o primeiro instrumento |
-o | nome do arquivo de saída |
# include " MidiFile.h "
# include " Options.h "
# include < iostream >
# include < utility >
# include < cmath >
using namespace std ;
using namespace smf ;
int main ( int argc, char ** argv) {
Options options;
options. define ( " a=i:2 " , " cycle division 1 " );
options. define ( " b=i:3 " , " cycle division 2 " );
options. define ( " c|cycle=i:10 " , " cycle count " );
options. define ( " d|dur=d:2.0 " , " duration of cycle in seconds " );
options. define ( " key1=i:76 " , " first percussion key number " );
options. define ( " key2=i:77 " , " second percussion key number " );
options. define ( " o|output-file=s " , " output filename " );
options. process (argc, argv);
int a = options. getInteger ( " a " );
int b = options. getInteger ( " b " );
int c = options. getInteger ( " cycle " );
int key1 = options. getInteger ( " key1 " );
int key2 = options. getInteger ( " key2 " );
double dur = options. getDouble ( " dur " );
double tempo = 60.0 / dur;
MidiFile midifile;
midifile. setTPQ (a*b);
midifile. addTempo ( 0 , 0 , tempo);
midifile. addTracks ( 2 );
for ( int i= 0 ; i<b*c + 1 ; i++) {
midifile. addNoteOn ( 1 , i*a, 9 , key1, 64 );
midifile. addNoteOff ( 1 , (i+ 1 )*a, 9 , key1);
}
for ( int i= 0 ; i<a*c + 1 ; i++) {
midifile. addNoteOn ( 2 , i*b, 9 , key2, 64 );
midifile. addNoteOff ( 2 , (i+ 1 )*b, 9 , key2);
}
string filename = options. getString ( " output-file " );
if (filename. empty ()) cout << midifile;
else midifile. write (filename);
return 0 ;
} Este programa demonstra como definir o valor de ticks-per-note no cabeçalho MIDI. Nesse caso, ele é definido como o fator de a*b , que é a duração de um ciclo (portanto, cada ciclo tem a duração de uma nota de um quarto). Uma meta-mensagem de ritmo também é calculada com base na duração desejada de um ciclo.
Por exemplo, tente as opções -a 3 -b 4 -c 200 -d 1 -o 3x4.mid , que jogará um padrão de 3 contra -4 para 200 ciclos com cada ciclo durando 1 segundo. Ou aqui está 11 -AGONTRA -13 PARA 100 CICLOS: -a 11 -b 13 -c 100 -d 5 -o 11x13.mid .