4.2.1 J’entends des voix

Dans une partition gérée par LilyPond, le niveau le plus bas, ou bien élémentaire ou fondamental, est le contexte de voixVoice context en anglais. Pour d’autres logiciels, on fait tantôt référence à la notion de « couche » ou de « calque ».

En réalité, le contexte de voix est le seul à pouvoir contenir de la musique. Si un contexte Voice n’est pas déclaré explicitement, il sera créé automatiquement comme nous l’avons vu au début de ce chapitre. Certains instruments, le hautbois par exemple, ne peuvent jouer qu’une seule note à la fois. Nous n’aurons besoin, pour ces instruments monodiques, que d’une seule voix. Les instruments qui, comme le piano, peuvent émettre plusieurs sons en même temps sont polyphoniques et nécessitent de recourir à plusieurs voix pour gérer efficacement l’alignement des notes et rythmes différents.

Si une voix unique peut tout à fait contenir plusieurs notes dans un accord, à partir de quand aurons-nous vraiment besoin de plusieurs voix ? Considérons déjà ces quatre accords :

\relative {
  \key g \major
  <d' g>4 <d fis> <d a'> <d g>
}

[image of music]

Nous exprimons ici chacun des accords par l’utilisation de chevrons gauche et droite simples, < … >, puisque nous n’avons besoin que d’une seule voix. Supposons maintenant que le fa dièse soit une croche, suivie d’un sol croche – une note de passage vers le la ? Nous avons alors deux notes qui débutent au même moment, mais dont la durée est différente : un ré noire et un fa dièse croche. Comment coder cela ? Dans la mesure où toutes les notes d’un accord doivent avoir la même durée, nous ne pouvons pas écrire un accord. Nous ne pouvons pas non plus écrire deux notes séparées, puisqu’elles débutent en même temps. Nous avons alors besoin de deux voix.

Voyons comment cela se pratique selon la grammaire de LilyPond.

Le plus sûr moyen de saisir un fragment où plusieurs voix cohabitent sur la même portée, consiste à saisir chacune des voix séquentiellement (avec { … }), puis à les combiner en simultané à l’aide de doubles chevrons gauche/droite, << … >>. Les fragments devront être séparés par une double oblique inversée, \\, pour les affecter à des voix séparées. Dans le cas contraire, les notes seraient toutes affectées à une même voix, ce qui pourrait générer des erreurs. Cette manière de procéder est tout à fait indiquée dans le cas d’une pièce homophonique ne comportant que quelques courts passages de polyphonie.

Voici comment éclater les accords en deux voix, avec la note de passage et la liaison :

