% ====================================================================== % KD Classical Greek Family of Fonts % ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ % % A set of MF source fonts for use with TeX version 3.0 or higher % accompanied with macros and hyphenation tables to facilitate % the typesetting of greek texts % % This piece of work is partially based on original work of % Sylvio Levi (design of an excellent set of fonts) % and Yianni Haralambous (ideas about macros other fonts). % % This file is part of the greektex package and abides to % copyright laws of the GNU general public software licence % % You are allowed to use or modify this file as long as the % original authors are clearly mentioned. It is ILLEGAL to sell % any part of this work or work derived from it. You may not % charge for this work except to cover for reasonable media % expensess. % % K J Dryllerakis (C) 1991-1992 % % ====================================================================== % % File : kdlower.mf % % Lower Case Greek Letters KD PAckage % % ====================================================================== % Lowercase alfa % ====================================================================== % def width = 9u enddef; def height = x_height enddef; def dims = width#,height#,0 enddef; def ital = 0 enddef; def fit_params = 0,.5u# enddef; % def gen_letter = pickup fine.nib; pos1(stem,0); top y1=x_height+oo; rt x1r=hround(w-.5u); %top right pos2(vstem,-90); pos4(vstem,-270); x4=x2=.5w-u; bot y2r=-oo; top y4r=x_height+oo; %bottom and top bulges pos3(hair,-180); lft x3r=hround .75u; y3=.5[y2,y4]; %left bulge pos6(vstem,90); x6=w-u; y6=y2; %bottom right % numeric theta; theta=angle((x4-x6),2.5(y4-y6))-90; pos5(hair,0); x5=.65[x4,x6]; y5=y3; %point of inflection alpha_tail(6,7); %hook filldraw stroke z1e{(x2-x1,2(y2-y1))}... %diagonal pulled_arc.e(2,3) & pulled_arc.e(3,4) %bowl ...z5e{down}...z6e{right}...{up}z7e; %diagonal and numeric x_baryctr; x_baryctr= .25[x4,x1]; numeric pos_stem; pos_stem=x_baryctr; %iota reference enddef; % cmchar "Lowercase alpha"; beginchar("a",dims); this_letter; penlabels(1,2,3,4,5,6,7); endchar; cmchar "Lowercase alpha with rough breathing"; beginchar(oct"200",width#,acc_ht#,0); this_letter; spirit(x_baryctr)<; endchar; cmchar "Lowercase alpha with smooth breathing"; beginchar(oct"210",width#,acc_ht#,0); this_letter; spirit(x_baryctr)>; endchar; % cmchar "Lowercase alpha with acute"; beginchar(oct"220",width#,acc_ht#,0); this_letter; acute(x_baryctr); endchar; % cmchar "Lowercase alpha with rough breathing and acute"; beginchar(oct"230",width#,acc_ht#,0); this_letter; spirit_acute(x_baryctr)<; endchar; % cmchar "Lowercase alpha with smooth breathing and acute"; beginchar(oct"240",width#,acc_ht#,0); this_letter; spirit_acute(x_baryctr)>; endchar; % cmchar "Lowercase alpha with rough breathing and grave"; beginchar(oct"260",width#,acc_ht#,0); this_letter; spirit_grave(x_baryctr)<; endchar; % cmchar "Lowercase alpha with smooth breathing and grave"; beginchar(oct"270",width#,acc_ht#,0); this_letter; spirit_grave(x_baryctr)>; endchar; % cmchar "Lowercase alpha with circumflex"; beginchar(oct"207",width#,circ_ht#,0); this_letter; circumflex(x_baryctr); endchar; % cmchar "Lowercase alpha with grave"; beginchar(oct"250",width#,acc_ht#,0); this_letter; grave(x_baryctr); endchar; % cmchar "Lowercase alpha with rough breathing and circumflex"; beginchar(oct"300",width#,Circ_ht#,0); this_letter; spirit_circumflex(x_baryctr)<; endchar; cmchar "Lowercase alpha with smooth breathing and circumflex"; beginchar(oct"310",width#,Circ_ht#,0); this_letter; spirit_circumflex(x_baryctr)>; endchar; % cmchar "Lowercase alpha with iota subscript"; beginchar(oct"320",width#,height#,iota_dp#); this_letter; iota_sub(pos_stem); endchar; % cmchar "Lowercase alpha with grave and iota subscript"; beginchar(oct"330",width#,acc_ht#,iota_dp#); this_letter; grave(x_baryctr); iota_sub(pos_stem); endchar; cmchar "Lowercase alpha with rough breathing and iota subscript"; beginchar(oct"340",width#,acc_ht#,iota_dp#); this_letter; spirit(x_baryctr)<; iota_sub(pos_stem); endchar; cmchar "Lowercase alpha with smooth breathing and iota subscript"; beginchar(oct"350",width#,acc_ht#,iota_dp#); this_letter; spirit(x_baryctr)>; iota_sub(pos_stem); endchar; cmchar "Lowercase alpha with acute and iota subscript"; beginchar(oct"301",width#,acc_ht#,iota_dp#); this_letter; acute(x_baryctr); iota_sub(pos_stem); endchar; cmchar "Lowercase alpha with rough breathing, acute and iota subscript"; beginchar(oct"311",width#,acc_ht#,iota_dp#); this_letter; spirit_acute(x_baryctr)<; iota_sub(pos_stem); endchar; cmchar "Lowercase alpha with smooth breathing and acute and iota subscript"; beginchar(oct"321",width#,acc_ht#,iota_dp#); this_letter; spirit_acute(x_baryctr)>; iota_sub(pos_stem); endchar; cmchar "Lowercase alpha with rough breathing, grave and iota subscript"; beginchar(oct"360",width#,acc_ht#,iota_dp#); this_letter; spirit_grave(x_baryctr)<; iota_sub(pos_stem); endchar; cmchar "Lowercase alpha with smooth breathing and grave and iota subscript"; beginchar(oct"361",width#,acc_ht#,iota_dp#); this_letter; spirit_grave(x_baryctr)>; iota_sub(pos_stem); endchar; cmchar "Lowercase alpha with circumflex and iota subscript"; beginchar(oct"331",width#,circ_ht#,iota_dp#); this_letter; circumflex(x_baryctr); iota_sub(pos_stem); endchar; cmchar "Lowercase alpha with rough breathing, circumflex and iota subscript"; beginchar(oct"341",width#,acc_ht#,iota_dp#); this_letter; spirit_circumflex(x_baryctr)<; iota_sub(pos_stem); endchar; cmchar "Lowercase alpha with smooth breathing, circumflex and iota subscript"; beginchar(oct"351",width#,acc_ht#,iota_dp#); this_letter; spirit_circumflex(x_baryctr)>; iota_sub(pos_stem); endchar; picture pic.iota; picture savedpicture; % % ====================================================================== % lowercase beta [KJD 19.02.91] % ====================================================================== % def dims = 9u#,asc_height#,desc_depth# enddef; def ital = 0 enddef; def fit_params = 0,0 enddef; def gen_letter= pickup fine.nib; numeric thin_stem; thin_stem=.6[hair,stem]; %for upper bowl numeric tilt; tilt=min(2*otilt,.5); %for both bowls pos1(stem,180); y1-.5stem=-d-o; %bottom left pos2(hair,180); y2=.5bar_height; %self-intersection (cf. z15) x1=x2; lft x1r=hround(.75u+.5(hair-stem)); %i.e., lft x2r ~ .75u x3r=x2r; %beginning of curve top y5r=h+oo; bot y14r=-oo; x5r=x14r; %top and bottom bulges top y10r=vstem+bot y9r=x_height; x9r=x10r; %top and bottom of cusp rt x12r=hround(w-.75u); %lower right bulge x5r=.5[lft x2r,rt x12r]; x9r-.5vstem=hround(x5r-.5u-.5vstem); % we want to simulate the following relations, to make slopes consistent % (where z7 is the upper right bulge): % z5r-z3r=whatever*(z9r-z7r)=whatever*(z14r-z12r); % z7r-z5r=whatever*(z12r-z10r)=whatever*(z5r-z3r) yscaled -1; numeric slope; slope=((y10r-y12r)+(y12r-y14r))/((x12r-x10r)+(x12r-x14r)); z7'r=z9r+whatever*(1,slope); z7'r=z5r+whatever*(1,-slope); y7r=y7'r; rt x7r=hround rt x7'r; z12r=z14r+whatever*(1,slope); z3r=z5r+whatever*(1,slope); filldraw double_circ_stroke gr_arc.e(7,6,5)(hair,thin_stem,tilt).. gr_arc.e(5,4,3)(hair,thin_stem,tilt)..{down}z2e..z1e; %top and left z2=z15; pos15(hair,slope-90); %intersection pt numeric slope; slope=angle((z14r-z15)yscaled 2); filldraw stroke z15e{dir slope}...gr_arc.e(14,13,12)(hair,stem,tilt); %bottom forsuffixes e=r,l: path curv[]e; numeric S[]e; curv1e=reverse gr_arc.e(9,8,7)(hair,thin_stem,tilt); %cusp bottom curv2e=gr_arc.e(12,11,10)(hair,stem,tilt); endfor %cusp top (S1r,S2r)=curv1r intersectiontimes curv2r; (whatever,S2l)=curv1r intersectiontimes curv2l; (S1l,whatever)=curv1l intersectiontimes curv2r; if S1l=-1 : S1l:=2; fi if S2l=-1 : S2l:=2; fi filldraw stroke subpath(0,S1e+eps) of curv1e; %fill in cusp filldraw stroke subpath(0,S2e+eps) of curv2e; filldraw subpath (S1r+eps,2) of curv1r...subpath(2,S2r+eps) of curv2r..cycle; enddef; cmchar "Lowercase beta"; beginchar("b",dims); this_letter; penlabels(1,2,3,4,5,6,7,8,9,10,11,12,13,14,15); endchar; picture savedpicture; % % ====================================================================== % lowercase gamma % ====================================================================== % def dims = 10u#,x_height#,desc_depth# enddef; def ital = 0 enddef; def fit_params = 0,0 enddef; % def gen_letter= pickup fine.nib; begingroup save t; t:=superness; interim superness:=.95t; pos2(curve,90); top y2r=h+oo; %top of left branch pos1(hair,180); bot y1=top y2r-4/3curve; %tip of hook lft x1r=hround .5u; x2-x1=y2-y1; %central arc is round pos3(hair,0); pos4(hair,-180); rt x3r-lft x4r=stem; %bottom of cusp y4=y3; .5[x3,x4]=.5w; if monowidth: y3=0 else: y3-.5stem=vround(-.8d) fi; pos5(curve,-270); top y5r=h+oo; x5+.5curve=hround(w-.75u); %right branch pos5'(curve,0); z5'=z5; filldraw stroke z1e{up}...z2e{right}; drawloop(2,3,4,5); %hook and cusp filldraw z5l{right}...z5'r{up}...z5r{left}--cycle; %right branch if monowidth: %complete stem x3'=x3r; x4'=x4r; y3'=y4'; y3'-.5stem=vround(-.8d); filldraw z3r--z3'{down}...{up}z4'--z4r--cycle; fi endgroup; enddef; % cmchar "Lowercase gamma"; beginchar("g",dims); this_letter; penlabels(1,2,3,3',4,4',5); endchar; % picture savedpicture; % % ====================================================================== % DELTA % ====================================================================== % def dims = 8.5u#,asc_height#,0 enddef; def ital = 0 enddef; def fit_params = 0,0 enddef; % def gen_letter = pickup fine.nib; top y1r=vround(if not monowidth:.95 fi x_height+oo); x1r=.5w; % top of loop x5r=.5w; bot y5r=-oo; % bottom of ditto lft x3r=w-rt x7r=hround(.75u); y3r=y7r=.5[y1r,y5r]; % left and right bulge filldraw stroke gr_arc.e(1,2,3)(vair,stem,.5otilt) % three quadrants of l & gr_arc.e(3,4,5)(vair,stem,.5otilt) & gr_arc.e(5,6,7)(vair,stem,.5otilt); % we now draw the hook |z8..z9..z10|. It must satisfy the following ints: % its outer contour is symmetric with respect to some axis containing |z9l|; % one end is known, the width there is |thin_stem|, and the width at |z10| % is, ideally, stem. (But since we may have to change that we callt |Stem|.) z8l=z1l; numeric thin_stem, med_stem; thin_stem=.5[hair,Stem]; % the aperture, measured perpendicular to the axis, equals |Stem| numeric apert; apert=2Stem+thin_stem-currentbreadth; % |apeth(z10l-z8l);| numeric left_goal; lft left_goal=vround(lft x3r+.5u); % most tangent known numeric top_goal; top top_goal=h+oo; % highest tangent known % if by taking |Stem=stem| we got |apert > top_goal-y1l|, the problem might % not have a solution with a horizontal tangent; in that case the % constraint is on |apert|: if 2stem+.7[hair,stem]-currentbreadth>top_goal-y8l: apert=top_goal-y8l; else: Stem=stem; fi % we first estimate the slope of the axis by imagining that, in the vicinity % of |z9l|, the hook looks like a semicircle of diameter |apert/2|. % (this value is empiric, but reasonable because the tension is high) z0l=(left_goal+.25apert,top_goal-.25apert); % center of semicircle numeric axis; axis=angle(z0l-z8l)+angle(length(z0l-z8l)+-+.5apert,.5apert); z9l=z0l+(.25apert,0)rotated(axis); z10l=z8l+(0,-apert)rotated(axis); % % we now iterate, correcting |z9l| until the tangencies are satisfied path hook; numeric left_real; numeric top_real; forever: % hook:=z8l{dir(axis)}..tension 1.5..z9l..tension 1.5..{-dir(axis)}z10l; if directiontime up of hook=-1: left_error:=0; message "hook has no vertical tangent!"; else: left_error:=xpart directionpoint up of hook-left_goal; fi if directiontime right of hook=-1: top_error:=0; message "hook has no horizontal tangent!"; else: top_error:=ypart directionpoint right of hook-top_goal; fi % exitif (abs(left_error)<.05) and (abs(top_error)<.05); x9l:=x9l-left_error; y9l:=y9l-top_error; axis:=angle(z9l-z8l)+angle(length(z9l-z8l)+-+.5apert,.5apert); x10l:=x8l+apert*sind axis; y10l:=y8l-apert*cosd axis; endfor % pos8(thin_stem,axis-90); pos10(Stem,axis+90); pos9(.3[hair,Stem],axis+180); filldraw stroke z7e{z7'e}..{dir axis}z8e..tension 1.5..z9e..tension 1.5..{-dir axis}z10e; enddef; % cmchar "Lowercase delta"; beginchar("d",dims); this_letter; penlabels(1,2,3,4,5,6,7,8,9,10); endchar; % picture savedpicture; % % ====================================================================== % Lowercase Epsilon [KJD 19.02.91] % ====================================================================== % def width = 7.75u enddef; def height = x_height enddef; def dims = width#,height#,0 enddef; def ital = 0 enddef; def fit_params = 0,0 enddef; % def gen_letter = pickup fine.nib; pos2(vstem,90); % * pos2(.75vstem,90) x2=.5w; top y2r=x_height+o; %top point pos7(vstem,630); x2=x7; bot y7r=-o; %bottom point rt x1r=hround(w-.75u); bot y1l=.3[bot y2l,bar_height];%top end % * rt x1r=w; z1'=(x1r,y1l+.5(flare-currentbreadth)); %approximation to z1 numeric slope; slope=angle((z2-z1')yscaled 2); pos1(flare,slope-90); % * pos1(.5flare,slope-90); bar_height=.5[y1,y8]; x8=x1; pos8(flare,slope+90); %bottom end pos3(vstem,120); lft x3r=hround .75u; y3=.5[y4r,y2r]; %top left bulge pos6(vstem,600); x6=x3; y6=.5[y5r,y7r]; %bottom left bulge y6:=y6r;y3:=y3r; %for the benefit of pulled_arc top y5r-bot y4r=curve; y5+y4=2bar_height; x5=x4=x2; %loop pos4(vair,-90); pos5(vair,90); filldraw stroke z1e{dir slope}...pulled_arc.e(2,3); %top drawloop(3,4,5,6); %loop and bottom forsuffixes e=l,r: path foo.e; foo.e= z8e...pulled_arc.e(7,6); if angle(direction 0 of foo.e) > angle(z8r-z8l): foo.e:= z8e{z8r-z8l}...pulled_arc.e(7,6); fi endfor; filldraw stroke foo.e; numeric x_baryctr; x_baryctr=x2; %accent reference enddef; % cmchar "Lowercase epsilon"; beginchar("e",dims); this_letter; penlabels(1,2,3,4,5,6,7,8); endchar; % cmchar "Lowercase epsilon with rough breathing"; beginchar(oct"201",width#,acc_ht#,0); this_letter; spirit(x_baryctr)<; endchar; cmchar "Lowercase epsilon with smooth breathing"; beginchar(oct"211",width#,acc_ht#,0); this_letter; spirit(x_baryctr)>; endchar; cmchar "Lowercase epsilon with acute"; beginchar(oct"221",width#,acc_ht#,0); this_letter; acute(x_baryctr); endchar; cmchar "Lowercase epsilon with rough breathing and acute"; beginchar(oct"231",width#,acc_ht#,0); this_letter; spirit_acute(x_baryctr)<; endchar; cmchar "Lowercase epsilon with smooth breathing and acute"; beginchar(oct"241",width#,acc_ht#,0); this_letter; spirit_acute(x_baryctr)>; endchar; cmchar "Lowercase epsilon with rough breathing and grave"; beginchar(oct"261",width#,acc_ht#,0); this_letter; spirit_grave(x_baryctr)<; endchar; cmchar "Lowercase epsilon with smooth breathing and grave"; beginchar(oct"271",width#,acc_ht#,0); this_letter; spirit_grave(x_baryctr)>; endchar; cmchar "Lowercase epsilon with grave"; beginchar(oct"251",width#,acc_ht#,0); this_letter; grave(x_baryctr); endchar; picture savedpicture; % % ====================================================================== % ZHTA % ====================================================================== % def dims = 8.5u#,asc_height#,desc_depth# enddef; def ital = 0 enddef; def fit_params = 0,0 enddef; % def gen_letter= pickup fine.nib; pos4(hair,-180); y4=bar_height; lft x4r=hround(.75u); % left bulge pos6(hair,-180); rt x6l=hround(w-.75u); y6=-.5stem; % bottom right y3+.5stem=h+o; x3+.5stem=hround(rt x6l-.25u); % top right numeric slope; slope=angle((z3-z4)xscaled 2); pos3(hair,slope+90); pos5(stem,-90); bot y5r=0; x5=.5w; % inflection pt pos7(vstem,-270); y6=.5[y7r,y5r]; x7-.5vstem=hround x5; pos2(stem,slope+90); z2l=z3l; filldraw double_circ_stroke % bowl and tail z7e{right}...z6e{up}...z5e{left}...z4e{up}...z2e{dir slope}; % where handle attaches pos1(curve,0); lft x1l=hround(lft x4r+.25u); y1+.5curve=h+o; % end of handle filldraw circ_stroke z1e{down}...z3e{dir slope}; enddef; % cmchar "Lowercase zeta"; beginchar("z",dims); this_letter; penlabels(1,2,3,4,5,6,7,8); endchar; % picture savedpicture; % % ====================================================================== % HTA % ====================================================================== % def width = 8.5u enddef; def dims = width#,x_height#,desc_depth# enddef; def ital = 0 enddef; def fit_params = if straight: .75 else: .5 fi u#,0 enddef; % def gen_letter = pickup fine.nib; y1r-.5stem=-d-o; pos1(stem,0); rt x2r=hround(w-.75u); y2r=.5x_height; pos2(hair,0); lft x5r=hround(1.5u); y5-.5stem=-o; pos5(stem,-180); top y4r=x_height+o; x4r=.5[lft x2l,rt x5l]; pos6(hair,180); y6=y2; if straight: x1=x2;x5=x6; pos4(stem,90); filldraw double_circ_stroke z1e--pulled_arc.e(2,4)&pulled_arc.e(4,6)--z5e; else: x1r=x2r; z2'l=z2'r=up; filldraw circ_stroke z1e{up}...gr_arc.e(2,3,4)(hair,stem,.8); % right leg filldraw circ_stroke z5e{(z4-z5) yscaled 4}...z4e{-z4'e}; % left leg z6r=((0,y2)--(w,y2)) intersectionpoint (z5r{(z4-z5) yscaled 4}...z4r{-z4'r}); fi pos8(vstem,0); rt x8r=hround(lft x6r-.75u); % end of handle pos7(vstem,-90); top y7l=x_height+o; z8r=z7r; % top of handle filldraw circ_stroke z8e{up}...z7e{right}...z6e{down}; numeric x_baryctr; x_baryctr=.1[x4,x7]; % accent reference numeric pos_stem; pos_stem=x5; % iota reference enddef; % cmchar "Lowercase eta"; beginchar("h",dims); this_letter; penlabels(1,2,3,4,5,6,7,8); endchar; % cmchar "Lowercase eta with rough breathing"; beginchar(oct"202",width#,acc_ht#,desc_depth#); this_letter; spirit(x_baryctr)<; endchar; cmchar "Lowercase eta with smooth breathing"; beginchar(oct"212",width#,acc_ht#,desc_depth#); this_letter; spirit(x_baryctr)>; endchar; cmchar "Lowercase eta with acute"; beginchar(oct"222",width#,acc_ht#,desc_depth#); this_letter; acute(x_baryctr); endchar; cmchar "Lowercase eta with rough breathing and acute"; beginchar(oct"232",width#,acc_ht#,desc_depth#); this_letter; spirit_acute(x_baryctr)<; endchar; cmchar "Lowercase eta with smooth breathing and acute"; beginchar(oct"242",width#,acc_ht#,desc_depth#); this_letter; spirit_acute(x_baryctr)>; endchar; % cmchar "Lowercase eta with rough breathing and grave"; beginchar(oct"262",width#,acc_ht#,desc_depth#); this_letter; spirit_grave(x_baryctr)<; endchar; cmchar "Lowercase eta with smooth breathing and grave"; beginchar(oct"272",width#,acc_ht#,desc_depth#); this_letter; spirit_grave(x_baryctr)>; endchar; % cmchar "Lowercase eta with circumflex"; beginchar(oct"217",width#,circ_ht#,desc_depth#); this_letter; circumflex(x_baryctr); endchar; % cmchar "Lowercase eta with grave"; beginchar(oct"252",width#,acc_ht#,desc_depth#); this_letter; grave(x_baryctr); endchar; % cmchar "Lowercase eta with rough breathing and circumflex"; beginchar(oct"302",width#,Circ_ht#,desc_depth#); this_letter; spirit_circumflex(x_baryctr)<; endchar; cmchar "Lowercase eta with smooth breathing and circumflex"; beginchar(oct"312",width#,Circ_ht#,desc_depth#); this_letter; spirit_circumflex(x_baryctr)>; endchar; % cmchar "Lowercase eta with grave and iota subscript"; beginchar(oct"332",width#,acc_ht#,desc_depth#); this_letter; grave(x_baryctr); iota_sub(pos_stem); endchar; cmchar "Lowercase eta with rough breathing and iota subscript"; beginchar(oct"342",width#,acc_ht#,desc_depth#); this_letter; spirit(x_baryctr)<; iota_sub(pos_stem); endchar; cmchar "Lowercase eta with smooth breathing and iota subscript"; beginchar(oct"352",width#,acc_ht#,desc_depth#); this_letter; spirit(x_baryctr)>; iota_sub(pos_stem); endchar; cmchar "Lowercase eta with acute and iota subscript"; beginchar(oct"303",width#,acc_ht#,desc_depth#); this_letter; acute(x_baryctr); iota_sub(pos_stem); endchar; cmchar "Lowercase eta with rough breathing, acute and iota subscript"; beginchar(oct"313",width#,acc_ht#,desc_depth#); this_letter; spirit_acute(x_baryctr)<; iota_sub(pos_stem); endchar; cmchar "Lowercase eta with smooth breathing and acute and iota subscript"; beginchar(oct"323",width#,acc_ht#,desc_depth#); this_letter; spirit_acute(x_baryctr)>; iota_sub(pos_stem); endchar; cmchar "Lowercase eta with rough breathing, grave and iota subscript"; beginchar(oct"362",width#,acc_ht#,desc_depth#); this_letter; spirit_grave(x_baryctr)<; iota_sub(pos_stem); endchar; cmchar "Lowercase eta with smooth breathing and grave and iota subscript"; beginchar(oct"363",width#,acc_ht#,desc_depth#); this_letter; spirit_grave(x_baryctr)>; iota_sub(pos_stem); endchar; cmchar "Lowercase eta with circumflex and iota subscript"; beginchar(oct"333",width#,circ_ht#,desc_depth#); this_letter; circumflex(x_baryctr); iota_sub(pos_stem); endchar; cmchar "Lowercase eta with rough breathing, circumflex and iota subscript"; beginchar(oct"343",width#,Circ_ht#,desc_depth#); this_letter; spirit_circumflex(x_baryctr)<; iota_sub(pos_stem); endchar; cmchar "Lowercase eta with smooth breathing, circumflex and iota subscript"; beginchar(oct"353",width#,Circ_ht#,desc_depth#); this_letter; spirit_circumflex(x_baryctr)>; iota_sub(pos_stem); endchar; cmchar "Lowercase eta with iota subscript"; beginchar(oct"322",width#,x_height#,desc_depth#); this_letter; iota_sub(pos_stem); endchar; picture pic.iota; picture savedpicture; % % ====================================================================== % JHTA % ====================================================================== % def dims = 9u#,asc_height#,0 enddef; def ital = 0 enddef; def fit_params = 0,0 enddef; % def gen_letter= pickup fine.nib; lft x4r=w-rt x8r=hround .75u; y4r=y8r=.5h; % left and right bulges x2r=x6r=.5w; top y2r=h+o; bot y6r=-o; % top and bottom filldraw stroke gr_arc.e(8,1,2)(vair,stem,otilt) & gr_arc.e(2,3,4)(vair,stem,otilt) & gr_arc.e(4,5,6)(vair,stem,otilt) & gr_arc.e(6,7,8)(vair,stem,otilt); pos4`(bar,90); pos8`(bar,90); x4`=x4; x8`=x8; y4`=y8`=.05[y4,y2]; filldraw stroke z4`e--z8`e; % bar enddef; % cmchar "Lowercase theta"; beginchar("j",dims); this_letter; penlabels(1,2,3,4,4`,5,6,7,8,8`); endchar; % picture savedpicture; % % ====================================================================== % IWTA % ====================================================================== % def width = 5u enddef; def dims = width#,x_height#,0 enddef; def ital = 0 enddef; def fit_params = if monospace: u#,u# else:0,2curve#-3u# fi enddef; % def gen_letter= pickup fine.nib; pos1(flare,180); lft x1r=hround u; top y1=x_height+oo; % top numeric neck; neck=.2[hair,stem]; pos2(neck,180); .2[lft x2r,rt x2l]=.2[lft x1r,rt x1l]; % neck pos3(curve,-90); bot y3r=-oo; % bottom y2r=if monowidth: 2 else: 1.5 fi[bot y3r,top y3l]; z3r-z2r=whatever*(1,-1.25); if monowidth: y4r+.5neck=vround y2r; x3=.5[x2,x4]; pos4(neck,0); % tip of hook filldraw stroke z4e...z3e...z2e---z1e; else: z4l=z4r; top y4r=y2r; z4l-z3l=whatever*(1,1); path p.r, p.l; forsuffixes e=r,l: p.e=z1e---z2e...z3e...z4e; endfor rt x3.5r=hround(rt xpart directionpoint up of p.r); z4'r=direction 3 of p.r; z3'r=direction 2 of p.r; forever: % avoid bad vertical tangent between 2l and 3l x2.5l:= rt xpart directionpoint down of p.l; exitif abs(hround(x2.5l)-x2.5l)<.05; x2l:=x2l+hround(x2.5l)-x2.5l; p.l:=(z1l---z2l...z3l...z4l); endfor p.r:=z1r---z2r...club.r(3,3.5,4); % avoid bad vertical tangent between 3r and 4r filldraw stroke p.e; fi numeric x_baryctr; x_baryctr=x1; enddef; % cmchar "Lowercase iota"; beginchar("i",dims); this_letter; penlabels(1,2,3,4); endchar; % cmchar "Lowercase iota with rough breathing"; beginchar(oct"205",width#,acc_ht#,0); this_letter; spirit(x_baryctr if serifs: +.25u fi)<; endchar; % cmchar "Lowercase iota with smooth breathing"; beginchar(oct"215",width#,acc_ht#,0); this_letter; spirit(x_baryctr if serifs: -.25u fi)>; endchar; % cmchar "Lowercase iota with acute"; beginchar(oct"225",width#,acc_ht#,0); this_letter; acute(x_baryctr); endchar; % cmchar "Lowercase iota with rough breathing and acute"; beginchar(oct"235",width#,acc_ht#,0); this_letter; spirit_acute(x_baryctr)<; endchar; % cmchar "Lowercase iota with smooth breathing and acute"; beginchar(oct"245",width#,acc_ht#,0); this_letter; spirit_acute(x_baryctr)>; endchar; % cmchar "Lowercase iota with rough breathing and grave"; beginchar(oct"265",width#,acc_ht#,0); this_letter; spirit_grave(x_baryctr)<; endchar; % cmchar "Lowercase iota with smooth breathing and grave"; beginchar(oct"275",width#,acc_ht#,0); this_letter; spirit_grave(x_baryctr)>; endchar; % cmchar "Lowercase iota with circumflex"; beginchar(oct"237",width#,circ_ht#,0); this_letter; circumflex(x_baryctr); endchar; % cmchar "Lowercase iota with grave"; beginchar(oct"255",width#,acc_ht#,0); this_letter; grave(x_baryctr); endchar; % cmchar "Lowercase iota with rough breathing and circumflex"; beginchar(oct"305",width#,Circ_ht#,0); this_letter; spirit_circumflex(x_baryctr)<; endchar; cmchar "Lowercase iota with smooth breathing and circumflex"; beginchar(oct"315",width#,Circ_ht#,0); this_letter; spirit_circumflex(x_baryctr)>; endchar; cmchar "Lowercase iota with diaeresis"; beginchar(oct"010",width#,circ_ht#,0); this_letter; diaeresis(x_baryctr); endchar; cmchar "Lowercase iota with diaeresis and grave"; beginchar(oct"012",width#,acc_ht#,0); this_letter; diaeresis_grave(x_baryctr); endchar; cmchar "Lowercase iota with diaeresis and acute"; beginchar(oct"011",width#,acc_ht#,0); this_letter; diaeresis_acute(x_baryctr); endchar; cmchar "Lowercase iota with diaeresis and circumflex"; beginchar(oct"013",width#,Circ_ht#,0); this_letter; diaeresis_circumflex(x_baryctr); endchar; picture savedpicture; % % ====================================================================== % KAPPA % ====================================================================== % def dims = 9.5u#,x_height#,0 enddef; def ital = 0 enddef; def fit_params = 0,0 enddef; % def gen_letter= pickup fine.nib; x1-.5stem=hround .75u; y1-.5stem=-o; % lower left z1+z3=(w,h); z2=.5[z1,z3]; % upper right and mid z1'=(z3-z1) if monowidth: xscaled 1/2 fi; % slope at 1 and 3 pos1(stem,angle z1'+90); pos2(.6[hair,stem],angle z1'+90); pos3(stem,angle z1'+90); filldraw double_circ_stroke z1e{z1'}..z2e..{z1'}z3e; % diagonal stroke z4=if monowidth: z1 else: 1/3[z1,z3] fi; z4-z1=z3-z7; % handle attachments z4'=if monowidth: z1' else: (z3-z1) xscaled .25 fi; % slope at 4 and 7 pos4(hair,angle z4'-90); pos7(hair,angle z4'+90); pos5(vstem,90); top y5r=h+o; pos6(vstem,180); z6l=z5l; lft x6r=hround(x1-.5stem-.25u); filldraw circ_stroke z6e{up}...z5e{right}...z4e{-z4'}; % left handle pos8(.5[vstem,stem],-90); bot y8r=-o; rt x9r=hround(x3+.5stem+.25u); pos9(.5[vstem,stem],0); z9l=z8l; filldraw circ_stroke z9e{down}...z8e{left}...z7e{z4'}; % right handle enddef; % cmchar "Lowercase kappa"; beginchar("k",dims); this_letter; penlabels(1,2,3,4,5,6,7,8,9,10); endchar; % picture savedpicture; % % ====================================================================== % LAMBDA % ====================================================================== % def dims = 9.5u#,asc_height#,0 enddef; def ital = 0 enddef; def fit_params = -.25u#,-.25u# enddef; def krn = -.75u# enddef; % def gen_letter= pickup fine.nib; x1-.5stem=hround .75u; y1+.5stem=h; % top left z1'=(1,.2); pos1(stem,angle z1'+90); % direction at z1 x3+x1=w; y3-.5stem=-oo; pos3(stem,-angle z1'+90); % bottom right y2=x_height-.5u; x2=.5[x1,x3]; % attachment z2'=(z3-z1)yscaled 2; pos2(hair,angle z2'+90); % direction at z4 filldraw double_circ_stroke z1e{z1'}... z2e{(z3-z1)yscaled 2}...{z1' yscaled -1}z3e; % diagonal lft x4l=hround.75u; bot y4l=0; % bottom left numeric stem'; stem'=stem-currentbreadth; numeric slope; % from z4 to z4 slope=angle(z2-z4l)+angle(length(z2-z4l)+-+.5stem',.5stem'); x4r=x4l+(stem'/sind slope); y4r=y4l; z4=.5[z4r,z4l]; path p; p=z1{z1'}...z2{(z3-z1)yscaled 2}...{z1' yscaled -1}z3; forsuffixes e=r,l: z5e=(z4e--(z4e+2(z2-z4))) intersectionpoint p; endfor filldraw stroke z4e{(z2-z4)if not monowidth: xscaled 1.2 fi}..z5e; enddef; % cmchar "Lowercase lambda"; beginchar("l",dims); this_letter; penlabels(1,2,3,4,5); endchar; % picture savedpicture; % % ====================================================================== % MI % ====================================================================== % def dims = 9.5u#,x_height#,desc_depth# enddef; def ital = 0 enddef; def fit_params = 0,.5stem# enddef; % def gen_letter= pickup fine.nib; y6+.5stem=h+o; pos6(stem,0); rt x6r=hround(w-vstem); % top right x5r=.5[x1,x6]; bot y5r=-oo; % bottom of bowl if straight: lft x1r=hround .75 u; y1+.5stem=h+o; pos1(stem,180); % top left x4=x1; x9=x6; y9=y4=.5x_height; pos4(stem,180); pos9(stem,0); pos5(vstem, 270); filldraw double_circ_stroke z1e..pulled_arc.e(4,5)&pulled_arc.e(5,9)..z6e; y8-.5stem=-d-oo; x8=x1; pos8(stem,180); % end of handle filldraw circ_stroke z8e..z4e; else: lft x2r=rt x2l-stem=hround .75u; % vertical tangents of left bulb top y1r=h+o; x1r=.5[x2r,x2l]; z1=z1l=z1r; z1'r=-z1'l=left; % top left y3r=.4[y1r,y5r]; lft x3r=x1r-.5hair; % middle left numeric tilt; tilt:=.6; path p.r, p.l; p.l=gr_arc.l(3,4,5)(hair,.4[hair,stem],tilt)...{up}z6l; p.r=subpath (2(1-tilt),2) of gr_arc.r(3,4,5)(fie,fo,fum)...{up}z6r; z3.5r=z4r; z3.5'r=z4'r; z3.5l=z3l; z3.5'l=z3'l; % a hybrid filldraw double_circ_stroke club.e(1,2,3.5) & p.e; % bowl x8=lft x2r+.5stem; bot y8=-d-oo; % end of handle pos8(stem,angle(z4'l xscaled 2)-120); z8'r=z8'l=z4'l xscaled 2; assign_z3'r(z3'l); % so club.r won't get confused lft x7r=rt x7l-max(hair,2)=lft x2r; % vertical tangents of handle filldraw double_circ_stroke club.e(3,7,8); % handle y9r=max(y4r+epsilon,-oo+2vstem); % where hook attaches z9r=((0,y9r)--(w,y9r)) intersectionpoint p.r; pos9(hair,0); fi pos10(vstem,90); y10l=y5r; x10-x9=vstem; % bottom of hook pos11(hair,180); top y11=bot y10l+4/3vstem; % tip of hook rt x11l=hround(x10+(y11-y10)+.5hair); % central arc is round filldraw stroke z9e{down}..z10e{right}..{up}z11e; % hook enddef; % cmchar "Lowercase mu"; beginchar("m",dims); this_letter; penlabels(1,2,3,4,5,6,7,8,9,10,11); endchar; % picture savedpicture; % % ====================================================================== % NI % ====================================================================== % def dims = 8.5u#,x_height#,0 enddef; def ital = 0 enddef; def fit_params = 0,0 enddef; % def gen_letter = pickup fine.nib; rt x4r=hround(w-.75u); lft x4l-rt x4r=hround -.2[hair,stem]; % vert tangents x5=lft x4l; y5+.5hair=h+oo; z5'l=z5'r=(u,-.2h); % right tip pos5(hair,angle z5'l+90); pos3(whatever,-90); bot y3r=-oo; x3=.5w; z3'l=z3'r=z5'l xscaled -2; % bottom z3l+whatever*z3'l=z3r+(stem-currentbreadth)*(dir(angle z3'l-90)); % width=stem filldraw circ_stroke club.e(5,4,3); % right stroke y1+.5stem=h+oo; x1-.5stem=hround.75u; % left tip z1'=(9u,-h); pos1(stem,angle z1'-90); z2r=z3r; z2l-z3l=(hair-currentbreadth,0); filldraw circ_stroke z1e{z1'}...{down}z2e; % left stroke enddef; % cmchar "Lowercase nu"; beginchar("n",dims); this_letter; penlabels(1,2,3,4,5); endchar; % picture savedpicture; % % ====================================================================== % XI % ====================================================================== % def dims = 8.5u#,asc_height#,desc_depth# enddef; def ital = 0 enddef; def fit_params = 0,0 enddef; % def gen_letter= pickup fine.nib; lft x7r=rt x7l-hair=hround(.75u); x7=.5[x7r,x7r]; % big bulge pos8(stem,-90); bot y8r=0; x8=.5w; z8'r=z8'l=left; % inflection pt pos9(hair,-180); rt x9l=hround(w-.75u); y9=-.5stem; % bottom right y6+.5stem=x_height+o; x6+.5stem=hround(rt x9l-1.5u); % middle right numeric slope; slope=angle(5(x6-x7),y6-y8); pos6(stem,slope+90); z6'r=z6'l=dir slope; pos10(vstem,-270); y9=.5[y10r,y8r]; x10-.5vstem=hround x8; filldraw double_circ_stroke % bowl and tail z10e{right}...z9e{up}...club.e(8,7,6); pos5(hair,slope-90); z5l=z6r; % attachment z4=.5[z3,z5]+whatever*dir slope; % small bulge pos4(hair,-180); lft x4r=hround(lft x7r+1.5u); y3+.5stem=h+o; x3+.5stem=hround(rt x9l-.25u); pos3(hair,slope+90); % top rt pos2(stem,slope+90); z2l=z3l; filldraw circ_stroke z2e{-dir slope}..z4{down}...z5e{dir slope}; % where handle attaches pos1(curve,0); lft x1l=hround(lft x7r+.25u); y1+.5curve=h+o; % end of handle filldraw circ_stroke z1e{down}...z3e{dir slope}; enddef; % cmchar "Lowercase xi"; beginchar("x",dims); this_letter; penlabels(1,2,3,4,5,6,7,8,9,10); endchar; % picture savedpicture; % % ====================================================================== % OMIKRON % ====================================================================== % def width = 9.5u enddef; def dims = width#,x_height#,0 enddef; def ital = 0 enddef; def fit_params = 0,0 enddef; % def gen_letter = pickup fine.nib; lft x4r=hround .75u; x8r=w-x4r; y4r=y8r=.5x_height; % top and bottom top y2r=x_height+oo; bot y6r=-oo; x2r=x6r=.5w; % right and left filldraw stroke gr_arc.e(8,1,2)(vair,curve,otilt) & gr_arc.e(2,3,4)(vair,curve,otilt) & gr_arc.e(4,5,6)(vair,curve,otilt) & gr_arc.e(6,7,8)(vair,curve,otilt) ; numeric x_baryctr; x_baryctr=x2; % accent reference enddef; % cmchar "Lowercase omicron"; beginchar("o",dims); this_letter; penlabels(1,2,3,4,5,6,7,8); endchar; % cmchar "Lowercase omicron with rough breathing"; beginchar(oct"203",width#,acc_ht#,0); this_letter; spirit(x_baryctr)<; endchar; % cmchar "Lowercase omicron with smooth breathing"; beginchar(oct"213",width#,acc_ht#,0); this_letter; spirit(x_baryctr)>; endchar; % cmchar "Lowercase omicron with acute"; beginchar(oct"223",width#,acc_ht#,0); this_letter; acute(x_baryctr); endchar; % cmchar "Lowercase omicron with rough breathing and acute"; beginchar(oct"233",width#,acc_ht#,0); this_letter; spirit_acute(x_baryctr)<; endchar; % cmchar "Lowercase omicron with smooth breathing and acute"; beginchar(oct"243",width#,acc_ht#,0); this_letter; spirit_acute(x_baryctr)>; endchar; % cmchar "Lowercase omicron with rough breathing and grave"; beginchar(oct"263",width#,acc_ht#,0); this_letter; spirit_grave(x_baryctr)<; endchar; % cmchar "Lowercase omicron with smooth breathing and grave"; beginchar(oct"273",width#,acc_ht#,0); this_letter; spirit_grave(x_baryctr)>; endchar; % cmchar "Lowercase omicron with grave"; beginchar(oct"253",width#,acc_ht#,0); this_letter; grave(x_baryctr); endchar; % picture savedpicture; % % ====================================================================== % PI % ====================================================================== % def dims = 9.5u#,x_height#,0 enddef; def ital = 0 enddef; def fit_params = -.25,0 enddef; % def gen_letter = pickup fine.nib; pi_bar; % bar pos4(hair,0); pos7(hair,0); y4=y7=y2; % attachments lft x4l-(x1-.5hair)=lft x7l-rt x4r=rt x3-rt x7r; pos5(hair,0); pos8(hair,0); y5=y8=.5x_height; x5=x4; x8=x7; % midstems x6+.5stem=hround(rt x4r if not straight:-.25u fi); y6-.7stem=-oo; % left stem numeric slope; slope=angle((z5-z6)xscaled2); pos6(1.2stem,slope-90); filldraw circ_stroke z6e...z5e---z4e; x9=x7+1.5u; bot y9l=-oo; pos9(stem,90); alpha_tail(9,10); % right stem filldraw stroke z10e...z9e{left}...z8e---z7e; enddef; % cmchar "Lowercase pi"; beginchar("p",dims); this_letter; penlabels(1,2,3,4,5,6,7,8,9,10); endchar; % picture savedpicture; % % ====================================================================== % RO % ====================================================================== % def width = 8.5u enddef; def height = x_height enddef; def depth = desc_depth enddef; def dims = width#,height#,depth# enddef; def ital = 0 enddef; def fit_params = 0,0 enddef; % def gen_letter = pickup fine.nib; lft x4r=hround .75u; x8r=w-x4r; y4r=y8r=.5h; % left and right top y2r=h+oo; bot y6r=-oo; x2r=x6r=.5w; % top and bottom filldraw stroke gr_arc.e(4,5,6)(curve,vair,-otilt) & gr_arc.e(6,7,8)(curve,vair,-otilt) & gr_arc.e(8,1,2)(curve,vair,-otilt) & gr_arc.e(2,3,4)(curve,vair,-otilt); if straight: y9-.5stem=-d-oo; x9=x4; pos9(stem,180); % end of handle filldraw circ_stroke z9e..z4e; else: y9=-d-oo; x9=lft x4r+.5stem; % end of handle pos9(stem,angle((z9-z4)xscaled3)-120); z9'r=z9'l=(z9-z4)xscaled3; rt x10l=lft x10r+vair; % vertical tangents of handle x10r=x4r-epsilon; assign_z4'r((-2eps,-1)); % so club.r won't get confused filldraw double_circ_stroke club.e(4,10,9); fi numeric x_baryctr; x_baryctr=x2; % breathing placement enddef; % cmchar "Lowercase rho"; beginchar("r",dims); this_letter; penlabels(1,2,3,4,5,6,7,8,9,10); endchar; % cmchar "Lowercase rho with rough breathing"; beginchar(oct"346",width#,acc_ht#,depth#); this_letter; spirit(x_baryctr)<; endchar; cmchar "Lowercase rho with smooth breathing"; beginchar(oct"356",width#,acc_ht#,depth#); this_letter; spirit(x_baryctr)>; endchar; % picture savedpicture; % % ====================================================================== % SIGMA % ====================================================================== % def dims= 8u#,x_height#,desc_depth# enddef; def ital = 0 enddef; def fit_params = 0,0 enddef; % def gen_letter = pickup fine.nib; pos4(hair,-180); y4=.5h; lft x4r=hround .75u; % left bulge pos6(hair,-180); rt x6l=hround(w-.75u); y6=-.5stem; % bottom right top y3r=h+oo; x3+.5stem=rt x6l; pos3(stem,90); % top right pos5(stem,-90); bot y5r=0; x5=.5w; % inflection pt pos7(vstem,-270); y6=.5[y7r,y5r]; x7-.5vstem=hround x5; filldraw double_circ_stroke % bowl and tail z7e{right}...z6e{up}...z5e{left}...z4e{up}...z3e{right}; enddef; % cmchar "Final lowercase sigma"; beginchar("c",dims); this_letter; penlabels(1,2,3,4,5,6,7,8); endchar; % numeric gen_sigma; gen_sigma=1; % def dim_sigma = 9.5u#,x_height#,0 enddef; def ital_sigma = 0 enddef; def fit_params_sigma = 0,.75u# enddef; % def mid_sigma= italcorr ital_sigma; adjust_fit(fit_params_sigma); if known pic.c: currentpicture:=pic.c; else: gen_mid_sigma; fi if not working_hard : picture pic.c; pic.c=currentpicture; fi enddef; % def gen_mid_sigma = pickup fine.nib; lft x4r=hround .75u; rt x8r=w-lft x4r; % left and right bulge top y2r=h; bot y6r=-oo; x2r=x6r; % top and bottom numeric fake; fake=y2r-(vstem-currentbreadth); % approx height of |z2l| 2y4r=y2r+y6r; 2y8r=fake+y6r; (x8r-x6r)/(y8r-y6r)=-(x4r-x6r)/(y4r-y6r); % determine |x6r| y1r=y2r;rt x1=hround(rt x8r+u); pos1(flare,90); % tip filldraw stroke z1e..gr_arc.e(2,3,4)(vstem,curve,otilt) & gr_arc.e(4,5,6)(vair,curve,otilt) % top stroke and left bowl & gr_arc.e(6,7,8)(vair,curve,otilt); % bottom part of right bowl z9l=z2l; pos9(vair,180); z9'l=z2'l; z9'r=left; filldraw stroke z8e{z8'e}..z9e{z9'e}; % top part of right bowl enddef; % cmchar "Initial and medial lowercase sigma"; beginchar("s",dim_sigma); mid_sigma; penlabels(1,2,3,4,5,6,7,8,9); endchar; % picture savedpicture; % % ====================================================================== % TAU % ====================================================================== % def dims = 8.5u#,x_height#,0 enddef; def ital = 0 enddef; def fit_params = -.25,0 enddef; % def gen_letter= pickup fine.nib; pi_bar; % bar pos4(hair,0); y4=y2; lft x4l-(x1-.5hair)=rt x3-rt x4r; % attachment pos5(hair,0); y5=.5x_height; x5=x4; % midstems x6=x4+1.5u; bot y6l=-oo; pos6(stem,90); alpha_tail(6,7); % stem filldraw stroke z7e...z6e{left}...z5e---z4e; enddef; % cmchar "Lowercase tau"; beginchar("t",dims); this_letter; penlabels(1,2,3,6,7,8); endchar; % picture savedpicture; % % ====================================================================== % UPSILON % ====================================================================== % def width = 9u enddef; def dims = width#,x_height#,0 enddef; def ital = 0 enddef; def fit_params = 0,0 enddef; % def gen_letter= pickup fine.nib; y2+.5stem=x_height+o; x2-.5stem=hround.75u; % left tip lft x4r=hround(x2-.5stem+.75u); y4r=.5x_height; % left middle y8r=y4r; rt x8r=hround(w-.75u); % right bulge x6r=.5[x4r,x8r]; bot y6r=-oo; % bottom numeric tilt; tilt:=min(2*otilt,.5); filldraw stroke gr_arc.e(6,7,8)(vair,stem,tilt) ; filldraw stroke gr_arc.e(4,5,6)(vair,.4[vair,stem],tilt) ; y9+.5hair=x_height+o; x9=x8-u; pos9(hair,angle ((z8-z9) xscaled 2)+90); filldraw circ_stroke z9e...{-z8'e}z8e; pos2(stem,angle((z4-z2) xscaled 2)-90); filldraw circ_stroke z2e...{z4'e}z4e; numeric x_baryctr; x_baryctr=.5w; enddef; % cmchar "Lowercase upsilon"; beginchar("u",dims); this_letter; penlabels(1,2,3,4,5,6,7,8,9); endchar; % cmchar "Lowercase upsilon with rough breathing"; beginchar(oct"206",width#,acc_ht#,0); this_letter; spirit(x_baryctr)<; endchar; % cmchar "Lowercase upsilon with smooth breathing"; beginchar(oct"216",width#,acc_ht#,0); this_letter; spirit(x_baryctr)>; endchar; % cmchar "Lowercase upsilon with acute"; beginchar(oct"226",width#,acc_ht#,0); this_letter; acute(x_baryctr); endchar; % cmchar "Lowercase upsilon with rough breathing and acute"; beginchar(oct"236",width#,acc_ht#,0); this_letter; spirit_acute(x_baryctr)<; endchar; % cmchar "Lowercase upsilon with smooth breathing and acute"; beginchar(oct"246",width#,acc_ht#,0); this_letter; spirit_acute(x_baryctr)>; endchar; % cmchar "Lowercase upsilon with rough breathing and grave"; beginchar(oct"266",width#,acc_ht#,0); this_letter; spirit_grave(x_baryctr)<; endchar; % cmchar "Lowercase upsilon with smooth breathing and grave"; beginchar(oct"276",width#,acc_ht#,0); this_letter; spirit_grave(x_baryctr)>; endchar; % cmchar "Lowercase upsilon with circumflex"; beginchar(oct"247",width#,circ_ht#,0); this_letter; circumflex(x_baryctr); endchar; % cmchar "Lowercase upsilon with grave"; beginchar(oct"256",width#,acc_ht#,0); this_letter; grave(x_baryctr); endchar; % cmchar "Lowercase upsilon with rough breathing and circumflex"; beginchar(oct"306",width#,Circ_ht#,0); this_letter; spirit_circumflex(x_baryctr)<; endchar; % cmchar "Lowercase upsilon with smooth breathing and circumflex"; beginchar(oct"316",width#,Circ_ht#,0); this_letter; spirit_circumflex(x_baryctr)>; endchar; % cmchar "Lowercase upsilon with diaeresis"; beginchar(oct"014",width#,circ_ht#,0); this_letter; diaeresis(x_baryctr); endchar; cmchar "Lowercase upsilon with diaeresis and grave"; beginchar(oct"016",width#,acc_ht#,0); this_letter; diaeresis_grave(x_baryctr); endchar; cmchar "Lowercase upsilon with diaeresis and acute"; beginchar(oct"015",width#,acc_ht#,0); this_letter; diaeresis_acute(x_baryctr); endchar; cmchar "Lowercase upsilon with diaeresis and circumflex"; beginchar(oct"017",width#,Circ_ht#,0); this_letter; diaeresis_circumflex(x_baryctr); endchar; picture savedpicture; % % ====================================================================== % FI % ====================================================================== % def dims = 10.5u#,x_height#,desc_depth# enddef; def ital = 0 enddef; def fit_params = 0,0 enddef; % def gen_letter = pickup fine.nib; lft x4r=w-rt x8r=hround .75u; y4r=y8r=.5h; x6r=.5[x4r,x8r]; bot y6r=-oo; numeric tilt; tilt:=min(2*otilt,.5); filldraw stroke gr_arc.e(6,7,8)(vair,stem,tilt) ; filldraw stroke gr_arc.e(4,5,6)(vair,.5[vair,stem],tilt) ; y2+.5stem=h+o; x2+.5stem=hround(x6-1.5u); pos2(stem,angle((z2-z4)xscaled 2)+90); filldraw circ_stroke z2e...{z4'e}z4e; pos10(stem,180); pos11(hair,180); y10-.5stem=-d-o; y11=.25h; x10=x11=x6; x9r=.5[x10r,x8r]; top y9r=h+o; filldraw stroke gr_arc.e(8,20,9)(.25[vair,stem],.5[vair,stem],.5tilt); filldraw circ_stroke z10e..z11e{up}..{-z9'e}z9e; enddef; % cmchar "Lowercase phi"; beginchar("f",dims); this_letter; penlabels(1,2,3,4,5,6,7,8,9,10,11,12,20,21); endchar; % picture savedpicture; % % ====================================================================== % HI % ====================================================================== % def ital = 0 enddef; def fit_params = 0,0 enddef; def dims = 10u#,x_height#,desc_depth# enddef; % def gen_letter= pickup fine.nib; x1-.5stem=hround .75u; y1+.5stem=h+oo; % top left z1'=(1,.2); pos1(stem,angle z1'+90); % direction at z1 x3+x1=w; y3-.5stem=-d-oo; pos3(stem,angle z1'+90); % bottom right z2=.5[z1,z3]; % attachment z2'=(z3-z1)yscaled 2; pos2(hair,angle z2'+90); % direction at z4 filldraw double_circ_stroke z1e{z1'}... z2e{(z3-z1)yscaled 2}...{z1'}z3e; lft x7l=hround .75u; bot y7l=-d-oo; z2=.5[z7l,z8r]=.5[z7r,z8l]; numeric stem'; stem'=stem-currentbreadth; numeric theta; theta=angle(z8r-z7l)+angle((x8r-x7l)++(y8r-y7l)+-+stem',stem'); x7r=x7l+(stem'/sind theta); y7r=y7l; filldraw stroke z7e..z8e; enddef; % cmchar "Lowercase chi"; beginchar("q",dims); this_letter; penlabels(1,2,3,7,8); endchar; % picture savedpicture; % % ====================================================================== % YI % ====================================================================== % def dims = 10.5u#,asc_height#,desc_depth# enddef; def ital = 0 enddef; def fit_params = 0,0 enddef; % def gen_letter = pickup fine.nib; lft x2r=w-rt x6r=.75u; y2r=y6r=.6x_height; %left and right bulges x4r=.5[x2r,x6r]; bot y4r=-oo; %bottom numeric tilt; tilt:=min(2*otilt,.5); filldraw stroke gr_arc.e(4,5,6)(vair,stem,tilt) ; filldraw stroke gr_arc.e(2,3,4)(vair,.4[vair,stem],tilt) ; y7+.5hair=x_height+o; x7+.5hair=hround(rt x6r-.75u); %right tip pos7(hair,angle ((z6-z7) xscaled 2)+90); filldraw circ_stroke z7e...{-z6'e}z6e; y1+.5stem=x_height+o; x1-.5stem=hround(lft x2r+.5u); %left tip pos1(stem,angle((z2-z1) xscaled 2)-90); filldraw circ_stroke z1e...{z2'e}z2e; pos10(stem,0); pos9(hair,0); pos8(stem,0); %vertical stroke y10-.5stem=-d-o; y9=.25x_height; y8+.5stem=h+o; x10=x9=x8=x4; filldraw double_circ_stroke z10e..z9e{up}..z8e; enddef; % cmchar "Lowercase psi"; beginchar("y",dims); this_letter; penlabels(1,2,3,4,5,6,7,8,9,10); endchar; % picture savedpicture; % % ====================================================================== % WMEGA % ====================================================================== % def width = 12u enddef; def height = x_height enddef; def dims = width#,height#,0 enddef; def ital = 0 enddef; def fit_params = 0,0 enddef; % def gen_letter = pickup fine.nib; pos2(stem,-180); pos8(stem,360); lft x2r=w-rt x8r=hround.75u; y2=y8=.8bar_height; % left and right bulges y4=y6=bar_height; .5[x4,x6]=.5w; rt x4r-lft x6r=stem; pos4(hair,0); pos6(hair,180); % left and right of loop bot y3r=bot y7r=-oo; x3=.5[x2,x4]; x7+.25u=.5[x6,x8]; pos3(vstem,-150); pos7(vstem,330); % left and right bottom top y1r=x_height+o=top y9r; % left tip x1=.5[x2,.5w]; pos1(.2[stem,hair],angle(-.5w,y2-x_height)-90); x9=.5[x8,.5w]; pos9(.8[stem,hair],angle(-.5w,x_height-y2)-90); % rt tip filldraw stroke z1e{(z2-z1) xscaled 2}...z2e{down}...z3e{right}; filldraw stroke z7e{right}...{up}z8e...{(z9-z8) xscaled 2}z9e; drawloop(3,4,6,7); numeric x_baryctr; x_baryctr=.5[x4,x6]; numeric pos_stem; pos_stem=x_baryctr; enddef; % cmchar "Lowercase omega"; beginchar("w",dims); this_letter; penlabels(0,1,2,3,4,5,6,7,8,9); endchar; % cmchar "Lowercase omega with rough breathing"; beginchar(oct"204",width#,acc_ht#,0); this_letter; spirit(x_baryctr)<; endchar; % cmchar "Lowercase omega with smooth breathing"; beginchar(oct"214",width#,acc_ht#,0); this_letter; spirit(x_baryctr)>; endchar; % cmchar "Lowercase omega with acute"; beginchar(oct"224",width#,acc_ht#,0); this_letter; acute(x_baryctr); endchar; % cmchar "Lowercase omega with rough breathing and acute"; beginchar(oct"234",width#,acc_ht#,0); this_letter; spirit_acute(x_baryctr)<; endchar; % cmchar "Lowercase omega with smooth breathing and acute"; beginchar(oct"244",width#,acc_ht#,0); this_letter; spirit_acute(x_baryctr)>; endchar; % cmchar "Lowercase omega with rough breathing and grave"; beginchar(oct"264",width#,acc_ht#,0); this_letter; spirit_grave(x_baryctr)<; endchar; % cmchar "Lowercase omega with smooth breathing and grave"; beginchar(oct"274",width#,acc_ht#,0); this_letter; spirit_grave(x_baryctr)>; endchar; % cmchar "Lowercase omega with circumflex"; beginchar(oct"227",width#,circ_ht#,0); this_letter; circumflex(x_baryctr); endchar; % % cmchar "Lowercase omega with grave"; beginchar(oct"254",width#,acc_ht#,0); this_letter; grave(x_baryctr); endchar; % cmchar "Lowercase omega with rough breathing and circumflex"; beginchar(oct"304",width#,Circ_ht#,0); this_letter; spirit_circumflex(x_baryctr)<; endchar; cmchar "Lowercase omega with smooth breathing and circumflex"; beginchar(oct"314",width#,Circ_ht#,0); this_letter; spirit_circumflex(x_baryctr)>; endchar; % cmchar "Lowercase omega with grave and iota subscript"; beginchar(oct"334",width#,acc_ht#,iota_dp#); this_letter; grave(x_baryctr); iota_sub(pos_stem); endchar; cmchar "Lowercase omega with rough breathing and iota subscript"; beginchar(oct"344",width#,acc_ht#,iota_dp#); this_letter; spirit(x_baryctr)<; iota_sub(pos_stem); endchar; cmchar "Lowercase omega with smooth breathing and iota subscript"; beginchar(oct"354",width#,acc_ht#,iota_dp#); this_letter; spirit(x_baryctr)>; iota_sub(pos_stem); endchar; cmchar "Lowercase omega with acute and iota subscript"; beginchar(oct"325",width#,acc_ht#,iota_dp#); this_letter; acute(x_baryctr); iota_sub(pos_stem); endchar; cmchar "Lowercase omega with rough breathing, acute and iota subscript"; beginchar(oct"335",width#,acc_ht#,iota_dp#); this_letter; spirit_acute(x_baryctr)<; iota_sub(pos_stem); endchar; cmchar "Lowercase omega with smooth breathing and acute and iota subscript"; beginchar(oct"345",width#,acc_ht#,iota_dp#); this_letter; spirit_acute(x_baryctr)>; iota_sub(pos_stem); endchar; cmchar "Lowercase omega with rough breathing, grave and iota subscript"; beginchar(oct"364",width#,acc_ht#,iota_dp#); this_letter; spirit_grave(x_baryctr)<; iota_sub(pos_stem); endchar; cmchar "Lowercase omega with smooth breathing and grave and iota subscript"; beginchar(oct"365",width#,acc_ht#,iota_dp#); this_letter; spirit_grave(x_baryctr)>; iota_sub(pos_stem); endchar; cmchar "Lowercase omega with circumflex and iota subscript"; beginchar(oct"355",width#,circ_ht#,iota_dp#); this_letter; circumflex(x_baryctr); iota_sub(pos_stem); endchar; cmchar "Lowercase omega with rough breathing, circumflex and iota subscript"; beginchar(oct"326",width#,acc_ht#,iota_dp#); this_letter; spirit_circumflex(x_baryctr)<; iota_sub(pos_stem); endchar; cmchar "Lowercase omega with smooth breathing, circumflex and iota subscript"; beginchar(oct"336",width#,acc_ht#,iota_dp#); this_letter; spirit_circumflex(x_baryctr)>; iota_sub(pos_stem); endchar; cmchar "Lowercase omega with iota subscript"; beginchar(oct"324",width#,height#,iota_dp#); this_letter; iota_sub(pos_stem); endchar; picture pic.iota; picture savedpicture; endinput; % ======================================================================