<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE article PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [ <!ENTITY howto "http://www.traduc.org/docs/howto/lecture/"> <!ENTITY guide "http://www.traduc.org/docs/guides/lecture/"> ]> <article lang="fr"> <articleinfo> <title> Guide pratique du MIDI sous Linux </title> <subtitle> Version française de <foreignphrase>The Linux MIDI-HOWTO</foreignphrase> </subtitle> <releaseinfo>Version : 1.2.fr.1.0</releaseinfo> <!-- La date de publication est la date de la v.f. --> <pubdate>2004-04-04</pubdate> <revhistory> <revision> <revnumber>1.20.fr.0.9</revnumber> <date>2004-04-04</date> <authorinitials>JML, ÉM, JPG</authorinitials> <revremark>Première traduction française.</revremark> </revision> <revision> <revnumber>1.20</revnumber> <date>2002-05-24</date> <authorinitials>PK</authorinitials> </revision> <revision> <revnumber>1.10</revnumber> <date>2002-04-02</date> <authorinitials>PK</authorinitials> </revision> <revision> <revnumber>1.00</revnumber> <date>2002-01-25</date> <authorinitials>PK</authorinitials> </revision> </revhistory> <author> <firstname>Phil</firstname> <surname>Kerr</surname> <email>phil CHEZ plus24 POINT com</email> </author> <othercredit role="traduction" class="translator"> <firstname>Jean-Marc</firstname> <surname>Legrand</surname> <contrib>Adaptation française</contrib> <email>cjm POINT legrand CHEZ wanadoo POINT fr</email> </othercredit> <othercredit role="relecture"> <firstname>Éric</firstname> <surname>Madesclair</surname> <contrib>Relecture de la version française</contrib> <email>eric TIRET m CHEZ wanadoo POINT fr</email> </othercredit> <othercredit role="relecture" class="translator"> <firstname>Jean-Philippe</firstname> <surname>Guérard</surname> <contrib>Relecture rapide</contrib> <email>fevrier CHEZ tigreraye POINT org</email> </othercredit> <othercredit role="publication" class="copyeditor"> <firstname>Jean-Philippe</firstname> <surname>Guérard</surname> <contrib>Préparation de la publication de la v.f.</contrib> <email>fevrier CHEZ tigreraye POINT org</email> </othercredit> <abstract><para> Ce document présente, et explique comment utiliser le matériel et les logiciels permettant de jouer et de composer des fichier MIDI sous Linux. </para></abstract> </articleinfo> <sect1> <title>Introduction</title> <para> Ce document traite des points suivants : </para> <itemizedlist> <listitem><para> comment configurer votre interface MIDI ; </para></listitem> <listitem><para> comment configurer et utiliser des synthétiseurs logiciels ; </para></listitem> <listitem><para> comment jouer des fichiers MIDI ; </para></listitem> <listitem><para> comment utiliser un séquenceur ; </para></listitem> <listitem><para> comment contrôler du matériel MIDI externe ; </para></listitem> <listitem><para> logiciels MIDI basés sur la synthèse de sons ; </para></listitem> <listitem><para> exemples de code MIDI. </para></listitem> </itemizedlist> </sect1> <sect1> <title>Droits d'utilisation (<foreignphrase>Copyright of this document</foreignphrase>)</title> <!-- La licence GFDL impose de conserver une copie du texte de ce chapitre dans sa version originale. --> <para> Copyright © 2002 Phil Kerr. </para> <para><foreignphrase> This HOWTO is copyrighted 2002 Phil Kerr. </foreignphrase></para> <para> Copyright © 2002 Frank Barknecht pour la <xref linkend="synthetiseurs-virtuels"/>. </para> <para><foreignphrase> The "HOWTO Use MIDI Sequencers With Softsynths" is copyright 2002 Frank Barknecht. </foreignphrase></para> <para> Copyright © 2004 Jean-Marc Legrand, Éric Madesclair, Jean-Philippe Guérard pour la version française. </para> <para> Ce guide pratique est distribué sous la licence de documentation libre GNU (GFDL). Vous devriez avoir reçu une copie de cette licence avec celui-ci. Si tel n'est pas le cas, vous pouvez vous la procurer en version originale anglophone à cette adresse : </para> <para><foreignphrase> This document is distributed under the terms of the GNU Free Documentation License. You should have received a copy along with it. If not, it is available from: </foreignphrase></para> <para> <ulink url="http://www.fsf.org/licenses/fdl.html"/> </para> <para> Il en existe une version française non-officielle à cette adresse : </para> <para> <ulink url="http://cesarx.free.fr/gfdlf.html"/> </para> </sect1> <sect1> <title>Où se procurer ce guide ?</title> <para> La dernière version française officielle de ce guide est disponible sur : <ulink url="&howto;MIDI-HOWTO.html"/>. </para> <para> La dernière version originale de ce guide pratique est publiée sur : <ulink url="http://www.midi-howto.com"/>. </para> </sect1> <sect1> <title>Remerciements</title> <para> Ce guide est basé sur le petit guide du MIDI-SB (<foreignphrase>MIDI-SB mini-HOWTO</foreignphrase>) écrit par Hideki Saito. Tous mes remerciements pour sa contribution à la communauté Linux. </para> <para> Ce guide contient désormais le <quote>Guide d'utilisation des Séquenceurs MIDI avec des Synthétiseurs virtuels</quote> écrit par Frank. Tous mes remerciements, Frank. </para> <para> Une grande partie des exemples de code contenus dans ce guide provient de la liste de discussions LAD (Développeurs Audio Linux). Merci à eux pour m'avoir permis de les reprendre dans ce guide. </para> </sect1> <sect1> <title> Avertissement (<foreignphrase>Disclaimer</foreignphrase>) </title> <!-- La licence GFDL impose de conserver une copie du texte de ce chapitre dans sa version originale. --> <para> L'utilisation des informations de ce document est de votre responsabilité. </para> <para><foreignphrase> Use the information in this document at your own risk. </foreignphrase></para> <para> Je décline toute responsabilité quant au contenu de ce document. </para> <para><foreignphrase> I disavow any potential liability for the contents of this document. </foreignphrase></para> <para> L'utilisation des principes, exemples, et autres contenus de ce document sera entièrement de votre responsabilité. </para> <para><foreignphrase> Use of the concepts, examples, and/or other content of this document is entirely at your own risk. </foreignphrase></para> <para> Tous les droits d'auteur et de copyright sont la propriété de leurs détenteurs respectifs, sauf indication contraire. </para> <para><foreignphrase> All copyrights are owned by their owners, unless specifically noted otherwise. </foreignphrase></para> <para> Aucune remarque contenue dans ce document ne pourra être considérée comme un jugement de valeur contre telle ou telle marque. </para> <para><foreignphrase> Use of a term in this document should not be regarded as affecting the validity of any trademark or service mark. </foreignphrase></para> <para> Le fait de citer une marque ou un produit particulier ne saurait être considérée comme une recommandation. </para> <para><foreignphrase> Naming of particular products or brands should not be seen as endorsements. </foreignphrase></para> <para> Il vous est fortement recommandé d'effectuer une sauvegarde de votre système avant toute installation d'importance et de le sauvegarder régulièrement au cours de votre travail. </para> <para><foreignphrase> You are strongly recommended to take a backup of your system before major installation and backups at regular intervals. </foreignphrase></para> </sect1> <sect1> <title>Histoire du MIDI</title> <para> Le MIDI est un ensemble de protocoles matériels et logiciels permettant à des instruments de musique électroniques de communiquer entre eux. Le MIDI est apparu pour la première fois en 1982, et s'est imposé comme le standard de communication pour ce type d'instruments. Ce protocole fixe les paramètres physiques du matériel (connexions et interfaces matérielles), et permet de disposer d'un éventail précis de protocoles de communication pour l'échange de données musicales et rythmiques. </para> <para> Avant le MIDI, il existait d'autres protocoles de connexion, tout d'abord analogiques, puis numériques. Le plus ancien, au alentours de 1974, permettait de transmettre des informations musicales sous forme de tension électrique via les câbles de liaison entre les différents claviers. Plus tard, en 1980-1981, Roland créa un protocole numérique de référence, le DCB. L'association des fabricants d'instruments MIDI (<foreignphrase lang="en">MIDI Manufacturers Association</foreignphrase> ‐ MMA) a défini, à partir de leurs propres équipements, un protocole et un câblage standards pour des matériels compatibles, qui permettait à tous les matériels issus de fabricants adhérent à ce standard de se connecter et de communiquer entre eux. </para> <para> À partir de 1985, les interfaces MIDI commencèrent à apparaître sur les PC personnels et peu après apparurent les premiers séquenceurs virtuels. </para> </sect1> <sect1> <title>Configurer ses périphériques MIDI</title> <para> Les périphériques MIDI sont soit intégrés à la carte son, soit inclus dans un matériel séparé. Les interfaces MIDI externes sont reliées soit au port série, soit à un port USB. </para> <para> La première chose à faire — et la plus importante — est de vérifier la compatibilité de votre carte son ! </para> <para> Les adresses suivantes peuvent vous y aider : </para> <para> <ulink url="http://www.alsa-project.org/alsa-doc/"/> </para> <para> <ulink url="http://www.4front-tech.com/osshw.html"/> </para> <para> La façon de configurer ses périphériques MIDI varie d'une distribution Linux à l'autre. Normalement, une carte son compatible sera configurée correctement à l'installation du système d'exploitation. </para> <para> Le noyau Linux contient les pilotes OSS, et, depuis les versions 2.5, les pilotes ALSA. La plupart des distributions offrent un outil de configuration (essentiellement dédié aux cartes son). Toutefois, si vous utilisez le port MIDI d'une carte son, il devra être configuré manuellement. Sous RedHat, il faut utiliser sndconfig, sous SuSE : yast, et sous Mandrake : DrakConf. </para> <para> Si aucun de ces outils n'est utilisable, ou si vous rencontrez des problèmes, suivez les étapes suivantes : </para> <para> Est-ce que la commande <command>lsmod</command> montre des modules spécifiques au MIDI ? Voici ce que l'on peut obtenir sur un système basé sur OSS : </para> <programlisting> [root@beatbox]# lsmod Module Size Used by lockd 32208 1 (autoclean) sunrpc 54640 1 (autoclean) [lockd] autofs 9456 2 (autoclean) usb-ohci 12624 0 (unused) usbcore 43632 1 [usb-ohci] hisax 470096 0 (autoclean) (unused) isdn 104208 0 (autoclean) [hisax] slhc 4544 0 (autoclean) [isdn] eepro100 16144 1 (autoclean) #---- modules de cartes son opl3 11376 2 mad16 7968 1 ad1848 16848 1 [mad16] sb 34752 1 [mad16] uart401 6384 1 [mad16 sb] sound 58368 0 [opl3 mad16 ad1848 sb uart401] soundlow 464 0 [sound] soundcore 2800 6 [sb sound] nls_cp437 3952 2 (autoclean) vfat 9408 1 (autoclean) fat 30432 1 (autoclean) [vfat] ide-scsi 7664 0 </programlisting> <para> Recherchez les modules mpu401, olp3, uart401 et oss. </para> <para> Si vous utilisez une interface USB, n'oubliez pas de vérifier que les modules USB correspondants apparaissent bien. </para> <para> Pour vérifier la configuration, faites un <command>cat</command> du fichier <filename class="devicefile">sndstat</filename> : </para> <programlisting> [root@beatbox]# cat /dev/sndstat OSS/Free:3.8s2++-971130 Load type: Driver loaded as a module Kernel: Linux mega 2.2.17-21mdk #1 Thu Oct 5 13:16:08 CEST 2000 i686 Config options: 0 Installed drivers: Card config: Audio devices: 0: MAD16 WSS (82C930) (DUPLEX) Synth devices: 0: Yamaha OPL3 Midi devices: 0: Mad16/Mozart Timers: 0: System clock Mixers: 0: MAD16 WSS (82C930) </programlisting> <para> Nous voyons ici que le périphérique MIDI est mad16, ce qui correspond au lsmod effectué plus haut. </para> <para> Si rien n'apparaît concernant le MIDI, vérifiez le contenu de votre fichier /etc/modules.conf. </para> <programlisting> [root@beatbox]# cat /etc/modules.conf alias net-pf-4 ipx pre-install pcmcia_core /etc/rc.d/init.d/pcmcia start alias usb-interface usb-ohci alias parport_lowlevel parport_pc alias block-major-11 scsi_hostadapter pre-install plip modprobe parport_pc ; echo 7 > /proc/parport/0/irq alias scsi_hostadapter ide-scsi alias eth0 eepro100 alias eth1 hisax #---- Carte Son alias sound-slot-0 mad16 options sound dmabuf=1 alias midi opl3 options opl3 io=0x388 options sb support=1 options mad16 io=0x530 irq=5 dma=0 dma16=1 mpu_io=0x300 mpu_irq=7 joystick=1 </programlisting> <para> Voici les données de sortie à vérifier dans le module /proc/modules pour voir si les modules MIDI sont bien chargés dans le noyau. </para> <programlisting> [root@mega /proc]# cat modules 0000-001f : dma1 0020-003f : pic1 0040-005f : timer 0060-006f : keyboard 0070-007f : rtc 0080-008f : dma page reg 00a0-00bf : pic2 00c0-00df : dma2 00f0-00ff : fpu 0170-0177 : ide1 01f0-01f7 : ide0 02f8-02ff : serial(auto) #---- Périphérique MIDI 0300-0303 : MPU-401 UART 0376-0376 : ide1 0388-038b : Yamaha OPL3 03c0-03df : vga+ 03f6-03f6 : ide0 03f8-03ff : serial(auto) 0530-0533 : MAD16 WSS config 0534-0537 : MAD16 WSS de00-de1f : Intel Speedo3 Ethernet f000-f007 : ide0 f008-f00f : ide1 </programlisting> <para> Vous devriez trouver quelque chose ressemblant à cela. Si tel n'est pas le cas, vous devrez installer manuellement les pilotes MIDI. </para> <para> Si vous êtes amenés à utiliser les pilotes ALSA 0.5x, — ce que je vous déconseille — je vous suggère de lire auparavant le Petit guide du son avec ALSA (<foreignphrase>Alsa-sound-mini-HOWTO</foreignphrase>) de Valentijn Sessink que vous trouverez au lien suivant : </para> <para> <ulink url="&howto;Alsa-sound.html"/> </para> <para> Je vous recommande vivement d'utiliser des versions d'ALSA supérieures à la version 0.9. Pour des pilotes ALSA plus récents que les versions 0.9x, je vous conseille de lire le Guide ALSA (<foreignphrase>Alsa HOWTO</foreignphrase>) de Madhu Maddy. </para> <para> <ulink url="http://www.alsa-project.org/alsa-doc/alsa-howto/"/> </para> <sect2> <title>Installation rapide de ALSA 0.9</title> <para> Vous trouverez ci-dessous une méthode d'installation rapide des pilotes et des bibliothèques ALSA 9.0, ainsi que les configurations les plus répandues dans les applications MIDI. </para> <programlisting> [root@beatbox] # tar jxvf alsa-driver....tar.bz2 [root@beatbox] # cd alsa-driver..... [root@beatbox] # ./configure messages - no errors [root@beatbox] # make messages - no errors [root@beatbox] # make install messages - no errors [root@beatbox] # ./snddevices </programlisting> <para> À ce stade, vous devez éditer le fichier /etc/modules.conf, ou, pour certaines distributions, le fichier ALSA de votre répertoire de modules. Il se pourrait que vous rencontriez des indications pour d'autres matériels, non MIDI : soyez prudent lors de l'édition du fichier. </para> <para> Si il existe déjà une ancienne configuration ALSA ou OSS dans ce fichier, vous devrez l'effacer ou, mieux encore, la commenter. </para> <para> Vous trouverez ci-dessous un exemple typique de fichier <filename>modules.conf</filename>, décrivant une configuration ALSA sous OSS. </para> <programlisting> alias char-major-116 snd alias char-major-14 soundcore alias snd-card-0 <replaceable>(carte son/MIDI)</replaceable> alias sound-slot-0 snd-card-0 alias sound-service-0-0 snd-mixer-oss alias sound-service-0-1 snd-seq-oss alias sound-service-0-3 snd-pcm-oss alias sound-service-0-12 snd-pcm-oss </programlisting> <para> Remplacez l'entrée <replaceable>(carte son/MIDI)</replaceable> par la référence correcte à votre carte son. Vous trouverez normalement les informations nécessaires sur le site web ALSA. </para> <para> Une fois les pilotes ALSA installés, vous devrez installer les fichiers de bibliothèques d'en-têtes nécessaires au fonctionnement des programmes basés sur ALSA. C'est ce que contient le paquet alsa-libs. </para> <para> Assurez-vous tout d'abord que votre paquet alsa-libs correspond bien à vos pilotes ALSA ! </para> <programlisting> [root@beatbox] # tar jxvf alsa-libs....tar.bz2 [root@beatbox] # cd alsa-libs..... [root@beatbox] # ./configure messages - no errors [root@beatbox] # make messages - no errors [root@beatbox] # make install </programlisting> <para> Votre système devrait alors être configuré ! :o) </para> <para> Vous pouvez le vérifier à l'aide d'un simple programme en C : si vous réussissez à le compiler et l'exécuter, c'est que votre système fonctionne bien. </para> <programlisting> // Compilez ce programme test ainsi : gcc alsatest.c -o alsatest -lasound #include <stdio.h> #include <alsa/asoundlib.h> int main (int argc, char *argv[]) { snd_seq_t *seq_handle; if (snd_seq_open(&seq_handle, "hw", SND_SEQ_OPEN_DUPLEX, 0) < 0) { fprintf(stderr, "Error opening ALSA sequencer.\n"); exit(1); } printf("The ALSA libraries are installed.\n"); return 0; } </programlisting> </sect2> <sect2> <title>Les problèmes de latence</title> <para> Le MIDI est un protocole temps-réel et les réglages de latence peuvent poser de sérieux problèmes. </para> <para> Désormais, plusieurs développeurs travaillent sur l'amélioration des temps de latence, et les progrès réalisés sur le noyau font aujourd'hui de Linux une plateforme tout à fait efficace pour le MIDI. </para> <para> Même si les distributions Linux fonctionnent correctement sur ce point, les utilisateurs avancés devront installer des correctifs noyau pour diminuer les temps de latence. Vous trouverez plus d'informations sur les sites suivants : </para> <para> <ulink url="http://www.gardena.net/benno/linux/audio/"/> </para> <para> <ulink url="http://www.linuxdj.com/audio/lad/resourceslatency.php3"/> </para> <para> Vous trouverez en outre le Petit guide de réduction des temps de latence (<foreignphrase lang="en">Low Latency Mini Howto</foreignphrase> — en anglais) à l'adresse suivante : </para> <para> <ulink url="http://web.archive.org/web/20021211025416/http://www.boosthardware.com/LAU/guide/Low_latency-Mini-HOWTO.html"/> </para> </sect2> </sect1> <sect1> <title>Les logiciels</title> <para> L'intérêt pour des solutions MIDI basées sur Linux étant croissant, la liste suivante ne sera probablement pas exhaustive, mais vous donnera un choix représentatif d'applications MIDI. </para> <para> Si vous êtes développeur ou utilisateur d'autres applications MIDI non listées, merci de m'en avertir par courrier électronique. </para> <sect2> <title>Les pilotes</title> <sect3> <title>Les pilotes ALSA</title> <para> ALSA (l'Architecture Sonore Linux Avancée — <foreignphrase lang="en">Advanced Linux Sound Architecture </foreignphrase>) est constituée de plusieurs éléments. Le premier est un pilote son totalement modulaire, compatible avec le chargement automatique des modules, l'utilisation de devfs, l'autoconfiguration isapnp, et permettant un accès complet aux composants audio analogique, audio numérique, contrôles, mixage, synthétiseur, DSP, MIDI et à la temporisation du matériel MIDI. Il comprend aussi un séquenceur noyau complet, une couche de compatibilité complète avec les applications libres basées sur OSS, une bibliothèque C orientée objet permettant de traiter et améliorer les fonctionnalités des pilotes ALSA pour certaines applications (client/serveur, modules d'extension, le partage et le mixage du son PCM, mesure du son PCM, et cætera), une interface de configuration du pilote, ainsi que quelques autres outils simples pour la configuration et la maintenance. </para> <para> <ulink url="http://www.alsa-project.org/"/> </para> </sect3> <sect3> <title>OSS</title> <para> OSS, le Système audio ouvert, fournit des pilotes de cartes son pour Linux et FreeBSD. Ces pilotes sont compatibles avec le son numérique, le MIDI, les synthétiseurs virtuels et les modules de mixage intégrés aux cartes son. Ces pilotes sonores sont conformes aux spécifications de la bibliothèque de programmation Système audio ouvert (OSS — <foreignphrase>Open Sound System</foreignphrase>). Le système OSS est muni d'une interface graphique très conviviale, qui rend très simple l'installation des pilotes ainsi que la configuration de la carte son. Ces pilotes sont compatibles avec plus de 200 cartes son de marque et permettent une détection automatique de la carte son, l'autoconfiguration (<foreignphrase>Plug-n-Play</foreignphrase>), l'utilisation des cartes son PCI et la capacité de fonctionnement audio bidirectionnel. </para> <para> <ulink url="http://www.opensound.com/"/> </para> </sect3> <sect3> <title>Notemidi</title> <para> Notemidi est un pilote de périphérique pour la sortie MIDI via le port série RS-232 sur les PC portables. Notemidi peut être utilisé avec l'interface MIDIator MS-124W, les modules de son Roland Sound Canvas, ou les modules de son de la série Yamaha MU-x. </para> <para> <ulink url="http://www.michaelminn.com/linux/notemidi"/> </para> </sect3> </sect2> <sect2> <title>Les lecteurs MIDI</title> <sect3> <title>KMid</title> <para> KMid est un lecteur MIDI basé sur KDE (et donc X11) pour Linux et FreeBSD. Il permet le défilement des textes de fichiers karaoke, et change la couleur du texte au fur et à mesure qu'il est joué, ce qui permet de le suivre facilement. KMid utilise <filename class="devicefile">/dev/sequencer</filename> comme périphérique de sortie compatible avec les synthétiseurs externes, ainsi qu'avec les cartes AWE, FM et GUS. </para> <para> <ulink url="http://perso.wanadoo.es/antlarr/kmid.html"/> </para> </sect3> <sect3> <title>Pmidi</title> <para> Pmidi est un programme en lignes de commande qui permet de jouer des fichiers MIDI sur le séquenceur ALSA. </para> <para> <ulink url="http://www.parabola.demon.co.uk/alsa/pmidi.html"/> </para> </sect3> <sect3> <title>TiMidity++</title> <para> TiMidity est un convertisseur MIDI vers WAVE qui utilise des bibliothèques de timbres dans un format compatible Gravis Ultrasound(*) afin de produire des données audionumériques à partir de fichiers General MIDI. Les données audio peuvent alors être jouées par n'importe quel périphérique son ou stockées sur disque. Sur une machine puissante, les données peuvent être jouées en temps réel. </para> <para> <ulink url="http://timidity.sourceforge.net/"/> </para> </sect3> </sect2> <sect2> <title>Les séquenceurs</title> <sect3> <title>Brahms</title> <para> Brahms est à la fois un séquenceur et un éditeur de partitions, muni de plusieurs outils d'édition comme Score-, Pianoroll-, Drum-, et Mastertrack Editor. Pour les développeurs C++, il est aisé de créer d'autres outils d'édition à partir d'un module d'édition générique. Ce programme possède aussi une fonction d'import et export MIDI. Combiné avec aRts-0.3.4, il est possible de jouer des fichiers WAVE et d'envoyer simultanément au synthétiseur virtuel des évènements MIDI. </para> <para> Ce logiciel était autrefois connu sous l'appellation Koobase. </para> <para> <ulink url="http://brahms.sourceforge.net/"/> </para> </sect3> <sect3> <title>Anthem</title> <para> Anthem est un séquenceur MIDI libre évolué. Anthem vous permet d'enregistrer, d'éditer et de jouer de la musique, en utilisant une technologie musicale orientée objet très sophistiquée et très appréciée. </para> <para> <ulink url="http://anthem.sourceforge.net/"/> </para> </sect3> <sect3> <title>Jazz++</title> <para> JAZZ++ est un séquenceur audio et MIDI complet, sous Linux et Windows. </para> <para> <ulink url="http://www.jazzware.com/cgi-bin/Zope.cgi/jazzware/"/> </para> </sect3> <sect3> <title>UltiMusE-LX </title> <para> UltiMusE-LX (<foreignphrase>the Ultimate Music Editor</foreignphrase>) est un logiciel de composition musicale. Non, non : il ne compose pas à votre place ! C'est un logiciel musical graphique. Vous composez votre partition à l'écran à l'aide de la souris et/ou du clavier, jusqu'à 16 parties ou voix, avec jusqu'à 7 portées. Il permet d'utiliser quasiment toutes les notations standards, ainsi que les outils MIDI de changement d'instrument, d'événement, et de gestion en temps réel. </para> </sect3> <sect3> <title>Melys</title> <para> Melys est une application séquenceur MIDI basé sur ALSA. Melys utilise le séquenceur ALSA et le combine avec les bibliothèques GNOME pour produire un séquenceur puissant et facile à utiliser. </para> <para> <ulink url="http://www.parabola.demon.co.uk/melys/"/> </para> </sect3> <sect3> <title>MidiMountain Sequencer</title> <para> MidiMountain est un séquenceur qui permet d'éditer des fichiers MIDI standard. La facilité d'utilisation de son interface devrait aider les débutants à éditer et créer des séquences MIDI. MidiMountain est conçu pour permettre de manipuler toutes les définitions connues des fichiers MIDI standards et du protocole de transfert MIDI, du simple rouleau de piano mécanique à la manipulation des messages exclusifs systèmes binaires. </para> <para> <ulink url="http://www.midimountain.com/"/> </para> </sect3> <sect3> <title>MusE</title> <para> MusE est un séquenceur MIDI pour Linux, basé sur Qt 2.1, avec fonctions d'édition et d'enregistrement. Pendant que le séquenceur joue, vous pouvez éditer des évènements MIDI en temps réel à l'aide du rouleau de piano mécanique ou de l'éditeur de partition. Les évènements MIDI enregistrés peuvent alors être traités à part avec le menu arrangeur. </para> <para> <ulink url="http://muse.seh.de/"/> </para> </sect3> <sect3> <title>Rosegarden</title> <para> Rosegarden est un séquenceur MIDI intégré et un éditeur de partition. </para> <para> <ulink url="http://www.rosegardenmusic.com/"/> </para> </sect3> </sect2> <sect2> <title>Consoles de mixage MIDI</title> <sect3> <title>tektracker</title> <para> ttrk (tektracker) est un séquenceur MIDI muni d'une interface de type console de mixage. Il est fait pour être utilisé en temps réel, notamment grâce à ses boutons de volume par piste et création de boucles. ttrk permet d'envoyer et de se synchroniser avec les pulsations d'horloge MIDI. </para> <para> <ulink url="http://vektor.ca/audio/ttrk/"/> </para> </sect3> <sect3> <title>ShakeTracker</title> <para> ShakeTracker est un séquenceur MIDI muni d'une interface de type console de mixage. Il fonctionne correctement et permet d'utiliser quasiment tous les effets de mixage habituels. Ceux d'entre vous qui auront utilisé Impulse Tracker auparavant se sentiront chez eux, et pour les nouveaux utilisateurs, ils bénéficieront d'un système d'aide en ligne très complet et très simple d'utilisation. La plupart des commandes et raccourcis ressemblent à leur équivalent sur une table de mixage. </para> <para> <ulink url="http://reduz.com.ar/shaketracker/"/> </para> </sect3> </sect2> <sect2> <title>Éditeurs de rythmes</title> <sect3> <title>DrumPatterns</title> <para> DrumPatterns est un générateur de rythmes, libre et orienté internet, dont l'objectif est d'apprendre à créer des motifs rythmiques. Il est capable de vous apprendre les bases rythmiques, aussi bien que les rythmes les plus compliqués. Il peut éditer des graphismes, des partitions, des évènements MIDI, et inclut des heures d'échantillons d'exemples. </para> <para> <ulink url="http://www.linux-france.org/prj/drumpatterns/index-fr.html"/> </para> </sect3> </sect2> <sect2> <title>Éditeurs de timbres</title> <sect3> <title>JSynthLib</title> <para> JSynthLib est un éditeur et conservateur libre de timbres, écrit en langage Java. Ce projet a pour but d'offrir une compatibilité avec tous les synthétiseurs existants, en fournissant aux utilisateurs des méthodes et des documentations qui leur permette de développer des pilotes et des éditeurs pour les synthétiseurs non compatibles, et de les diffuser via le projet. </para> </sect3> </sect2> <sect2> <title>Synthétiseurs virtuels</title> <sect3> <title>Spiral Synth</title> <para> Spiral Synth est un synthétiseur polyphonique analogique virtuel. Il est capable de réutiliser des sons fabriqués par des synthétiseurs analogiques matériels, comme les bruits utilisés dans la musique électronique. Vous pouvez aussi l'utiliser pour créer les sons les plus bizarres. Il est compatible MIDI et il utilise la sortie sonore standard du système OSS libre (<filename class="devicefile">/dev/dsp</filename>). </para> <para> <ulink url="http://www.pawfal.org/SpiralSynth/"/> </para> </sect3> <sect3> <title>UltraMaster Juno-6</title> <para> UltraMaster Juno-6 est une reproduction virtuelle fidèle du synthétiseur polyphonique Roland Juno-6. Il intègre la synthèse d'ondes ULTRANAMOG en temps-réel et en 64 bit, permet de produire des accords et des chœurs dans le style des années 80. Tous les paramètres peuvent être contrôlés en temps réel, soit via une interface graphique, soit via des actions sur des contrôleurs MIDI externes. </para> <para> <ulink url="http://www.ultramaster.com/juno6/index.html"/> </para> </sect3> <sect3> <title>Pure-Data</title> <para> Pure-Data est un logiciel temps réel pour l'exécution en direct de pièces musicales et multimédia. Il est développé par Miller Puckette , sans doute en collaboration avec d'autres développeurs. Ce logiciel n'est pas encore abouti, mais peut tout à fait être utilisé dans le cadre de projets complexes. Il a été adapté sur Linux, IRIX, et Windows. </para> <para> <ulink url="http://www.pure-data.org/"/> </para> </sect3> <sect3> <title>Csound</title> <para> Csound est un synthétiseur virtuel qui ne souffre pas des limitations des autres synthétiseurs matériels ou logiciels de ce type. Le nombre d'oscillateurs ou de filtres utilisables est illimité. Csound est aussi complètement modulable, de façon à ce que chaque fonction soit utilisable de plusieurs façons différentes. </para> <para> <ulink url="http://www.csound.org/"/>. </para> </sect3> <sect3> <title>Émulateur de Synthétiseur Bristol</title> <para> Bristol est une collection d'émulateurs de synthétiseur. Il comprend Moog Mini, Moog Voyager, Hammond B3, Prophet 5, Juno 6, DX 7, ainsi que d'autres logiciels. </para> <para> <ulink url="http://www.slabexchange.org/index.cgi?DOWNLOAD"/> </para> </sect3> </sect2> <sect2> <title> Les modules d'extension (<foreignphrase>plugins</foreignphrase>) </title> <sect3> <title>xmms-midi</title> <para> Il ajoute à x11amp la compatibilité avec les fichiers MIDI (via timidity). Une interface de mixage simplifiée est disponible par le menu de configuration. </para> <para> <ulink url="http://ban.joh.cam.ac.uk/~cr212/xmms-midi/"/> </para> </sect3> </sect2> <sect2> <title>Partitions musicales</title> <sect3> <title>Mup</title> <para> Mup prend des données d'entrée de type texte pour les transformer en données Postcript imprimables. Les notations standards classiques et la notation en tablature sont toutes deux utilisables. MUP peut aussi produire des données de sortie de type MIDI. </para> <para> <ulink url="http://www.arkkra.com/"/> </para> </sect3> <sect3> <title>Lilypond</title> <para> LilyPond est un logiciel de composition musicale. Il permet de réaliser de très belles partitions, à partir de données d'entrée très détaillées. LilyPond fait partie du projet GNU. </para> <para> <ulink url="http://www.lilypond.org/"/> </para> </sect3> </sect2> <sect2> <title>Développement</title> <sect3> <title>sfront</title> <para> Sfront convertit des flux de données audio MP4-SA (MPEG 4 Structured Audio) en programmes C très efficaces qui produisent de l'audio à l'exécution. MP4-SA est un format standard pour des algorithmes de son, combinant un langage de création de signaux audio (SAOL) avec un langage de notation musicale (SASL, et le traditionnel format de fichier MIDI). Sous Linux, sfront exploite le temps réel, les entrées-sorties audio à faible temps de latence, les entrées MIDI à partir de cartes son, ainsi que les entrées MIDI via internet utilisant le RTP et le SIP. Un serveur SIP hébergé sur le campus de Berkeley organise des sessions de travail. Le site comprend aussi une aide en ligne à propos du MP4-SA. </para> <para> <ulink url="http://www.cs.berkeley.edu/~lazzaro/sa/index.html"/> </para> </sect3> <sect3> <title>jMax</title> <para> jMax est un système qui permet de dessiner des circuits de flux de données. On peut y entrer des données de type entier, symbole, liste, et cætera. C'est un système piloté par les événements. JMax est utilisé pour la création MIDI. Une autre partie de ce système, DSP, permet de faire circuler un signal en continu dans le circuit, ce qui est le plus pratique pour les sons PCM (i. e. : micros, fichiers son, et cætera). Ce système est extensible avec des bibliothèques partagées, permettant l'utilisation de différents types de gestion des données, de périphériques, d'interfaces, de matériels, et cætera. Les modules de traitement de données peuvent être traités comme des circuits et utilisés en tant que tel. </para> <para> <ulink url="http://sourceforge.net/projects/jmax/"/> </para> </sect3> <sect3> <title>TSE3</title> <para> TSE3 est un puissant séquenceur en mode texte, dont les sources sont publiques, écrit en C++. C'est un séquenceur en mode texte parce qu'il présente toutes les fonctionnalités d'un séquenceur mais sans interface graphique. Différentes applications séquenceur ou multimédia utilisent TSE3 derrière leur interface graphique. </para> <para> <ulink url="http://TSE3.sourceforge.net/"/> </para> </sect3> <sect3> <title>KeyKit</title> <para> KeyKit est un langage de programmation multi-tâches (inspiré de awk), exclusivement réservé aux opération MIDI algorithmiques et temps réel. Son interface graphique propose plusieurs douzaines d'outils pour expérimenter différents algorithmes musicaux, y compris un séquenceur multipistes et un éditeur de motifs rythmiques. L'interface et les outils sont complètement écrits dans le langage de KeyKit. Cela permet d'ajouter de nouveaux outils et nouvelles fonctionnalités à l'existant, tout en utilisant le système. </para> <para> <ulink url="http://nosuch.com/keykit/"/> </para> </sect3> </sect2> </sect1> <sect1> <title>Le développement MIDI</title> <para> Ceux qui souhaitent développer des applications MIDI ont souvent besoin de bons exemples pour démarrer. </para> <para> Les exemples suivants proviennent de la liste de discussions LAD. </para> <sect2> <title>Exemple 1</title> <para> Vous trouverez ci-dessous une fonction de séquencement écrite par Dr. Matthias Nagorni. D'autres exemples sont disponibles sur son site (cf la section Liens). </para> <para> Vous le compilez de la façon suivante : </para> <programlisting> [phil@beatbox] $ gcc seqdemo.c -o seqdemo -lasound #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <alsa/asoundlib.h> snd_seq_t *open_seq(); void midi_action(snd_seq_t *seq_handle); snd_seq_t *open_seq() { snd_seq_t *seq_handle; int portid; if (snd_seq_open(&seq_handle, "hw", SND_SEQ_OPEN_DUPLEX, 0) < 0) { fprintf(stderr, "Error opening ALSA sequencer.\n"); exit(1); } snd_seq_set_client_name(seq_handle, "ALSA Sequencer Demo"); if ((portid = snd_seq_create_simple_port(seq_handle, "ALSA Sequencer Demo", SND_SEQ_PORT_CAP_WRITE|SND_SEQ_PORT_CAP_SUBS_WRITE, SND_SEQ_PORT_TYPE_APPLICATION)) < 0) { fprintf(stderr, "Error creating sequencer port.\n"); exit(1); } return(seq_handle); } void midi_action(snd_seq_t *seq_handle) { snd_seq_event_t *ev; do { snd_seq_event_input(seq_handle, &ev); switch (ev->type) { case SND_SEQ_EVENT_CONTROLLER: fprintf(stderr, "Control event on Channel %2d: %5d \r", ev->data.control.channel, ev->data.control.value); break; case SND_SEQ_EVENT_PITCHBEND: fprintf(stderr, "Pitchbender event on Channel %2d: %5d \r", ev->data.control.channel, ev->data.control.value); break; case SND_SEQ_EVENT_NOTEON: fprintf(stderr, "Note On event on Channel %2d: %5d \r", ev->data.control.channel, ev->data.note.note); break; case SND_SEQ_EVENT_NOTEOFF: fprintf(stderr, "Note Off event on Channel %2d: %5d \r", ev->data.control.channel, ev->data.note.note); break; } snd_seq_free_event(ev); } while (snd_seq_event_input_pending(seq_handle, 0) > 0); } int main(int argc, char *argv[]) { snd_seq_t *seq_handle; int npfd; struct pollfd *pfd; seq_handle = open_seq(); npfd = snd_seq_poll_descriptors_count(seq_handle, POLLIN); pfd = (struct pollfd *)alloca(npfd * sizeof(struct pollfd)); snd_seq_poll_descriptors(seq_handle, pfd, npfd, POLLIN); while (1) { if (poll(pfd, npfd, 100000) > 0) { midi_action(seq_handle); } } } </programlisting> </sect2> <sect2> <title>Exemple 2</title> <para> Vous trouverez ci-dessous un <quote>aiguilleur</quote> MIDI basé sur ALSA 0.9 écrit par Nick Dowell. </para> <programlisting> /* Aiguilleur pour séquenceur ALSA. Aiguille les données d'entrée vers les sorties définies par le canal MIDI (à la demande de Nathaniel Virgo sur Linux-Audio-Dev ;o)). Est basé sur l'exemple de fonction séquenceur ALSA écrit par Dr. Matthias Nagorni. Nick Dowell <nixx CHEZ nixx POINT org POINT uk> */ #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <alsa/asoundlib.h> int main() { snd_seq_t *seq_handle; snd_seq_event_t *ev; int i; int portid; /* port d'entrée (input) */ int oportid[16]; /* ports de sortie (outputs) */ int npfd; struct pollfd *pfd; char txt[20]; if (snd_seq_open(&seq_handle, "hw", SND_SEQ_OPEN_DUPLEX, 0) < 0) { fprintf(stderr, "Error opening ALSA sequencer.\n"); exit(1); } snd_seq_set_client_name(seq_handle, "MIDI Redirect"); /* open one input port */ if ((portid = snd_seq_create_simple_port (seq_handle, "Input", SND_SEQ_PORT_CAP_WRITE | SND_SEQ_PORT_CAP_SUBS_WRITE, SND_SEQ_PORT_TYPE_APPLICATION)) < 0) { fprintf(stderr, "fatal error: could not open input port.\n"); exit(1); } /* open 16 output ports for the MIDI channels */ for (i=0; i<16; i++){ sprintf( txt, "MIDI Channel %d", i ); if ((oportid[i] = snd_seq_create_simple_port (seq_handle, txt, SND_SEQ_PORT_CAP_READ | SND_SEQ_PORT_CAP_SUBS_READ, SND_SEQ_PORT_TYPE_APPLICATION)) < 0) { fprintf(stderr, "fatal error: could not open output port.\n"); exit(1); } } npfd = snd_seq_poll_descriptors_count(seq_handle, POLLIN); pfd = (struct pollfd *)alloca(npfd * sizeof(struct pollfd)); snd_seq_poll_descriptors(seq_handle, pfd, npfd, POLLIN); while (1) /* main loop */ if (poll(pfd, npfd, 1000000) > 0){ do { snd_seq_event_input(seq_handle, &ev); snd_seq_ev_set_source( ev, oportid[ev->data.control.channel] ); snd_seq_ev_set_subs( ev ); snd_seq_ev_set_direct( ev ); snd_seq_event_output_direct( seq_handle, ev ); snd_seq_free_event(ev); } while (snd_seq_event_input_pending(seq_handle, 0) > 0); } return 0; } </programlisting> </sect2> <sect2> <title>Exemple 3</title> <para> Vous trouverez ci-dessous un exemple d'écriture de données dans l'interface OSS <filename class="devicefile">/dev/midi</filename> par Craig Stuart Sapp. </para> <para> Vous pourrez trouver plus d'exemples sur son site (cf la section Liens). </para> <programlisting> // // Programmeur: Craig Stuart Sapp // Adresse électronique : craig CHEZ ccrma POINT standford POINT edu // Date de Création : Lundi 21 décembre 1998 18:00:42 // Dernière modification : Lundi 21 décembre 1998 18:00:42 // Nom de fichier : ...linuxmidi/output/method1.c // Langage : C // $Smake: gcc -O -o devmidiout devmidiout.c && strip devmidiout // #include <linux/soundcard.h> #include <unistd.h> #include <fcntl.h> #include <stdio.h> int main(void) { char* device = "/dev/midi" ; unsigned char data[3] = {0x90, 60, 127}; // étape 1: ouvre le module OSS pour écriture int fd = open(device, O_WRONLY, 0); if (fd < 0) { printf("Error: cannot open %s\n", device); exit(1); } // étape 2: écrit les données MIDI dans le module OSS write(fd, data, sizeof(data)); // étape 3: (en option) ferme le module OSS close(fd); return 0; } </programlisting> </sect2> </sect1> <sect1 id="synthetiseurs-virtuels"> <sect1info> <author> <firstname>Frank</firstname> <surname>Barknecht</surname> <email>barknech CHEZ ph TIRET cip POINT uni TIRET koeln POINT de</email> </author> </sect1info> <title> Guide d'utilisation de séquenceurs MIDI avec des synthétiseurs virtuels </title> <subtitle> Version française du guide pratique <foreignphrase>HOWTO Use MIDI Sequencers With Softsynths</foreignphrase> </subtitle> <para> <ulink url="http://linux-sound.org/quick-toots/4-sequencers_and_softsynths/quick-toot-midisynth_howto.html"/> </para> <para> Ce guide décrit les réglages nécessaires pour contrôler un synthétiseur MIDI virtuel à partir d'un séquenceur MIDI et via une connexion MIDI virtuelle sous ALSA 0.9. Ce document peut être librement traduit et diffusé. Il est soumis à la licence de documentation libre GNU. </para> <sect2> <title>Introduction</title> <para> Les synthétiseurs virtuels, tels que Csound, Pure Data, jMax ou Spiral Synth Modular offrent des possibilités quasi infinies pour expérimenter les sons les plus usuels ou les plus inhabituels. Ils peuvent en outre remplacer les synthétiseurs matériels, relativement chers, ou ceux, souvent de mauvaise qualité, qui équipent les cartes son, si tant est qu'ils soient compatibles avec Linux. En contrepartie, composer sur ces synthétiseurs virtuels peut s'avérer fastidieux, comme sur Csound où l'on doit aligner des pages entières de chiffres pour composer, ce qui n'est pas l'idéal pour faire de la musique. </para> <para> Les logiciels séquenceurs MIDI virtuels permettent de rendre la tâche plus agréable. Ils sont munis d'une interface permettant d'insérer des notes et des évènements MIDI de façon pratique : soit par l'intermédiaire d'une vraie partition, soit par un rouleau de piano mécanique ou via une liste d'évènements MIDI, suivant vos préférences. D'autres types de séquenceurs virtuels permettent d'entrer les notes en utilisant des morceaux de pistes, comme on le faisait dans le temps en direct. Dernier point, non des moindres, certains séquenceurs MIDI vous permettent d'enregistrer vos propres musiques par l'intermédiaire d'un matériel externe (clavier ou autre), ce qui se révèle, pour certains musiciens, le moyen le plus naturel de faire de la musique. </para> <para> D'habitude, les séquenceurs MIDI envoient leurs données vers des périphériques MIDI qui à leur tour vont réorienter les données vers l'extérieur, à savoir vers des synthétiseurs et des échantillonneurs matériels. Grâce aux outils MIDI virtuels, on peut garder au sein du PC toutes les données MIDI et les faire contrôler par un logiciel tournant sur la même machine. Ce guide décrit tout ce qui est nécessaire pour en arriver là. </para> </sect2> <sect2> <title>paramétrage du matériel</title> <para> Pour le paramétrage, nous utiliserons les bibliothèques et les pilotes d'ALSA, ce qui doit être le cas si l'on veut utiliser sérieusement le son et le MIDI sous Linux. À partir de maintenant, nous supposerons que vous utilisez la version 0.9.0 d'ALSA. Toutefois, le module MIDI utilisé est aussi présent dans la version 0.5.x, ce qui rend les explications à venir tout aussi valables. Sous les architectures son OSS/Free (avec les modules de son trouvés dans les noyaux antérieurs à la version 2.5.x) et OSS/Linux, le module v_midi peut être utilisé, mais cela dépasse le cadre de ce guide. </para> <para> Pour utiliser la carte MIDI virtuelle d'ALSA, le module snd-card-virmidi doit être présent. Avec la plupart des versions récentes d'ALSA (ainsi que dans la version 2.5.x de développement de noyau), le nom de ce module a été renommé <quote>snd-virmidi</quote>. Assurez-vous que vous avez bien pris en compte ce module : il pourrait vous manquer lors de la configuration d'ALSA, si vous n'avez pris en compte que les modules propres à votre carte son. </para> <para> Vous devez charger le module virmidi pour activer les ports MIDI. Vous pouvez les tester avec : </para> <programlisting> $ modprobe snd-virmidi snd_index=1 </programlisting> <para> où snd_index doit être adapté au premier index de carte libre (= 1 si vous disposez uniquement d'une carte qui a déjà l'index 0). Cela dit, il est plus pratique d'adapter la configuration de vos modules pour qu'ils soient disponible chaque fois que vous les utilisez. Pour cela, il faut ajouter à la section ALSA du fichier <filename>/etc/modules.conf</filename> (le chemin dépend de votre distribution) les lignes suivantes : </para> <programlisting> # Configure les supports pour OSS /dev/sequencer et # /dev/music (aussi appelé /dev/sequencer2) # # (Takashi Iwai nous indique qu'il n'est pas nécessaire # de créer des alias pour des cartes au-delà de la première # carte, i.e., la carte 0) # alias sound-service-0-1 snd-seq-oss alias sound-service-0-8 snd-seq-oss # Configure la carte 1 (deuxième carte) en tant que carte MIDI virtuelle alias sound-slot-1 snd-card-1 alias snd-card-1 snd-virmidi </programlisting> <para> Désormais, votre carte MIDI virtuelle est configurée en tant que carte d'index 1, ce qui suppose que vous possédez une carte son réelle (ce qui peut s'avérer très utile). Si vous possédez comme moi une seconde carte son réelle, modifiez la configuration ci-dessus comme suit : </para> <programlisting> # Configure la carte d'index 2 (troisième carte) en tant que # carte MIDI virtuelle alias sound-slot-2 snd-card-2 alias snd-card-2 snd-virmidi </programlisting> <para> Si vous possédez plus de cartes son que cela, vous saurez sûrement vous adapter. </para> <para> Il se peut qu'il soit nécessaire de redémarrer le système ALSA, après quoi vous devriez voir indiquée la carte son virtuelle dans le fichier /proc/asound/cards : </para> <programlisting> $ cat /proc/asound/cards 0 [card0 ]: ICE1712 - M Audio Audiophile 24/96 M Audio Audiophile 24/96 at 0xb800, irq 5 1 [card1 ]: EMU10K1 - Sound Blaster Live! Sound Blaster Live! at 0xc800, irq 11 2 [card2 ]: VirMIDI - VirMIDI Virtual MIDI Card 1 </programlisting> <para> Dans cet exemple tiré de mon propre PC, ma carte VirMIDI est la troisième, d'index 2. Cette configuration se retrouve dans le fichier /proc/asound/devices (seul les paramètres MIDI sont affichés) : </para> <programlisting> $ cat /proc/asound/devices 8: [0- 0]: raw MIDI 41: [1- 1]: raw MIDI 42: [1- 2]: raw MIDI 75: [2- 3]: raw MIDI 74: [2- 2]: raw MIDI 73: [2- 1]: raw MIDI 72: [2- 0]: raw MIDI </programlisting> <para> Les entrées commençant par <quote>2-</quote> correspondent à ma carte MIDI virtuelle . Si vous ne possédez qu'une seule carte réelle, ces entrées commenceront par <quote>1-</quote>. </para> <para> Vous pouvez obtenir un affichage plus conviviale des paramètres avec l'outil aconnect. Il s'agit d'un outil propre à ALSA, dont vous aurez de toutes façons besoin. Pour obtenir la liste des périphériques MIDI utilisables en sortie, appelez-le avec l'option <option>-o</option> (ou <option>-lo</option>). Pour ceux utilisables en entrée, appelez-le avec l'option <option>-i</option>. </para> <programlisting> $ aconnect -o [...] client 80: 'Virtual Raw MIDI 2-0' [type=kernel] 0 'VirMIDI 2-0 ' client 81: 'Virtual Raw MIDI 2-1' [type=kernel] 0 'VirMIDI 2-1 ' client 82: 'Virtual Raw MIDI 2-2' [type=kernel] 0 'VirMIDI 2-2 ' client 83: 'Virtual Raw MIDI 2-3' [type=kernel] 0 'VirMIDI 2-3 ' $ aconnect -i [...] client 80: 'Virtual Raw MIDI 2-0' [type=kernel] 0 'VirMIDI 2-0 ' client 81: 'Virtual Raw MIDI 2-1' [type=kernel] 0 'VirMIDI 2-1 ' client 82: 'Virtual Raw MIDI 2-2' [type=kernel] 0 'VirMIDI 2-2 ' client 83: 'Virtual Raw MIDI 2-3' [type=kernel] 0 'VirMIDI 2-3 ' </programlisting> <para> Les périphériques affichés correspondent aux périphériques MIDI compatibles OSS propres à ALSA tels que définis dans le répertoire /proc/asound/dev. Par exemple, le périphérique /proc/asound/dev/midiC2D0 est le premier de notre carte MIDI virtuelle indexée 2, nommée Virtual Raw MIDI 2-0 par l'outil aconnect. Sous Débian, ces périphériques sont aussi visibles dans le répertoire <filename class="directory">/dev/snd/</filename>, et sont aussi liés en interne aux anciens répertoires de périphériques <filename class="devicefile">/dev/midiXX</filename>. Pour m'assurer que je pouvais accéder aux ports MIDI d'ALSA à partir de <filename class="devicefile">/dev/midiXX</filename>, je les ai renommés ainsi : </para> <programlisting> $ ln -s /dev/snd/midiC2D0 /dev/midi20 $ ln -s /dev/snd/midiC2D1 /dev/midi21 [...] </programlisting> <para> mais cela n'est pas nécessaire : ne le faites surtout pas chez vous ! </para> <para> Maintenant que nous avons créé et configuré une carte MIDI virtuelle, nous pouvons l'utiliser dans nos applications comme tout autre périphériques MIDI. Il vous suffit d'indiquer la référence du périphérique MIDI, qu'il s'agisse d'une référence compatible OSS, comme <filename class="devicefile">/dev/midi20</filename> ou d'un port MIDI ALSA comme <literal>80:0</literal>, à l'endroit approprié dans le paramétrage de votre séquenceur ou synthétiseur préféré. </para> </sect2> <sect2> <title>Canalisation des évènements MIDI</title> <sect3> <title>aconnect</title> <para> Sans autre manipulation, il ne vous sera pas possible d'envoyer des évènements MIDI à partir de votre séquenceur vers le synthétiseur virtuel. Pour ce faire, nous devons connecter deux ports avec, vous l'aurez deviné, l'outil aconnect. Cet outil permet de connecter deux ports ou plus. Les fichier obtenus avec -i ou -o plus haut nous ont déjà indiqué les ports disponibles. Maintenant, avec une syntaxe très simple, ces ports peuvent être connectés ainsi : </para> <programlisting> $ aconnect <replaceable>port_d_envoi</replaceable> <replaceable>port_de_reception</replaceable> $ aconnect 80:0 81:0 </programlisting> <para> Cette manipulation permet d'aiguiller toutes les données MIDI envoyées sur le port <literal>80:0</literal> vers le port <literal>80:1</literal>. Dans notre configuration, cela signifie que toute donnée entrant sur le port <filename class="devicefile">/dev/midi20</filename> est réorientée vers le port <filename class="devicefile">/dev/midi21</filename>, sur lequel elle peut être lue (<quote>reçue</quote>) par une autre application. </para> <para> Si votre carte MIDI virtuelle est configurée en tant que seconde carte (index 1), vous devez obtenir les ports suivants : </para> <programlisting> $ aconnect -lo client 72: 'Virtual Raw MIDI 1-0' [type=kernel] 0 'VirMIDI 1-0 ' client 73: 'Virtual Raw MIDI 1-1' [type=kernel] 0 'VirMIDI 1-1 ' client 74: 'Virtual Raw MIDI 1-2' [type=kernel] 0 'VirMIDI 1-2 ' client 75: 'Virtual Raw MIDI 1-3' [type=kernel] 0 'VirMIDI 1-3 </programlisting> <para> Ici, vous pouvez par exemple connecter le port <literal>72:0</literal> (<filename class="devicefile">/dev/midi10</filename>) au port <literal>73:0</literal> (<filename class="devicefile">/dev/midi11</filename>) en tapant : </para> <programlisting> $ aconnect 72:0 73:0 </programlisting> <para> aconnect peut nous montrer ce qui a été crée avec ses options -lo et -li : </para> <programlisting> $ aconnect -lo client 72: 'Virtual Raw MIDI 1-0' [type=kernel] 0 'VirMIDI 1-0 ' Connecting To: 73:0 client 73: 'Virtual Raw MIDI 1-1' [type=kernel] 0 'VirMIDI 1-1 ' Connected From: 72:0 client 74: 'Virtual Raw MIDI 1-2' [type=kernel] 0 'VirMIDI 1-2 ' client 75: 'Virtual Raw MIDI 1-3' [type=kernel] 0 'VirMIDI 1-3 </programlisting> <para> Vous constatez que le <quote>Virtual Raw MIDI 1-0</quote> est maintenant connecté au <quote>Virtual Raw MIDI 1-1</quote>. Dès lors, en fonction de vos applications, vous pourrez lire les données MIDI envoyées à votre port <quote>Virtual Raw MIDI 1-0</quote> à partir du port <quote>Virtual Raw MIDI 1-1</quote>, ou, en reprenant le vocabulaire OSS : tout ce qui est envoyé sur le port <filename class="devicefile">/dev/midi10</filename> est aiguillé sur le port <filename class="devicefile">/dev/midi11</filename> et peut être lu à partir de là. </para> <para> Vous pouvez aussi connecter plus d'un port sur un autre. Si vous faites aconnect une deuxième fois comme ceci : </para> <programlisting> $ aconnect 72:0 73:0 $ aconnect 72:0 74:0 </programlisting> <para> vous pouvez recevoir les mêmes données envoyées sur <filename class="devicefile">/dev/midi10</filename>, sur les ports <filename class="devicefile">/dev/midi11</filename> et <filename class="devicefile">/dev/midi12</filename>. Et bien entendu, vous risquez vraiment de surcharger votre système si vous créez encore plus de cartes MIDI virtuelles et que vous les connectez entre elles. Mais rien n'empêche de le faire. </para> <para> Pour déconnecter tous les ports, faites : </para> <programlisting> $ aconnect -x </programlisting> <para> Pour ne déconnecter qu'un seul port, faites : </para> <programlisting> $ aconnect -d 72:0 74:0 </programlisting> </sect3> </sect2> <sect2> <title>Tableaux de raccordement MIDI graphiques</title> <para> Le tableau de raccordement MIDI ALSA (<foreignphrase>Alsa Patch Bay</foreignphrase>) de Bob Ham est une interface graphique très pratique pour la configuration MIDI d'ALSA sous Linux. Son utilisation est très simple et intuitive : sur la gauche, vous disposez des ports MIDI capables d'envoyer des évènements MIDI, alors que sur la droite, vous avez les ports capables d'en recevoir. Si vous cliquez sur un port de gauche, cela le sélectionne pour être connecté au port de droite sur lequel vous cliquez ensuite. Pour un port connecté, il suffit de cliquer sur le port de droite pour le déconnecter : un outil précis facile à utiliser, qui aurait presque tendance à rendre inutile ce qui a été dit plus haut ! ;o) </para> <sect3> <title>aseqview</title> <para> aseqview est un autre outil très utile pour gérer les flux MIDI. Il a été créé par Takashi Iwai, qui fait partie des développeurs d'ALSA. Vous pouvez le télécharger depuis la page web d'Iwai-sama <ulink url="http://members.tripod.de/iwai/alsa.html" />, mais il est souvent inclus dans les distributions. Cet outil graphique a été créé pour visualiser et modifier les évènements MIDI pendant qu'ils transitent par votre PC. Il peut aussi orienter les données MIDI vers d'autres ports, tout comme aconnect. Cela peut s'avérer utile lorsque vous devez utiliser le séquenceur OSS, qu'aconnect est parfois incapable d'utiliser. Si vous lancez aseqview sans aucune option, vous obtenez une jolie interface graphique et un nouveau port MIDI. Le port par défaut est nommé <literal>128:0</literal>, et il ressemble à cela : </para> <programlisting> client 128: 'MIDI Viewer' [type=user] 0 'Viewer Port 0 ' </programlisting> <para> Avec ce port, toutes les manipulations effectuées plus haut avec aconnect sont possibles. Si vous souhaitez seulement connecter le port aseqview à un autre port, aseqview peut le faire par lui-même avec l'option -d : </para> <programlisting> $ aseqview -d 73:0 & </programlisting> <para> Cela connecte le port <literal>128:0</literal> au port <literal>73:0</literal> dès le démarrage d'aseqview. </para> <para> Il existe d'autre outils graphiques de connexion, avec des fonctions très similaires. Maarten de Boer a utilisé la plupart des sources aconnect d'origine pour écrire une interface graphique appelée <quote>aconnectgui</quote> à l'aide de l'outil FLTK. Vous pouvez la trouver à l'adresse <ulink url="http://www.iua.upf.es/~mdeboer/"/>. C'est, à mon avis, l'interface la plus agréable à utiliser. </para> <para> Personnellement, j'utilise kaconnect, sans doute parce son nom est court et donc plus rapide à taper. kaconnect a été développé par Dr. Matthias Nagorni de SuSE, au sein d'une série d'outils et de synthétiseurs virtuels pour ALSA, les kalsatools. Ne vous méprenez pas sur le <quote>k</quote > : ce logiciel n'a pas besoin de KDE. Il utilise directement les bibliothèques graphiques QT. kaconnect, et d'autres logiciels, sont disponibles sur <ulink url="http://www.suse.de/~mana/kalsatools.html"/>. </para> </sect3> </sect2> <sect2> <title>Applications</title> <para> Dans ce dernier chapitre, je veux vous montrer quelques exemples d'utilisation des connections virtuelles MIDI dans diverses applications. Mettons que je dispose d'une carte VirMIDI, troisième sur mon système, utilisant les ports MIDI ALSA <literal>80:0</literal> à <literal>83:0</literal>, ce qui correspond aux périphériques OSS MIDI : <filename class="devicefile">/dev/midi20</filename> à <filename class="devicefile">/dev/midi23</filename>, et aux périphériques ALSA MIDI : <filename class="devicefile">/dev/snd/midiC2D0</filename> à <filename class="devicefile">/dev/snd/midiC2D3</filename>. Le deux premiers d'entre eux ont été connectés de la façon suivante : </para> <programlisting> $ aconnect 80:0 81:0 </programlisting> <para> Ce qui signifie que toutes les données envoyées au port <filename class="devicefile">/dev/midi20</filename> (ou port <literal>80:0</literal> ou <filename class="devicefile">/dev/snd/midiC2D0</filename>) peuvent être maintenant lues sur le port <filename class="devicefile">/dev/midi21</filename> (ou port <literal>80:1</literal> ou <filename class="devicefile">/dev/snd/midiC2D1</filename>). </para> </sect2> <sect2> <title>Les séquenceurs</title> <sect3> <title>MusE</title> <para> MusE est un séquenceur virtuel complet écrit par Werner Schweer, disponible à l'adresse : <ulink url="http://muse.seh.de."/>. Nous devons configurer le port MIDI virtuel comme port de sortie (output) dans le menu <quote>Config->MIDI Ports</quote>. Avec MusE, les ports sont désignés par leur dénomination ALSA, du type <quote>VirMIDI X-X</quote>. </para> <para> Assurez-vous d'avoir bien sélectionné le bon port comme port de sortie pour le canal sur lequel vous souhaitez que le synthétiseur oriente et joue les données MIDI. </para> <para> Pour des raisons que j'ignore, je n'ai pas pu utiliser <quote>VirMIDI 2-0</quote> comme sortie avec MusE 0.4.9. Ce devrait être pourtant la bonne sortie pour recevoir les données sur le port <quote>VirMIDI 2-1</quote>, mais j'ai dû l'utiliser d'une autre façon. Je ne sais pas pourquoi. On peut aussi utiliser les ports <filename class="devicefile">midi02</filename> ou <filename class="devicefile">midi2</filename>. </para> </sect3> <sect3> <title>ttrk</title> <para> ttrk, développé par Billy Biggs, est un petit séquenceur très simple muni d'une interface de mixage. Il peut sortir toutes ses données MIDI vers n'importe lequel des ports configurés dans le fichier $HOME/.ttrkrc. </para> </sect3> <sect3> <title>Shaketracker</title> <para> Le Shaketracker de Juan Linietsky reprend une interface de mixage MIDI semblable à celle de ttrk, avec toutefois une transposition complète des effets classiques de mixage sur les données MIDI. Malheureusement, il utilise comme sortie MIDI le séquenceur d'OSS (<filename class="devicefile">/dev/sequencer</filename>), et non les périphériques MIDI natifs (<literal>raw MIDI</literal>). Je n'ai pas pu le faire fonctionner avec aconnect. Toutefois, il possède un environnement qui inclut aseqview. Si l'on démarre aseqview avant Shaketracker, le gestionnaire de piste reconnaîtra et utilisera les ports de aseqview. Il suffit de le sélectionner dans le menu <quote>User Devices</quote> de Shaketracker, où il figure sous son nom ALSA <quote>Viewer Port 0</quote>. </para> <para> Il peut être pratique de donner à ce périphérique utilisateur un nom plus explicite que <quote>Null Output</quote>. </para> <para> Si nous démarrons aseqview sans option, nous aurons besoin de connecter le port aseqview avec le port du synthétiseur virtuel. Mais, comme dit précédemment, nous pourrions aussi démarrer directement aseqview avec un port de destination. N'oubliez pas d'utiliser le menu User Device pour chacune des pistes qui doit aller vers le synthétiseur virtuel. Je fais toujours tourner Shaketracker avec un script qui démarre aseqview, attend la création des ports, et démarre enfin Shaketracker: </para> <programlisting> #!/bin/sh aseqview -d 81:0 & # sleep 2 seconds to let aseqview do its work: sleep 2 shaketracker </programlisting> </sect3> </sect2> <sect2> <title>Synthétiseurs virtuels</title> <sect3> <title>Pure Data</title> <para> Miller Puckette est le génie qui se cache derrière Pure Data, un synthétiseur logiciel libre et un environnement de développement multimédia. Pure Data est issu de MAX et est à la base de l'extension MAX MSP. Pure Data peut aussi utiliser des périphériques MIDI natifs pour lire les évènements MIDI. Il faut, pour cela, indiquer quels périphériques utiliser avec l'option <option>-midiindev <replaceable>numéro_de_périphérique</replaceable></option>. Cependant, la manière d'indiquer quel périphérique utiliser est assez déroutante. Voici la façon de faire : pour utiliser <filename class="devicefile">/dev/midi0</filename>, démarrez Pure Data avec <option>-midiindev 1</option>, pour utiliser <filename class="devicefile">/dev/midi1</filename> démarrez-le avec <option>-midiindev 2</option> et ainsi de suite. Vous devez donc indiquer le numéro de port + 1. Un autre exemple : pour <filename class="devicefile">/dev/midi21</filename> démarrez Pure Data avec l'option <option>-midiindev 22</option>. </para> <para> Pure Data offre aussi un guide d'aide : <quote>Test audio and MIDI</quote>, ce qui peut vraiment aider pour détecter le bon périphérique MIDI. </para> </sect3> <sect3> <title>Csound</title> <para> Csound est l'ancêtre de quasiment tous les synthétiseurs virtuels actuels, et il a contribué à l'évolution du MIDI. Lancer <userinput>csound --help</userinput> vous indiquera comment configurer le port d'entrée MIDI. Faites <option>-M <replaceable>nom_du_port</replaceable></option> ou <option>--midieventdev=<replaceable>nom_du_port</replaceable></option> et vous pourrez lire les données MIDI en temps réel. </para> <para> Ainsi, dans notre exemple, nous lancerons Csound de la façon suivante : </para> <programlisting> $ csound -M /dev/midi22 -o devaudio midi.csd </programlisting> </sect3> <sect3> <title>Conclusion</title> <para> Dorénavant, vous devriez pouvoir vous débrouiller avec tous les synthétiseurs virtuels pour orchestrer de la musique créée et jouée par un séquenceur MIDI. Bien sûr, des outils comme aconnect et aseqview ne sont pas nécessaires pour utiliser un séquenceur virtuel. Vous pouvez tout aussi bien rediriger les flux de données MIDI qui arrivent sur votre PC à partir d'un séquenceur externe ou d'un clavier MIDI directement vers le synthétiseur virtuel sans passer par l'étape du séquenceur MIDI. Vous devez simplement <quote>aconnecter</quote> le matériel MIDI externe à votre synthétiseur virtuel ou sur le synthétiseur embarqué sur votre carte son. Ou faire l'inverse : Pure Data, Csound ou des environnements comme KeyKit vous permettent de créer des évènements MIDI de façon algorithmique, ce qui est presque impossible avec des logiciel de type Cubase. Avec aconnect, vous pouvez aiguiller les évènements MIDI vers n'importe quel logiciel capable de les jouer. </para> </sect3> </sect2> <sect2> <title>Remerciements</title> <para> L'auteur souhaite remercier Takashi Iwai pour son aide technique lors de l'élaboration de ce document et pour ses précieux conseils en Japonais. Merci, Takashi ! </para> </sect2> </sect1> <sect1> <title>Liens Utiles</title> <para> Vous trouverez ci-dessous une liste de liens vers des sites traitant du MIDI sous Linux. </para> <para> <ulink url="http://www.linux-sound.org/" /> Logiciels audio et MIDI sous Linux. Une mine de renseignements sur le MIDI et l'audio. </para> <para> <ulink url="http://www.linuxdj.com/audio/lad/" /> La liste de discussions des développeurs Audio sous Linux. Pour toute discussion sur le développement MIDI. </para> <para> <ulink url="http://www.linuxdj.com/audio/quality"/> Le guide Linux de la qualité audio. Un bon chapitre sur les cartes MIDI, essentiel pour créer son studio Linux. </para> <para> <ulink url="http://www.alsa-project.org/"/> Le projet ALSA — Pilotes audio et MIDI. </para> <para> <ulink url="http://www.4front-tech.com/"/> OSS — Pilotes audio et MIDI. </para> <para> <ulink url="http://www.gardena.net/benno/linux/audio/"/> Correctif de minimisation des temps de latence. </para> <para> <ulink url="http://ccrma-www.stanford.edu/~craig/articles/linuxmidi/"/> Introduction à la programmation MIDI sous Linux. Craig Stuart Sapp décrit les outils de base pour écrire du MIDI en C ou C++ pour des pilotes OSS. </para> <para> <ulink url="http://www.suse.de/~mana"/> Excellente collection de programmes C pour ALSA 0.9 MIDI et PCM, par Dr. Matthias Nagorni. </para> </sect1> <sect1> <title>Commentaires et corrections</title> <para> Comme toujours, un guide évolue dans le temps. Je vous encourage à me transmettre (en anglais) vos suggestions ou informations sur les nouvelles applications et les développements intéressants du MIDI sous Linux. </para> <para> Par leur grande variété, les cartes son sont parfois difficiles à configurer, notamment parce qu'elles ont plusieurs niveaux de pilotes et d'options de configuration. Les meilleures sources de renseignement en cas de dysfonctionnement sont les sites web de ALSA et OSS, mais aussi les forums, ainsi que les listes de discussions consacrées à l'audio sous Linux. </para> </sect1> <colophon> <title>Adaptation française des guides pratiques Linux</title> <para> L'adaptation française de ce document a été réalisée dans le cadre du Projet de traduction des Guides pratiques Linux. </para> <para> Vous pourrez lire d'autres guides pratiques traduits et en apprendre plus sur ce projet en allant sur le site de l'association <ulink url="http://wiki.traduc.org">Traduc.org</ulink>. </para> <para> Si vous souhaitez apporter votre contribution, n'hésitez pas à nous rejoindre, nous serons heureux de vous accueillir. </para> <para> N'hésitez pas à faire parvenir vos commentaires et suggestions concernant l'adaptation française de ce document à l'adresse : <email>commentaires CHEZ traduc POINT org</email>. </para> </colophon> </article>