.PS # EVplugs.m4 # https://en.wikipedia.org/wiki/CHAdeMO # https://en.wikipedia.org/wiki/North_American_Charging_Standard # https://tesla-cdn.thron.com/static/HXVNIC_North_American_Charging_Standard_Technical_Specification_TS-0023666_HFTPKZ.pdf?xseo=&response-content-disposition=inline%3Bfilename%3D%22North-American-Charging-Standard-Technical-Specification-TS-0023666.pdf%22 gen_init divert(-1) `EV_J1772(keys) EV charging plug in a [] block keys: wdth=expr; # plug width diamLNP=expr; # diam of L1, N, PE twdth=expr; # tab width thgt=expr; # tab hght thick=expr; # outer line thickness (pt) thickin=expr; # inner line thickness (pt) BG=attributes; # shaded gray etc L1=attributes; # L1 attributes ... N=attributes; PE=attributes; PP=attributes; CP=attributes; ' define(`pEVskale',25.4) dnl default plug size (20 mm) define(`EV_J1772',`[ pushkeys_(`$1', `wdth:20/pEVskale; twdth:3.5/20*m4`'wdth; thgt:1.5/20*m4`'wdth; diamLNP:6/20*m4`'wdth; thick:2; thickin:1.5; BG::N; L1::N; N::N; PE::N; PP::N; CP::N; ') tang = atan2(m4twdth/2,m4wdth/2)*rtod_ TS: (Rect_(m4wdth/2,-90-tang)); TE: (Rect_(m4wdth/2,-90+tang)) Tab: line thick m4thick from TS down_ m4thgt \ then to TE-(0,m4thgt) then to TE m4BG Arc: arc thick m4thick to TS with .c at (0,0) m4BG round(at TS,last arc.thick); round(at TE,last arc.thick) L1: circle diam m4diamLNP thick m4thickin at (Rect_(m4wdth/4,150)) m4L1 N: circle diam m4diamLNP thick m4thickin at (Rect_(m4wdth/4, 30)) m4N PE: circle diam m4diamLNP thick m4thickin at (0,-m4wdth/4) m4PE PP: circle diam m4diamLNP*0.55 thick m4thickin at (Rect_(m4wdth/3,210)) m4PP CP: circle diam m4diamLNP*0.55 thick m4thickin at (Rect_(m4wdth/3,-30)) m4CP `$2' popdef(`m4CP',`m4PP',`m4PE',`m4N',`m4L1',`m4BG', `m4wdth',`m4diamLNP',`m4twdth',`m4thgt',`m4thick',`m4thickin') ]') `EV_J3068(keys,shade) EV charging plug in a [] block keys: wdth=expr; # plug width diamLNP=expr; # diam of L1, N, PE twdth=expr; # tab width thgt=expr; # tab hght thick=expr; # outer line thickness (pt) thickin=expr; # inner line thickness (pt) BG=attributes; # shaded gray etc L1|L2|L3=attributes; # pin attributes ... N=attributes; PE=attributes; PP=attributes; CP=attributes; arg2= R:G:B background fill color ' define(`EV_J3068',`[ pushkeys_(`$1', `wdth:25/pEVskale; diamLNP:m4`'wdth*0.25; thick:2; thickin:1.5; BG::N; L1::N; L2::N; L3::N; N::N; PE::N; PP::N; CP::N; ') C: Here NE: C+(Rect_(m4wdth/2,45)); NW: C+(Rect_(m4wdth/2,135)) Ac: NE-(1,1)/sqrt(2)*m4diamLNP/2 Arc: arc thick m4thick from NW to NE with .c at C m4BG ifelse(`$2',,, `shaded rgbstring(patsubst(`$2',:,`,')) line invis from NE to Ac+(0,m4diamLNP/2) \ then to NW+(1,-1)/sqrt(2)*m4diamLNP/2 + (0,m4diamLNP/2) \ then to NW then to NE shaded rgbstring(patsubst(`$2',:,`,'))') arc thick m4thick to Ac+(0,m4diamLNP/2) with .c at Ac m4BG Top: line thick m4thick to (NW+NE-Ac, Here) m4BG arc thick m4thick to NW with .c at Here+(0,-m4diamLNP/2) m4BG PE: circle diam m4diamLNP thick m4thickin at C m4PE PP: circle diam m4diamLNP*0.55 thick m4thickin at C+(Rect_(m4wdth/3,45)) m4PP CP: circle diam m4diamLNP*0.55 thick m4thickin at C+(Rect_(m4wdth/3,135)) m4CP L1: circle diam m4diamLNP thick m4thickin at C+(m4wdth*.3,0) m4L1 L2: circle diam m4diamLNP thick m4thickin at C+(Rect_(m4wdth*.3,-60)) m4L2 L3: circle diam m4diamLNP thick m4thickin at C+(Rect_(m4wdth*.3,-120)) m4L3 N: circle diam m4diamLNP thick m4thickin at C-(m4wdth*.3,0) m4N `$3' popdef(`m4wdth',`m4diamLNP',`m4thick',`m4thickin', `m4BG',`m4L1',`m4L2',`m4L3',`m4N',`m4PE',`m4PP',`m4CP') ]') `EV_CCS1(J1772 keys,DC keys) DC keys: wdth=expr; # DC socket width hght=expr; # DC socket height diamPM=expr; # diam of DC+, DC- circles sep=expr; # separation of Jack and DC thick=expr; # outer line thickness (pt) thickin=expr; # inner line thickness (pt) BG=attributes; # shaded gray etc DCplus=attributes; DCminus=attributes; ' define(`EV_CCS1',`[ J: EV_J1772(`$1') pushkeys_(`$2',`wdth:J.wid:23.5/20; hght:J.wid*11/20; diamPM:m4`'hght*7/11; sep:J.wid*3/30; thick:J.Arc.thick; thickin:J.PE.thick; BG::N; DCplus::N; DCminus::N;') DC: [ Box: box thick m4thick wid m4wdth ht m4hght rad m4hght/2 m4BG DCplus: circle thick m4thickin diam m4diamPM at Box.w+(m4hght/2,0) m4DCplus DCminus:circle thick m4thickin diam m4diamPM at Box.e-(m4hght/2,0) m4DCminus ] with .n at J.s+(0,-m4sep) popdef(`m4wdth',`m4hght',`m4diamPM',`m4sep',`m4thick',`m4thickin',`m4BG', `m4DCplus',`m4DCminus') ]') `EV_CCS2(J3068 keys,shade,DC keys) DC keys: wdth=expr; # DC socket width hght=expr; # DC socket height diamPM=expr; # diam of DC+, DC- circles sep=expr; # separation of Jack and DC thick=expr; # outer line thickness (pt) thickin=expr; # inner line thickness (pt) BG=attributes; # shaded gray etc DCplus=attributes; DCminus=attributes; arg2= R:G:B background fill color ' define(`EV_CCS2',`[ J: EV_J3068(`$1',`$2') pushkeys_(`$3',`wdth:J.wid:23.5/20; hght:J.wid*11/20; diamPM:m4`'hght*7/11; sep:J.wid*3/30; thick:J.Arc.thick; thickin:J.PE.thick; BG::N; DCplus::N; DCminus::N;') DC: [ Box: box thick m4thick wid m4wdth ht m4hght rad m4hght/2 dnl m4BG ifelse(`$2',,,`shaded rgbstring(patsubst(`$2',:,`,'))') DCplus: circle thick m4thickin diam m4diamPM at Box.w+(m4hght/2,0) m4DCplus DCminus:circle thick m4thickin diam m4diamPM at Box.e-(m4hght/2,0) m4DCminus ] with .n at J.s+(0,-m4sep) popdef(`m4wdth',`m4hght',`m4diamPM',`m4sep',`m4thick',`m4thickin',`m4BG', `m4DCplus',`m4DCminus') ]') `EV_CHAdeMO(keys,shade) EV charging plug in a [] block keys: wdth=expr; # plug width thick=expr; # outer line thickness (pt) thickin=expr; # inner line thickness (pt) BG=attributes; # background shaded gray etc DCplus=|DCminusNS=|FG=|NC=|SS1=|DCP=|PP=| CL=|CH=|SS2=attributes # pin attributes ...' define(`EV_CHAdeMO',`[ pushdef(`m4sk',33/140/pEVskale) pushkeys_(`$1', `wdth:140*m4sk; thick:m4`'wdth*9/140/(1bp__); thickin:m4`'thick*1.5/9; BG::N; DCplus::N; DCminus::N;N::N;S::N; FG::N; NC::N; SS1::N; DCP::N; PP::N; CL::N; CH::N; SS2::N') C: circle thick m4thick diam m4wdth-m4thick bp__ m4BG line thick m4thick*0.6 from C+(Rect_(C.rad+m4thick bp__*3/4,42)) \ to C+(Rect_(C.rad+m4thick bp__*3/4,50)) then left m4thick bp__ m4BG line thick m4thick*0.6 from C+(Rect_(C.rad+m4thick bp__*3/4,138)) \ to C+(Rect_(C.rad+m4thick bp__*3/4,130)) then right m4thick bp__ m4BG idiam = (m4wdth-m4thick bp__*2)*47/(27+47*2) N: circle diam idiam thick m4thickin with .n at C.n-(0,m4thick bp__/2) m4N S: circle diam idiam thick m4thickin with .s at C.s+(0,m4thick bp__/2) m4S E: circle diam idiam thick m4thickin at Cintersect(N,N.diam,S,S.diam) m4DCminus W: circle diam idiam thick m4thickin at Cintersect(S,S.diam,N,N.diam) m4DCplus foreach_(`Z', `line thick m4thickin up Z.diam*0.6 right Z.diam*0.6 with .c at Z line thick m4thickin up Z.diam*0.6 left Z.diam*0.6 with .c at Z',N,S) foreach_(`L',`L: circle diam idiam/4 thick linethick/2 \ at N+(Rect_(idiam/4,90*m4Lx)) m4xpand(m4`'L)',FG,NC,DCP,SS1) foreach_(`L',`L: circle diam idiam/4 thick linethick/2 \ at S+(Rect_(idiam/4,90*m4Lx)) m4xpand(m4`'L)',PP,CL,SS2,CH) `$3' popdef(`m4sk',`m4wdth',`m4thick',`m4thickin',`m4BG', `m4DCplus',`m4DCminus',`m4N',`m4S', `m4FG',`m4NC',`m4SS1',`m4DCP',`m4PP',`m4CL',`m4CH',`m4SS2') ]') `EV_NAC(keys) NAC (Tesla) charging plug in a [] block keys: wdth=expr; # plug width diamL=expr; # diam of L1, L2 BG=background attributes; # shaded "gray" L1=attributes; # L1 attributes ... L1inner=attributes; # inner circle... L2=attributes; # L2 attributes ... L2inner=attributes; # inner circle... inner=attributes; # central object Gnd=attributes; Gndinner=attributes; PP=attributes; CP=attributes; ' define(`EV_NAC',`[ pushkeys_(`$1', `wdth:1.6; diamL:m4`'wdth*0.28; BG::N; L1::N; L1inner::N; L2::N; L2inner::N; Gndinner::N; inner::N; Gnd::N; PP::N; CP::N; ') sN = 1/pEVskale*m4wdth/1.6 # drawing coord scale factor tt = 8.5/160*m4wdth; # outer width rt = (4^2+43^2)/(2*4)/4*sN; rb = (23^2+56.5^2)/(2*23)/4*sN # arc radii Ct: (0,0.83*m4wdth-rt); Cb: (0,rb) # arc centres ra = rb*0.45; ri = ra/4 # radii NAC_fillet(Ct,-rt,Cb,-rb,ra,NW,Wt,Wb) # draw outer boundary NE: (-NW.x,NW.y); Eb: (-Wb.x,Wb.y); Et: (-Wt.x,Wt.y) m = 9; n = 0; P[n]: (0,0) NAC_arc(m,Cb,rb,-pi_/2,langle(Cb,Eb)) NAC_arc(m,NE,ra,langle(NE,Eb),langle(NE,Et)) NAC_arc(m,Ct,rt,langle(Ct,Et),pi_/2) fitcurve(P,n,shaded "lightgray" m4BG,-n) pushdef(`m4EVs',`shaded graystring(1)')dnl # inner circles L1: circle diam m4diamL at ( 21.5/2,23.75)*sN m4EVs m4L1 inLt = L1.rad/4/(1bp__) L1i: circle thick inLt rad L1.rad-(inLt+L1.thick)/2 bp__ outlined "yellow" \ at L1 m4L1inner L2: circle diam m4diamL at (-21.5/2,23.75)*sN m4EVs m4L2 L2i: circle thick inLt rad L2.rad-(inLt+L2.thick)/2 bp__ outlined "yellow" \ at L2 m4L2inner Gnd: circle diam m4wdth/7 at (0,L1.y-15.92*sN) m4EVs m4Gnd Gndi: circle thick Gnd.rad/4/(1bp__) rad Gnd.rad-(Gnd.rad/4/(1bp__)+ \ Gnd.thick)/2 bp__ outlined "green" at Gnd m4Gndinner PP: circle diam Gnd.diam/2 at (-17/2*sN,L1.y-16.52*sN) m4EVs m4PP CP: circle diam Gnd.diam/2 at ( 17/2*sN,L1.y-16.52*sN) m4EVs m4CP rs = (15^2+50^2)/(2*15)/4*sN; Cs: (0,0.3*m4wdth-rs) # inner tri-shape m = 9; n = 0; P[0]: Ct+(0,rt-tt) NAC_fillet(L2,L2.rad+tt,Ct,-(rt-tt),ri,FW,Fb,Ft) NAC_fillet(Cb,-(rb-tt),L2,L2.rad+tt,ri,GW,Gt,Gb) NAC_fillet(Cs,rs,Cb,-(rb-tt),ri,SW,St,Sb) NAC_arc(3,Ct,rt-tt,pi_/2,langle(Ct,Ft)) NAC_arc(m,FW,ri,langle(FW,Ft),NAC_ang(FW,Fb)) NAC_arc(m,L2,L2.rad+tt,langle(L2,Fb),langle(L2,Gb)) NAC_arc(m,GW,ri,NAC_ang(GW,Gb),NAC_ang(GW,Gt)) NAC_arc(m,Cb,rb-tt,NAC_ang(Cb,Gt),NAC_ang(Cb,Sb)) NAC_arc(m,SW,ri,NAC_ang(SW,Sb),NAC_ang(SW,St)) NAC_arc(m,Cs,rs,langle(Cs,St),pi_/2) fitcurve(P,n,fill_(1) m4inner,-n) popdef(`m4EVs',`m4CP',`m4PP',`m4Gnd',`m4inner', `m4L2',`m4L2inner',`m4L1',`m4L1inner',`m4Gndinner', `m4BG',`m4diamL',`m4wdth') `$2' ]') define(`NAC_fillet', #( C1, r1, C2, r2, frad, Cf, T1, T2 ) ``$6': Cintersect(`$1',(abs(`$2')+sign(`$2')*(`$5')), `$3',(abs(`$4')+sign(`$4')*(`$5'))) `$7': LCintersect(,`$6',`$5',ifelse(index(`$2',-),0,R),`$1',`$6') `$8': LCintersect(,`$6',`$5',ifelse(index(`$4',-),0,R),`$3',`$6')') define(`NAC_arc', #( m, C, rad, a0, af ) `m4a0 = `$4'; m4af = `$5'; for i=1 to `$1' do { n+=1 P[n]: `$2'+(rect_(`$3',(1-i/`$1')*m4a0+i/`$1'*m4af)) P[-n]: (-P[n].x,P[n].y) }') define(`NAC_ang',`pmod(langle(`$1',`$2'),twopi_)') divert(0)dnl ifsvg(svg_font(sans-serif,6bp__)) iflatex(command "{\sf\scriptsize") define(`EVsmall',`ifsvg(svg_small(`$1'),{\tiny `$1'})') define(`EVtxt',`ifsvg(``$1'',`{patsubst(`$1',_,\\_)}')') define(`EVk',`ifsvg(+(0,0.75bp__))') [ P1: EV_J1772(BG=fill_(0.75); PE=fill_(1) "PE";L1=fill_(1) "L1";N=fill_(1) "N"; PP=fill_(1); CP=fill_(1);) "EVsmall(PP)" at P1.PP EVk "EVsmall(CP)" at P1.CP EVk P2: EV_J3068(PE=shaded "green" "PE";\ L1=shaded "yellow" "L1";L2=shaded "yellow" "L2";L3=shaded "yellow" "L3"; N=fill_(1) "N";", 0.85:0.85:0.85) at P1+(15bp__,0) \ with .w at P1.e+(P1.wid/5,0) "EVsmall(PP)" at P2.PP EVk "EVsmall(CP)" at P2.CP EVk P3: EV_CCS1(L1="L1";N="N";PE="PE", DCplus="DC+";DCminus="DC-") with .w at P2.e+(P1.wid/5,0) "EVsmall(PP)" at P3.J.PP EVk "EVsmall(CP)" at P3.J.CP EVk P4: EV_CCS2(L1="L1";L2="L2";L3="L3";N="N";PE="PE",0.85:0.85:0.85, DCplus="DC+";DCminus="DC-") with .w at P3.e+(P1.wid/5,0) "EVsmall(PP)" at P4.J.PP EVk "EVsmall(CP)" at P4.J.CP EVk P5: EV_CHAdeMO( BG=outlined "blue" fill_(0.8); DCplus=shaded "red" "DC+"; DCminus=shaded "red" "DC-"; foreach_(`L',`L=fill_(1);',N,S) FG=shaded "green"; foreach_(`L',`L=shaded "orange";',SS1,DCP,NC,PP,CH,SS2,CL)) \ with .w at P4.e+(P4.w.x-P3.e.x,0) foreach_(`L',`"EVsmall(L)" at P5.L EVk',FG,NC,DCP,SS1,PP,CL,CH,SS2) P6: EV_NAC(wdth=1) with .w at P5.e+(P5.wid/5,0) foreach_(`L',`"EVtxt(`L'm4Lx)" at P6.L',L1,L2) thinlines_ arrow <- from P6.Gnd.s down P6.ht/5; "EVtxt(Gnd)" below arrow <- from P6.PP.sw down P6.ht/8 left P6.ht/8; "EVtxt(`PP')" rjust arrow <- from P6.CP.se down P6.ht/8 right P6.ht/8; "EVtxt(`CP')" ljust thicklines_ "EVtxt(`EV_CCS2')" at P4.s+(0,-10bp__) "EVtxt(`EV_NAC')" at (P6,last "") "EVtxt(`EV_CHAdeMO')" at (P5,last "") "EVtxt(`EV_CCS1')" at (P3,last "") "EVtxt(`EV_J3068')" at (P2,last "") "EVtxt(`EV_J1772')" at (P1,last "") ] iflatex(command "}%") ifsvg(command "") .PE