| Klarinet Archive - Posting 000037.txt from 1994/02 From: Martin Brown <martinb@-----.AU>Subj: Re: Harness for clarinet?
 Date: Fri,  4 Feb 1994 16:07:03 -0500
 
 There is a guy here (Tom Sparkes who also makes oboes) who invented a
 clarinet support which I found excellent. I don't know if you can buy
 them but it would be pretty simple to make one up yourself.
 
 It consists of an extendable post about 15-20cm long with a rubber
 boot on one end to slot the thumb support into and a flat rectangular
 piece of sheet (about 10x2cm) on the other to rest against your
 stomach. The post has a hook on the top side about half way along to
 hook in a sax neck strap to hold the weight of the clarinet. Note that
 there is a mechanical advantage so the force on your neck is less than
 the weight of the clarinet (about half). You also don't have to exert
 force to keep the clarinet out at an angle to your body - the post
 does that for you. Since the strap hooks on about half way down the
 post, the strap is kept clear of your left hand thumb.
 
 The post extension is done by having one half of the post slide inside
 the other with a thumb screw to tighten down on the inside half.
 
 The flat rectangular end rests just below your wishbone. Your thumb
 goes under the rubber boot which is slotted over the usual thumb rest.
 
 The length of the post is variable so you can set the angle of the
 clarinet to whatever suits you.
 
 This is also excellent for young students as it keeps the clarinet at
 the proper angle and doesn't strain their thumbs or shoulders.
 
 If your interested, Tom Sparkes can be contacted on 61 2 487 1169,
 6 Clyde Pl., Wahroonga, NSW, Australia. I believe he patented so it
 wouldn't be a good idea to go into production.
 
 I had one of these for a few years until it broke and now I don't use
 one. Since I do all my playing sitting down, I usually rest my A
 clarinet on my knee while I'm playing it. Girls can rest the bell
 between both their knees - this is not a macho pose for boys so I only
 use one knee. :-) If you use this method, remember not to jog your leg
 in time with the beat or you'll end up with a bloody lip.
 
 If it's any help here is a PostScript thumbnail sketch of the setup:
 
 %!PS-Adobe-2.0 EPSF-1.2
 %%DocumentFonts:
 %%Pages: 1
 %%BoundingBox: 167 401 433 606
 %%EndComments
 
 50 dict begin
 
 /arrowHeight 8 def
 /arrowWidth 4 def
 /none null def
 /numGraphicParameters 17 def
 /stringLimit 65535 def
 
 /Begin {
 save
 numGraphicParameters dict begin
 } def
 
 /End {
 end
 restore
 } def
 
 /SetB {
 dup type /nulltype eq {
 pop
 false /brushRightArrow idef
 false /brushLeftArrow idef
 true /brushNone idef
 } {
 /brushDashOffset idef
 /brushDashArray idef
 0 ne /brushRightArrow idef
 0 ne /brushLeftArrow idef
 /brushWidth idef
 false /brushNone idef
 } ifelse
 } def
 
 /SetCFg {
 /fgblue idef
 /fggreen idef
 /fgred idef
 } def
 
 /SetCBg {
 /bgblue idef
 /bggreen idef
 /bgred idef
 } def
 
 /SetF {
 /printSize idef
 /printFont idef
 } def
 
 /SetP {
 dup type /nulltype eq {
 pop true /patternNone idef
 } {
 /patternGrayLevel idef
 patternGrayLevel -1 eq {
 /patternString idef
 } if
 false /patternNone idef
 } ifelse
 } def
 
 /BSpl {
 0 begin
 storexyn
 newpath
 n 1 gt {
 0 0 0 0 0 0 1 1 true subspline
 n 2 gt {
 0 0 0 0 1 1 2 2 false subspline
 1 1 n 3 sub {
 /i exch def
 i 1 sub dup i dup i 1 add dup i 2 add dup false subspline
 } for
 n 3 sub dup n 2 sub dup n 1 sub dup 2 copy false subspline
 } if
 n 2 sub dup n 1 sub dup 2 copy 2 copy false subspline
 patternNone not brushLeftArrow not brushRightArrow not and and { ifill } if
 brushNone not { istroke } if
 0 0 1 1 leftarrow
 n 2 sub dup n 1 sub dup rightarrow
 } if
 end
 } dup 0 4 dict put def
 
 /Circ {
 newpath
 0 360 arc
 patternNone not { ifill } if
 brushNone not { istroke } if
 } def
 
 /CBSpl {
 0 begin
 dup 2 gt {
 storexyn
 newpath
 n 1 sub dup 0 0 1 1 2 2 true subspline
 1 1 n 3 sub {
 /i exch def
 i 1 sub dup i dup i 1 add dup i 2 add dup false subspline
 } for
 n 3 sub dup n 2 sub dup n 1 sub dup 0 0 false subspline
 n 2 sub dup n 1 sub dup 0 0 1 1 false subspline
 patternNone not { ifill } if
 brushNone not { istroke } if
 } {
 Poly
 } ifelse
 end
 } dup 0 4 dict put def
 
 /Elli {
 0 begin
 newpath
 4 2 roll
 translate
 scale
 0 0 1 0 360 arc
 patternNone not { ifill } if
 brushNone not { istroke } if
 end
 } dup 0 1 dict put def
 
 /Line {
 0 begin
 2 storexyn
 newpath
 x 0 get y 0 get moveto
 x 1 get y 1 get lineto
 brushNone not { istroke } if
 0 0 1 1 leftarrow
 0 0 1 1 rightarrow
 end
 } dup 0 4 dict put def
 
 /MLine {
 0 begin
 storexyn
 newpath
 n 1 gt {
 x 0 get y 0 get moveto
 1 1 n 1 sub {
 /i exch def
 x i get y i get lineto
 } for
 patternNone not brushLeftArrow not brushRightArrow not and and { ifill } if
 brushNone not { istroke } if
 0 0 1 1 leftarrow
 n 2 sub dup n 1 sub dup rightarrow
 } if
 end
 } dup 0 4 dict put def
 
 /Poly {
 3 1 roll
 newpath
 moveto
 -1 add
 { lineto } repeat
 closepath
 patternNone not { ifill } if
 brushNone not { istroke } if
 } def
 
 /Rect {
 0 begin
 /t exch def
 /r exch def
 /b exch def
 /l exch def
 newpath
 l b moveto
 l t lineto
 r t lineto
 r b lineto
 closepath
 patternNone not { ifill } if
 brushNone not { istroke } if
 end
 } dup 0 4 dict put def
 
 /Text {
 ishow
 } def
 
 /idef {
 dup where { pop pop pop } { exch def } ifelse
 } def
 
 /ifill {
 0 begin
 gsave
 patternGrayLevel -1 ne {
 fgred bgred fgred sub patternGrayLevel mul add
 fggreen bggreen fggreen sub patternGrayLevel mul add
 fgblue bgblue fgblue sub patternGrayLevel mul add setrgbcolor
 eofill
 } {
 eoclip
 originalCTM setmatrix
 pathbbox /t exch def /r exch def /b exch def /l exch def
 /w r l sub ceiling cvi def
 /h t b sub ceiling cvi def
 /imageByteWidth w 8 div ceiling cvi def
 /imageHeight h def
 bgred bggreen bgblue setrgbcolor
 eofill
 fgred fggreen fgblue setrgbcolor
 w 0 gt h 0 gt and {
 l b translate w h scale
 w h true [w 0 0 h neg 0 h] { patternproc } imagemask
 } if
 } ifelse
 grestore
 end
 } dup 0 8 dict put def
 
 /istroke {
 gsave
 brushDashOffset -1 eq {
 [] 0 setdash
 1 setgray
 } {
 brushDashArray brushDashOffset setdash
 fgred fggreen fgblue setrgbcolor
 } ifelse
 brushWidth setlinewidth
 originalCTM setmatrix
 stroke
 grestore
 } def
 
 /ishow {
 0 begin
 gsave
 fgred fggreen fgblue setrgbcolor
 /fontDict printFont findfont printSize scalefont dup setfont def
 /descender fontDict begin 0 [FontBBox] 1 get FontMatrix end
 transform exch pop def
 /vertoffset 0 descender sub printSize sub printFont /Courier ne
 printFont /Courier-Bold ne and { 1 add } if def {
 0 vertoffset moveto show
 /vertoffset vertoffset printSize sub def
 } forall
 grestore
 end
 } dup 0 3 dict put def
 
 /patternproc {
 0 begin
 /patternByteLength patternString length def
 /patternHeight patternByteLength 8 mul sqrt cvi def
 /patternWidth patternHeight def
 /patternByteWidth patternWidth 8 idiv def
 /imageByteMaxLength imageByteWidth imageHeight mul
 stringLimit patternByteWidth sub min def
 /imageMaxHeight imageByteMaxLength imageByteWidth idiv patternHeight idiv
 patternHeight mul patternHeight max def
 /imageHeight imageHeight imageMaxHeight sub store
 /imageString imageByteWidth imageMaxHeight mul patternByteWidth add string def
 0 1 imageMaxHeight 1 sub {
 /y exch def
 /patternRow y patternByteWidth mul patternByteLength mod def
 /patternRowString patternString patternRow patternByteWidth getinterval def
 /imageRow y imageByteWidth mul def
 0 patternByteWidth imageByteWidth 1 sub {
 /x exch def
 imageString imageRow x add patternRowString putinterval
 } for
 } for
 imageString
 end
 } dup 0 12 dict put def
 
 /min {
 dup 3 2 roll dup 4 3 roll lt { exch } if pop
 } def
 
 /max {
 dup 3 2 roll dup 4 3 roll gt { exch } if pop
 } def
 
 /arrowhead {
 0 begin
 transform originalCTM itransform
 /taily exch def
 /tailx exch def
 transform originalCTM itransform
 /tipy exch def
 /tipx exch def
 /dy tipy taily sub def
 /dx tipx tailx sub def
 /angle dx 0 ne dy 0 ne or { dy dx atan } { 90 } ifelse def
 gsave
 originalCTM setmatrix
 tipx tipy translate
 angle rotate
 newpath
 0 0 moveto
 arrowHeight neg arrowWidth 2 div lineto
 arrowHeight neg arrowWidth 2 div neg lineto
 closepath
 patternNone not {
 originalCTM setmatrix
 /padtip arrowHeight 2 exp 0.25 arrowWidth 2 exp mul add sqrt brushWidth mul
 arrowWidth div def
 /padtail brushWidth 2 div def
 tipx tipy translate
 angle rotate
 padtip 0 translate
 arrowHeight padtip add padtail add arrowHeight div dup scale
 arrowheadpath
 ifill
 } if
 brushNone not {
 originalCTM setmatrix
 tipx tipy translate
 angle rotate
 arrowheadpath
 istroke
 } if
 grestore
 end
 } dup 0 9 dict put def
 
 /arrowheadpath {
 newpath
 0 0 moveto
 arrowHeight neg arrowWidth 2 div lineto
 arrowHeight neg arrowWidth 2 div neg lineto
 closepath
 } def
 
 /leftarrow {
 0 begin
 y exch get /taily exch def
 x exch get /tailx exch def
 y exch get /tipy exch def
 x exch get /tipx exch def
 brushLeftArrow { tipx tipy tailx taily arrowhead } if
 end
 } dup 0 4 dict put def
 
 /rightarrow {
 0 begin
 y exch get /tipy exch def
 x exch get /tipx exch def
 y exch get /taily exch def
 x exch get /tailx exch def
 brushRightArrow { tipx tipy tailx taily arrowhead } if
 end
 } dup 0 4 dict put def
 
 /midpoint {
 0 begin
 /y1 exch def
 /x1 exch def
 /y0 exch def
 /x0 exch def
 x0 x1 add 2 div
 y0 y1 add 2 div
 end
 } dup 0 4 dict put def
 
 /thirdpoint {
 0 begin
 /y1 exch def
 /x1 exch def
 /y0 exch def
 /x0 exch def
 x0 2 mul x1 add 3 div
 y0 2 mul y1 add 3 div
 end
 } dup 0 4 dict put def
 
 /subspline {
 0 begin
 /movetoNeeded exch def
 y exch get /y3 exch def
 x exch get /x3 exch def
 y exch get /y2 exch def
 x exch get /x2 exch def
 y exch get /y1 exch def
 x exch get /x1 exch def
 y exch get /y0 exch def
 x exch get /x0 exch def
 x1 y1 x2 y2 thirdpoint
 /p1y exch def
 /p1x exch def
 x2 y2 x1 y1 thirdpoint
 /p2y exch def
 /p2x exch def
 x1 y1 x0 y0 thirdpoint
 p1x p1y midpoint
 /p0y exch def
 /p0x exch def
 x2 y2 x3 y3 thirdpoint
 p2x p2y midpoint
 /p3y exch def
 /p3x exch def
 movetoNeeded { p0x p0y moveto } if
 p1x p1y p2x p2y p3x p3y curveto
 end
 } dup 0 17 dict put def
 
 /storexyn {
 /n exch def
 /y n array def
 /x n array def
 n 1 sub -1 0 {
 /i exch def
 y i 3 2 roll put
 x i 3 2 roll put
 } for
 } def
 
 %%EndProlog
 
 %I Idraw 7 Grid 8
 
 %%Page: 1 1
 
 Begin
 %I b u
 %I cfg u
 %I cbg u
 %I f u
 %I p u
 %I t
 [ 0.765957 0 0 0.765957 0 0 ] concat
 /originalCTM matrix currentmatrix def
 
 Begin %I Line
 %I b 65535
 1 0 0 [] 0 SetB
 %I cfg Black
 0 0 0 SetCFg
 %I cbg White
 1 1 1 SetCBg
 %I p
 0 SetP
 %I t
 [ 1 0 0 1 165 219 ] concat
 %I
 101 570 135 557 Line
 End
 
 Begin %I Line
 %I b 65535
 1 0 0 [] 0 SetB
 %I cfg Black
 0 0 0 SetCFg
 %I cbg White
 1 1 1 SetCBg
 %I p
 0 SetP
 %I t
 [ 1 0 0 1 165 219 ] concat
 %I
 135 558 376 339 Line
 End
 
 Begin %I Line
 %I b 65535
 1 0 0 [] 0 SetB
 %I cfg Black
 0 0 0 SetCFg
 %I cbg White
 1 1 1 SetCBg
 %I p
 0 SetP
 %I t
 [ 1 0 0 1 165 219 ] concat
 %I
 377 340 399 335 Line
 End
 
 Begin %I Line
 %I b 65535
 1 0 0 [] 0 SetB
 %I cfg Black
 0 0 0 SetCFg
 %I cbg White
 1 1 1 SetCBg
 %I p
 0 SetP
 %I t
 [ 1 0 0 1 165 219 ] concat
 %I
 399 336 367 307 Line
 End
 
 Begin %I Line
 %I b 65535
 1 0 0 [] 0 SetB
 %I cfg Black
 0 0 0 SetCFg
 %I cbg White
 1 1 1 SetCBg
 %I p
 0 SetP
 %I t
 [ 1 0 0 1 165 219 ] concat
 %I
 367 308 366 327 Line
 End
 
 Begin %I Line
 %I b 65535
 1 0 0 [] 0 SetB
 %I cfg Black
 0 0 0 SetCFg
 %I cbg White
 1 1 1 SetCBg
 %I p
 0 SetP
 %I t
 [ 1 0 0 1 165 219 ] concat
 %I
 366 329 99 572 Line
 End
 
 Begin %I Line
 %I b 65535
 1 0 0 [] 0 SetB
 %I cfg Black
 0 0 0 SetCFg
 %I cbg White
 1 1 1 SetCBg
 %I p
 0 SetP
 %I t
 [ 1 0 0 1 165 219 ] concat
 %I
 236 449 218 441 Line
 End
 
 Begin %I Line
 %I b 65535
 1 0 0 [] 0 SetB
 %I cfg Black
 0 0 0 SetCFg
 %I cbg White
 1 1 1 SetCBg
 %I p
 0 SetP
 %I t
 [ 1 0 0 1 165 219 ] concat
 %I
 218 441 225 435 Line
 End
 
 Begin %I Line
 %I b 65535
 1 0 0 [] 0 SetB
 %I cfg Black
 0 0 0 SetCFg
 %I cbg White
 1 1 1 SetCBg
 %I p
 0 SetP
 %I t
 [ 1 0 0 1 165 219 ] concat
 %I
 225 437 242 441 Line
 End
 
 Begin %I Line
 %I b 65535
 1 0 0 [] 0 SetB
 %I cfg Black
 0 0 0 SetCFg
 %I cbg White
 1 1 1 SetCBg
 %I p
 0 SetP
 %I t
 [ 1 0 0 1 165 219 ] concat
 %I
 221 439 132 406 Line
 End
 
 Begin %I Line
 %I b 65535
 1 0 0 [] 0 SetB
 %I cfg Black
 0 0 0 SetCFg
 %I cbg White
 1 1 1 SetCBg
 %I p
 0 SetP
 %I t
 [ 1 0 0 1 165 219 ] concat
 %I
 182 426 183 434 Line
 End
 
 Begin %I Line
 %I b 65535
 1 0 0 [] 0 SetB
 %I cfg Black
 0 0 0 SetCFg
 %I cbg White
 1 1 1 SetCBg
 %I p
 0 SetP
 %I t
 [ 1 0 0 1 165 219 ] concat
 %I
 183 434 191 429 Line
 End
 
 Begin %I Line
 %I b 65535
 1 0 0 [] 0 SetB
 %I cfg Black
 0 0 0 SetCFg
 %I cbg White
 1 1 1 SetCBg
 %I p
 0 SetP
 %I t
 [ 1 0 0 1 136 330 ] concat
 %I
 84 440 84 434 Line
 End
 
 Begin %I Line
 %I b 65535
 1 0 0 [] 0 SetB
 %I cfg Black
 0 0 0 SetCFg
 %I cbg White
 1 1 1 SetCBg
 %I p
 0 SetP
 %I t
 [ 1 0 0 1 136 330 ] concat
 %I
 84 434 124 424 Line
 End
 
 Begin %I Line
 %I b 65535
 1 0 0 [] 0 SetB
 %I cfg Black
 0 0 0 SetCFg
 %I cbg White
 1 1 1 SetCBg
 %I p
 0 SetP
 %I t
 [ 1 0 0 1 136 330 ] concat
 %I
 85 439 126 428 Line
 End
 
 Begin %I Line
 %I b 65535
 1 0 0 [] 0 SetB
 %I cfg Black
 0 0 0 SetCFg
 %I cbg White
 1 1 1 SetCBg
 %I p
 0 SetP
 %I t
 [ 1 0 0 1 136 330 ] concat
 %I
 126 428 126 424 Line
 End
 
 Begin %I Line
 %I b 65535
 1 0 0 [] 0 SetB
 %I cfg Black
 0 0 0 SetCFg
 %I cbg White
 1 1 1 SetCBg
 %I p
 0 SetP
 %I t
 [ 1 0 0 1 136 330 ] concat
 %I
 127 427 213 323 Line
 End
 
 Begin %I Line
 %I b 65535
 1 0 0 [] 0 SetB
 %I cfg Black
 0 0 0 SetCFg
 %I cbg White
 1 1 1 SetCBg
 %I p
 0 SetP
 %I t
 [ 1 0 0 1 136 330 ] concat
 %I
 158 305 161 289 Line
 End
 
 Begin %I Line
 %I b 65535
 1 0 0 [] 0 SetB
 %I cfg Black
 0 0 0 SetCFg
 %I cbg White
 1 1 1 SetCBg
 %I p
 0 SetP
 %I t
 [ 1 0 0 1 136 330 ] concat
 %I
 169 442 157 434 Line
 End
 
 End %I eop
 
 showpage
 
 %%Trailer
 
 end
 
 ^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~^~
 Martin Brown, Telectronics Pacing Systems
 Sydney, Australia
 Ph: (612) 413 6973    Email: martinb@-----.au
 
 
 |  |  |