\relative {
  \key g \major
  %    Voice = "1"              Voice = "2"
  << { g'4 fis8( g) a4 g } \\ { d4 d d d }  >>
}

[image of music]

Notez que les hampes de la seconde voix sont dirigées vers le bas.

Autre exemple :

\key d \minor
%    Voice = "1"           Voice = "2"
<< { r4 g g4. a8 }    \\ { d,2 d4 g }       >> |
<< { bes4 bes c bes } \\ { g4 g g8( a) g4 } >> |
<< { a2. r4 }         \\ { fis2. r4 }       >> |

[image of music]

Le recours à une construction << \\ >> particulière à chaque mesure n’est pas nécessaire. Bien qu’on y gagne en lisibilité si chaque mesure ne contient que quelques notes, il est plus judicieux de carrément séparer chaque voix :

<<
  \key d \minor
  \relative { % Voice = "1"
    r4 g' g4. a8 |
    bes4 bes c bes |
    a2. r4 |
  } \\
  \relative { % Voice = "2"
    d'2 d4 g |
    g4 g g8( a) g4 |
    fis2. r4 |
  }
>>

[image of music]

Cet exemple ne comporte que deux voix, mais il peut être étendu pour traiter trois voix ou plus en ajoutant autant de séparateurs \\ que de besoin.

Les contextes Voice créés implicitement par << \\ >> portent les noms "1", "2", etc. Les premiers contextes définissent les voix extrêmes, la plus haute au contexte "1", la plus basse au contexte "2". Les voix intermédiaires seront affectées aux contextes "3" et "4". Pour chacun de ces contextes, le positionnement et l’orientation des liaisons, hampes, nuances, etc. est définie automatiquement.

\new Staff \relative {
  % Main voice
  c'16 d e f
  %  Voice = "1"   Voice = "2"             Voice = "3"
  << { g4 f e } \\ { r8 e4 d c8~ } >> |
  << { d2 e }   \\ { c8 b16 a b8 g~ 2 } \\ { s4 b c2 } >> |
}

[image of music]

Notez l’utilisation d’un s4 pour insérer un silence invisible, et ainsi décaler le début (visible) de la voix "3".

Les voix peuvent se saisir dans un ordre différent, comme par exemple du haut vers le bas, auquel cas leurs numéros respectifs seront spécifiés dès avant la construction << … >> à l’aide de la commande \voices comme ici :

\new Staff \relative {
  % Main voice
  c'16 d e f
  %  Voice = "1"   Voice = "2"
  << { g4 f e } \\ { r8 e4 d c8~ } >> |
  \voices 1,3,2
  %  Voice = "1"   Voice = "3"    Voice = "2"
  << { d2 e }   \\ { s4 b c2 } \\ { c8 b16 a b8 g~ 2 } >> |
}

[image of music]

Ces voix sont séparées de la voix principale, laquelle contient les notes en dehors de la construction << … >> – que nous appellerons construction simultanée. Les liaisons, de prolongation ou non, ne peuvent relier des notes que si elles appartiennent à la même voix ; elles ne peuvent ni pénétrer une construction simultanée, ni en sortir. Inversement, les voix parallèles issues de constructions simultanées apparaissant sur une même portée appartiennent à la même voix. Les autres propriétés liées au contexte de voix s’appliquent tout au long des constructions simultanées. Reprenons notre exemple, en affectant une couleur et une allure différentes aux notes de chacune des voix. Vous noterez qu’un changement apporté à une voix ne se propage pas aux autres, et qu’il se reporte jusqu’au bout, et que la voix aux triangles bleus comporte une liaison de prolongation entre deux constructions.

\new Staff \relative {
  % Main voice
  c'16 d e f
  <<  % Bar 1
    { \voiceOneStyle g4 f e }
  \\
    { \voiceTwoStyle r8 e4 d c8~ }
  >> |
  <<  % Bar 2
    % Voice 1 continues
    { d2 e }
  \\
    % Voice 2 continues
    { c8 b16 a b8 g~ 2 }
  \\
    { \voiceThreeStyle s4 b c2 }
  >> |
}

[image of music]

Les commandes \voiceXXXStyle sont principalement dédiées à une utilisation pédagogique, comme l’est ce document. Elles modifient la couleur des hampes et ligatures et le style de tête des notes pour permettre une meilleure distinction entre les différentes voix. La première voix comporte des têtes en losange rouge, la deuxième en triangle bleu, la troisième en cercle barré vert, la quatrième (non utilisée ici) en croix magenta ; \voiceNeutralStyle (non utilisé ici) revient au style par défaut. Nous verrons plus tard comment créer de telles commandes. Voir Visibilité et couleur des objets et Utilisation de variables dans les retouches.

La polyphonie ne modifie en rien la relation entre les notes au sein d’un bloc \relative. Chaque note est calculée par rapport à celle qui la précède, ou bien par rapport à la première note de l’accord qui précède. Ainsi, dans

\relative c' { noteA << <noteB noteC> \\ noteD >> noteE }

Une méthode alternative, et qui peut simplifier les choses si les notes des différentes voix sont espacées, consiste à placer une commande \relative au début de chacune des voix :

\relative { noteA … }
<<
  \relative { <noteB noteC> … }
\\
  \relative { noteD … }
>>
\relative { noteE … }

Pour finir, analysons le principe d’utilisation des voix dans une pièce complexe. Nous allons nous concentrer sur les deux premières mesures du second des Deux nocturnes, opus 32 de Chopin. Cet exemple nous servira à plusieurs reprises, y compris dans le chapitre suivant, pour illustrer certaines techniques de notation. Aussi, ne prêtez pas trop d’attention à ce qui pour l’instant pourrait vous paraître vraiment mystérieux dans le code, et intéressons-nous uniquement à ce qui concerne la musique et les voix – ce qui est plus compliqué sera décortiqué plus tard.

[image of music]

La direction des hampes sert souvent à indiquer dans la continuité deux lignes mélodiques simultanées. Ici, les hampes des notes les plus hautes vont vers le haut, et celles des notes plus basses vers le bas. C’est une première indication de ce que nous avons eu recours à plus d’une voix.

Mais le réel besoin de multiples voix se fait sentir dès lors que plusieurs notes qui débutent en même temps ont des durées différentes. C’est évident au troisième temps de la première mesure : le la bémol est une noire pointée, le fa une noire, et le ré bémol une blanche. On ne peut les grouper dans un accord, puisque toutes les notes composant un accord doivent être de même durée. On ne peut non plus les écrire séquentiellement, puisqu’elles débutent toutes au même instant. Ce fragment de mesure nécessite trois voix, et une bonne pratique voudrait que l’intégralité de la mesure soit sur trois voix, comme ci-dessous où nous avons une allure et une couleur différentes aux notes de chacune d’entre elles. Une fois de plus, nous reviendrons plus tard sur le code que vous ne comprendriez pas.

[image of music]

Essayons à présent de coder cette musique en partant de zéro. Comme nous le verrons, certaines difficultés vont se présenter. Partons de ce que nous avons appris : utilisons la construction << \\ >> pour saisir la première mesure dans trois voix :

\new Staff \relative {
  \key aes \major
  <<
    { c''2 aes4. bes8 } \\ { <ees, c>2 des } \\ { aes'2 f4 fes }
  >> |
  <c ees aes c>1 |
}

[image of music]

La direction des hampes est attribuée automatiquement : les voix impaires portent des hampes vers le haut, les voix paires des hampes vers le bas. Les hampes des voix 1 et 2 sont orientées comme il faut mais celles de la voix 3 devraient, dans le cas qui nous occupe, aller vers le bas. Nous pouvons corriger cela en sautant la voix 3 et en plaçant la musique dans la voix 4. Ceci pourrait s’obtenir à l’aide d’un \\ supplémentaire, mais nous utiliserons plutôt la commande \voices qui, par ailleurs, nous permettrait de saisir les voix dans un autre ordre selon notre convenance :

\new Staff \relative {
  \key aes \major
  \voices 1,2,4   % Omit voice three
  <<  % Voice one
    { c''2 aes4. bes8 }
  \\  % Voice two
    { <ees, c>2 des }
  \\  % Voice four
    { aes'2 f4 fes }
  >> |
  <c ees aes c>1 |
}

[image of music]

Cette manipulation nous permet de régler la direction des hampes, mais le positionnement horizontal des notes n’est pas satisfaisant. LilyPond décale les notes des voix intermédiaires lorsque leur tête ou leur hampe viendrait à chevaucher celles des voix extrêmes. Bien entendu, ce n’est pas souhaitable dans le cas d’une partition pour piano. Dans d’autres situations, les décalages que LilyPond applique peuvent ne pas éviter certaines collisions. LilyPond met à notre disposition plusieurs moyens d’ajuster le positionnement horizontal des notes. Nous ne sommes pas encore tout à fait prêts pour voir comment corriger cela, aussi nous examinerons ce problème dans un autre chapitre (voir la propriété force-hshift dans Correction des collisions d’objets).

Note : Paroles et objets étendus (liaisons, soufflets, etc.) ne peuvent passer d’une voix à l’autre.

Voir aussi

Manuel de notation : Plusieurs voix.


GNU LilyPond – Manuel d’initiation v2.25.19 (branche de développement).