]> git.donarmstrong.com Git - lilypond.git/blob - Documentation/notation/percussion.itely
Merge remote branch 'origin' into release/unstable
[lilypond.git] / Documentation / notation / percussion.itely
1 @c -*- coding: utf-8; mode: texinfo; -*-
2 @ignore
3     Translation of GIT committish: FILL-IN-HEAD-COMMITTISH
4
5     When revising a translation, copy the HEAD committish of the
6     version that you are working on.  For details, see the Contributors'
7     Guide, node Updating translation committishes..
8 @end ignore
9
10 @c \version "2.14.0"
11
12 @node Percussion
13 @section Percussion
14
15 @menu
16 * Common notation for percussion::
17 @end menu
18
19 @node Common notation for percussion
20 @subsection Common notation for percussion
21
22 Rhythmic music is primarily used for percussion and drum notation, but it can
23 also be used to show the rhythms of melodies.
24
25 @menu
26 * References for percussion::
27 * Basic percussion notation::
28 * Drum rolls::
29 * Pitched percussion::
30 * Percussion staves::
31 * Custom percussion staves::
32 * Ghost notes::
33 @end menu
34
35 @node References for percussion
36 @unnumberedsubsubsec References for percussion
37
38 @c TODO add more references.
39
40 @itemize
41
42 @item Some percussion may be notated on a rhythmic staff; this is
43 discussed in @ref{Showing melody rhythms}, and
44 @ref{Instantiating new staves}.
45
46 @item MIDI output is discussed in a separate section; please see
47 @ref{Percussion in MIDI}.
48
49 @end itemize
50
51
52 @seealso
53 Notation Reference:
54 @ref{Showing melody rhythms},
55 @ref{Instantiating new staves}.
56 @ref{Percussion in MIDI}.
57
58 Snippets:
59 @rlsr{Percussion}.
60
61
62 @node Basic percussion notation
63 @unnumberedsubsubsec Basic percussion notation
64
65 @cindex percussion
66 @cindex drums
67
68 Percussion notes may be entered in @code{\drummode} mode, which is
69 similar to the standard mode for entering notes.  The simplest way
70 to enter percussion notes is to use the @code{\drums} command,
71 which creates the correct context and entry mode for percussion:
72
73 @lilypond[quote,verbatim]
74 \drums {
75   hihat4 hh bassdrum bd
76 }
77 @end lilypond
78
79 This is shorthand for:
80
81 @lilypond[quote,verbatim]
82 \new DrumStaff {
83   \drummode {
84     hihat4 hh bassdrum bd
85   }
86 }
87 @end lilypond
88
89 Each piece of percussion has a full name and an abbreviated name,
90 and both can be used in input files.  The full list of percussion
91 note names may be found in @ref{Percussion notes}.
92
93 @cindex clef, percussion
94 @cindex percussion clef
95
96 Note that the normal notation of pitches (such as @code{cis4}) in a
97 @code{DrumStaff} context will cause an error message.  Percussion clefs
98 are added automatically to a @code{DrumStaff} context but they can also
99 be set explicitly.  Other clefs may be used as well.
100
101 @lilypond[quote,ragged-right,verbatim]
102 \drums {
103   \clef percussion
104   bd4 bd bd bd
105   \clef treble
106   hh4 hh hh hh
107 }
108 @end lilypond
109
110
111 There are a few issues concerning MIDI support for percussion
112 instruments; for details please see @ref{Percussion in MIDI}.
113
114
115 @seealso
116 Notation Reference:
117 @ref{Percussion in MIDI},
118 @ref{Percussion notes}.
119
120 File:
121 @file{ly/drumpitch-init.ly}
122
123 Snippets:
124 @rlsr{Percussion}.
125
126
127 @node Drum rolls
128 @unnumberedsubsubsec Drum rolls
129
130 Drum rolls are indicated with three slashes across the stem.  For
131 quarter notes or longer the three slashes are shown explicitly,
132 eighth notes are shown with two slashes (the beam being the
133 third), and drum rolls shorter than eighths have one stem slash to
134 supplement the beams.  This is achieved with the tremolo notation,
135 as described in @ref{Tremolo repeats}.
136
137 @lilypond[quote,verbatim]
138 \drums {
139   \time 2/4
140   sn16 sn8 sn16 sn8 sn8:32 ~
141   sn8 sn8 sn4:32 ~
142   sn4 sn8 sn16 sn16
143   sn4 r4
144 }
145 @end lilypond
146
147 Sticking can be indicated by placing placing markup for @code{"R"}
148 or @code{"L"} above or below notes, as discussed in
149 @ref{Direction and placement}.  The @code{staff-padding} property
150 may be overridden to achieve a pleasing baseline.
151
152 @lilypond[quote,verbatim]
153 \drums {
154   \repeat unfold 2 {
155     sn16^"L" sn^"R" sn^"L" sn^"L" sn^"R" sn^"L" sn^"R" sn^"R"
156     \stemUp
157     sn16_"L" sn_"R" sn_"L" sn_"L" sn_"R" sn_"L" sn_"R" sn_"R"
158   }
159 }
160 @end lilypond
161
162
163 @seealso
164
165 Notation Reference:
166 @ref{Tremolo repeats}.
167
168 Snippets:
169 @rlsr{Percussion}.
170
171
172 @node Pitched percussion
173 @unnumberedsubsubsec Pitched percussion
174
175 Certain pitched percussion instruments (e.g. xylophone,
176 vibraphone, and timpani) are written using normal staves.
177 This is covered in other sections of the manual.
178
179
180 @seealso
181 @c TODO: possibly link to an alternate section of NR 3.5, if
182 @c "percussion in MIDI" gets a separate subsubsection for
183 @c pitched percussion sounds.  -gp
184 Notation Reference:
185 @ref{Percussion in MIDI}.
186
187 Snippets:
188 @rlsr{Percussion}.
189
190
191 @node Percussion staves
192 @unnumberedsubsubsec Percussion staves
193
194 @cindex percussion
195 @cindex drums
196
197 A percussion part for more than one instrument typically uses a
198 multiline staff where each position in the staff refers to one
199 piece of percussion.  To typeset the music, the notes must be
200 interpreted in @code{DrumStaff} and @code{DrumVoice} context.
201
202 @lilypond[quote,verbatim]
203 up = \drummode {
204   crashcymbal4 hihat8 halfopenhihat hh hh hh openhihat
205 }
206 down = \drummode {
207   bassdrum4 snare8 bd r bd sn4
208 }
209 \new DrumStaff <<
210   \new DrumVoice { \voiceOne \up }
211   \new DrumVoice { \voiceTwo \down }
212 >>
213 @end lilypond
214
215 The above example shows verbose polyphonic notation.  The short
216 polyphonic notation, described in @rlearning{I'm hearing Voices},
217 can also be used.
218 For example,
219
220 @lilypond[quote,verbatim]
221 \new DrumStaff <<
222   \drummode {
223     bd4 sn4 bd4 sn4
224     << {
225       \repeat unfold 16 hh16
226     } \\ {
227       bd4 sn4 bd4 sn4
228     } >>
229   }
230 >>
231 @end lilypond
232
233 There are also other layout possibilities.  To use these, set the
234 property @code{drumStyleTable} in context @code{DrumVoice}.  The
235 following variables have been predefined:
236
237 @c TODO: decide what to do about this table.  (ie verbatim or not)
238 @table @code
239
240 @item drums-style
241 This is the default.  It typesets a typical drum kit on a
242 five-line staff:
243
244 @lilypond[quote,line-width=10.0\cm]
245 nam = \lyricmode {
246   cymc cyms cymr hh hhc hho hhho hhp
247   cb hc bd sn ss tomh tommh tomml toml tomfh tomfl }
248 mus = \drummode {
249   cymc cyms cymr hh hhc hho hhho hhp \break
250   cb hc bd sn ss tomh tommh tomml toml tomfh tomfl s16 }
251 \score {
252   << \new DrumStaff \with {
253        \remove Bar_engraver
254        \remove Time_signature_engraver
255        \override Stem #'transparent = ##t
256        \override Stem #'Y-extent = ##f
257      } \mus
258      \new Lyrics \nam
259   >>
260   \layout {
261     \context {
262       \Score
263       \override LyricText #'font-family = #'typewriter
264       \override BarNumber #'transparent =##T
265     }
266   }
267 }
268 @end lilypond
269
270 The drum scheme supports six different toms.  When there are fewer
271 toms, simply select the toms that produce the desired result.  For
272 example, to get toms on the three middle lines you use
273 @code{tommh}, @code{tomml}, and @code{tomfh}.
274
275 @item timbales-style
276 This typesets timbales on a two line staff:
277
278 @lilypond[quote,ragged-right]
279 nam = \lyricmode { timh ssh timl ssl cb }
280 mus = \drummode { timh ssh timl ssl cb s16 }
281
282 <<
283   \new DrumStaff \with {
284     \remove Bar_engraver
285     \remove Time_signature_engraver
286     \override Stem #'transparent = ##t
287     \override Stem #'Y-extent = ##f
288     \override StaffSymbol #'line-count = #2
289     \override StaffSymbol #'staff-space = #2
290     \override VerticalAxisGroup #'minimum-Y-extent = #'(-3.0 . 4.0)
291     drumStyleTable = #timbales-style
292   } \mus
293   \new Lyrics {
294     \override LyricText #'font-family = #'typewriter
295     \nam
296   }
297 >>
298 @end lilypond
299
300 @item congas-style
301 This typesets congas on a two line staff:
302
303 @lilypond[quote,ragged-right]
304 nam = \lyricmode { cgh cgho cghm ssh cgl cglo cglm ssl }
305 mus = \drummode { cgh cgho cghm ssh cgl cglo cglm ssl s16 }
306
307 <<
308   \new DrumStaff \with {
309     \remove Bar_engraver
310     \remove Time_signature_engraver
311     drumStyleTable = #congas-style
312     \override StaffSymbol #'line-count = #2
313
314     %% this sucks; it will lengthen stems.
315     \override StaffSymbol #'staff-space = #2
316     \override Stem #'transparent = ##t
317     \override Stem #'Y-extent = ##f
318   } \mus
319   \new Lyrics {
320     \override LyricText #'font-family = #'typewriter
321     \nam
322   }
323 >>
324 @end lilypond
325
326 @item bongos-style
327 This typesets bongos on a two line staff:
328
329 @lilypond[quote,ragged-right]
330 nam = \lyricmode { boh boho bohm ssh bol bolo bolm ssl }
331 mus = \drummode { boh boho bohm ssh bol bolo bolm ssl s16 }
332
333 <<
334   \new DrumStaff \with {
335     \remove Bar_engraver
336     \remove Time_signature_engraver
337     \override StaffSymbol #'line-count = #2
338     drumStyleTable = #bongos-style
339
340     %% this sucks; it will lengthen stems.
341     \override StaffSymbol #'staff-space = #2
342     \override Stem #'transparent = ##t
343     \override Stem #'Y-extent = ##f
344   } \mus
345   \new Lyrics {
346     \override LyricText #'font-family = #'typewriter
347     \nam
348   }
349 >>
350 @end lilypond
351
352 @item percussion-style
353 To typeset all kinds of simple percussion on one line staves:
354
355 @lilypond[quote,ragged-right]
356 nam = \lyricmode { tri trio trim gui guis guil cb cl tamb cab mar hc }
357 mus = \drummode { tri trio trim gui guis guil cb cl tamb cab mar hc s16 }
358
359 <<
360   \new DrumStaff \with{
361     \remove Bar_engraver
362     drumStyleTable = #percussion-style
363     \override StaffSymbol #'line-count = #1
364     \remove Time_signature_engraver
365     \override Stem #'transparent = ##t
366     \override Stem #'Y-extent = ##f
367   } \mus
368   \new Lyrics {
369     \override LyricText #'font-family = #'typewriter
370     \nam
371   }
372 >>
373 @end lilypond
374 @end table
375
376
377 @node Custom percussion staves
378 @unnumberedsubsubsec Custom percussion staves
379
380 If you do not like any of the predefined lists you can define your
381 own list at the top of your file.
382
383 @lilypond[quote,verbatim]
384 #(define mydrums '(
385          (bassdrum        default   #f           -1)
386          (snare           default   #f           0)
387          (hihat           cross     #f           1)
388          (halfopenhihat   cross     "halfopen"   1)
389          (pedalhihat      xcircle   "stopped"    2)
390          (lowtom          diamond   #f           3)))
391 up = \drummode { hh8 hh hhho hhho hhp4 hhp }
392 down = \drummode { bd4 sn bd toml8 toml }
393
394 \new DrumStaff <<
395   \set DrumStaff.drumStyleTable = #(alist->hash-table mydrums)
396   \new DrumVoice { \voiceOne \up }
397   \new DrumVoice { \voiceTwo \down }
398 >>
399 @end lilypond
400
401
402 @snippets
403
404 @c TODO: MOVE ALL THESE TO LSR!  -gp
405
406 Here are some examples:
407
408 Two Woodblocks, entered with wbh (high woodblock) and wbl (low woodblock)
409
410 @lilypond[quote,verbatim]
411 % These lines define the position of the woodblocks in the stave;
412 % if you like, you can change it or you can use special note heads
413 % for the woodblocks.
414 #(define mydrums '((hiwoodblock default #t  3)
415                    (lowoodblock default #t -2)))
416
417 woodstaff = {
418   % This defines a staff with only two lines.
419   % It also defines the positions of the two lines.
420   \override Staff.StaffSymbol #'line-positions = #'(-2 3)
421
422   % This is necessary; if not entered, the barline would be too short!
423   \override Staff.BarLine #'bar-extent = #'(-1.5 . 1.5)
424 }
425
426 \new DrumStaff {
427   \set DrumStaff.drumStyleTable = #(alist->hash-table mydrums)
428
429   % with this you load your new drum style table
430   \woodstaff
431
432   \drummode {
433     \time 2/4
434     wbl8 wbl16 wbl wbh8-> wbl |
435     wbl8 wbl16 wbh-> ~ wbh wbl16 r8 |
436   }
437 }
438 @end lilypond
439
440 Note that in this special case the length of the barline must
441 altered with @code{\override Staff.BarLine #'bar-extent #'(from . to)}.
442 Otherwise it would be too short.  And you have also to define the
443 positions of the two stafflines.  For more information about these
444 delicate things have a look at @ref{Staff symbol}.
445
446 A tambourine, entered with @q{tamb}:
447
448 @lilypond[quote,verbatim]
449 #(define mydrums '((tambourine default #t 0)))
450
451 tambustaff = {
452   \override Staff.StaffSymbol #'line-positions = #'( 0 )
453   \override Staff.BarLine #'bar-extent = #'(-1.5 . 1.5)
454   \set DrumStaff.instrumentName = #"Tambourine"
455 }
456
457 \new DrumStaff {
458   \tambustaff
459   \set DrumStaff.drumStyleTable = #(alist->hash-table mydrums)
460
461   \drummode {
462     \time 6/8
463     tamb8. tamb16 tamb8 tamb tamb tamb |
464     tamb4. tamb8 tamb tamb |
465     % the trick with the scaled duration and the shorter rest
466     % is neccessary for the correct ending of the trill-span!
467     tamb2.*5/6 \startTrillSpan s8 \stopTrillSpan |
468   }
469 }
470 @end lilypond
471
472 Music for Tam-Tam (entered with @q{tt}):
473
474 @lilypond[quote,verbatim]
475 #(define mydrums '((tamtam default #t 0)))
476
477 tamtamstaff = {
478   \override Staff.StaffSymbol #'line-positions = #'( 0 )
479   \override Staff.BarLine #'bar-extent = #'(-1.5 . 1.5)
480   \set DrumStaff.instrumentName = #"Tamtam"
481 }
482
483 \new DrumStaff {
484   \tamtamstaff
485   \set DrumStaff.drumStyleTable = #(alist->hash-table mydrums)
486
487   \drummode {
488     tt 1 \pp \laissezVibrer
489   }
490 }
491 @end lilypond
492
493 Two different bells, entered with @q{cb} (cowbell) and @q{rb} (ridebell)
494
495 @lilypond[quote,verbatim]
496 #(define mydrums '((ridebell default #t  3)
497                    (cowbell  default #t -2)))
498
499 bellstaff = {
500   \override DrumStaff.StaffSymbol #'line-positions = #'(-2 3)
501   \set DrumStaff.drumStyleTable = #(alist->hash-table mydrums)
502   \override Staff.BarLine #'bar-extent = #'(-1.5 . 1.5)
503   \set DrumStaff.instrumentName = #"Different Bells"
504 }
505
506 \new DrumStaff {
507   \bellstaff
508   \drummode {
509     \time 2/4
510     rb8 rb cb cb16 rb-> ~ |
511     rb16 rb8 rb16 cb8 cb |
512   }
513 }
514 @end lilypond
515
516 Here a short example taken from Stravinsky's @q{L'histoire du Soldat}.
517
518 @lilypond[quote,verbatim]
519 #(define mydrums '((bassdrum   default #t  4)
520                    (snare      default #t -4)
521                    (tambourine default #t  0)))
522
523 global = {
524   \time 3/8 s4.
525   \time 2/4 s2*2
526   \time 3/8 s4.
527   \time 2/4 s2
528 }
529
530 drumsA = {
531   \context DrumVoice <<
532     { \global }
533     { \drummode {
534         \autoBeamOff
535         \stemDown sn8 \stemUp tamb s8 |
536         sn4 \stemDown sn4 |
537         \stemUp tamb8 \stemDown sn8 \stemUp sn16 \stemDown sn \stemUp sn8 |
538         \stemDown sn8 \stemUp tamb s8 |
539         \stemUp sn4 s8 \stemUp tamb
540       }
541     }
542   >>
543 }
544
545 drumsB = {
546   \drummode {
547     s4 bd8 s2*2 s4 bd8 s4 bd8 s8
548   }
549 }
550
551 \layout {
552   indent = #40
553 }
554
555 \score {
556   \new StaffGroup <<
557     \new DrumStaff {
558       \set DrumStaff.instrumentName = \markup {
559         \column {
560           "Tambourine"
561           "et"
562           "caisse claire s. timbre"
563         }
564       }
565       \set DrumStaff.drumStyleTable = #(alist->hash-table mydrums)
566       \drumsA
567     }
568
569    \new DrumStaff {
570      \set DrumStaff.instrumentName = #"Grosse Caisse"
571      \set DrumStaff.drumStyleTable = #(alist->hash-table mydrums)
572      \drumsB }
573   >>
574 }
575 @end lilypond
576
577
578 @seealso
579 Snippets:
580 @rlsr{Percussion}.
581
582 Internals Reference:
583 @rinternals{DrumStaff},
584 @rinternals{DrumVoice}.
585
586
587 @c TODO: check name -gp
588 @node Ghost notes
589 @unnumberedsubsubsec Ghost notes
590
591 Ghost notes for drums and percussion may be created using the
592 @code{\parenthesize} command detailed in @ref{Parentheses}.
593 However, the default @code{\drummode} does not include the
594 @code{Parenthesis_engraver} plugin which allows this.
595
596 @lilypond[quote,ragged-right,verbatim]
597 \new DrumStaff \with {
598   \consists "Parenthesis_engraver"
599 }
600 <<
601   \context DrumVoice  = "1" { s1 }
602   \context DrumVoice  = "2" { s1 }
603   \drummode {
604     <<
605       {
606         hh8[ hh] <hh sn> hh16
607         < \parenthesize sn > hh
608         < \parenthesize sn > hh8 <hh sn> hh
609       } \\
610       {
611         bd4 r4 bd8 bd r8 bd
612       }
613     >>
614   }
615 >>
616 @end lilypond
617
618 @noindent
619 Also note that you must add chords (@code{< >} brackets)
620 around each @code{\parenthesize} statement.
621
622
623 @seealso
624 Snippets:
625 @rlsr{Percussion}.