divert(-1)
# tubedefs.m4
# macros for the Tubediags.m4 file

# Size parameters
define(`tubediam',`dimen_')
define(`tubethick',`2')     # thick line thickness
define(`tubepindiam',`tubediam*3/8')
define(`tubeplatelen',`tubediam/2')
define(`tubegridlen',`tubediam*7/12')
define(`tubecathlen',`tubeplatelen-tubethick bp__')
define(`tubedotthick',`1.2')
define(`tubedotdiam',`tubediam/6')
define(`tgap',`tubediam*3/20')

# Generic tubes
                           `triode(diam,R[N|S|E|W])
                             R=tubeplate at bottom
                             N,S,E,W=half circle'
define(`triode',`[ ifelse(`$1',,,`pushdef(`tubediam',`$1')')
 drawEnv(`$2')
 G1: tubegrid(right tubegridlen at Env)
 ifinstr(`$2',R,
  `K1: tubecathode(,`$2') with .s at G1+(0,tgap)
   P1: tubeplate(at G1+(0,-tgap))',
  `K1: tubecathode(,`$2') with .n at G1+(0,-tgap)
   P1: tubeplate(at G1+(0,tgap))')
 `$3' ifelse(`$1',,,`popdef(`tubediam')')] ')

                           `tetrode(diam,R[N|S|E|W])
                             R=tubeplate at bottom
                             N,S,E,W=half circle'
define(`tetrode',`[ ifelse(`$1',,,`pushdef(`tubediam',`$1')')
 drawEnv(`$2')
 ifinstr(`$2',R,
  `G1: tubegrid(right tubegridlen at Env+(0,tgap/2))
   G2: tubegrid(right tubegridlen at G1-(0,tgap))
   P1: tubeplate(at G2-(0,tgap))
   K1: tubecathode(,`$2') with .s at G1+(0,tgap)',
  `G1: tubegrid(right tubegridlen at Env-(0,tgap/2))
   G2: tubegrid(right tubegridlen at G1+(0,tgap))
   P1: tubeplate(at G2+(0,tgap))
   K1: tubecathode(,`$2') with .n at G1+(0,-tgap)')
 `$3' ifelse(`$1',,,`popdef(`tubediam')')] ')

                           `pentode(diam,R[N|S|E|W])
                             R=tubeplate at bottom
                             N,S,E,W=half circle'
define(`pentode',`[ ifelse(`$1',,,`pushdef(`tubediam',`$1')')
 drawEnv(`$2') pushdef(`tgap',`tubediam/8')
 ifinstr(`$2',R,
  `G2: tubegrid(right tubegridlen at Env-(0,tgap/4))
   G3: tubegrid(right tubegridlen at G2-(0,tgap))
   P1: tubeplate(at G3-(0,tgap))
   G1: tubegrid(right tubegridlen at G2+(0,tgap))
   K1: tubecathode(,`$2') with .s at G1+(0,tgap)',
  `G2: tubegrid(right tubegridlen at Env+(0,tgap/4))
   G3: tubegrid(right tubegridlen at G2+(0,tgap))
   P1: tubeplate(at G3+(0,tgap))
   G1: tubegrid(right tubegridlen at G2-(0,tgap))
   K1: tubecathode(,`$2') with .n at G1-(0,tgap)') popdef(`tgap')
 `$3' ifelse(`$1',,,`popdef(`tubediam')')] ')

# utilities
define(`drawEnv',
`thktmp = linethick; linethick_(tubethick)
 Env: circle invis diam tubediam
 ifinstr(`$1',N,
  `line from Env.w down tubediam*3/2/8
   line from Env.e down tubediam*3/2/8
   arc from Env.e to Env.w',
 `$1',S,
  `line from Env.w up tubediam*3/2/8
   line from Env.e up tubediam*3/2/8
   arc from Env.w to Env.e',
 `$1',E,
  `line from Env.n left tubediam*3/2/8
   line from Env.s left tubediam*3/2/8
   arc from Env.s to Env.n',
 `$1',W,
  `line from Env.n right tubediam*3/2/8
   line from Env.s right tubediam*3/2/8
   arc from Env.n to Env.s',
  `circle diam tubediam') with .c at Env
 linethick_(thktmp) ')

define(`tubedot',`dot(ifelse(`$1',,`at Here',`$1'),tubedotdiam/2,1,thick tubedotthick)')

define(`pin',`circle diam tubepindiam `$1'')

define(`Base_pins',`define(`pincount',`ifelse(`$2',,8,`$2')')dnl
 define(`pinpattern',`ifelse(`$1',,8,`$1')')dnl
 define(`pininit',`ifelse(`$3',,-90,`$3')')dnl
 for_(1,pincount,1,
  `pinang = pininit+360/(2*pinpattern)-m4x*360/pinpattern
   Pin`'m4x: pin(at \
     Base+(Rect_(Base.rad+tubepindiam/2+tubethick/2bp__,pinang)) \
     ifsvg("svg_small(m4x)","\small m4x"))
   {PinT`'m4x: Base+(Rect_(Base.rad+tubethick/2bp__,pinang))} ')
 ')

# structural elements
                           `tubeplate(attributes,length)'
define(`tubeplate',`line thick tubethick right ifelse(`$2',,tubeplatelen,`$2') `$1'')

define(`thinthick',0.4)dnl
define(`thinline',`line thick thinthick')dnl

define(`tubeTab',`[
 ang = ifelse(`$1',,90,`$1')
 ca = cosd(ang); sa = sind(ang)
 tabht = tubepindiam/2
 tabwd = tabht*5/6
 T0: Here
 T1: T0+(vrot_(0,tabwd/2,ca,sa))
 T2: T0+(vrot_(tabht,tabwd/2,ca,sa))
 T3: T0+(vrot_(tabht,-tabwd/2,ca,sa))
 T4: T0+(vrot_(0,-tabwd/2,ca,sa))
 line from T1 to T2 then to T3 then to T4 fill_(ifelse(`$2',,1,`$2'))
 ] with .T0 at Base+(Rect_(tubediam*3/2/2+tubethick/2bp__,ifelse(`$1',,90,`$1')))
')

define(`tubegrid',`dashline(ifelse(`$1',,`right tubegridlen',`$1'),
 thick tubethick,(tubegridlen*7/8/3),(tubegridlen/8/2))')

                           `tubecathode(length,R)'
define(`tubecathode',`[
 box invis wid ifelse(`$1',,tubecathlen,`$1') ht tubeplatelen/6
 ifinstr(`$2',R,
  `line thick tubethick from last box.nw to last box.sw \
     then to last box.se then to last box.ne',
  `line thick tubethick from last box.sw to last box.nw \
     then to last box.ne then to last box.se ')
 `$3'] ')

                           `tubefilament(length,R)'
define(`tubefilament',`[ define(`filalen',`ifelse(`$1',,`tubeplatelen/3',`$1')')dnl
 round(,tubethick) define(`filn',`ifinstr(`$2',R,-)')
 line thick tubethick up filn`'tubeplatelen/3 right tubeplatelen*2/9; round(,tubethick)
 line thick tubethick down filn`'tubeplatelen/3 right tubeplatelen*2/9
 round(,tubethick)
 `$3'] ')

# specific base examples, bottom view
define(`B_2AG',`[ ifelse(`$1',,,`pushdef(`tubediam',`$1')')
 Base: circle thick tubethick diam tubediam*3/2
 Base_pins(8,7)
 Dk1: tubedot(at Base+(0,-tubedotdiam*5/6))
 P1: tubeplate(at Base+(0,tubedotdiam/3))
 thinline from PinT1 to Dk1 chop 0 chop tubedotdiam/2
 thinline from P1 to Base.n
 tubeTab(90)
 `$2' ifelse(`$1',,,`popdef(`tubediam')') ]')

define(`B_2D',`[ ifelse(`$1',,,`pushdef(`tubediam',`$1')')
 Base: circle thick tubethick diam tubediam*3/2
 Base_pins(4,4)
 G1: tubegrid(right tubegridlen at Base)
 F1: tubefilament with .n at G1+(0,-tgap)
 P1: tubeplate(at G1+(0,tgap))
 thtmp = linethick; linethick = thinthick
 T1: tubeTab(105)
 T2: tubeTab(75)
 line from PinT1 to F1.sw
 line from PinT4 to F1.se
 line from G1.start left tubediam*3/2/8 then to T1.T0
 line from P1 up tubediam*3/2/8 then to T2.T0
 linethick = thtmp
 `$2' ifelse(`$1',,,`popdef(`tubediam')') ] ')

define(`B_4BB',`[ ifelse(`$1',,,`pushdef(`tubediam',`$1')')
 Base: circle thick tubethick diam tubediam*3/2
 Base_pins(8,8)
 K1: tubecathode with .n at Base-(0,tgap/2)
 F1: tubefilament with .n at K1.s
 G1: tubegrid(right tubegridlen at K1.n+(0,tgap))
 P1: tubeplate(at G1+(0,tgap))
 pushdef(`hoprad_',`dimen_/16') thtmp = linethick; linethick_(thinthick)
 T1: tubeTab(135)
 T2: tubeTab(-45)
 T3: tubeTab(-90,0)
 line from PinT2 to F1.sw
 L7: line from PinT7 to F1.se
 line up tgap from P1 then to T1.T0
 move to K1.se
 crossover(to (Here,PinT8),,L7)
 line right tgap from G1.end; corner
 crossover(to (Here,T2.T1),,L7); line to T2.T0
 popdef(`hoprad_') linethick_(thtmp)
 `$2' ifelse(`$1',,,`popdef(`tubediam')') ] ')

define(`B_9K',`[ ifelse(`$1',,,`pushdef(`tubediam',`$1')')
 Base: circle thick tubethick diam tubediam*3/2
 Base_pins(10,9,-90-360/20)
 G1: tubegrid(right tubegridlen at Base-(0,tgap/2))
 K1: tubecathode with .n at G1+(0,-tgap)
 F1: tubefilament with .n at K1.s
 G2: tubegrid(right tubegridlen at G1+(0,tgap))
 G3: tubegrid(right tubegridlen at G2+(0,tgap))
 P1: tubeplate(at G3+(0,tgap))
 pushdef(`hoprad_',`dimen_/16') thtmp = linethick; linethick_(thinthick)
 L3: line from G3.start to PinT3
 M6: move from G2.end to (PinT6,G2.end)
 line from M6.start to M6.end then to PinT6
 L7: line from K1.se right tubediam*3/2/5
 L71: line to PinT7
 line up tgap from P1 then left tubeplatelen/2
 { M1: move left tgap down tgap
   M21: move up tgap from PinT1 }
 line to Intersect_(M1,M21)
 crossover(to PinT1,R,L3)
 L8: line right tgap from G1.e
 crossover(to PinT8,,L71)
 line from F1.se to (K1.e+(tgap*3/4,0),F1)
 corner(thinthick)
 crossover(to P1.e+(tgap*3/4,tgap/2),R,L7,L8)
 line to PinT5
 line up tgap*3/2 from PinT9 then to PinT8
 line from F1.sw to (K1.w-(tgap*3/4,0),F1)
 crossover(up P1.y-tgap/2-Here.y,,L3)
 crossover(to PinT4,,M1)
 popdef(`hoprad_') linethick_(thtmp)
 `$2' ifelse(`$1',,,`popdef(`tubediam')') ] ')

# specific tubes
                           `V_6L6G(diam,R[N|S|E|W],G1|G2)
                             R=plate at bottom
                             N,S,E,W=half circle'
define(`V_6L6G',`[ ifelse(`$1',,,`pushdef(`tubediam',`$1')')
 drawEnv(`$2') pushdef(`tgap',`tubediam/8')
 ifinstr(`$2',R,
  `G2: tubegrid(right tubegridlen at Env-(0,tgap/4))
   G3: dashline(right tubegridlen at G2-(0,tgap),thick tubethick,
         (tubegridlen*3/10),(tubegridlen*4/10))
   P1: tubeplate(at G3-(0,tgap))
   G1: tubegrid(right tubegridlen at G2+(0,tgap))
   K1: tubecathode(,`$2') with .s at G1+(0,tgap)
   line from K1.nw down tgap/2 left tgap
   crossover(to (Here,G3),R,ifelse(`$3',,G1,`$3')); corner; line to G3.w ',
  `G2: tubegrid(right tubegridlen at Env+(0,tgap/4))
   G3: dashline(right tubegridlen at G2+(0,tgap),thick tubethick,
         (tubegridlen*3/10),(tubegridlen*4/10))
   P1: tubeplate(at G3+(0,tgap))
   G1: tubegrid(right tubegridlen at G2-(0,tgap))
   K1: tubecathode(,`$2') with .n at G1-(0,tgap)
   line from K1.sw up tgap/2 left tgap
   crossover(to (Here,G3),,ifelse(`$3',,G1,`$3')); corner; line to G3.w ')
   popdef(`tgap') `$4' ifelse(`$1',,,`popdef(`tubediam')')] ')

                           `5U4G rectifier(diam,R)'
define(`V_5U4G',`[ ifelse(`$1',,,`pushdef(`tubediam',`$1')')
 drawEnv(`$2')
 P1: line thick tubethick up tubediam/3 with .c at Env-(tubediam/6,0)
 P2: line thick tubethick up tubediam/3 with .c at Env+(tubediam/6,0)
 ifinstr(`$2',R,
  `F1: tubefilament(,R) with .n at Env.n-(0,tubediam/20) ',
  `F1: tubefilament with .s at Env.s+(0,tubediam/20) ')
 `$3'] ')

divert(0)dnl