]> git.donarmstrong.com Git - lilypond.git/blob - Documentation/de/essay/engraving.itely
Merge branch 'master' into lilypond/translation
[lilypond.git] / Documentation / de / essay / engraving.itely
1 @c -*- coding: utf-8; mode: texinfo; -*-
2
3 @ignore
4     Translation of GIT committish: ab9e3136d78bfaf15cc6d77ed1975d252c3fe506
5
6
7     When revising a translation, copy the HEAD committish of the
8     version that you are working on.  For details, see the Contributors'
9     Guide, node Updating translation committishes..
10 @end ignore
11
12 @c \version "2.13.4"
13
14 @c Translators: Till Paala
15
16 @node Notensatz
17 @chapter Notensatz
18 @translationof Music engraving
19
20 Dieser Aufsatz beschreibt, wie LilyPond entstand und wie es
21 benutzt werden kann, um schönen Notensatz zu erstellen.
22
23 @menu
24 * Die Geschichte von LilyPond::
25 * Details des Notensetzens::
26 * Automatisierter Notensatz::
27 * Ein Programm bauen::
28 * LilyPond die Arbeit überlassen::
29 * Notensatzbeispiele (BWV 861)::
30 @end menu
31
32
33 @node Die Geschichte von LilyPond
34 @section Die Geschichte von LilyPond
35 @translationof The LilyPond story
36
37 Lange bevor LilyPond benutzt werden konnte, um wunderschöne
38 Aufführungspartituren zu setzen, bevor es in der Lage war, Noten
39 für einen Unversitätskurs oder wenigstens eine einfache Melodie zu
40 setzen, bevor es eine Gemeinschaft von Benutzern rund um die Welt oder
41 wenigstens einen Aufsatz über den Notensatz gab, begann LilyPond
42 mit einer Frage:
43
44 @quotation
45 Warum schaffen es die meisten computergesetzten Noten nicht, die
46 Schönheit und Ausgeglichenheit von handgestochenem Notensatz aufzuweisen?
47 @end quotation
48
49 @noindent
50 Einige der Antworten können gefunden werden, indem wir uns die
51 beiden folgenden Noten zur Analyse vornehmen.  Das erste Beispiel
52 ist ein schöner handgestochener Notensatz von 1950, das zweite
53 Beispiel eine moderne, computergesetzte Edition.
54
55 @ifnottex
56 @quotation
57 @noindent
58 Bärenreiter BA 320, @copyright{}1950:
59
60 @sourceimage{baer-suite1-fullpage,,,png}
61 @end quotation
62
63 @quotation
64 @noindent
65 Henle Nr. 666, @copyright{}2000:
66 @sourceimage{henle-suite1-fullpage,,,png}
67 @end quotation
68 @end ifnottex
69
70 Die Noten sind identisch und stammen aus der ersten Solosuite für
71 Violoncello von J. S. Bach, aber ihre Erscheinung ist sehr
72 unterschiedlich, insbesondere wenn man sie ausdruckt und aus einigem
73 Abstand betrachtet. 
74 @ifnottex
75 (Die PDF-Version dieses Handbuchs hat hochauflösende Abbildungen,
76 die sich zum Drucken eignen.)
77 @end ifnottex
78 Versuchen Sie, beide Beispiele zu lesen oder von ihnen zu spielen,
79 und Sie werden feststellen, dass der handgestochene Satz sich
80 angenehmer benutzen lässt.  Er weist fließende Linien und Bewegung
81 auf und fühlt sich wie ein lebendes, atmendes Stück Musik an, während
82 die neuere Edition kalt und mechanisch erscheint.
83
84 Es ist schwer, sofort die Unterschiede zur neueren Edition auszumachen.
85 Alles sieht sauber und fein aus, möglicherweise sogar @qq{besser},
86 weil es eher computerkonform und einheitlich wirkt.  Das hat uns
87 tatsächlich für eine ganze Weile beschäftigt.  Wir wollten die
88 Computernotation verbessern, aber wir mussten erst verstehen, was
89 eigentlich falsch mit ihr war.
90
91 Die Antwort findet sich in der präzisen, mathematischen Gleichheit
92 der neueren Edition.  Suchen Sie die Taktstriche in der Mitte jeder
93 Zeile: im handgestochenen Satz hat die Position dieser Taktstriche
94 sozusagen natürliche Variation, während die neuere Version sie
95 fast immer perfekt in die Mitte setzt.  Das zeigen diese vereinfachten
96 Diagramme des Seitenlayouts vom handgestochenen (links) und
97 Computersatz (rechts):
98
99 @quotation
100 @iftex
101 @sourceimage{pdf/page-layout-comparison,,,}
102 @end iftex
103 @ifnottex
104 @sourceimage{page-layout-comparison,,,png}
105 @end ifnottex
106 @end quotation
107 @noindent
108
109 Im Computersatz sind sogar die einzelnen Notenköpfe vertikal
110 aneinander ausgerichtet, was dazu führt, dass die Melodie hinter
111 einem starren Gitter aus musikalischen Zeichen verschwindet.
112
113 Es gibt noch weitere Unterschiede: in der handgestochenen Version
114 sind die vertikalen Linien stärker, die Bögen liegen dichter an den
115 Notenköpfen und es gibt mehr Abweichungen in der Steigung der
116 Balken.  Auch wenn derartige Details als Haarspalterei erscheinen,
117 haben wir trotzdem als Ergebnis einen Satz, der einfacher zu lesen
118 ist.  In der Computerausgabe ist jede Zeile fast identisch mit den
119 anderen und wenn der Musiker für einen Moment weg schaut, wird
120 er die Orientierung auf der Seite verlieren.
121
122 LilyPond wurde geschaffen, um die Probleme zu lösen, die wir in
123 existierenden Programmen gefunden haben und um schöne Noten zu
124 schaffen, die die besten handgestochenen Partituren imitieren.
125
126 @iftex
127 @page
128 @noindent
129 Bärenreiter BA 320, @copyright{}1950:
130
131 @sourceimage{baer-suite1-fullpage-hires,16cm,,}
132 @page
133 @noindent
134 Henle no. 666, @copyright{}2000:
135 @sp 3
136 @sourceimage{henle-suite1-fullpage-hires,16cm,,}
137 @page
138 @end iftex
139
140
141 @node Details des Notensetzens
142 @section Details des Notensetzens
143 @translationof Engraving details
144
145 @cindex Notensatz
146 @cindex Typographie
147 @cindex Notengravur
148 @cindex Gravur, Notensatz
149 @cindex Plattendruck, Noten
150
151 Die Kunst des Notensatzes wird auch als Notenstich bezeichnet. Dieser 
152 Begriff stammt aus dem traditionellen Notendruck@footnote{Frühe
153 europäische Drucker versuchten sich an verschiedenen Techniken
154 wie handgeschnitzten Holzblöcken, beweglichen Lettern und
155 gravierten dünnen Metallblechen.  Der Satz mit Lettern hat den
156 Vorteil, dass man ihn schnell korrigieren kann und auch Text
157 einfach einfügen kann, aber nur der Notenstich als Gravur
158 ermöglichte die Möglichkeit, lebendiges Layout ohne
159 Qualitätsabstriche zu erstellen.  So wurden der Notenstich
160 mit der Hand bis ins 20. Jahrhundert zum Standard für alle
161 gedruckten Noten, ausgenommen einige Hymnale und Liederbücher, wo
162 der Letterdruck durch seine Einfachheit und Kostenersparnis
163 gerechtfertigt war.}. Noch bis vor etwa 20 
164 Jahren wurden Noten erstellt, indem man sie in eine Zink- oder Zinnplatte 
165 schnitt oder mit Stempeln schlug. Diese Platte wurde dann mit Druckerschwärze
166 versehen, so dass sie in den geschnittenen und gestempelten Vertiefungen 
167 blieb. Diese Vertiefungen schwärzten dann ein auf die Platte gelegtes 
168 Papier. Das Gravieren wurde vollständig von Hand erledigt. Es war darum 
169 sehr mühsam, Korrekturen anzubringen, weshalb man von vornherein richtig
170 schneiden musste. Die Kunst des Notenstechens war eine sehr
171 spezialisierte Handwerkskunst, für die ein Handwerker etwa fünf
172 Ausbildungsjahre benötigte, bevor der den Meistertitel tragen durfte.
173 Weitere fünf Jahre waren erforderlich, um diese Kunst wirklich zu
174 beherrschen.
175
176 @quotation
177 @iftex
178 @sourceimage{hader-slaan,,7cm,}
179 @end iftex
180 @ifnottex
181 @sourceimage{hader-slaan,,,jpg}
182 @end ifnottex
183 @end quotation
184
185 LilyPond wurde von den handgestochenen traditionellen Noten
186 inspiriert, die in der ersten Hälfte des 20. Jahrhunderts von
187 europäischen Notenverlagen herausgegeben wurden (insbesondere
188 Bärenreiter, Duhem, Durand, Hofmeister, Peters und Scott).  Sie
189 werden teilweise als der Höhepunkt des traditionellen Notenstichs
190 angesehen.  Beim Studium dieser Editionen haben wir eine Menge
191 darüber gelernt, was einen gut gesetzten Musikdruck ausmacht und
192 welche Aspekte des handgestochenen Notensatzes wir in LilyPond
193 imitieren wollten.
194
195 @c Heutzutage wird fast alle gedruckte Musik von Computern erstellt. Das 
196 @c hat einige deutliche Vorteile: Drucke sind billiger als die gravierten
197 @c Platten und der Computersatz kann per E-Mail verschickt werden. Leider
198 @c hat der intensive Einsatz des Computers die graphische Qualität
199 @c des Notensatzes vermindert. Mit dem Computer erstellte Noten sehen 
200 @c langweilig und mechanisch aus, was es erschwert, von ihnen zu spielen.
201
202 @menu
203 * Notenschriftarten::
204 * Optischer Ausgleich::
205 * Hilfslinien::
206 * Optische Größen::
207 * Warum der große Aufwand?::
208  @end menu
209
210 @node Notenschriftarten
211 @unnumberedsubsec Notenschriftarten
212 @translationof Music fonts
213
214 Die Abbildung unten illustriert den Unterschied zwischen  
215 traditionellem Notensatz und einem typischen Computersatz.
216 Das linke Bild zeigt ein eingescanntes b-Vorzeichen
217 einer handgestochenen Bärenreiter-Edition, das rechte Bild
218 hingegen ein Symbol aus einer 2000 herausgegebenen Edition
219 der selben Noten.  Obwohl beide Bilder mit der gleichen
220 Tintenfarbe gedruckt sind, wird die frühere Version dunkler: die
221 Notenlinien sind dicker und das Bärenreiter-b hat ein rundliches,
222 beinahe sinnliches Aussehen.  Der rechte Scan hingegen hat
223 dünnere Linien und eine gerade Form mit scharfen Ecken und Kanten.
224
225 @multitable @columnfractions .25 .25 .25 .25
226 @item @tab
227 @ifnotinfo
228 @iftex
229 @sourceimage{baer-flat-gray,,4cm,}
230 @end iftex
231 @ifnottex
232 @sourceimage{baer-flat-gray,,,png}
233 @end ifnottex
234
235 @tab
236 @iftex
237 @sourceimage{henle-flat-gray,,4cm,}
238 @end iftex
239 @ifnottex
240 @sourceimage{henle-flat-gray,,,png}
241 @end ifnottex
242
243 @end ifnotinfo
244 @ifinfo
245 @sourceimage{henle-flat-bw,,,png}
246 @sourceimage{baer-flat-bw,,,png}
247 @sourceimage{lily-flat-bw,,,png}
248 @end ifinfo
249
250
251 @item @tab
252 Bärenreiter (1950)
253 @tab
254 Henle (2000)
255
256 @end multitable
257
258
259 @cindex Musiksymbole
260 @cindex Schriftart
261 @cindex Dichte
262 @cindex Balance
263
264 Als wir uns entschlossen hatten, ein Programm zu schreiben, das
265 die Typographie des Notensatzes beherrscht, gab es keine freien
266 Musikschriftarten, die unserem geplanten eleganten Notenbild passen
267 würden.  Unbeirrt schufen wir eine Schriftart und dazu einen
268 Computerfont mit den musikalischen Symbolen, wobei wir uns an den
269 schönen Musikdrucken der handgestochenen Noten orientierten.  Ohne
270 diese Erfahrung hätten wir nie verstanden, wie hässlich die
271 Schriftarten waren, die wir zuerst bewunderten.
272
273 Unten ein Beispiel zweier Notenschriftarten.  Das obere Beispiel ist der
274 Standard im Sibelius-Programm (die @emph{Opus}-Schriftart), das
275 untere unsere eigene LilyPond-Schriftart.
276
277 @quotation
278 @iftex
279 @sourceimage{pdf/OpusAndFeta,,,}
280 @end iftex
281 @ifnottex
282 @sourceimage{OpusAndFeta,,,png}
283 @end ifnottex
284 @end quotation
285
286 Die LilyPond-Symbole sind schwerer und ihre Dicke ist durchgängiger,
287 wodurch sie einfacher zu lesen sind.  Feine Enden, wie etwa die
288 Seiten der Viertelpause, sollten nicht als scharfe Spitzen enden,
289 sondern etwas abgerundet.  Das liegt daran, dass scharfe Enden
290 der Stempel sehr fragil sind und sich schnell durch die Verwendung
291 abnutzen.  Zusammengefasst muss die Schwärze der Schriftart sehr
292 vorsichtig mit der Schwärze von Notenlinien, Balken und Bögen
293 abgeglichen werden, um ein starkes, aber doch ausgewogenes Gesamtbild
294 zu ergeben.
295
296 Einige weitere Besonderheiten: der Notenkopf der Halben ist nicht
297 elliptisch, sondern etwas rautenförmig.  Der vertikale Hals des
298 b-Symbols ist schwach keilförmig nach oben hin.  Das Kreuz und das
299 Auflösungszeichen sind einfacher aus der Entfernung zu unterscheiden,
300 weil ihre schrägen Linien eine andere Neigung haben und die vertikalen
301 Linien dicker sind.
302
303 @node Optischer Ausgleich
304 @unnumberedsubsec Optischer Ausgleich
305 @translationof Optical spacing
306
307 Die Aufteilung der Noten in der Horizontalen sollte die Dauer der
308 jeweiligen Note widerspiegeln.  Wie wir jedoch im Beispiel der
309 Bach-Suite oben sehen konnten, orientieren sich viele moderne
310 Partituren an den Dauern mit mathematischer Präzision, was zu
311 schlechten Ergebnissen führt.  Im nächsten Beispiel ist ein Motiv
312 zweimal dargestellt: das erste Mal mit exakter mathematischer
313 Aufteilung, das zweite Mal mit Korrekturen.  Welches Beispiel
314 spricht Sie mehr an?
315
316 @cindex Optischer Ausgleich
317
318 @lilypond
319 \paper {
320   ragged-right = ##t
321   indent = #0.0
322 }
323
324 music = {
325    c'4 e''4 e'4 b'4
326    \stemDown
327    b'8[ e'' a' e'']
328    \stemNeutral
329    e'8[ e'8 e'8 e'8]
330 }
331 \score
332 {
333   \music
334   \layout {
335     \context {
336       \Staff
337       \override NoteSpacing #'stem-spacing-correction = #0.0
338       \override NoteSpacing #'same-direction-correction = #0.0
339       \override StaffSpacing #'stem-spacing-correction = #0.0
340     }
341   }
342 }
343 @end lilypond
344
345 @lilypond
346 \paper {
347   ragged-right = ##t
348   indent = #0.0
349 }
350
351 music = {
352    c'4 e''4 e'4 b'4 |
353    \stemDown
354    b'8[ e'' a' e'']
355    \stemNeutral
356    e'8[ e'8 e'8 e'8]
357 }
358
359 \score
360 {
361   \music
362   \layout {
363     \context {
364       \Staff
365       \override NoteSpacing #'stem-spacing-correction = #0.6
366     }
367   }
368 }
369 @end lilypond
370
371 @cindex normale Rhythmen
372 @cindex normale Abstände
373 @cindex Abstände, normal
374 @cindex Rhythmen, normal
375
376 In jedem Takt in diesem Ausschnitt kommen Noten vor, die in einem
377 gleichmäßigen Rhythmus gespielt werden. Die Abstände sollten das
378 widerspiegeln. Leider lässt uns aber das Auge im Stich: es beachtet
379 nicht nur den Abstand von aufeinander folgenden Notenköpfen, sondern
380 auch den ihrer Hälse. Also müssen Noten, deren Hälse in direkter
381 Folge zuerst nach oben und dann nach unten ausgerichtet sind, weiter
382 auseinander gezogen werden, während die unten/oben-Folge engere
383 Abstände fordert, und das alles auch noch in Abhängigkeit von der 
384 vertikalen Position der Noten. Das untere Beispiel ist mit dieser 
385 Korrektur gesetzt. Im oberen Beispiel hingegen bilden sich 
386 für das Auge bei unten/oben-Folgen Notenklumpen.  Ein Notenstechermeister
387 hätte die Notenaufteilung angepasst, sodass die angenehm zu lesen ist.
388
389 Die Algorithmen zur Platzaufteilung von LilyPond berechnen sogar die
390 Taktstriche mit ein, weshalb die letzte Noten mit Hals nach oben im
391 richtig platzierten Beispiel etwas mehr Platz vor dem Taktstrich
392 erhält, damit sie nicht gedrängt wirkt. Ein Hals nach unten würde diesen Ausgleich nicht benötigen.
393
394
395 @node Hilfslinien
396 @unnumberedsubsec Hilfslinien
397 @translationof Ledger lines
398
399 @cindex Hilfslinien
400 @cindex Zusammenstöße
401
402 Hilfslinien stellen eine typographische Herausforderung dar: sie
403 machen es schwerer, die Notensymbole dicht anzuordnen und sie müssen
404 klar genug sein, dass sich die Tonhöhe mit einem schnellen Blick
405 erkennen lässt.  Im Beispiel unten können wir sehen, dass
406 Hilfslinien dicker als normale Notenlinien sein sollten und dass
407 ein gelernter Notenstecher eine Hilfslinie verkürzt, um dichteres
408 Platzieren von Versetzungszeichen zu erlauben.  Wir haben diese
409 Eigenschaft in den Notensatz von LilyPond eingebaut.
410
411 @multitable @columnfractions .25 .25 .25 .25
412 @item @tab
413
414 @iftex
415 @sourceimage{baer-ledger,3cm,,}
416 @end iftex
417 @ifnottex
418 @sourceimage{baer-ledger,,,png}
419 @end ifnottex
420
421 @tab
422
423 @iftex
424 @sourceimage{lily-ledger,3cm,,}
425 @end iftex
426 @ifnottex
427 @sourceimage{lily-ledger,,,png}
428 @end ifnottex
429
430 @end multitable
431
432
433 @node Optische Größen
434 @unnumberedsubsec Optische Größen
435 @translationof Optical sizing
436
437 Noten werden in verschiedenen Größen gedruckt.  Ursprünglich hatte
438 man hierzu Stempel in verschiedenen Größen, was gleichzeitig heißt,
439 dass jeder Stempel so beschaffen war, dass er für seine Größe ein
440 ideales Abbild erzeugte.  Mit den digitalen Fonts kann ein einziger
441 Umriss mathematisch skaliert werden, um eine beliebige Größe zu
442 erzeugen, was sehr viele Vorteile hat.  In kleinen Größen erscheinen
443 die Symbole jedoch zu dünn.
444
445 Für LilyPond haben wir Schriftarten mit einer Reihe von Dicken
446 erstellt, die jeweils einer Notengröße entsprechen.  Hier ein
447 LilyPond-Notensatz mit der Systemgröße 26:
448
449 @quotation
450 @iftex
451 @sourceimage{pdf/size26,,23mm,}
452 @end iftex
453 @ifnottex
454 @sourceimage{size26,,,png}
455 @end ifnottex
456 @end quotation
457
458 @noindent
459 und hier die gleichen Noten mit Systemgröße 11, anschließend um 236%
460 vergrößert, damit das Bild in exakt der gleichen Größe wie das
461 vorige erscheint:
462
463 @quotation
464 @iftex
465 @sourceimage{pdf/size11,,23mm,}
466 @end iftex
467 @ifnottex
468 @sourceimage{size11,,,png}
469 @end ifnottex
470 @end quotation
471
472 @noindent
473 Bei kleineren Größen benutzt LilyPond proportional dickere
474 Notenlinien, sodass das Notenbild immer noch gut zu lesen ist.
475
476 @ignore
477 Dadurch können auch Notensysteme unterschiedlicher Größe
478 friedlich nebeneinander auf der gleichen Seite erscheinen:
479
480 @c TODO: are the stems in this example the right thickness? How should
481 @c line weights be scaled for small staves?
482
483 @c Grieg's Violin Sonata Op. 45
484 @lilypond[indent=1.5cm]
485 global = {
486   \time 6/8
487   \key c \minor
488 }
489
490 \new Score <<
491   \new Staff \with {
492       fontSize = #-4
493       \override StaffSymbol #'staff-space = #(magstep -4)
494       \override StaffSymbol #'thickness = #(magstep -3)
495     }
496     \relative c' {
497       \global
498       \set Staff.instrumentName = #"Violin"
499       c8.(\f^> b16 c d) ees8.(^> d16 c b)
500       g8.(^> b16 c ees) g8-.^> r r
501       R2.
502     }
503   \new PianoStaff <<
504     \set PianoStaff.instrumentName = #"Piano"
505     \new Staff \relative c' {
506       \global
507       s2.
508       s4. s8 r8 r16 <c f aes c>
509       <c f aes c>4.^> <c ees g>8 r r
510     }
511     \new Staff \relative c {
512       \global
513       \clef "bass"
514       << {
515         \once \override DynamicText #'X-offset = #-3
516         <ees g c>2.~->^\f
517         <ees g c>4.~ <ees g c>8
518       } \\ {
519         <c g c,>2.~
520         <c g c,>4.~ <c g c,>8
521       } >>
522       r8 r16 <f, c' aes'>16
523       <f c' aes'>4.-> <c' g'>8 r r
524     }
525   >>
526 >>
527 @end lilypond
528 @end ignore
529
530
531 @node Warum der große Aufwand?
532 @unnumberedsubsec Warum der große Aufwand?
533 @translationof Why work so hard?
534
535 Musiker sind üblicherweise zu sehr damit beschäftigt, die Musik aufzuführen, 
536 als dass sie das Aussehen der Noten studieren könnten; darum mag diese 
537 Beschäftigung mit typographischen Details akademisch wirken. 
538 Das ist sie aber nicht.  Notenmaterial ist Aufführungsmaterial:
539 alles muss unternommen werden, damit der Musiker die Aufführung
540 besser bewältigt, und alles, das unklar oder unangenehm ist,
541 ist eine Hindernis.
542
543 Der dichtere Eindruck, den die dickeren Notenlinien und schwereren
544 Notationssymbole schaffen, eignet sich besser für Noten,
545 die weit vom Leser entfernt stehen, etwa auf einem Notenständer.
546 Eine sorgfältige Verteilung der Zwischenräume erlaubt es, die 
547 Noten sehr dicht zu setzen, ohne dass die Symbole zusammenklumpen. 
548 Dadurch werden unnötige Seitenumbrüche vermieden, so dass man 
549 nicht so oft blättern muss.
550
551 Dies sind die Anforderungen der Typographie: Das Layout sollte
552 schön sein -- nicht nur aus Selbstzweck, sondern vor allem um dem
553 Leser zu helfen.  Für Aufführungsmaterial ist das umso wichtiger,
554 denn Musiker haben eine begrenzte Aufnahmefähigkeit. Je weniger
555 Mühe nötig ist, die Noten zu erfassen, desto mehr Zeit bleibt für
556 die Gestaltung der eigentlichen Musik. Das heißt: Gute 
557 Typographie führt zu besseren Aufführungen!
558
559 Die Beispiele haben gezeigt, dass der Notensatz eine subtile und 
560 komplexe Kunst ist und gute Ergebnisse nur mit viel Erfahrung 
561 erlangt werden können, die Musiker normalerweise nicht haben.
562 LilyPond stellt unser Bemühen dar, die graphische Qualität
563 handgestochener Notenseiten ins Computer-Zeitalter zu transportieren 
564 und sie für normale Musiker erreichbar zu machen. Wir haben 
565 unsere Algorithmen, die Gestalt der Symbole und die Programm-Einstellungen
566 darauf abgestimmt, einen Ausdruck zu erzielen, der der Qualität 
567 der alten Editionen entspricht, die wir so gerne betrachten 
568 und aus denen wir gerne spielen.
569
570
571
572 @node Automatisierter Notensatz
573 @section Automatisierter Notensatz
574 @translationof Automated engraving
575
576 @cindex Notensatz, automatisch
577 @cindex automatischer Notensatz
578
579 Dieser Abschnitt beschreibt, was benötigt wird um ein Programm zu
580 schreiben, welches das Layout von gestochenen Noten nachahmen kann:
581 eine Methode, dem Computer gute Layouts zu erklären und detailliertes
582 Vergleichen mit echten Notendrucken.
583
584 @menu
585 * Schönheitswettbewerb::
586 * Verbessern durch Benchmarking::
587 * Alles richtig machen::     
588 @end menu
589
590 @node Schönheitswettbewerb
591 @unnumberedsubsec Schönheitswettbewerb
592 @translationof Beauty contests
593
594 Wie sollen wir also jetzt die Typographie anwenden?
595 Anders gesagt: welcher von den drei Konfigurationen sollte für
596 den folgenden Bogen ausgewählt werden?
597
598 @lilypond
599 \relative c {
600   \clef bass
601   \once \override Slur #'positions = #'(1.5 . 1)
602   e8[( f] g[ a b d,)] r4
603   \once \override Slur #'positions = #'(2 . 3)
604   e8[( f] g[ a b d,)] r4
605   e8[( f] g[ a b d,)] r4
606 }
607 @end lilypond
608
609 Es gibt wenige Bücher über die Kunst des Notensatzes.  Leider
610 haben sie nur Daumenregeln und einige Beispiele zu bieten.  Solche
611 Regeln können sehr informativ sein, aber sie sind weit entfernt
612 von einem Algorithmus, den wir in unser Programm einbauen könnten.
613 Indem man die Anweisungen der Literatur anwendet, kommt man zu
614 Algorithmen mit sehr vielen manuellen Ausnahmen.  Alle die möglichen
615 Fälle zu analysieren stellt sehr viel Arbeit dar und meistens
616 werden dennoch nicht alle Fälle vollständig abgedeckt:
617
618 @quotation
619 @iftex
620 @sourceimage{ross-beam-scan,7cm,,}
621 @end iftex
622 @ifnottex
623 @sourceimage{ross-beam-scan,,,.jpg}
624 @end ifnottex
625 @end quotation
626
627 (Bildquelle: Ted Ross, @emph{The Art of Music Engraving})
628
629 Anstatt zu versuchen, für jedes mögliche Szenario eine passende
630 Layoutregel zu definieren, müssen wir nur die Regeln genau genug
631 beschreiben, sodass LilyPond die Gefälligkeit von mehreren
632 Alternativen selber einschätzen kann.  Dann errechnen wir für jede
633 mögliche Konfiguration eine Hässlichkeits-Rangliste und wir wählen
634 die Konfiguration aus, die am wenigsten hässlich ist.
635
636 Zum Beispiel hier drei mögliche Konfiguration eines Legatobogens,
637 und LilyPond hat jeder Konfiguration @qq{Hässlichkeitspunkte}
638 verliehen.  Das erste Beispiel erhält 15.39 Punkte, weil einer der
639 Notenköpfe angeschnitten wird:
640
641 @lilypond
642 \relative c {
643   \clef bass
644   \once \override Slur #'positions = #'(1.5 . 1)
645   e8[(_"15.39" f] g[ a b d,)] r4
646 }
647 @end lilypond
648
649 Das zweite Beispiel ist schöner, aber der Bogen beginnt weder noch
650 endet er an den Notenköpfen.  Hier werden 1.71 Punkte auf der linken
651 und 9.37 Punkte auf der rechten Seite verliehen, plus weiteren
652 2 Punkten, weil der Bogen aufsteigt, während die Melodie absteigt.
653 Insgesamt also 13.08 Punkte:
654
655 @lilypond
656 \relative c {
657   \clef bass
658   \once \override Slur #'positions = #'(2 . 3)
659   e8[(_"13.08" f] g[ a b d,)] r4
660 }
661 @end lilypond
662
663 Der letzte Bogen erhält 10.04 Punkte für die Lücke rechts und
664 2 Punkte für die Neigung nach oben, aber er ist die schönste
665 der drei Varianten, sodass LilyPond ihn auswählt:
666
667 @lilypond
668 \relative c {
669   \clef bass
670   e8[(_"12.04" f] g[ a b d,)] r4
671 }
672 @end lilypond
673
674 Diese Technik ist sehr allgemein und wird benutzt, um optimale
675 Entscheidungen für Bögenkonfigurationen, Bindebögen und Punkten
676 in Akkorden, Zeilenumbrüche und Seitenumbrüche zu erhalten.  Die
677 Ergebnisse dieser Entscheidungen können durch einen Vergleich mit
678 handgestochenen Noten eingeschätzt werden.
679
680
681 @node Verbessern durch Benchmarking
682 @unnumberedsubsec Verbessern durch Benchmarking
683 @translationof Improvement by benchmarking
684
685 Die Ausgabe von LilyPond hat sich schrittweise mit der Zeit
686 verbessert, und sie verbessert sich weiter, indem sie immer wieder
687 mit handgestochenen Noten verglichen wird.
688
689 Hier als Beispiel eine Zeile eines Benchmark-Stückes aus einer 
690 handgestochenen Notenedition (Bärenreiter BA320):
691
692 @iftex
693 @sourceimage{baer-sarabande-hires,16cm,,}
694 @end iftex
695 @ifnottex
696 @sourceimage{baer-sarabande,,,png}
697 @end ifnottex
698
699 @noindent
700 und die gleiche Zeile als Satz einer sehr alten LilyPond-Version
701 (Version 1.4, Mai 2001):
702
703 @iftex
704 @sourceimage{pdf/lily14-sarabande,16cm,,}
705 @end iftex
706 @ifnottex
707 @sourceimage{lily14-sarabande,,,png}
708 @end ifnottex
709
710 @noindent
711 Die Ausgabe von LilyPond 1.4 ist auf jeden Fall leserlich, aber
712 ein ausführlicher Vergleich mit der Vorlage zeigt viele Fehler in
713 den Formatierungsdetails:
714
715 @iftex
716 @sourceimage{lily14-sarabande-annotated-hires,16cm,,}
717 @end iftex
718 @ifnottex
719 @sourceimage{lily14-sarabande-annotated,,,png}
720 @end ifnottex
721
722 @itemize @bullet
723 @item vor der Taktangabe ist nicht genug Platz
724 @item die Hälse der bebalkten Noten sind zu lang
725 @item der zweite und vierte Takt sind zu schmal
726 @item der Bogen sieht ungeschickt aus
727 @item das Triller-Symbol ist zu groß
728 @item die Hälse sind zu dünn
729 @end itemize
730
731 @noindent
732 (Es gibt auch zwei fehlende Notenköpfe, verschiedene editorische
733 Anweisungen, die Fehler und eine falsche Tonhöhe!)
734
735 Indem die Layoutregeln und das Design der Schriftarten angepasst
736 wurde, hat sich die Ausgabe sehr stark verbessert.  Vergleichen
737 Sie das gleiche Referenzbeispiel und die Ausgabe der aktuellen
738 LilyPond-Version (@version{}):
739
740 @iftex
741 @sourceimage{baer-sarabande-hires,16cm,,}
742 @end iftex
743 @ifnottex
744 @sourceimage{baer-sarabande,,,png}
745 @end ifnottex
746
747 @lilypond[staffsize=17.5,line-width=15.9\cm]
748 \relative c {
749   \clef "bass"
750   \key d \minor
751   \time 3/4
752   \mergeDifferentlyDottedOn
753   <<
754     { \slurDashed d8.-\flageolet( e16) e4.-\trill( d16 e) }
755      \\
756     { d4_2 a2 }
757   >>
758   \slurDashed
759   <f' a, d,>4. e8( d c)
760   \slurSolid
761   bes8 g' f e16( f g_1 a_2 bes_3 d,_2)
762   \slurDashed
763   cis4.-\trill b8_3( a g)
764   <<
765     { \slurDashed d'8.( e16) e4.-\trill( d16 e) }
766      \\
767     { <f, a>4 a2 }
768   >>
769 }
770 @end lilypond
771
772 @noindent
773 Die jetzige Ausgabe ist kein Klon der Referenzedition, aber sie ist
774 sehr viel näher an einer Publikationsqualität.
775
776
777 @node Alles richtig machen
778 @unnumberedsubsec Alles richtig machen
779 @translationof Getting things right
780
781 Wir können auch die Fähigkeiten von LilyPond, Notensatzentscheidungen
782 alleine zu fällen, messen, indem wir die Ausgabe von LilyPond mit
783 der Ausgabe eines kommerziellen Notensatzprogramms vergleichen.
784 In diesem Fall haben wir Finale 2008 genommen, eines der beliebtesten
785 Notensatzprogramme, insbesondere in Nordamerika.  Sibelius ist
786 Finales hauptsächlicher Gegenspieler, offensichtlich vor allem in
787 Europa verbreitet.
788
789 Für unseren Vergleich haben wir uns für die Fuge in G-Moll aus
790 dem Wohltemperierten Clavier 1, BWV 861 von J. S. Bach entschieden,
791 mit dem Hauptthema:
792
793 @lilypond
794 \relative c' {
795   \key g \minor
796   \clef "treble_8"
797   r8 d ees g, fis4 g
798   r8 a16 bes c8 bes16 a bes8
799 }
800 @end lilypond
801
802 @noindent
803 In unserem Vergleich setzten wir die letzten sieben Takte des
804 Stückes (28--34) in Finale und LilyPond.  Das ist der Punkt, an
805 der das Thema als dreistimmige Engführung in den Schlussabschnitt
806 überleitet.  In der Finale-Version haben wir der Versuchung
807 widerstanden, jedwede Anpassungen abweichend vom Standard vorzunehmen,
808 weil wir zeigen wollen, welche Dinge von den beiden Programmen
809 ohne Hilfeleistung richtig gemacht werden.  Die einzigen größeren
810 Änderungen, die wir vorgenommen haben, war die Anpassung der
811 Seitengröße an die Seitengröße dieses Aufsatzes und die Begrenzung
812 der Noten auf zwei Systeme, um den Vergleich einfacher zu machen.
813 In der Standardeinstellung Finale hätte zwei Zeilen mit je drei
814 Takten und schließlich eine letzte Zeile gesetzt, die nur einen einzigen
815 Takt enthält.
816
817 Viele der Unterschiede zwischen den beiden Sätzen finden sich
818 in den Takten 28--29, hier zuerst in Finales Version, dann in der
819 Version von LilyPond:
820
821 @iftex
822 @sourceimage{pdf/bwv861mm28-29,14cm,,}
823 @end iftex
824 @ifnottex
825 @sourceimage{bwv861mm28-29,,,png}
826 @end ifnottex
827
828 @lilypond[staffsize=19.5,line-width=14\cm]
829 global = { \key g \minor }
830
831 partI = \relative c' {
832   \voiceOne
833   fis8 d' ees g, fis4 g
834   r8 a16 bes c8 bes16 a d8 r r4
835 }
836
837 partII = \relative c' {
838   \voiceTwo
839   d4 r4 r8 d'16 c bes8 c16 d
840   ees8 d c ees a, r r4
841 }
842 partIII = \relative c' {
843   \voiceOne
844   r2 r8 d ees g, fis4 g r8 a16 bes c8 bes16 a
845 }
846 partIV = \relative c {
847   \voiceTwo
848   d4 r r2
849   r8 d ees g, fis4 a
850 }
851
852 \score {
853   <<
854     % \set Score.barNumberVisibility = #all-bar-numbers-visible
855     % required in 2.13
856     \set Score.currentBarNumber = #28
857     \bar ""
858     \new PianoStaff <<
859       \new Staff = "RH"
860       <<
861         \global
862         \new Voice = "voiceI" { \partI }
863         \new Voice = "voiceII" { \partII }
864       >>
865
866       \new Staff = "LH" <<
867         \clef "bass"
868         \global
869         \new Voice = "voiceIII" { \partIII }
870         \new Voice = "voiceIV" { \partIV }
871       >>
872     >>
873   >>
874   \layout {
875     \context {
876       \Staff
877       \remove "Time_signature_engraver"
878     }
879     \context {
880       \PianoStaff
881       \override StaffGrouper #'between-staff-spacing #'padding = #1
882     }
883   }
884 }
885 @end lilypond
886
887 Einige der Mängel des nicht editierten Finale-Satzes beinhalten:
888
889 @itemize @bullet
890
891 @item Die meisten Balken sind zu weit vom Notensystem entfernt.
892 Ein Balken, der zum Zentrum des Systems zeigt, sollte etwa die
893 Länge einer Oktave haben, aber Notensetzer verkürzen die Länge,
894 wenn der Balken in polyphonen Situationen aus dem System
895 herauszeigt.  Die Bebalkung von Finale kann einfach mit ihrem
896 Patterson Beams-Plugin verbessert werden, aber wir haben diesen
897 Schritt für dieses Beispiel ausgelassen.
898
899 @item Finale passt die Position von ineinander greifenden Notenköpfen
900 nicht an, sodass die Noten sehr schwer lesbar werden, wenn
901 die untere und obere Stimme zeitweise ausgetauscht werden:
902
903 @lilypond
904 collide = \once \override NoteColumn #'force-hshift = #0
905 \new Score <<
906   \new Voice = "sample" \relative c''{
907     \key g \minor
908     <<
909       { \voiceOne g4 \collide g4 }
910       \new Voice { \voiceTwo bes \collide bes }
911     >>
912   }
913   \new Lyrics \lyricsto "sample" \lyricmode { "good " " bad" }
914 >>
915 @end lilypond
916
917 @item Finale positioniert alle Pausen an einer festen Position auf
918 dem System.  Der Benutzer kann sie anpassen, wie er es richtig
919 findet, aber das Programm unternimmt keinen Versuch, den Inhalt
920 der anderen Stimme mit einzubeziehen.  Durch einen Glücksfall
921 kommen keine wirklichen Kollisionen zwischen Noten und Pausen
922 in diesem Beispiel vor, aber das liegt mehr an der Position der
923 Noten als an der der Pausen.  Anders gesagt: Bach verdient mehr
924 Aufmerksamkeit um vollständige Kollisionen zu vermeiden als
925 Finale ihm gönnt.
926
927 @end itemize
928
929 Dieses Beispiel soll nicht suggerieren, dass man mit Finale nicht
930 Notensatz in Publikationsqualität erstellen könnte.  Das Programm ist
931 durchaus dazu fähig, wenn ein erfahrener Benutzer genug Zeit und Fähigkeit mitbringt.
932 Einer der fundamentalen Unterschiede zwischen LilyPond und kommerziellen
933 Notensatzprogrammen ist, dass LilyPond versucht, den Aufwand an
934 menschlicher Intervention auf ein absolutes Minimum zu reduzieren,
935 während andere Programme versuchen, ein attraktives Programmfenster
936 zu bieten, in dem die Anpassungen vorgenommen werden können.
937
938 Einen besonders hervorstechenden Mangel von Finale
939 ist ein fehlendes b-Vorzeichen in Takt 33:
940
941 @quotation
942 @iftex
943 @sourceimage{pdf/bwv861mm33-34-annotate,7.93cm,,}
944 @end iftex
945 @ifnottex
946 @sourceimage{bwv861mm33-34-annotate,,,png}
947 @end ifnottex
948 @end quotation
949
950 @noindent
951 Das b-Symbol wird benötigt, um das Auflösungzeichen im selben
952 Takt rückgängig zu machen, aber Finale lässt es aus, weil es in
953 einer anderen Stimme vorkommt.  Der Benutzer muss nicht nur daran
954 denken, ein Balken-Plugin zu starten und die Notenköpfe und Pausen
955 neu anzuordnen, er muss auch jeden Takt prüfen, ob Versetzungszeichen
956 aus anderen Stimmen korrigiert werden müssen, damit nicht ein
957 Notensatzfehler die Probe unnötig unterbricht.
958
959 Wenn Sie diese Beispiel noch detaillierter betrachten wollen,
960 können Sie den vollen siebentaktigen Ausschnitt am Ende dieses
961 Aufsatzes als Notensatz in vier unterschiedlichen
962 publizierten Editionen finden.  Nähere Betrachtung zeigt, dass
963 es einige akzeptable Variationen zwischen den handgestochenen
964 Beispielen gibt, dass LilyPond aber ziemlich guten Notensatz
965 im Rahmen dieser Variationen produziert.  Auch die LilyPond-Ausgabe
966 hat noch ihre Fehler: sie ist beispielsweise etwas zu aggressiv
967 bei der Verkürzung einiger Hälse -- hier ist also noch Raum für
968 weitere Entwicklung und Feineinstellung.
969
970 Natürlich hängt Typographie vom menschlichen Urteil der Erscheinung
971 ab, sodass Menschen nicht vollständig ersetzt werden können.  Viel
972 der eintönigen Arbeit kann jedoch automatisiert werden.  Wenn
973 LilyPond die meisten üblichen Situationen richtig löst, ist das
974 schon eine große Verbesserung gegenüber existierender Software.
975 Im Laufe der Jahre wir das Programm immer besser und macht mehr
976 und mehr Sachen automatisch, sodass manuelles Eingreifen immer
977 seltener wird.  Wo manuelle Anpassungen benötigt werden,
978 wurde die Struktur von LilyPond mit Flexibilität im Hinterkopf
979 geplant.
980
981
982 @node Ein Programm bauen
983 @section Ein Programm bauen
984 @translationof Building software
985
986 Dieser Abschnitt beschreibt einige der Entscheidungen,
987 die wir während des Programmierens für das Design von LilyPond
988 getroffen haben.
989
990 @menu
991 * Die Darstellung der Musik::
992 * Welche Symbole?::
993 * Flexible Architektur::
994 @end menu
995
996 @node Die Darstellung der Musik
997 @unnumberedsubsec Die Darstellung der Musik
998 @translationof Music representation
999
1000 @cindex Syntax
1001 @cindex rekursive Strukturen
1002
1003 Idealerweise ist das Eingabeformat für ein komplexes Satzsystem die 
1004 abstrakte Beschreibung des Inhaltes. In diesem Fall wäre das die 
1005 Musik selber. Das stellt uns aber vor ein ziemlich großes Problem, 
1006 denn wie können wir definieren, was Musik wirklich ist? Anstatt darauf 
1007 eine Antwort zu suchen, haben wir die Frage einfach umgedreht. Wir
1008 schreiben ein Programm, das den Notensatz beherrscht und machen das 
1009 Format so einfach wie möglich. Wenn es nicht mehr vereinfacht 
1010 werden kann, haben wir per Definition nur noch den reinen Inhalt. Unser 
1011 Format dient als die formale Definition eines Musiktextes.
1012
1013 Die Syntax ist gleichzeitig die Benutzerschnittstelle bei LilyPond, 
1014 darum soll sie einfach zu schreiben sein; z. B. bedeutet
1015
1016 @example
1017 @{
1018   c'4 d'8
1019 @}
1020 @end example
1021
1022 @noindent
1023 dass eine Viertel c' und eine Achtel d' erstellt werden sollen,
1024 wie in diesem Beispiel:
1025
1026 @lilypond[quote]
1027 {
1028   c'4 d'8
1029 }
1030 @end lilypond
1031
1032 In kleinem Rahmen ist diese Syntax sehr einfach zu benutzen.  In
1033 größeren Zusammenhängen aber brauchen wir Struktur.  Wie sonst kann
1034 man große Opern oder Symphonien notieren?  Diese Struktur wird
1035 gewährleistet durch sog. @emph{music expressions} (Musikausdrücke):
1036 indem kleine Teile zu größeren kombiniert werden, kann komplexere
1037 Musik dargestellt werden. So etwa hier:
1038
1039 @lilypond[quote,verbatim,fragment,relative=1]
1040 f4
1041 @end lilypond
1042
1043 @noindent
1044 Gleichzeitig erklingende Noten werden hinzugefügt, indem man alle in @code{<<} und @code{>>} einschließt.
1045
1046 @example
1047 <<c4 d4 e4>>
1048 @end example
1049
1050 @lilypond[quote,fragment,relative=1]
1051 \new Voice { <<c4 d4 e>> }
1052 @end lilypond
1053
1054 @noindent
1055 Um aufeinanderfolgende Noten darzustellen, werden sie in geschweifte Klammern gefasst:
1056
1057 @code{@{@tie{}@dots{}@tie{}@}}
1058
1059 @example
1060 @{ f4 <<c4 d4 e4>> @}
1061 @end example
1062
1063 @lilypond[quote,relative=1,fragment]
1064 { f4 <<c d e4>> }
1065 @end lilypond
1066
1067 @noindent
1068 Dieses Gebilde ist in sich wieder ein Ausdruck, und kann
1069 daher mit einem anderen Ausdruck kombiniert werden (hier mit einer Halben), wobei @code{<<}, @code{\\}, and @code{>>} eingesetzt wird:
1070
1071 @example
1072 << g2 \\ @{ f4 <<c4 d4 e4>> @} >>
1073 @end example
1074
1075 @lilypond[quote,fragment,relative=2]
1076 \new Voice { << g2 \\ { f4 <<c d e>> } >> }
1077 @end lilypond
1078
1079 Solche geschachtelten Strukturen können sehr gut in einer 
1080 kontextunabhängigen Grammatik beschrieben werden. Der Programmcode 
1081 für den Satz ist auch mit solch einer Grammatik erstellt. Die Syntax 
1082 von LilyPond ist also klar und ohne Zweideutigkeiten definiert.
1083
1084 Die Benutzerschnittstelle und die Syntax werden als erstes vom Benutzer 
1085 wahrgenommen. Teilweise sind sie eine Frage des Geschmackes und werden viel
1086 diskutiert. Auch wenn Geschmacksfragen ihre Berechtigung 
1087 haben, sind sie nicht sehr produktiv. Im großen Rahmen von LilyPond 
1088 spielt die Eingabe-Syntax nur eine geringe Rolle, denn eine logische 
1089 Syntax zu schreiben ist einfach, guten Formatierungscode aber sehr viel 
1090 schwieriger. Das kann auch die Zeilenzahl der Programmzeilen zeigen: 
1091 Analysieren und Darstellen nimmt nur etwa 10% des Codes ein:
1092
1093 Während wir die Strukturen von LilyPond entwickelten, machten wir einige Entscheidungen, die sich von anderen Programmen unterscheiden.
1094 Nehmen wir etwa die hierarchische Natur der Musiknotation:
1095
1096 @lilypond[quote,fragment]
1097 <<
1098   \new Staff \relative c'' {
1099     \key g \major
1100     \time 3/4
1101     d4 g,8 a b c d4 g, g
1102   }
1103   \new Staff \relative c' {
1104     \clef "bass"
1105     \key g \major
1106     <g b d>2 a4 b2.
1107   }
1108 >>
1109 @end lilypond
1110
1111 In diesem Fall werden Tonhöhen in Akkorde gruppiert, die zu Takten
1112 gehören, welche wiederum zu Notensystemen gehören.  Das erinnert an
1113 die saubere Struktur von geschachtelten Kästen:
1114
1115 @quotation
1116 @iftex
1117 @sourceimage{pdf/nestedboxes,,4cm,}
1118 @end iftex
1119 @ifnottex
1120 @sourceimage{nestedboxes,,,png}
1121 @end ifnottex
1122 @end quotation
1123
1124 Leider ist die Struktur nur sauber, weil sie auf einige sehr beschränkte
1125 Annahmen basiert.  Das wird offensichtlich, wenn man ein komplizierteres
1126 Beispiel heranzieht:
1127
1128 @lilypond[quote]
1129 \layout {
1130   \context {
1131     \Score
1132     \remove "Timing_translator"
1133     \remove "Default_bar_line_engraver"
1134   }
1135   \context {
1136     \Staff
1137     \consists "Timing_translator"
1138     \consists "Default_bar_line_engraver"
1139  }
1140 }
1141
1142 \new PianoStaff <<
1143   \new Staff = "RH" <<
1144     \new Voice = "I" \relative c''' {
1145       \time 3/4
1146       \voiceOne
1147       \times 6/7 { g8 g g g g g g }
1148       \oneVoice
1149       r4 <b,, fis' g bes> r4\fermata
1150     }
1151     \new Voice = "II" \relative c' {
1152       \voiceTwo
1153       c4
1154       \times 4/5 {
1155         <c ees>8 f g
1156         \change Staff = "LH" \oneVoice
1157         \stemUp g,( c}
1158       r4
1159       \override Stem #'cross-staff = ##t
1160       \override Stem #'length = #12
1161       <fis, b>) r\fermata
1162     }
1163   >>
1164   \new Staff = "LH" <<
1165     \new Voice = "III" \relative c' {
1166       \time 2/4
1167       \clef "bass"
1168       g4 \stopStaff s
1169       \startStaff s2*2
1170     }
1171   >>
1172 >>
1173 @end lilypond
1174
1175 In diesem Beispiel beginnen Systeme plötzlich und enden plötzlich,
1176 Stimmen springen zwischen den Systemen herum und die Systeme haben
1177 unterschiedliche Taktarten.  Viele Software-Pakte würden sehr damit
1178 zu kämpfen haben, dieses Beispiel darzustellen, weil sie nach dem
1179 Prinzip von geschachtelten Kästen aufgebaut sind.  In LilyPond dagegen
1180 haben wir versucht, die Struktur und das Eingabeformat so flexibel wie
1181 möglich zu gestalten.
1182
1183
1184 @node Welche Symbole?
1185 @unnumberedsubsec Welche Symbole?
1186 @translationof What symbols to engrave?
1187
1188 @cindex Notensatz
1189 @cindex Typographie
1190 @cindex Stempel
1191 @cindex Matrize
1192 @cindex Engraver
1193 @cindex Plugin
1194
1195 Während des Notensatzprozesses entscheidet sich, wo
1196 Symbole platziert werden.  Das kann aber nur gelingen, 
1197 wenn vorher entschieden wird, @emph{welche} Symbole
1198 gesetzt werden sollen, also welche Art von Notation benutzt
1199 werden soll.
1200
1201 Die heutige Notation ist ein System zur Musikaufzeichnung,
1202 das sich über die letzten 1000 Jahre entwickelt hat.  Die
1203 Form, die heute üblicherweise benutzt wird, stammt aus der frühen
1204 Renaissance.  Auch wenn sich die grundlegenden Formen (also
1205 die Notenköpfe, das Fünfliniensystem) nicht verändert haben,
1206 entwickeln sich die Details trotzdem immer noch weiter, um
1207 die Errungenschaften der Neuen Musik darstellen zu können.  Die
1208 Notation umfasst also 500 Jahre Musikgeschichte.  Ihre Anwendung
1209 reicht von monophonen Melodien bis zu ungeheuer komplexem Kontrapunkt 
1210 für großes Orchester.
1211
1212 Wie bekommen wir dieses vielköpfige Monster zu fassen und in die
1213 Fesseln eines Computerprogrammes zu legen?
1214 Unsere Lösung ist es, das Problem in kleine (programmierbare) Happen zu zerteilen, so dass jede Art
1215 von Symbol durch ein eigenes Modul, als Plugin bezeichnet,
1216 verarbeitet werden kann.  Jedes Plugin ist vollständig modular
1217 und unabhängig und kann unabhängig entwickelt und verbessert
1218 werden.  Derartige Plugins werden @code{engraver} genannt,
1219 analog zu den Notenstechern (engl. engraver), die musikalische
1220 Ideen in graphische Symbole übersetzen.
1221
1222 Im nächsten Beispiel wird gezeigt, wie mit dem Plugin für die Notenköpfe, 
1223 dem @code{Note_heads_engraver} (@qq{Notenkopfstecher}) der Satz begonnen wird.
1224
1225 @lilypond[quote,ragged-right]
1226 \include "engraver-example.ily"
1227
1228 \score {
1229   \topVoice
1230   \layout {
1231     \context {
1232       \Voice
1233       \remove "Stem_engraver"
1234       \remove "Phrasing_slur_engraver"
1235       \remove "Slur_engraver"
1236       \remove "Script_engraver"
1237       \remove "Beam_engraver"
1238       \remove "Auto_beam_engraver"
1239     }
1240     \context {
1241       \Staff
1242       \remove "Accidental_engraver"
1243       \remove "Key_engraver"
1244       \remove "Clef_engraver"
1245       \remove "Bar_engraver"
1246       \remove "Time_signature_engraver"
1247       \remove "Staff_symbol_engraver"
1248       \consists "Pitch_squash_engraver"
1249     }
1250   }
1251 }
1252 @end lilypond
1253
1254 @noindent
1255 Dann fügt ein @code{Staff_symbol_engraver} (@qq{Notensystemstecher}) 
1256 die Notenlinien hinzu.
1257
1258 @lilypond[quote,ragged-right]
1259 \include "engraver-example.ily"
1260
1261 \score {
1262   \topVoice
1263   \layout {
1264     \context {
1265       \Voice
1266       \remove "Stem_engraver"
1267       \remove "Phrasing_slur_engraver"
1268       \remove "Slur_engraver"
1269       \remove "Script_engraver"
1270       \remove "Beam_engraver"
1271       \remove "Auto_beam_engraver"
1272     }
1273     \context {
1274       \Staff
1275       \remove "Accidental_engraver"
1276       \remove "Key_engraver"
1277       \remove "Clef_engraver"
1278       \remove "Bar_engraver"
1279       \consists "Pitch_squash_engraver"
1280       \remove "Time_signature_engraver"
1281     }
1282   }
1283 }
1284 @end lilypond
1285
1286 @noindent
1287 Der @code{Clef_engraver} (@qq{Notenschlüsselstecher}) definiert 
1288 eine Referenzstelle für das System.
1289
1290 @lilypond[quote,ragged-right]
1291 \include "engraver-example.ily"
1292
1293 \score {
1294   \topVoice
1295   \layout {
1296     \context {
1297       \Voice
1298       \remove "Stem_engraver"
1299       \remove "Phrasing_slur_engraver"
1300       \remove "Slur_engraver"
1301       \remove "Script_engraver"
1302       \remove "Beam_engraver"
1303       \remove "Auto_beam_engraver"
1304     }
1305     \context {
1306       \Staff
1307       \remove "Accidental_engraver"
1308       \remove "Key_engraver"
1309       \remove "Bar_engraver"
1310       \remove "Time_signature_engraver"
1311     }
1312   }
1313 }
1314 @end lilypond
1315
1316 @noindent
1317 Der @code{Stem_engraver} (@qq{Halsstecher}) schließlich fügt
1318  Hälse hinzu.
1319
1320 @lilypond[quote,ragged-right]
1321 \include "engraver-example.ily"
1322
1323 \score {
1324   \topVoice
1325   \layout {
1326     \context {
1327       \Voice
1328       \remove "Phrasing_slur_engraver"
1329       \remove "Slur_engraver"
1330       \remove "Script_engraver"
1331       \remove "Beam_engraver"
1332       \remove "Auto_beam_engraver"
1333     }
1334     \context {
1335       \Staff
1336       \remove "Accidental_engraver"
1337       \remove "Key_engraver"
1338       \remove "Bar_engraver"
1339       \remove "Time_signature_engraver"
1340     }
1341   }
1342 }
1343 @end lilypond
1344
1345 @noindent
1346 Dem @code{Stem_engraver} wird jeder Notenkopf mitgeteilt, 
1347 der vorkommt. Jedes Mal, wenn ein Notenkopf erscheint (oder mehrere bei 
1348 einem Akkord), wird ein Hals-Objekt erstellt und an den 
1349 Kopf geheftet. Wenn wir dann noch Engraver für Balken, Bögen, 
1350 Akzente, Versetzungszeichen, Taktstriche, Taktangaben und Tonartbezeichnungen 
1351 hinzufügen, erhalten wir eine vollständige Notation.
1352
1353
1354 @lilypond[quote,ragged-right]
1355 \include "engraver-example.ily"
1356 \score { \topVoice }
1357 @end lilypond
1358
1359 @cindex Polyphonie
1360 @cindex Mehrstimmigkeit
1361 @cindex Notensatz, Mehrstimmigkeit
1362 @cindex Kontexte
1363
1364 Dieses System funktioniert gut für monophone Musik, aber wie geht 
1365 es mit Polyphonie? Hier müssen sich mehrere Stimmen ein System teilen.
1366
1367 @lilypond[quote,ragged-right]
1368 \include "engraver-example.ily"
1369 \new Staff << \topVoice \\ \botVoice >>
1370 @end lilypond
1371
1372 In diesem Fall benutzen beide Stimmen das System und die Vorzeichen gemeinsam,
1373 aber die Hälse, Bögen, Balken usw. sind jeder einzelnen Stimme
1374 eigen. Die Engraver müssen also gruppiert werden. Die Köpfe,
1375 Hälse, Bögen usw. werden in einer Gruppe mit dem Namen @qq{Voice
1376 context} (Stimmenkontext) zusammengefasst, die Engraver für den
1377 Schlüssel, die Vorzeichen, Taktstriche usw. dagegen in einer
1378 Gruppe mit dem Namen @qq{Staff context} (Systemkontext). Im Falle
1379 von Polyphonie hat ein Staff-Kontext dann also mehr als nur einen
1380 Voice-Kontext. Auf gleiche Weise können auch mehrere Staff-Kontexte
1381 in einen großen Score-Kontext (Partiturkontext) eingebunden werden.
1382 Der Score-Kontext ist auf der höchsten Ebene der Kontexte.
1383
1384
1385 @lilypond[quote,ragged-right]
1386 \include "engraver-example.ily"
1387 \score {
1388    <<
1389       \new Staff << \topVoice \\ \botVoice >>
1390       \new Staff << \pah \\ \hoom >>
1391    >>
1392 }
1393 @end lilypond
1394
1395 @seealso
1396 Referenz der Interna: @rinternals{Contexts}.
1397
1398
1399 @node Flexible Architektur
1400 @unnumberedsubsec Flexible Architektur
1401 @translationof Flexible architecture
1402
1403 Als wir anfingen, haben wir LilyPond vollständig in der Programmiersprache C++
1404 geschrieben. Das hieß, dass der Funktionsumfang des Programms vollständig durch
1405 die Programmierer festgelegt war. Das stellte sich aus einer Reihe von Gründen
1406 als unzureichend heraus:
1407
1408 @itemize @bullet
1409
1410 @item Wenn LilyPond Fehler macht, muss der Benutzer die
1411 Einstellungen ändern können. Er muss also Zugang zur 
1412 Formatierungsmaschinerie haben.  Deshalb können die Regeln und 
1413 Einstellungen nicht beim Kompilieren des Programms festgelegt 
1414 werden, sondern sie müssen zugänglich sein, während das Programm
1415 aktiv ist.
1416
1417 @item Notensatz ist eine Frage des Augenmaßes, und damit auch vom
1418 Geschmack abhängig.  Benutzer können mit unseren Entscheidungen 
1419 unzufrieden sein.  Darum müssen also auch die Definitionen des 
1420 typographischen Stils dem Benutzer zugänglich sein.
1421
1422 @item Schließlich verfeinern wir unseren Formatierungsalgorithmus 
1423 immer weiter, also müssen die Regeln auch flexibel sein. Die
1424 Sprache C++ zwingt zu einer bestimmten Gruppierungsmethode, 
1425 die nicht den Regeln für den Notensatz entspricht.
1426 @end itemize
1427
1428 @cindex Scheme-Programmiersprache
1429
1430 Diese Probleme wurden angegangen, indem ein Übersetzer für 
1431 die Programmiersprache Scheme integriert wurde und Teile
1432 von LilyPond in Scheme neu geschrieben wurden.  Die derzeitige 
1433 Formatierungsarchitektur ist um die Notation von graphischen 
1434 Objekten herum aufgebaut, die von Scheme-Variablen und -Funktionen
1435 beschrieben werden.  Diese Architektur umfasst Formatierungsregeln,
1436 typographische Stile und individuelle Formatierungsentscheidungen. 
1437 Der Benutzer hat direkten Zugang zu den meisten dieser Einstellungen.
1438
1439 Scheme-Variablen steuern Layout-Entscheidungen.  Zum Beispiel haben 
1440 viele graphische Objekte eine Richtungsvariable, die zwischen 
1441 oben und unten (oder rechts und links) wählen kann.  Hier etwa 
1442 sind zwei Akkorde mit Akzenten und Arpeggien.
1443 Beim ersten Akkord sind alle Objekte nach unten (oder links)
1444 ausgerichtet, beim zweiten nach oben (rechts).
1445
1446 @lilypond[quote,ragged-right]
1447 \new Score \with {
1448    \override SpacingSpanner #'spacing-increment = #3
1449    \override TimeSignature #'transparent = ##t
1450 } \relative c' {
1451    \stemDown <e g b>4_>-\arpeggio
1452    \override Arpeggio #'direction = #RIGHT
1453    \stemUp <e g b>4^>-\arpeggio
1454 }
1455 @end lilypond
1456
1457 @cindex Formatierung einer Partitur
1458 @cindex Partitur, Formatierung
1459 @cindex Formatierungsregeln
1460
1461 @noindent
1462 Der Prozess des Notensetzens besteht für das Programm darin,
1463 die Variablen der graphischen Objekte zu lesen und zu
1464 schreiben.  Einige Variablen haben festgelegte Werte. So
1465 ist etwa die Dicke von vielen Linien – ein Charakteristikum
1466 des typographischen Stils – von vornherein festgelegt.
1467 Wenn sie geändert werden, ergibt sich ein anderer typographischer Eindruck.
1468
1469 @lilypond[quote,ragged-right]
1470 fragment = {
1471    \clef bass f8 as8
1472    c'4-~ c'16 as g f e16 g bes c' des'4
1473 }
1474 <<
1475    \new Staff \fragment
1476    \new Staff \with {
1477       \override Beam #'beam-thickness = #0.3
1478       \override Stem #'thickness = #0.5
1479       \override Bar #'thickness = #3.6
1480       \override Tie #'thickness = #2.2
1481       \override StaffSymbol #'thickness = #3.0
1482       \override Tie #'extra-offset = #'(0 .  0.3)
1483       }
1484       \fragment
1485 >>
1486 @end lilypond
1487
1488 Formatierungsregeln sind auch vorbelegte Variablen.  Zu jedem Objekt gehören
1489 Variablen, die Prozeduren enthalten. Diese Prozeduren machen die eigentliche
1490 Satzarbeit aus, und wenn man sie durch andere ersetzt, kann die Darstellung
1491 von Objekten verändert werden.  Im nächsten Beispiel wird die Regel, nach der
1492 die Notenköpfe gezeichnet werden, während des Ausschnitts verändert.
1493
1494 @lilypond[quote,ragged-right]
1495 #(set-global-staff-size 30)
1496
1497 #(define (mc-squared grob orig current)
1498   (let* ((interfaces (ly:grob-interfaces grob))
1499          (pos (ly:grob-property grob 'staff-position)))
1500     (if (memq 'note-head-interface interfaces)
1501         (begin
1502           (ly:grob-set-property! grob 'stencil
1503             (grob-interpret-markup grob
1504               (make-lower-markup 0.5
1505                 (case pos
1506                   ((-5) "m")
1507                   ((-3) "c ")
1508                   ((-2) (make-smaller-markup (make-bold-markup "2")))
1509                   (else "bla")))))))))
1510
1511 \new Voice \relative c' {
1512   \stemUp
1513   \set autoBeaming = ##f
1514   \time 2/4
1515   <d f g>4
1516   \once \override NoteHead #'stencil = #note-head::brew-ez-stencil
1517   \once \override NoteHead #'font-size = #-7
1518   \once \override NoteHead #'font-family = #'sans
1519   \once \override NoteHead #'font-series = #'bold
1520   <d f g>4
1521   \once \override NoteHead #'style = #'cross
1522   <d f g>4
1523   \applyOutput #'Voice #mc-squared
1524   <d f g>4
1525   <<
1526     { d8[ es-( fis^^ g] fis2-) }
1527     \repeat unfold 5 { \applyOutput #'Voice #mc-squared s8 }
1528   >>
1529 }
1530 @end lilypond
1531
1532
1533 @node LilyPond die Arbeit überlassen
1534 @section LilyPond die Arbeit überlassen
1535 @translationof Putting LilyPond to work
1536
1537 @cindex einfaches Beispiel
1538 @cindex Beispiel, einfach
1539
1540 Wir haben LilyPond als einen Versuch geschrieben, wie man die Kunst des 
1541 Musiksatzes in ein Computerprogramm gießen kann. Dieses 
1542 Programm kann nun dank vieler harter Arbeitsstunden benutzt werden, 
1543 um sinnvolle Aufgaben zu erledigen. Die einfachste ist dabei der 
1544 Notendruck.
1545
1546 @lilypond[quote,relative=1]
1547 {
1548   \time 2/4
1549   c4 c g'4 g a4 a g2
1550 }
1551 @end lilypond
1552
1553 @noindent
1554 Indem wir Akkordsymbole und einen Text hinzufügen, erhalten wir 
1555 ein Liedblatt.
1556
1557 @lilypond[quote,ragged-right]
1558 <<
1559    \chords { c2 c f2 c }
1560    \new Staff
1561    \relative c' {
1562      \time 2/4
1563      c4 c g' g a a g2
1564    }
1565    \addlyrics { twin -- kle twin -- kle lit -- tle star }
1566 >>
1567 @end lilypond
1568
1569 Mehrstimmige Notation und Klaviermusik kann auch gesetzt werden. Das 
1570 nächste Beispiel zeigt einige etwas exotischere Konstruktionen:
1571
1572 @lilypond[quote,line-width=15.9\cm]
1573 \header {
1574   title = "Screech and boink"
1575   subtitle = "Random complex notation"
1576   composer = "Han-Wen Nienhuys"
1577 }
1578
1579 \score {
1580   \context PianoStaff <<
1581     \new Staff = "up" {
1582       \time 4/8
1583       \key c \minor
1584       << {
1585         \revert Stem #'direction
1586         \change Staff = down
1587         \set subdivideBeams = ##t
1588         g16.[
1589           \change Staff = up
1590           c'''32
1591           \change Staff = down
1592           g32
1593           \change Staff = up
1594           c'''32
1595           \change Staff = down
1596           g16]
1597         \change Staff = up
1598         \stemUp
1599         \set followVoice = ##t
1600         c'''32([ b''16 a''16 gis''16 g''32)]
1601       } \\ {
1602         s4 \times 2/3 { d'16[ f' g'] } as'32[ b''32 e'' d'']
1603       } \\ {
1604         s4 \autoBeamOff d''8.. f''32
1605       } \\ {
1606         s4 es''4
1607       } >>
1608     }
1609
1610     \new Staff = "down" {
1611       \clef bass
1612       \key c \minor
1613       \set subdivideBeams = ##f
1614       \override Stem  #'french-beaming = ##t
1615       \override Beam  #'beam-thickness = #0.3
1616       \override Stem  #'thickness = #4.0
1617       g'16[ b16 fis16 g16]
1618       << \makeClusters {
1619         as16 <as b>
1620         <g b>
1621         <g cis>
1622       } \\ {
1623         \override Staff.Arpeggio  #'arpeggio-direction =#down
1624         <cis, e, gis, b, cis>4\arpeggio
1625       }
1626     >> }
1627   >>
1628   \midi {
1629     \context {
1630       \Score
1631       tempoWholesPerMinute = #(ly:make-moment 60 8)
1632     }
1633   }
1634   \layout {
1635     \context {
1636       \Staff
1637       \consists Horizontal_bracket_engraver
1638     }
1639   }
1640 }
1641 @end lilypond
1642
1643 Die obenstehenden Beispiele wurde manuell erstellt, aber das ist nicht 
1644 die einzige Möglichkeit. Da der Satz fast vollständig automatisch abläuft, 
1645 kann er auch von anderen Programmen angesteuert werden, die Musik oder Noten
1646 verarbeiten. So können etwa ganze Datenbanken musikalischer Fragmente automatisch 
1647 in Notenbilder umgewandelt werden, die dann auf Internetseiten oder 
1648 in Multimediapräsentation Anwendung finden.
1649
1650 Dieser Aufsatz zeigt eine weitere Möglichkeit: Die Noten werden als 
1651 reiner Text eingegeben und können darum sehr einfach integriert werden
1652 in andere textbasierte Formate wie etwa @LaTeX{}, HTML oder, wie in diesem 
1653 Fall, Texinfo. Mithilfe des Programmes @command{lilypond-book},
1654 das in LilyPond inbegriffen ist, werden die Fragmente mit
1655 Notenbildern ersetzt und in die produzierte PDF- oder HTML-Datei
1656 eingefügt.  Ein weiteres Beispiel ist die von LilyPond unabhängige
1657 Erweiterung OOoLilyPond für OpenOffice.org, mit der es sehr einfach
1658 ist, Musikbeispiele in Dokumente einzufügen.
1659
1660 Zu mehr Beispielen, wie LilyPond sich in Aktion verhält, für vollständige
1661 Dokumentation und das Programm LilyPond besuchen Sie unsere
1662 Webseite: www.lilypond.org.
1663
1664
1665 @page
1666 @node Notensatzbeispiele (BWV 861)
1667 @section Notensatzbeispiele (BWV 861)
1668 @translationof Engraved examples (BWV 861)
1669
1670 Dieser Abschnitt enthält vier Referenz-Notenstiche und zwei
1671 computergesetzte Versionen der Fuge G-Moll aus dem Wohltemperierten
1672 Clavier I (BWV 681) von J. S. Bach (die letzten sieben Takte).
1673
1674 @noindent
1675 Bärenreiter BA5070 (Neue Ausgabe Sämtlicher Werke, Serie V, Band 6.1,
1676 1989):
1677
1678 @iftex
1679 @sourceimage{bwv861-baer,16cm,,}
1680 @end iftex
1681 @ifnottex
1682 @sourceimage{bwv861-baer-small,,,png}
1683 @end ifnottex
1684
1685 @noindent
1686 Bärenreiter BA5070 (Neue Ausgabe Sämtlicher Werke, Serie V, Band 6.1,
1687 1989), eine alternative musikalische Quelle.  Neben den
1688 musikalischen Unterschieden sind hier auch ein paar unterschiedliche
1689 Notensatzentscheidungen getroffen worden, sogar vom selben Herausgeber
1690 in der selben Edition:
1691
1692 @iftex
1693 @sourceimage{bwv861-baer-alt,16cm,,}
1694 @end iftex
1695 @ifnottex
1696 @sourceimage{bwv861-baer-alt-small,,,png}
1697 @end ifnottex
1698
1699 @noindent
1700 Breitkopf & Härtel, bearbeitet von Ferruccio Busoni (Wiesbaden, 1894),
1701 auch in der Petrucci Music Library (IMSLP #22081) erhältlich.
1702 Die editorischen Bezeichnungen (Fingersatz, Artikulation usw.)
1703 wurde entfernt, um bessere Vergleichbarkeit mit den anderen
1704 Editionen zu bieten:
1705
1706 @iftex
1707 @sourceimage{bwv861-breitkopf,16cm,,}
1708 @end iftex
1709 @ifnottex
1710 @sourceimage{bwv861-breitkopf-small,,,png}
1711 @end ifnottex
1712
1713 @noindent
1714 Bach-Gesellschaft Edition (Leipzig, 1866), erhältlich in der Petrucci
1715 Music Library (IMSPL #02221):
1716
1717 @iftex
1718 @sourceimage{bwv861-gessellschaft,16cm,,}
1719 @end iftex
1720 @ifnottex
1721 @sourceimage{bwv861-gessellschaft-small,,,png}
1722 @end ifnottex
1723
1724 @noindent
1725 Finale 2008:
1726
1727 @iftex
1728 @sourceimage{pdf/bwv861-finale2008a,,,}
1729 @end iftex
1730 @ifnottex
1731 @sourceimage{bwv861-finale2008a,,,png}
1732 @end ifnottex
1733
1734 @sp 4
1735 @noindent
1736 LilyPond, version @version{}:
1737
1738 @lilypond[staffsize=14.3,line-width=15.9\cm]
1739 global = {\key g \minor}
1740
1741 partI = \relative c' {
1742   \voiceOne
1743   fis8 d' ees g, fis4 g
1744   r8 a16 bes c8 bes16 a d8 r r4
1745   r2 r8 d16 ees f8 ees16 d
1746   ees4 ~ ees16 d c bes a4 r8 ees'16 d
1747   c8 d16 ees d8 e16 fis g8 fis16 g a4 ~
1748   a8 d, g f ees d c bes
1749   a2 g\fermata \bar "|."
1750 }
1751
1752 partII = \relative c' {
1753   \voiceTwo
1754   d4 r4 r8 d'16 c bes8 c16 d
1755   ees8 d c ees a, r r4
1756   r8 fis16 g a8 g16 fis g2 ~
1757   g2 r8 d' ees g,
1758   fis4 g r8 a16 bes c8 bes16 a
1759   bes4. <g b>8 <a c> r <d, g> r
1760   <ees g>4 <d fis> d2
1761 }
1762 partIII = \relative c' {
1763   \voiceOne
1764   r2 r8 d ees g, fis4 g r8 a16 bes c8 bes16 a
1765   bes2 ~ bes8 b16 a g8 a16 b
1766   c4 r r2
1767   R1
1768   r8 d ees g, fis4 g
1769   r8 a16 bes c8 bes16 a b2
1770 }
1771 partIV = \relative c {
1772   \voiceTwo
1773   d4 r r2
1774   r8 d ees g, fis4 a
1775   d,8 d'16 c bes8 c16 d ees2 ~
1776   ees8 ees16 d c8 d16 ees fis,8 a16 g fis8 g16 a
1777   d,8 d'16 c bes8 c16 d ees8 c a fis'
1778   g f ees d c bes a g
1779   c a d d, g2\fermata
1780 }
1781
1782 \score {
1783   <<
1784     % \set Score.barNumberVisibility = #all-bar-numbers-visible
1785     % required in 2.13
1786     \set Score.currentBarNumber = #28
1787     \bar ""
1788     \new PianoStaff <<
1789       \new Staff = "RH" <<
1790         \global
1791         \new Voice = "voiceI" { \partI }
1792         \new Voice = "voiceII" { \partII }
1793       >>
1794
1795       \new Staff = "LH" <<
1796         \clef "bass"
1797         \global
1798         \new Voice = "voiceIII" { \partIII }
1799         \new Voice = "voiceIV" { \partIV }
1800       >>
1801     >>
1802   >>
1803   \layout {
1804     \context {
1805       \Staff
1806       \remove "Time_signature_engraver"
1807     }
1808     \context {
1809       \PianoStaff
1810       \override StaffGrouper #'between-staff-spacing #'padding = #1
1811     }
1812   }
1813 }
1814 @end lilypond
1815