% Special font for the TeX and METAFONT manuals
% This file was prepared "hastily" and hasn't been "polished".
% In particular, some characters won't work when aspect_ratio<>1.

font_size 10pt#;
em#:=10pt#; ht#:=250/36pt#;
mode_setup;

font_identifier "MANFNT";
font_coding_scheme "PI";

message "Hex symbols";
width1#=.4pt#*(ht#/(100/36pt#));
width2#=.6pt#*(ht#/(100/36pt#));
define_blacker_pixels(width1,width2);

beginchar(1,2ht#,ht#,0); "Original hex";  % \hexa
pickup pencircle scaled width1;
w:=2good.x .5w;
x1=x4=good.x 0; x2=x5=.5w; x3=x6=good.x w;
y1=y2=y3=good.y h; y4=y5=y6=good.y 0;
draw z1..z6; draw z2..z5; draw z3..z4;
for k=1 upto 6: drawdot z[k]; endfor
labels (1,2,3,4,5,6); endchar;

beginchar(2,2ht#,ht#,0); "Top/bot adjusted hex";  % \hexb
pickup pencircle scaled width1;
w:=2good.x .5w;
x1=x4=good.x 0; x2=x5=.5w; x3=x6=good.x w;
top y1=h; y1=y2=y3; bot y4=0; y4=y5=y6;
draw z1..z6; draw z2..z5; draw z3..z4;
for k=1 upto 6: drawdot z[k]; endfor
labels (1,2,3,4,5,6); endchar;

beginchar(3,2ht#,ht#,0); "Bold top/bot adjusted hex";  % \hexc
pickup pencircle scaled width2;
w:=2good.x .5w;
x1=x4=good.x 0; x2=x5=.5w; x3=x6=good.x w;
top y1=h; y1=y2=y3; bot y4=0; y4=y5=y6;
draw z1..z6; draw z2..z5; draw z3..z4;
for k=1 upto 6: drawdot z[k]; endfor
labels (1,2,3,4,5,6); endchar;

beginchar(4,2ht#,ht#,0); "Bold top/bot/lft/rt adjusted hex";  % \hexd
pickup pencircle scaled width2;
w:=2good.x .5w;
lft x1=0; x1=x4; x2=x5=.5w; rt x3=w-1; x3=x6;
top y1=h; y1=y2=y3; bot y4=0; y4=y5=y6;
draw z1..z6; draw z2..z5; draw z3..z4;
for k=1 upto 6: drawdot z[k]; endfor
labels (1,2,3,4,5,6); endchar;

beginchar(5,2ht#,ht#,0); "Hex corrected for darkness in the center"; % \hexe
pickup pencircle scaled width1;
w:=2good.x .5w;
top z1=(0,h); top z2=(.5w,h); top z3=(w,h);
bot z4=(0,0); bot z5=(.5w,0); bot z6=(w,0);
for k=1 upto 6: drawdot z[k]; endfor
z1'=.25[z1,z6]; z6'=.75[z1,z6]; theta1:=angle(z6-z1)+90;
z3'=.25[z3,z4]; z4'=.75[z3,z4]; theta3:=angle(z4-z3)+90;
z7=z8=.5[z1,z6];
penpos1'(width1,theta1); penpos6'(width1,theta1); penpos7(.6width1,theta1);
penpos3'(width1,theta3); penpos4'(width1,theta3); penpos8(.6width1,theta3);
draw z1..z1'; penstroke z1'e{z6'-z1'}..z7e..{z6'-z1'}z6'e; draw z6'..z6;
draw z2..z5;
draw z3..z3'; penstroke z3'e{z4'-z3'}..z8e..{z4'-z3'}z4'e; draw z4'..z4;
penlabels(1,1',7,2,3,3',8,4,4',5,6,6'); endchar;

message "Stick A's";
b#:=250/36pt#; a#:=150/36pt#; s#:=30/36pt#;
standardwidth#:=.4pt#;
darkwidth#:=.8pt#; lightwidth#:=.2pt#;
define_blacker_pixels(standardwidth,darkwidth,lightwidth);
define_pixels(b,a,s);
def stick_A(expr alpha)(text pentype)=
beginchar (incr(charcode),s#+a#+s#,b#,0);
pickup pentype;
bot z1=(good.x s,0); z5=z1+(a,0);
z3=(1/2[x1,x5],good.y b);
z2=alpha[z1,z3]; z4=alpha[z5,z3];
draw z1..z3; draw z3..z5; draw z2..z4;
drawdot z1; drawdot z5; drawdot z3;
labels(1,2,3,4,5); endchar; enddef;
charcode:=5; % the first A will be number 6

stick_A((3-sqrt5)/2, % (area above bar / area below) = golden ratio % \Aa
 pencircle scaled standardwidth);

for alpha=.2 step .05 until .5+10epsilon:
 stick_A(alpha,pencircle scaled standardwidth); endfor % chars 7..13

beginchar(14,s#+a#+s#,b#,0);
pickup pencircle scaled standardwidth;
bot z1=(good.x s,0); z5=z1+(a,0);
z3=(1/2[x1,x5],good.y b);
z4-z2=whatever*dir20; 1/2[y2,y4]=2/3[y3,y1];
z2=whatever[z1,z3]; z4=whatever[z3,z5];
draw z1..z3; draw z3..z5; draw z2..z4;
drawdot z1; drawdot z5; drawdot z3;
labels(1,2,3,4,5); endchar;

stick_A((3-sqrt5)/2,pencircle xscaled darkwidth yscaled lightwidth); % \Ab=15
stick_A((3-sqrt5)/2,
 pencircle xscaled darkwidth yscaled lightwidth rotated 30); % \Ac=16

message "Kidney beans";
standardwidth#:=.4pt#;
darkwidth#:=.8pt#; lightwidth#:=.2pt#;
define_blacker_pixels(standardwidth,darkwidth,lightwidth);
b#:=100/36pt#;
define_pixels(b);
def bean(text pentype)=
beginchar (incr(charcode),2b#,1.5b#,0);
pickup pentype;
z1=(0,b); z2=(b,b); z3=(2b,b);
z4=(0,0); z5=(b,0); z6=(2b,0);
draw z5..z4..z1..z3..z6..cycle;
labels(1,2,3,4,5,6); endchar; enddef;
charcode:=16; % the first bean will be number 17

bean(pencircle scaled standardwidth);  % \beana=17
bean(pencircle scaled darkwidth);  % \beanb=18
bean(pencircle xscaled darkwidth yscaled lightwidth); % \beanc=19
bean(pencircle xscaled darkwidth yscaled lightwidth rotated 30); % \beand=20

message "Pen nibs";
bigthickwidth#:=8pt#; littlethickwidth#:=2pt#;
define_blacker_pixels(bigthickwidth,littlethickwidth);

beginchar(21,bigthickwidth#,0,0);  % \niba
pickup pencircle xscaled bigthickwidth yscaled littlethickwidth;
lft z1=(0,good.y 0);
drawdot z1;
labels(1); endchar;

beginchar(22,bigthickwidth#,0,0);  % \nibb
pickup pencircle xscaled bigthickwidth yscaled littlethickwidth rotated 30;
lft z1=(0,good.y 0);
drawdot z1;
labels(1); endchar;

beginchar(23,littlethickwidth#,0,0);  % \nibc
pickup pencircle yscaled bigthickwidth xscaled littlethickwidth;
lft z1=(0,good.y 0);
drawdot z1;
labels(1); endchar;

message "Ionian letters";
em#:=10pt#; cap#:=7pt#;
thin#:=1/3pt#; thick#:=5/6pt#;
slab#:=.8pt#;
stem#:=.9pt#;
o#:=1/5pt#;

define_pixels(em,cap);
define_blacker_pixels(thin,thick,slab,stem);
define_corrected_pixels(o);

curve_sidebar=round 1/18em;

%vardef pentaper@#(expr lt,rt) = % dropped from PLAIN
% x@#l:=lt[x@#l,x@#]; x@#r:=rt[x@#r,x@#];
% y@#l:=lt[y@#l,y@#]; y@#r:=rt[y@#r,y@#] enddef;


% ill-fated example wasn't attractive enough by itself:
%bar:=slab;
%beginchar(24,0.6em#,cap#,0); % "The letter T"; \IOT=24
%penpos1(bar,70);
%penpos2(bar,35);
%penpos4(bar,35);
%penpos5(bar,55);
%x1=0; y1r=h; y2r=y4r=.2[y1r,y1]; y5l=.3[y1l,y1];
%x2l=1/3[x1l,x5l]; x4l=2/3[x1l,x5l]; x5=w;
%penpos6(stem,20); pentaper6(.1,0);
%penpos3(x6r-x6l,0);
%penpos7(stem,10);
%y3=y2; x3=.5w;
%x6r=x3r; y6=2/3h;
%x7=x6; y7=0;
%penstroke z1e{curl infinity}..z2e..z4e..{curl infinity}z5e;
%penstroke z3e..z6e{down}..z7e;
%labels.top(1r,2l,2,2r,4l,4,4r,6);
%labels.lft(1,1l,6l);
%labels.rt(5,5r,5l,6r);
%labels.bot(3l,3,3r,7,7r,7l);
%endchar;

beginchar(25,5/9em#,cap#,0); % "The letter S"; /IOS=25
penpos1(slab,70);
penpos2(.5slab,80);
penpos3(.5[slab,thick],200);
penpos5(.5[slab,thick],210);
penpos6(.7slab,80);
penpos7(.25[slab,thick],72);
x1=x5; y1r=.94h+o;
x2=x4=x6=.5w; y2r=h+o; y4=.54h; y6l=-o;
x3r=.04em; y3=.5[y4,y2];
x5l=w-.03em; y5=.5[y4,y6];
.5[x7l,x7]=.04em; y7l=.12h-o;
path trial; trial=z3{down}..z4..{down}z5;
pair dz; dz=direction 1 of trial;
penpos4(thick,angle dz-90);
penstroke z1e..z2e{left}..z3e{down}..z4e{dz}..z5e{down}..z6e{left}..z7e;
labels.lft(2,3r,5r,6,7);
labels.rt(1,3l,4,5l);
labels.top(1r,2r,3,4l,5,6r,7r);
labels.bot(1l,2l,4r,6l,7l);
endchar;

beginchar(26,0.8em#,cap#,0); % "The letter O"; \IOO=26
 penpos1(thick,10); penpos2(.1[thin,thick],90-10);
 penpos3(thick,180+10); penpos4(thin,270-10);
 x1l=w-x3l=curve_sidebar; x2=x4=.5w;
 y1=.49h; y2l=-o; y3=.51h; y4l=h+o;
 penstroke z1e{down}..z2e{right}..z3e{up}..z4e{left}..cycle;
 penlabels(1,2,3,4); endchar;

beginchar(27,.35em#,cap#,0); % "The letter I"; \IOI=27
 penpos1(stem,15); penpos2(.9stem,12); penpos3(stem,10);
 x1=x2=x3=.5w; y1=h; y2=.55h; y3=0; x2l:=1/6[x2l,x2];
 penstroke z1e..z2e{down}..z3e;
 penlabels(1,2,3); endchar;

%ligtable 24: 24 kern .05em#, 26 kern -.05em#; % TT and TO are adjusted

message "Cubes and such";
s#:=5pt#; define_pixels(s); % side of the square
beginchar(28,5/3s#,4/3s#,0); % "Possible cube"; \cubea=28
z1=(-epsilon,-epsilon);  z2=(s+epsilon,-epsilon);
  z3=(-epsilon,s+epsilon); z4=(s+epsilon,s+epsilon);
for k=1 upto 4: z[k+4]=z[k]+(2/3s,1/3s); endfor
pickup pencircle scaled .4pt;
draw z5--z6--z8--z7--cycle;
pickup pencircle scaled 1.6pt;
erase draw z2--z4--z3;
pickup pencircle scaled .4pt;
draw z1--z2--z4--z3--cycle;
for k=1 upto 4:  draw z[k]--z[k+4]; endfor
labels.top(1,2,5,6);
labels.bot(3,4,7,8);
endchar;

beginchar(29,5/3s#,4/3s#,0); % "Impossible cube"; \cubeb=29
z1=(-epsilon,-epsilon);  z2=(s+epsilon,-epsilon);
  z3=(-epsilon,s+epsilon); z4=(s+epsilon,s+epsilon);
for k=1 upto 4: z[k+4]=z[k]+(2/3s,1/3s); endfor
pickup pencircle scaled .4pt;
draw z3--z4; draw z5--z6;
cullit; pickup pencircle scaled 1.6pt;
undraw z7--1/2[z7,z5];
 undraw z2--1/2[z2,z4];
cullit; pickup pencircle scaled .4pt;
draw z3--z1--z2--z4;
 draw z5--z7--z8--z6;
for k=1 upto 4:  draw z[k]--z[k+4]; endfor
labels.top(1,2,5,6);
labels.bot(3,4,7,8);
endchar;

beginchar(30,10pt#,7pt#,2pt#); % bicentennial star
pair center; center=(.5w,2pt);
numeric radius; radius=5pt;
for k=0 upto 4: z[k]=center+(radius,0) rotated(90+360/5k); endfor
def :: = ..tension 5.. enddef;
path star; star=z0::z2::z4::z1::z3::cycle;
pickup pencircle scaled .4pt; draw star;
cullit;  pickup pencircle scaled 1.6pt;
for k=0 upto 4: undraw subpath(k+.55,k+.7) of star; endfor
cullit;  pickup pencircle scaled .4pt;
for k=0 upto 4: draw subpath(k+.47,k+.8) of star; endfor
labels(0,1,2,3,4); endchar;

beginchar(31,2/3*11pt#,.5*11pt#,0); % \oneu=31
pickup pencircle scaled 3/4pt yscaled 1/3 rotated 30;
save ww; ww=3/2w;
save t; transform t;
t=identity rotatedaround((.5ww,h),-90);
x2=.35ww; x3=good.x .6ww;
y2=good.y .2h; top y3=round .8h+eps;
save p; path p; p=z2{right}...{up}z3;
top z1=point .5 of p transformed t;
draw (z1...p);
labels(1,2,3); endchar;

beginchar(38,11pt#,11pt#,0); % \fouru=38
pickup pencircle scaled 3/4pt yscaled 1/3 rotated 30;
save t; transform t;
t=identity rotatedaround((.5w,.5h),-90);
x2=.35w; x3=good.x .6w;
y2=good.y .1h; top y3=round .4h+eps;
save p; path p; p=z2{right}...{up}z3;
top z1=point .5 of p transformed t;
draw (z1...p);
addto currentpicture also currentpicture transformed t;
addto currentpicture also currentpicture transformed(t transformed t);
labels.bot(1,3); labels.rt(2); endchar;

beginchar(39,11pt#,11pt#,0); % \fourc=39
pickup pencircle scaled 3/4pt yscaled 1/3 rotated 30;
save t; transform t;
t=identity rotatedaround((.5w,.5h),-90);
x2=.35w; x3=good.x .6w;
y2=good.y .1h; top y3=round .4h+eps;
save p; path p; p=z2{right}...{up}z3;
top z1=point .5 of p transformed t;
draw (z1...p) rotatedaround((.5w,.5h),-45)
 withpen pencircle scaled 3/4pt yscaled 1/3 rotated-15;
addto currentpicture also currentpicture transformed t;
addto currentpicture also currentpicture transformed(t transformed t);
labels.bot(1,3); labels.rt(2); endchar;

message "Circle variations";

beginchar(32,5pt#,5pt#,0); "Quarter circle";  % \circa
pickup pencircle scaled (.4pt+blacker);
draw quartercircle scaled 10pt; endchar;

beginchar(33,5pt#,5pt#,0); "Filled quarter circle";  % \circb
fill ((0,0)--quartercircle--cycle) scaled 10pt; endchar;

beginchar(34,5pt#,5pt#,0); "Rotated quarter circle";  % \circc
pickup pencircle scaled (.4pt+blacker);
draw quartercircle rotated 90 scaled 10pt shifted (5pt,0); endchar;

beginchar(35,5pt#*sqrt2,5pt#,0); "Cone";  % \circd
pickup pencircle scaled (.4pt+blacker);
draw ((0,0)--quartercircle--cycle)
 rotated 45 scaled 10pt shifted (.5w,0); endchar;

beginchar(36,10pt#,7.5pt#,2.5pt#); "Concentric circles";  % \circe
pickup pencircle scaled (.4pt+blacker);
for D=.2w,.6w,w:
 draw fullcircle scaled D shifted (.5w,.5[-d,h]);
 endfor endchar;

beginchar(37,10pt#,7.5pt#,2.5pt#); "Concentric diamonds";  % \circf
pickup pencircle scaled (.4pt+blacker);
for D=.2w,.6w,w:
 draw unitsquare shifted -(.5,.5) rotated 45
  scaled (D/sqrt2) shifted (.5w,.5[-d,h]);
 endfor endchar;

message "Miscellaneous symbols"; % mostly from the old manfnt

beginchar(oct"171",15pt#,7.5pt#,2.5pt#); % arrow for errata lists
curve#:=30/36pt#; dcurve#:=60/36pt#; bar#:=25/36pt#;
define_whole_blacker_pixels(curve,dcurve,bar);
penpos1(curve,90); penpos2(curve,90); penpos3(dcurve,90);
penpos4(dcurve,90); penpos5(curve,90); penpos6(curve,90);
y1r=vround(y1r-(y1-.5[-d,h])); y2=y5=y6=y1=y0; y4l=-d; y3r=h;
x1=0; x2=.1w; x3=.2w; x4=.55w; x5=.65w;
x2l:=x2l+.25curve; x5r:=x5r-.25curve;
penstroke z1e--z2e--z3e--z4e--z5e;    % crooked arrow
penpos13(bar,0); penpos14(bar,0); x0=w;
y13-y0=y0-y14=.24h+eps; x13=x14=7/8w-eps;
penpos15(.5bar,angle(z14-z0)); z15l=z0; penpos16(.5bar,angle(z13-z0)); z16l=z0;
z19=.381966[.5[z13,z14],z0];
numeric t; path p; p=z14l{z19-z14}..z16r;
t=xpart(p intersectiontimes((0,y6l)--(w,y6l))); x6=xpart point t of p;
filldraw z0..{z14-z19}z14r--subpath (0,t) of\\(z14l{z19-z14}..z16r)
 --z6l--z5l--z5r--z6r--subpath (t,0) of\\(z13l{z19-z13}..z15r)
 --z13r{z19-z13}..z0 & cycle;  % arrowhead and link
penlabels(range 1 thru 19); endchar;

beginchar(oct"170", 5pt#, 6.25pt#, 0); "Triangle for exercises";
x1=x2=w-x3=round .43pt; y3=.5+floor.5h;
z1-z2=(z3-z2) rotated 60;
y1:=.5sqrt3+round(y1-.5sqrt3); y2:=h-y1;
fill z1--z2--z3--cycle;
labels(1,2,3); endchar;

beginchar("6",256/36pt#,250/36pt#,0); % upper triangle for Addison-Wesley logo
x1=round 5/36pt; x2=round .5w; x2-x1=x3-x2=(y2-y1)/(sqrt 3);
y1=y3=0; fill z1--z2--z3--cycle; labels(1,2,3); endchar;

beginchar("7",256/36pt#,250/36pt#,0); % lower triangle for Addison-Wesley logo
x1=round 5/36pt; x2=round .5w; x2-x1=x3-x2=(y1-y2)/(sqrt 3);
y1=y3; y2=0; fill z1--z2--z3--cycle; labels(1,2,3); endchar;

def font_setup=
define_pixels(u,tiny,axis,hheight,border);
define_blacker_pixels(hair,thin,thick,rulethickness);
pickup if tiny<.5: nullpen else: pencircle scaled tiny fi;
tinypen:=savepen;
currenttransform:=identity yscaled aspect_ratio slanted slant;
enddef;

% typical cmr10 parameters
u#:=20/36pt#;
tiny#:=0;
axis#:=90/36pt#;
hheight#:=250/36pt#;
border#:=20/36pt#;
hair#:=8/36pt#;
thin#:=9/36pt#;
thick#:=25/36pt#;
fixwidth:=0;
slant:=0;
rulethickness#:=.4pt#;

baselinedistance#:=11pt#;
heavyline#:=50/36pt#;
font_setup;
define_whole_pixels(baselinedistance);
define_blacker_pixels(heavyline);

beginchar(127,25u#,hheight#+border#,0); "Dangerous bend sign";
pickup pencircle scaled rulethickness;
top y1=25/27h; lft x4=0;
x1+x1=x1a+x1b=x4b+x2a=x4+x2=x4a+x2b=x3b+x3a=x3+x3=w;
x4a=x4b=x4+u; x3b=x1a=x1-2u;
y4+y4=y4a+y4b=y3b+y1a=y3+y1=y3a+y1b=y2b+y2a=y2+y2=0;
y1a=y1b=y1-2/27h; y4b=y2a=y4+4/27h;
draw z1a..z1..z1b---z2a..z2..z2b---
  z3a..z3..z3b---z4a..z4..z4b---cycle;  % signboard
x10=x11=x12=x13=good.x(.5w-u); x14=x15=x16=x17=w-x10;
y10=y14=28/27h+epsilon; bot y13=-baselinedistance;
z11=(z10..z13) intersectionpoint (z1a{z1a-z4b}..z1{right});
y15=y11; y16=y12=-y11; y17=y20=y21=y13;
draw z11--z10--z14--z15; draw z12--z13; draw z16--z17;  % signpost
x20=w-x21; x21-x20=16u; draw z20--z21;  % ground level
x38=w-x31; x38-x31=8u; x32=x34=x38; x31=x35=x37;
y31=-y38=12/27h; y32=-y37=9/27h; y34=-y35=3/27h;
pickup pencircle scaled heavyline;
draw z32{z32-z31}..z34---z35..z37{z38-z37};  % the dangerous bend
pickup penrazor xscaled heavyline rotated (angle(z32-z31)+90);
draw z31--z32; draw z37--z38;    % upper and lower bars
labels(1,1a,1b,2,2a,2b,3,3a,3b,4,4a,4b,10,11,12,13,14,15,16,17,20,21,
  31,32,33,34,35,36,37,38);
picture dbend; dbend=currentpicture;
endchar;
beginchar(126,25u#,hheight#+border#,0); "Lefthanded ditto";
currentpicture:=dbend reflectedabout((.5w,0),(.5w,h));
endchar;
beginchar(0,25u#,hheight#+border#,0); "Reverse video ditto";
fill (0,-11pt)--(w,-11pt)--(w,h)--(0,h)--cycle;
addto currentpicture also -dbend;
endchar;

beginchar(oct"140",3.75pt#,7pt#,4/3pt#); "special 1/7 for a quotation";
currenttransform:=currenttransform slanted(2/7/aspect_ratio);
y3=y4=.5[h,-d]=.5[y2,y5]; y5=y6;
x1=x2=x7=.5w; x5+x6=x3+x4=w; x5=x3+1/6pt;
pickup pencircle xscaled .5pt yscaled .35pt;
bot y2=top y3+pt; top y1=h; bot y7=-d; lft x3=0; % y2 moved up 1/3pt (Feb 5)
draw z1..z2; draw z3..z4;
draw z5--z6..{down}z7;
labels(1,2,3,4,5,6,7);
endchar;
currenttransform:=currenttransform slanted(-2/7/aspect_ratio);

% Circumscribed circles
pickup pencircle scaled(.4pt+blacker); rpen:=savepen;
def begincircle(expr code,units,depth,asp,superness)=
beginchar(code,units*20/36pt#,0,0); pickup rpen;
aa:=.5(w++depth*pt/asp);
x2=x4=.5[x1,x3]=.5w; y1=y3=.5[y2,y4]=-.5round(depth*pt);
x1=good.x(x2+aa); y2=good.y(y1+asp*aa);
draw superellipse(z1,z2,z3,z4,superness); labels(1,2,3,4) enddef;

"Ellipse for floating-point mod operator"; % also for pseudo coin top
begincircle(oct"130",29,5,.5,.75786); endchar;

"Edge and bottom of pseudo coin";
begincircle(oct"133",29,5,.5,.75786); charht:=2pt#;
erase fill rt z1--(rt x1,top y2)--(lft x3,top y2)--lft z3--cycle;
x0=x1; x5=x3; y0=y5=y1+2pt; draw z0--z1; draw z3--z5; labels(0,5); endchar;

"Circle to enclose two digits";
begincircle(oct"131",19,7.5,1,.75786); endchar;

"Circle to enclose an exponent of 2";
begincircle(oct"132",9,6,1,1/sqrt2); endchar;

% Now we do the \qc font from TeXbook Appendix D
pickup pencircle scaled ceiling pt; ptpen:=savepen;

beginchar("a",10pt#,5.5pt#,4.5pt#); pickup ptpen; % W to S
bot y1=lft x2=0; x2=.5[x1,x1+w]; y1=.5[y2,y2+h+d];
draw z1{right}..{down}z2; labels(1,2); endchar;

beginchar("b",10pt#,5.5pt#,4.5pt#); pickup ptpen; % W to N
bot y1=lft x2=0; x2=.5[x1,x1+w]; y1=.5[y2,y2-h-d];
draw z1{right}..{up}z2; labels(1,2); endchar;

beginchar("c",10pt#,5.5pt#,4.5pt#); pickup ptpen; % E to N
bot y1=lft x2=0; x2=.5[x1,x1-w]; y1=.5[y2,y2-h-d];
draw z1{left}..{up}z2; labels(1,2); endchar;

beginchar("d",10pt#,5.5pt#,4.5pt#); pickup ptpen; % E to S
bot y1=lft x2=0; x2=.5[x1,x1-w]; y1=.5[y2,y2+h+d];
draw z1{left}..{down}z2; labels(1,2); endchar;

fontdimen 8: pt#; % rule thickness in \qc

message "METAFONT logo";

def arc(suffix i,j) =
       (z.i{0,y.j-y.i}..
  (beta[x.i,x.j],beta[y.j,y.i]){z.j-z.i}..
  z.j{x.j-x.i,0}) enddef;

def double_arc(suffix i,j,k) =
  arc(i,j) & reverse arc(k,j) enddef;

alpha:=.45;  % controls bar location and similar things
beta:=.2;  % controls squareness of bowls

def setparameters(text parameter_equations) =
  string code.M,code.E,code.T,code.A,code.F,code.O,code.N;
  numeric h#, xx#, yy#, o#, s#, u#, px#, py#;
  numeric leftstemloc, barheight;
  parameter_equations;
  yy#=(h#/13.5u#)*xx#; define_whole_pixels(xx,yy);
  define_pixels(s,u);
  define_corrected_pixels(o);
  py#=.9px#; define_blacker_pixels(px,py);
  pickup pencircle xscaled px yscaled py;
  logo_pen:=savepen;
  leftstemloc:=good.x((2.5u#+s#)*pt);
  barheight:=good.y(alpha*h#*pt);
  ligtable code.T: code.A kern -.5u#;
  ligtable code.F: code.O kern -u#;
enddef;

def beginlogochar(suffix c)(expr n) = % code c; width is n units plus sidebars
  beginchar(code.c,n*u#+2s#,h#,0); pickup logo_pen enddef;

def do_it =
beginlogochar(M,18);
x1=x2=leftstemloc; x4=x5=w-x1; x3=w-x3;
y1=y5; y2=y4; bot.y1=-o; top y2=h+o; y3=y1+yy;
draw z1--z2--z3--z4--z5;
labels(1,2,3,4,5);
endchar;

beginlogochar(E,14);
x1=x2=x3=leftstemloc; x4=x6=w-x1+o; x5=x4-xx;
y1=y6; y2=y5; y3=y4; bot.y1=0; top.y3=h; y2=barheight;
draw z6--z1--z3--z4; draw z2..z5;
labels(1,2,3,4,5,6);
endchar;

beginlogochar(T,13);
italcorr h#*slant+.5u#;
if odd(w-px): w:=w+1; fi  % allows a symmetric stem
lft x1=-epsilon; x2=w-x1; x3=x4=.5w; % I tried lft x1=s-o; not as good
y1=y2=y3; top.y1=h; bot.y4=-o;
draw z1..z2; draw z3..z4;
labels(1,2,3,4);
endchar;

beginlogochar(A,15);  % changed from 16 on Oct 16!
x1+x4=x2+x3=2x5=w; x1=x2=leftstemloc;
y1=y4; y2=y3; bot.y1=-o; top.y5=h+o; y2=barheight;
draw double_arc(2,5,3); draw z1--z2--z3--z4;
labels(1,2,3,4,5);
endchar;

beginlogochar(F,14);
x1=x2=x3=leftstemloc; x4=w-x1+o; x5=x4-xx;
y2=y5; y3=y4; bot.y1=-o; top.y3=h; y2=barheight;
draw z1--z3--z4; draw z2..z5;
labels(1,2,3,4,5);
endchar;

beginlogochar(O,15);
x1+x2=x3+x4=w; x1=good.x(1.5u+s); x3=x4;
bot.y3=-o; top.y4=h+o; y1=y2=barheight;
draw double_arc(1,4,2); draw double_arc(2,3,1);
labels(1,2,3,4);
endchar;

beginlogochar(N,15);
x1+x4=x1+x3=x2+x5=w; x1=x2=leftstemloc;
y1=y4=y3-yy; bot.y1=-o; y2=y5; top.y5=h+o;
draw z1--z2--z3; draw z4..z5;
labels(1,2,3,4,5);
endchar;
enddef;  % the end of "do_it"

% ten-point size
message "  ten point";
setparameters(h#=6;  % height of characters, in pt
slant:=0;
  xx#=0.6;  % extra length of certain features, in pt
  u#=4/9;  % unit width, in pt
  s#=0;  % extra sidebar, in pt
  o#=1/9;  % overshoot of curves, in pt
  px#=2/3;  % horizontal thickness of pen, in pt
  code.M="M"; code.E="E"; code.T="T"; code.A="A";
  code.F="F"; code.O="O"; code.N="N")
do_it;

currenttransform:=currenttransform slanted(.25/aspect_ratio);
% ten-point size, slanted: 89:;<=>: = METAFONT!
message "  slanted ten point";
setparameters(h#=6;  % height of characters, in pt
slant:=.25;
  xx#=0.6;  % extra length of certain features, in pt
  u#=4/9;  % unit width, in pt
  s#=0;  % extra sidebar, in pt
  o#=1/9;  % overshoot of curves, in pt
  px#=2/3;  % horizontal thickness of pen, in pt
  code.M="8"; code.E="9"; code.T=":"; code.A=";";
  code.F="<"; code.O="="; code.N=">")
do_it;
currenttransform:=currenttransform slanted(-.25/aspect_ratio);

% nine-point size: hijklmnj = METAFONT!
message "  nine point";
setparameters(h#=.9*6;  % height of characters, in pt
slant:=0;
  xx#=.9*0.6;  % extra length of certain features, in pt
  u#=.91*4/9;  % unit width, in pt
  s#=.08;  % extra sidebar, in pt
  o#=1/10;  % overshoot of curves, in pt
  px#=.9*2/3;  % horizontal thickness of pen, in pt
  code.M="h"; code.E="i"; code.T="j"; code.A="k";
  code.F="l"; code.O="m"; code.N="n")
do_it;
font_quad  18u#+2s#;  % we take spacing from the 9-point logo font
font_normal_space  6u#+2s#;
font_normal_stretch  3u#;
font_normal_shrink  2u#;

% eight-point size: opqrstuq = METAFONT!
message "  eight point";
setparameters(h#=.8*6;  % height of characters, in pt
slant:=0;
  xx#=.8*0.6;  % extra length of certain features, in pt
  u#=.82*4/9;  % unit width, in pt
  s#=.2;  % extra sidebar, in pt
  o#=1/12;  % overshoot of curves, in pt
  px#=.8*2/3;  % horizontal thickness of pen, in pt
  code.M="o"; code.E="p"; code.T="q"; code.A="r";
  code.F="s"; code.O="t"; code.N="u")
do_it;

% eight-point size, magnified 10/8: /0123451 = METAFONT!
message "  magnified eight point";
setparameters(h#=.8*6*10/8;  % height of characters, in pt
slant:=0;
  xx#=.8*0.6*10/8;  % extra length of certain features, in pt
  u#=.82*4/9*10/8;  % unit width, in pt
  s#=.2*10/8;  % extra sidebar, in pt
  o#=1/12*10/8;  % overshoot of curves, in pt
  px#=.8*2/3*10/8;  % horizontal thickness of pen, in pt
  code.M="/"; code.E="0"; code.T="1"; code.A="2";
  code.F="3"; code.O="4"; code.N="5")
do_it;

currenttransform:=currenttransform slanted(2/7/aspect_ratio);
% eight-point size, slanted: \]^_efg^ = METAFONT!
message "  slanted eight point";
slant:=2/7;
setparameters(h#=.8*6;  % height of characters, in pt
  xx#=.8*0.6;  % extra length of certain features, in pt
  u#=.82*4/9;  % unit width, in pt
  s#=.2;  % extra sidebar, in pt
  o#=1/12;  % overshoot of curves, in pt
  px#=.8*2/3;  % horizontal thickness of pen, in pt
  code.M="\"; code.E="]"; code.T="^"; code.A="_";
  code.F="e"; code.O="f"; code.N="g")
do_it;
currenttransform:=currenttransform slanted(-2/7/aspect_ratio);

% special size for the title page: ()*+,-.* = METAFONT!
message "  title page size";
setparameters(h#=250/9;  % height of characters, in pt (same as cmssc40)
slant:=0;
  xx#=2.9;  % extra length of certain features, in pt
  u#=(1+sqrt5)/2;  % unit width, in pt
  s#=.2;  % extra sidebar, in pt
  o#=4/9;  % overshoot of curves, in pt
  px#=4;  % horizontal thickness of pen, in pt
  code.M="("; code.E=")"; code.T="*"; code.A="+";
  code.F=","; code.O="-"; code.N=".")
do_it;

currenttransform:=currenttransform slanted(-1/9/aspect_ratio);
% backslanted skinny bold: BCDGHIJD = METAFONT!
message "  weird skinny bold condensed";
setparameters(h#=25;  % height of characters, in pt
slant:=-1/9;  % leftward bias
  xx#=1.5;  % extra length of certain features, in pt
  u#=3/9;  % unit width, in pt
  s#=1/3;  % extra sidebar, in pt
  o#=2/9;  % overshoot of curves, in pt
  px#=1;  % horizontal thickness of pen, in pt
  code.M="B"; code.E="C"; code.T="D"; code.A="G";
  code.F="H"; code.O="I"; code.N="J")
do_it;
currenttransform:=currenttransform slanted(+1/9/aspect_ratio);

% ultrawide light: KLUVWvwU = METAFONT!
message "  weird light extended";
setparameters(h#=6;  % height of characters, in pt
slant:=0;
  xx#=2;  % extra length of certain features, in pt
  u#=4/3;  % unit width, in pt
  s#=-2/3;  % extra sidebar, in pt
  o#=1/9;  % overshoot of curves, in pt
  px#=1/3;  % horizontal thickness of pen, in pt
  code.M="K"; code.E="L"; code.T="U"; code.A="V";
  code.F="W"; code.O="v"; code.N="w")
do_it;

message "Pixel symbols";

beginchar("P",722.7/722.909pt#,722.7/722.909pt#,0); % 1pt pixel
pickup pencircle scaled .2pt;
top lft z1=(0,.8h); top rt z2=(.8w,.8h);
bot lft z3=(0,0); bot rt z4=(.8w,0);
draw z1--z4; draw z2--z3; endchar;

beginchar("Q",722.7/722.909pt#,722.7/722.909pt#,0); % 1pt nonpixel
pickup pencircle scaled .2pt;
drawdot(.4w,.4h); endchar;

beginchar("R",3*722.7/722.909pt#,3*722.7/722.909pt#,0); % 3pt pixel
pickup pencircle scaled .3pt;
interim autorounding:=0;
top lft z1=(0,.9h); top z2=(.45w,.9h); top rt z3=(.9w,.9h);
lft z4=(0,.45h); rt z5=(.9w,.45h);
bot lft z6=(0,0); bot z7=(.45w,0); bot rt z8=(.9w,0);
draw z1+(-50epsilon,50epsilon)--z8+(50epsilon,-50epsilon);
draw z2+(0,50epsilon)--z7-(0,50epsilon);
draw z3+(50epsilon,50epsilon)--z6-(50epsilon,50epsilon);
draw z4-(50epsilon,0)--z5+(50epsilon,0); endchar;

beginchar("S",3*722.7/722.909pt#,3*722.7/722.909pt#,0); % 3pt nonpixel
pickup pencircle scaled .3pt;
drawdot(.45w,.45h); endchar;

message "Gothic d";

beginchar("?",4pt#,8pt#,0);
 % taken from NB, but my changes may have spoiled it
stem_length#:=10/6.7pt#; define_blacker_pixels(stem_length);
xheight:=6pt;
penpos1  (2*stem_length,30);     % normal points
penpos2  (2*stem_length,30);   % normal points
penpos3  (2*stem_length,30);  % normal points
penpos4  (2*stem_length,30);  % normal points

x1l=x2=0;  y1r=xheight; y2l=0;
  penpos40(stem_length,30); z40r=round z1;
  penpos41(stem_length,40); x40r=x41r=x42r; y41=.5[y40,y42];
  penpos42(stem_length,30); y42l=y2;
fill z40r--(x40r,y42l)--z42l...z41l{up}...z40l--cycle; % left stem

x3=x4r=w; y3=y1; y4=y2;
  penpos50(stem_length,30); z50l=round z3l;
  penpos51(stem_length,40); x50l=x51l=x52l; y51=.5[y50,y52];
  penpos52(stem_length,30); y52l=y4;
fill z52l--(x52l,y50r)--z50r...z51r{down}...z52r--cycle; % right stem

  penpos10(stem_length,30); z10=z42;
  penpos11(stem_length,25); x11=.5[x10,x12]; y10l=y11=y12r;
  penpos12(stem_length,30); x12r=x4; % redundant: y12l=0;
  penpos14(stem_length*(1+cosd30),30); z14l=z12l;
  penpos15(.07stem_length,120); z15l=z14r;
fill z10l...z11l{z12-z10}...z12l--z14r
 --z15r{z14l-z14r}...z11r{z10-z12}...z10r--cycle;  % lower join

numeric ch; ch=10; % Neenie's version was more like ch=7.5 (steeper)
numeric s_length[];
 s_length0*cosd(30-ch)=stem_length*cosd 30;
 s_length1*cosd(40-ch)=stem_length*cosd 40;
pair corner; corner=z50r;
vardef f(expr theta)=
 save x,y; penpos60(s_length0,theta); y60r=h; x60l=0;
 angle(z60r-corner)<theta+60+ch enddef;
numeric theta; theta=solve f(90,0);
  penpos60(s_length0,theta); y60r=h; x60l=0;
  penpos61(s_length1,theta+10); z61l=.5[z60l,z62l];
  penpos62(s_length0,theta); z62r=corner;
fill z60l--((z60l--z62l)intersectionpoint((x4,0)--(x4,h)))
 --z62r...z61r{z60-z62}...z60r--cycle;      % diagonal

charwd:=charwd+1.03277pt#; w:= w + round(1.03277pt);
penlabels(1,2,3,4,10,11,12,13,14,15,40,41,42,50,51,52,60,61,62);
interim xoffset:=.46687pt; interim yoffset:=-.3pt;
endchar;

bye