Métapost : exemples
warningcheck:=0;
input rboxes;
input sarith;
input graph;
verbatimtex
\documentclass[a4paper,12pt]{article}
\usepackage[T1]{fontenc}
\usepackage[latin1]{inputenc}
\begin{document}
etex
vardef TEX primary s =
write "verbatimtex" to "mptextmp.mp";
write "\documentclass[12pt]{article}" to "mptextmp.mp";
write "\usepackage[T1]{fontenc}" to "mptextmp.mp";
write "\usepackage{amsmath,amssymb}" to "mptextmp.mp";
write "\begin{document}" to "mptextmp.mp";
write "etex" to "mptextmp.mp";
write "btex "&s&" etex" to "mptextmp.mp";
write EOF to "mptextmp.mp";
scantokens "input mptextmp"
enddef;
vardef longueur(expr p) =
save l,i;
numeric l;
l:=0;
for i=0 step .01 until length(p):
l:=l+abs( (point i of p) - (point(i+.01) of p) );
endfor;
l % Pas de point-virgule
enddef;
vardef milieu(expr p) =
save l,i,tot,A,B;
numeric l,tot,i;
pair A,B;
tot := longueur(p);
l:=0;
B := point 0 of p;
for i:=0 step .01 until length(p):
A := B;
B := point i of p;
l := l+abs(B-A);
exitif l > 1/2 tot;
endfor;
show l; show tot;
1/2[A,B]
enddef;
vardef milieu_time(expr p) =
save l,i,tot,A,B,t;
numeric l,tot,i,t;
pair A,B;
tot := longueur(p);
l:=0;
B := point 0 of p;
for i:=0 step .01 until length(p):
t:=i;
A := B;
B := point i of p;
l := l+abs(B-A);
exitif l > 1/2 tot;
endfor;
t
enddef;
data:image/s3,"s3://crabby-images/08abd/08abd7c1aa4e23a2aff6f70a2d2fc2c6360a09ad" alt=""
beginfig(1)
pair A, B, C;
A:=(0,0); B:=(1cm,0); C:=(0,1cm);
draw A--B--C;
endfig;
data:image/s3,"s3://crabby-images/77cfd/77cfdde770352d567998266407313d51be63cf72" alt=""
beginfig(2)
pair A, B, C;
A:=(0,0); B:=(1cm,0); C:=(0,1cm);
draw A--B--C--cycle;
endfig;
data:image/s3,"s3://crabby-images/1d327/1d327559e2ffa6867b6b38e98eb9cff6695a84a4" alt=""
beginfig(3)
pair A[];
A[0]:=(-1cm, -1cm);
A[1]:=( 1cm, -1cm);
A[2]:=( 1cm, 1cm);
A[3]:=(-1cm, 1cm);
draw A[0]--A[1]--A[2]--A[3]--cycle;
draw A[0]--A[2];
draw A[1]--A[3];
endfig;
data:image/s3,"s3://crabby-images/f9085/f9085e2d7a78cc1c21359c30c36f0f6bb9ab3a89" alt=""
beginfig(4)
pair A;
A:=(0,0); B:=(1cm,0); C:=(0,1cm);
draw A withpen pencircle scaled 4bp;
endfig;
data:image/s3,"s3://crabby-images/cf80a/cf80ab749b6142a62960ced8a243d62ac21b2a4c" alt=""
beginfig(5)
pair A, B, C;
A:=(0,0); B:=(1cm,0); C:=(0,1cm);
draw A--B--C--cycle;
draw A withpen pencircle scaled 4bp;
draw B withpen pencircle scaled 4bp;
draw C withpen pencircle scaled 4bp;
endfig;
data:image/s3,"s3://crabby-images/4dc02/4dc021d4895a8b10a56410528f7fc71ad51a69e0" alt=""
beginfig(6)
pair A, B, C, D;
A:=(0,0); B:=(1cm,0);
C:=(1cm,1cm); D:=(0,1cm);
draw A--B--C--D--cycle;
draw A--C;
draw B--D;
draw A withpen pencircle scaled 4bp;
draw B withpen pencircle scaled 4bp;
draw C withpen pencircle scaled 4bp;
draw D withpen pencircle scaled 4bp;
endfig;
data:image/s3,"s3://crabby-images/a9439/a94397fff4cf79f06f3e2b8521c30dcf634739f1" alt=""
beginfig(7)
pair A, B, C;
A:=(0,0); B:=(1cm,0); C:=(0,1cm);
draw A--B--C--cycle;
draw 1/2[A,B] -- C;
draw 1/2[B,C] -- A;
draw 1/2[C,A] -- B;
endfig;
data:image/s3,"s3://crabby-images/78601/78601aa37e76277f6d86562f27549ed82eb5fe80" alt=""
beginfig(8)
pair A, B, C;
A:=(0,0); B:=(1cm,0); C:=(0,1cm);
draw A--B--C--cycle;
draw 1/2[A,B] -- C;
draw 1/2[B,C] -- A;
draw 1/2[C,A] -- B;
draw 1/3 A + 1/3 B + 1/3 C
withpen pencircle scaled 4bp;
endfig;
data:image/s3,"s3://crabby-images/2ebe9/2ebe9c22206e5a933f74d54b75c1eeb9e06a69fd" alt=""
beginfig(9)
pair A, B, C;
A:=(0,0); B:=(1cm,0); C:=(0,1cm);
draw A--B--C--cycle;
draw A--B withpen pencircle scaled 2bp;
endfig;
data:image/s3,"s3://crabby-images/0bdfe/0bdfe109e512960f1a06277ba2311fa3c810bd7f" alt=""
beginfig(10)
pair A, B, C;
A:=(0,0); B:=(1cm,0); C:=(0,1cm);
draw A--B--C--cycle;
draw A--B withcolor (green + red);
endfig;
data:image/s3,"s3://crabby-images/504cd/504cd3a45d8a42996fca06932c15de6871f3f447" alt=""
beginfig(11)
pair A, B, C;
A:=(0,0); B:=(1cm,0); C:=(0,1cm);
draw A--B;
draw B--C dashed evenly;
draw C--A dashed withdots;
endfig;
data:image/s3,"s3://crabby-images/28b5c/28b5c0d8a7310bb7f87a406b1b162f97b8170efa" alt=""
beginfig(12)
pair A, B, C;
A:=(0,0); B:=(1cm,0); C:=(0,1cm);
draw A--B withpen pencircle scaled 2bp withcolor .8white;
draw B--C withpen pencircle scaled 2bp withcolor .6white;
draw C--A withpen pencircle scaled 2bp withcolor .4white;
endfig;
data:image/s3,"s3://crabby-images/87cc2/87cc299916a8974c90ca9a61a452254547df524a" alt=""
beginfig(13)
pair A, B, C;
A:=(0,0); B:=(1cm,0); C:=(0,1cm);
draw A--B--C--cycle;
draw 1/2[A,B] -- C dashed evenly;
draw 1/2[B,C] -- A dashed evenly;
draw 1/2[C,A] -- B dashed evenly;
draw 1/3 A + 1/3 B + 1/3 C
withpen pencircle scaled 4bp
withcolor red;
endfig;
data:image/s3,"s3://crabby-images/fe3df/fe3df1fd4a42922d4b7d5242a6b267b155cee3cc" alt=""
beginfig(14)
draw (0,0)--(3cm,0) dashed evenly scaled 2;
draw (0,-5mm)--(3cm,-5mm) dashed evenly;
endfig;
data:image/s3,"s3://crabby-images/6b0aa/6b0aa61d54d9bbb817d061d3b23972c053a1f1f0" alt=""
beginfig(15)
draw (0,0)--(3cm,0)
dashed dashpattern(on 2bp off 3bp);
endfig;
data:image/s3,"s3://crabby-images/0749d/0749d16eaa797703e8918507559f715521b6ecf8" alt=""
beginfig(16)
draw (0,0)--(3cm,0) dashed dashpattern(on 1bp off 2bp on 10bp off 2bp);
endfig;
data:image/s3,"s3://crabby-images/69724/697249a8bcba0a6e166af6e3b07625d23208981d" alt=""
beginfig(17)
pair A, B, C;
A:=(0,0); B:=(1cm,0); C:=(0,1cm);
drawarrow C--B--A;
drawarrow A--C withpen pencircle scaled 2bp;
endfig;
data:image/s3,"s3://crabby-images/7fbad/7fbad28b3b0f5544a08a0d830822503f2c7a7f1d" alt=""
beginfig(18)
pair A, B, C;
A:=(0,0); B:=(1cm,0); C:=(0,1cm);
draw C--B--A--cycle;
drawdblarrow A--C withpen pencircle scaled 2bp;
endfig;
data:image/s3,"s3://crabby-images/a1493/a1493399fa33daf858a17d370614c8e0d47850fb" alt=""
beginfig(19)
draw (-1.5cm,0)--(1.5cm,0);
draw (0,-1.5cm)--(0,1.5cm);
drawarrow (0,0)--(1cm,0)
withpen pencircle scaled 2bp;
drawarrow (0,0)--(0,1cm)
withpen pencircle scaled 2bp;
endfig;
data:image/s3,"s3://crabby-images/b2a32/b2a3293d2737483545dddadc07ba893843500043" alt=""
beginfig(20)
pair A, B, C;
A:=(0,0); B:=(1cm,0); C:=(0,1cm);
fill A--B--C--cycle withcolor .8 white;
endfig;
data:image/s3,"s3://crabby-images/edde7/edde78085482637deab4ecd9625ff7067ed6e04d" alt=""
beginfig(21)
pair A, B, C;
A:=(0,0); B:=(1cm,0); C:=(0,1cm);
fill A--B--C--cycle withcolor .8 white;
draw A--B--C--cycle;
endfig;
data:image/s3,"s3://crabby-images/f7fcf/f7fcf5a6f88c6328660bfa015de02a03fc9f5975" alt=""
beginfig(22)
pair A, B, C;
A:=(0,0); B:=(1cm,0); C:=(0,1cm);
fill A--B--C--cycle withcolor .8 white;
draw A--B--C--cycle withpen pencircle scaled 2bp;
endfig;
data:image/s3,"s3://crabby-images/999e1/999e1821b461d6e7dcc559489b09a0fb0f01246f" alt=""
beginfig(23)
pair A, B, C;
A:=(0,0); B:=(1cm,0); C:=(0,1cm);
draw A--B--C--cycle withpen pencircle scaled 2bp;
fill A--B--C--cycle withcolor .8 white;
endfig;
data:image/s3,"s3://crabby-images/0b9b2/0b9b262f6c4b5d7ec539181879c6f25ce70db025" alt=""
beginfig(24)
pair A, B, C, D;
A:=(0,0); B:=(1cm,0);
C:=(1cm,1cm); D:=(0,1cm);
fill A--C--B--D--cycle withcolor .8white;
endfig;
data:image/s3,"s3://crabby-images/113d7/113d7a5ccf27b9f107fff484d501d595e61095da" alt=""
beginfig(25)
pair A, B, C, D;
A:=(0,0); B:=(1cm,0);
C:=(1cm,1cm); D:=(0,1cm);
path p;
p := A--C--B--D--cycle;
fill p withcolor .8white;
draw p;
endfig;
data:image/s3,"s3://crabby-images/abb46/abb4664554068899068db17d754a59f76c9dcdd2" alt=""
beginfig(26)
pair A, B, C, D;
A:=(-1.5cm,-1.5cm); B:=(1.5cm,-1.5cm);
C:=(1.5cm,1.5cm); D:=(-1.5cm,1.5cm);
fill A--C--B--D--cycle withcolor .8white;
draw (-1.5cm,0)--(1.5cm,0);
draw (0,-1.5cm)--(0,1.5cm);
drawarrow (0,0)--(1cm,0)
withpen pencircle scaled 2bp;
drawarrow (0,0)--(0,1cm)
withpen pencircle scaled 2bp;
endfig;
data:image/s3,"s3://crabby-images/b2adc/b2adc5e0603e1e9760580071ec5dd9b5d6fd061a" alt=""
beginfig(27)
pair A;
A := (0,0);
draw A withpen pencircle scaled 4bp;
label.top(btex Au dessus etex, A);
label.bot(btex En dessous etex, A);
label.rt (btex À droite etex, A);
label.lft(btex À gauche etex, A);
endfig;
data:image/s3,"s3://crabby-images/86163/861637a92966c11c5a6cdf9ca2ca256e32d3adc8" alt=""
beginfig(28)
pair A;
A := (0,0);
draw A withpen pencircle scaled 4bp;
label.ulft(btex En haut à gauche etex, A);
label.urt (btex En haut à droite etex, A);
label.llft(btex En bas à gauche etex, A);
label.lrt (btex En bas à droite etex, A);
endfig;
data:image/s3,"s3://crabby-images/11ada/11adae99caa5a72297707b0e2decf34a01d784c8" alt=""
beginfig(29)
pair A;
A := (0,0);
dotlabel.urt(btex $A$ etex, A);
endfig;
data:image/s3,"s3://crabby-images/985b9/985b99ef8fd59fc441c0d6f0fdf404e1c557b552" alt=""
beginfig(30)
pair A, B, C;
A:=(0,0); B:=(1cm,0); C:=(0,1cm);
draw A--B--C--cycle;
dotlabel.llft(btex $A$ etex, A);
dotlabel.lrt(btex $B$ etex, B);
dotlabel.top(btex $C$ etex, C);
endfig;
data:image/s3,"s3://crabby-images/5a6af/5a6afab09fd351d357fe41bcc1cdabd69ce7a83c" alt=""
beginfig(31)
pair A, B, C;
A:=(0,0); B:=(1cm,0); C:=(0,1cm);
draw A--B--C--cycle;
label.bot(btex $1$ etex, 1/2[A,B]);
label.lft(btex $1$ etex, 1/2[A,C]);
label.urt(btex $\sqrt 2$ etex, 1/2[B,C]);
endfig;
data:image/s3,"s3://crabby-images/377be/377becbd2f5d0be9c6d246833cd7e589a6bd74b8" alt=""
beginfig(32)
u:=1cm;
pair A,B,C,D,E,F,G;
A := (-u,u);
B := (0,u);
C := (u,u);
D := (-u,0);
E := (0,0);
F := (u,0);
draw A--D; draw A--E; draw A--F;
draw B--D; draw B--E; draw B--F;
draw C--D; draw C--E; draw C--F;
dotlabel.top(btex $a$ etex, A);
dotlabel.top(btex $b$ etex, B);
dotlabel.top(btex $c$ etex, C);
dotlabel.bot(btex $a'$ etex, D);
dotlabel.bot(btex $b'$ etex, E);
dotlabel.bot(btex $c'$ etex, F);
endfig;
data:image/s3,"s3://crabby-images/91cd0/91cd09798cc48b9425e790833f61ef56be7f9e27" alt=""
beginfig(33)
draw fullcircle;
endfig;
data:image/s3,"s3://crabby-images/939be/939be4423807cd9c116dce34ce97d742292e2fc2" alt=""
beginfig(34)
draw (0,0) withpen pencircle scaled 4bp;
draw fullcircle scaled 1cm;
endfig;
data:image/s3,"s3://crabby-images/4dedc/4dedcd237fe4fa5f35da2680c016ca47ff932f24" alt=""
beginfig(35)
draw (0,0) withpen pencircle scaled 4bp;
draw fullcircle scaled 1cm shifted (1cm,1cm);
endfig;
data:image/s3,"s3://crabby-images/5dc5a/5dc5aeebe2954a115076c655767e0209572b7bc7" alt=""
beginfig(36)
pair A, B, C;
A:=(0,0); B:=(1cm,0); C:=(0,1cm);
draw A--B--C--cycle;
fill fullcircle scaled 4bp shifted A withcolor white;
fill fullcircle scaled 4bp shifted B withcolor white;
fill fullcircle scaled 4bp shifted C withcolor white;
draw fullcircle scaled 4bp shifted A;
draw fullcircle scaled 4bp shifted B;
draw fullcircle scaled 4bp shifted C;
endfig;
data:image/s3,"s3://crabby-images/2d82e/2d82eb8d4df931733efe6091e52b4303bffcfe6e" alt=""
beginfig(37)
draw (0,0) .. (0,1cm) .. (1cm,0) .. (1cm,1cm);
draw (0,0) withpen pencircle scaled 4bp;
draw (0,1cm) withpen pencircle scaled 4bp;
draw (1cm,0) withpen pencircle scaled 4bp;
draw (1cm,1cm) withpen pencircle scaled 4bp;
endfig;
data:image/s3,"s3://crabby-images/8ea6d/8ea6ddb13430a967c6fc108cef4e4563ebb63b8d" alt=""
beginfig(38)
draw (0,0) -- (0,1cm) .. (1cm,0) .. (1cm,1cm);
endfig;
data:image/s3,"s3://crabby-images/9df49/9df4950cea5ba91f729501015ce49bc4c4a0c14f" alt=""
beginfig(39)
draw (0,0) --- (0,1cm) .. (1cm,0) .. (1cm,1cm);
endfig;
data:image/s3,"s3://crabby-images/ac7b7/ac7b7ed3e71593d4e9cae7f99a82d020e316b1e9" alt=""
beginfig(40)
draw (0,0) .. (0,1cm) .. (1cm,0) .. (1cm,1cm)
.. cycle;
endfig;
data:image/s3,"s3://crabby-images/a2344/a2344ee9c9378885d185dc3d9266c9b2de2d6ea1" alt=""
beginfig(41)
pair A, B, C, D;
A:=(0,0); B:=(1cm,0);
C:=(1cm,1cm); D:=(0,1cm);
draw A..B..C..D..cycle;
endfig;
data:image/s3,"s3://crabby-images/cf0ac/cf0ac33518d18e98cc7b8b585f8968fc1ba94787" alt=""
beginfig(42)
draw (0,0) .. (1cm,1cm) .. cycle;
endfig;
data:image/s3,"s3://crabby-images/d1b51/d1b5105d94677d170e847a38f95c3f05c5a0c321" alt=""
beginfig(43)
draw (0,0){(0,1)} .. (2cm,0){(1,0)};
endfig;
data:image/s3,"s3://crabby-images/847a6/847a6732bc944f2dcd6c9f6441617da03ffb163f" alt=""
beginfig(44)
draw (0,0){dir 90} .. (2cm,0){dir 0};
endfig;
data:image/s3,"s3://crabby-images/47321/473214b77586f5b0e07808bf7bf104325d9f495e" alt=""
beginfig(45)
draw (0,0){up} .. (2cm,0){right};
endfig;
data:image/s3,"s3://crabby-images/fd17a/fd17aa47085ae1115a947d7fc80725db1fca4f12" alt=""
beginfig(46)
draw (0,0){up} .. (2cm,0){up};
endfig;
data:image/s3,"s3://crabby-images/69d97/69d9768eb8c31ac7bcf9db8f73ab21551cab1e54" alt=""
beginfig(47)
draw (0,0){up} .. (2cm,0){up} .. cycle;
endfig;
data:image/s3,"s3://crabby-images/a94ae/a94aebb4ced07917900cd557536e1cbb33eb8271" alt=""
beginfig(48)
alpha := 30;
draw (0,0) -- 2cm*dir 0;
draw (0,0) -- 2cm*dir alpha;
draw 1cm * dir 0 {dir 90} ..
1cm * dir alpha {dir(90+alpha)};
endfig;
data:image/s3,"s3://crabby-images/b9e28/b9e283d3370573fbc708d52d3d57245850e91956" alt=""
beginfig(49)
alpha := 30;
draw (0,0) -- 2cm*dir 0;
draw (0,0) -- 2cm*dir alpha;
draw 1cm * dir 0 {dir 90} ..
1cm * dir alpha {dir(90+alpha)};
draw 1.1cm * dir 0 {dir 90} ..
1.1cm * dir alpha {dir(90+alpha)};
endfig;
data:image/s3,"s3://crabby-images/5090c/5090ccfdaa843fd025077b805fd64f78f770320a" alt=""
beginfig(50)
def draw_angle(expr A, O, B, n) =
draw_angle_(A,O,B,5mm);
if n>1 : draw_angle_(A,O,B,4.5mm); fi;
if n>2 : draw_angle_(A,O,B,4mm); fi;
if n>3 : draw_angle_(A,O,B,5.5mm); fi;
enddef;
def draw_angle_(expr A,O,B,d) =
draw (O + d*unitvector(A-O))
{ d*unitvector(A-O) rotated 90 }
..
{ d*unitvector(B-O) rotated 90 }
(O + d*unitvector(B-O));
enddef;
pair A, B, C;
A := (0,0);
B := (3cm,0);
C := (1cm,2cm);
draw A--B--C--cycle;
draw_angle(B,A,C,1);
draw_angle(C,B,A,2);
draw_angle(A,C,B,3);
endfig;
data:image/s3,"s3://crabby-images/b8975/b897527ec73142f859cbbb64887b18bd12a026f1" alt=""
beginfig(51)
u:=1cm;
path p;
p := (u,0){up}..(-u,0){down}--cycle;
fill p withcolor .8*white;
draw p withpen pencircle scaled 1bp;
endfig;
data:image/s3,"s3://crabby-images/52abc/52abcde255e24cea24650bddeb635dd8a7c95e26" alt=""
beginfig(52)
u:=1cm;
path p;
p := (u,0){up} ..
(-u,0){down} --
(-.2u,0){up} ..
(.2u,0){down} --
cycle;
fill p withcolor .8*white;
draw p withpen pencircle scaled 1bp;
endfig;
data:image/s3,"s3://crabby-images/15d25/15d25d33da5c890154e812fb7276f78e0b9a0db0" alt=""
beginfig(53)
u:=1cm;
pair A,AA,B,BB,C,D;
A := ( .2u, .05u);
AA := ( .2u, -.05u);
B := ( u, .05u);
BB := ( u, -.05u);
C := (-.2u, 0);
D := ( -u, 0);
path p;
p:= B{up} .. D{down} .. BB{up} --
AA{down} .. C{up} .. A{down} -- cycle;
fill p withcolor .8*white;
draw p withpen pencircle scaled 1bp;
endfig;
data:image/s3,"s3://crabby-images/4e747/4e747dfab13522555720ad622bf234425950ed30" alt=""
beginfig(54)
u:=1cm;
pair A,B,C,D;
A:=(0,0);
B:=u*dir 60;
C:=u*dir -60;
D:=(2u,0);
draw A withpen pencircle scaled 4bp;
draw B withpen pencircle scaled 4bp;
draw C withpen pencircle scaled 4bp;
draw D withpen pencircle scaled 4bp;
draw A--D--B--D--C;
draw A{up}..B;
draw A{down}..C;
draw A{dir 30}..B;
draw A{dir -30}..C;
endfig;
data:image/s3,"s3://crabby-images/315d8/315d8a4ef98f52a38666897ae7fa6291334d194c" alt=""
beginfig(55)
draw (0,0) .. (1cm,1cm) .. (2cm,0);
endfig;
data:image/s3,"s3://crabby-images/16289/162890caeca2392435b039ee743ffc1bbd7acd31" alt=""
beginfig(56)
draw (0,0) .. tension 2 ..
(1cm,1cm) .. (2cm,0);
endfig;
data:image/s3,"s3://crabby-images/2236e/2236e10bb4ee30fbbd8a015943a5282d9499105f" alt=""
beginfig(57)
draw (0,u) {right} ..
( u*dir -150 ){dir 120} ..
( u*dir -30 ){dir -120} ..
cycle;
endfig;
data:image/s3,"s3://crabby-images/5d636/5d636159a070309a2c106f78359e648c52157ae7" alt=""
beginfig(58)
draw (0,u) {right} .. tension 2 ..
( u*dir -150 ){dir 120} .. tension 2 ..
( u*dir -30 ){dir -120} .. tension 2 ..
cycle;
endfig;
data:image/s3,"s3://crabby-images/2e90c/2e90cc342866dda4a06714f7fd6db1d6f931896e" alt=""
beginfig(59)
draw (0,u) {right} .. tension 4 ..
( u*dir -150 ){dir 120} .. tension 4 ..
( u*dir -30 ){dir -120} .. tension 4 ..
cycle;
endfig;
data:image/s3,"s3://crabby-images/75aff/75aff5fd1f4317dff0832636f1d30d93965b14f9" alt=""
beginfig(60)
u:=.5cm;
pair A,B,C,D;
A:=(0,0); B:=(-u,2u);
C:=(4u,3u); D:=(3u,0);
draw A.. controls B and C .. D
withpen pencircle scaled 2pt;
draw B--C dashed evenly;
drawarrow A--B;
drawarrow D--C;
endfig;
data:image/s3,"s3://crabby-images/ea99c/ea99cb1941187704f19627f626e980f6c90a8a63" alt=""
beginfig(61)
pair A, B, C, D;
A = (0,0);
D = (2u,0);
B = (-u,2u);
C = (3u,3u);
draw A withpen pencircle scaled 4bp;
draw B withpen pencircle scaled 4bp;
draw C withpen pencircle scaled 4bp;
draw D withpen pencircle scaled 4bp;
draw A .. controls B and C .. D;
pair a[];
a[1] := A;
a[2] := B;
a[3] := C;
a[4] := D;
a[12] := 1/2 [ a[1], a[2] ];
a[23] := 1/2 [ a[2], a[3] ];
a[34] := 1/2 [ a[3], a[4] ];
a[123] := 1/2 [ a[12], a[23] ];
a[234] := 1/2 [ a[23], a[34] ];
a[1234] := 1/2 [ a[123], a[234] ];
draw a[1234] withpen pencircle scaled 4bp;
endfig;
data:image/s3,"s3://crabby-images/59017/59017bf8cd2d9fc2a86a680856dae7d75ea30bf0" alt=""
beginfig(62)
vardef bezier(expr n,A,B,C,D) =
save a;
pair a[];
a[1] := A;
a[2] := B;
a[3] := C;
a[4] := D;
a[12] := 1/2 [ a[1], a[2] ];
a[23] := 1/2 [ a[2], a[3] ];
a[34] := 1/2 [ a[3], a[4] ];
a[123] := 1/2 [ a[12], a[23] ];
a[234] := 1/2 [ a[23], a[34] ];
a[1234] := 1/2 [ a[123], a[234] ];
if n>0:
bezier(n-1, a[1], a[12], a[123], a[1234]);
bezier(n-1, a[1234], a[234], a[34], a[4]);
else:
draw a[1234] withpen pencircle scaled 2bp;
fi;
enddef;
pair A, B, C, D;
A = (0,0);
D = (2u,0);
B = (-u,2u);
C = (3u,3u);
draw A withpen pencircle scaled 4bp;
draw B withpen pencircle scaled 4bp;
draw C withpen pencircle scaled 4bp;
draw D withpen pencircle scaled 4bp;
bezier(5,A,B,C,D);
endfig;
data:image/s3,"s3://crabby-images/2af4e/2af4e6dcb17782fe2ccfeb8e440b580406b897eb" alt=""
beginfig(63)
draw (0,0){up} .. (1cm, 1mm) .. (2cm,0){down};
endfig;
data:image/s3,"s3://crabby-images/66d65/66d65e5c60c396e9b75890d7d15e3a33cba9193e" alt=""
beginfig(64)
draw (0,0){up} ... (1cm, 1mm) ... (2cm,0){down};
endfig;
data:image/s3,"s3://crabby-images/01e04/01e045b0eab221b9e5be066631d6339371a619a9" alt=""
beginfig(65)
draw (0,0){curl 0} .. (0,1cm)..(1cm,0)..(1cm,1cm);
endfig;
data:image/s3,"s3://crabby-images/8c2bb/8c2bb13242ba6d1703c8deb8c44235959070fa4f" alt=""
beginfig(66)
draw (0,0){curl 1} .. (0,1cm)..(1cm,0)..(1cm,1cm);
endfig;
data:image/s3,"s3://crabby-images/1dc08/1dc0891e4a44241bbb01c1ffb1f25506023e11ad" alt=""
beginfig(67)
draw (0,0){curl 2} .. (0,1cm)..(1cm,0)..(1cm,1cm);
endfig;
data:image/s3,"s3://crabby-images/08c4b/08c4b2c4fd108ac65594367e48d5570f26d147b3" alt=""
beginfig(68)
pair A,B,C,D;
xpart A = ypart A = ypart B = xpart C = 0;
xpart B = ypart C = xpart D = ypart D = 2cm;
draw A--B--C--D--cycle withpen pencircle scaled 2bp;
endfig;
data:image/s3,"s3://crabby-images/19bdf/19bdf9efa7588f7d5d7650214ece405c98e9abfa" alt=""
beginfig(69)
pair A,B,C,D,M;
numeric lambda, mu;
A=(0,0); B=(2cm,3cm);
C=(1cm,0); D=(-1cm,2cm);
M = lambda [A,B];
M = mu [C,D];
draw A--B;
draw C--D;
draw M withpen pencircle scaled 4bp;
endfig;
data:image/s3,"s3://crabby-images/66d6d/66d6d47cb76d8afd2dc79caf499144616ec121b0" alt=""
beginfig(70)
pair A,B,C,D,M;
A=(0,0); B=(2cm,3cm);
C=(1cm,0); D=(-1cm,2cm);
M = whatever [A,B];
M = whatever [C,D];
draw A--B;
draw C--D;
draw M withpen pencircle scaled 4bp;
endfig;
data:image/s3,"s3://crabby-images/69be6/69be69820a506e785675349dfe1c33228e6df9eb" alt=""
beginfig(71)
pair A,B,C,AA,BB,CC,G;
A=(0,0); B=(3cm,0); C=(1cm,2cm);
AA = 1/2 [B,C];
BB = 1/2 [C,A];
CC = 1/2 [A,B];
G = whatever [A,AA];
G = whatever [B,BB];
draw A--B--C--cycle;
draw A--AA dashed withdots;
draw B--BB dashed withdots;
draw C--CC dashed withdots;
draw G withpen pencircle scaled 4bp;
endfig;
data:image/s3,"s3://crabby-images/05a44/05a4428aba73f3e1c9fe218e67fe42177c061021" alt=""
beginfig(72)
path p;
p := fullcircle scaled 5mm;
draw p;
draw p shifted (1mm,2mm);
draw p shifted 2(1mm,2mm);
draw p shifted 3(1mm,2mm);
draw p shifted 4(1mm,2mm);
draw p shifted 5(1mm,2mm);
endfig;
data:image/s3,"s3://crabby-images/48c4a/48c4a1565cd7e14599470df2f346e781257c25de" alt=""
beginfig(73)
path p;
p := (5mm,-5mm) {right} .. (2cm,0);
draw p;
draw p rotated 10;
draw p rotated 20;
draw p rotated 30;
draw p rotated 40;
draw p rotated 50;
draw p rotated 60;
draw p rotated 70;
draw p rotated 80;
draw p rotated 90;
endfig;
data:image/s3,"s3://crabby-images/eefc7/eefc75372b58a8416928e030c1e4a7e0b0d5ea8b" alt=""
beginfig(74)
path p;
p := fullcircle scaled 5mm;
draw p;
draw p xscaled 2;
draw p xscaled 3;
draw p xscaled 4;
endfig;
data:image/s3,"s3://crabby-images/cb6f5/cb6f57367beb03c7705182a99f08033d434ff085" alt=""
beginfig(75)
pair A,B,C,D,E;
A := (1cm,0);
B := A rotated 72;
C := B rotated 72;
D := C rotated 72;
E := D rotated 72;
draw A--B--C--D--E--cycle;
endfig;
data:image/s3,"s3://crabby-images/1a765/1a7659bce533d90c7c4b8533fb26ab0f484ddb5a" alt=""
beginfig(76)
pair A,B,C,D,E;
A := (1cm,0);
B := A rotated 72;
C := B rotated 72;
D := C rotated 72;
E := D rotated 72;
draw A--C--E--B--D--cycle;
endfig;
data:image/s3,"s3://crabby-images/bc6e8/bc6e88a693b44fc45e64f43da7b1bd39ebede578" alt=""
beginfig(77)
pair A,B,C,D,E;
A := (1cm,0);
B := A rotated 72;
C := B rotated 72;
D := C rotated 72;
E := D rotated 72;
pair AA, BB, CC, DD, EE;
AA = whatever [A, C];
AA = whatever [B, D];
BB = whatever [B, D];
BB = whatever [C, E];
CC = whatever [C, E];
CC = whatever [D, A];
DD = whatever [D, A];
DD = whatever [E, B];
EE = whatever [E, B];
EE = whatever [A, C];
fill A--C--E--B--D--cycle withcolor .8white;
fill AA--BB--CC--DD--EE--cycle withcolor white;
draw A--C--E--B--D--cycle;
endfig;
data:image/s3,"s3://crabby-images/368f7/368f790cbff7a061cf45ebf697eff479866f709e" alt=""
beginfig(78)
path p;
p := (0,0) -- (1cm,0);
drawarrow p withpen pencircle scaled 2bp;
drawarrow p zscaled (1,2);
endfig;
data:image/s3,"s3://crabby-images/d07ab/d07ab1c3494ae02063e6cc979b1cd6d4cb00a148" alt=""
beginfig(79)
u:=1cm;
path p; p := (0,0) -- (u,0);
pair A; A := (u,-u);
numeric a; a := 90;
drawarrow p withpen pencircle scaled 1bp;
drawarrow p rotatedaround( A, a );
drawarrow p shifted -A rotated a shifted A
withpen pencircle scaled 1bp dashed withdots;
endfig;
data:image/s3,"s3://crabby-images/15009/1500939f160aff6aa8a9b885c309f30d877cd308" alt=""
beginfig(80)
path p; p := (0,0) -- (u,0);
pair A; A := (u,-u);
numeric a; a := 90;
drawarrow p withpen pencircle scaled 1bp;
draw A withpen pencircle scaled 4bp;
label ulft ( btex $A$ etex, A );
draw (0,0) withpen pencircle scaled 4bp;
label bot ( btex $O$ etex, (0,0) );
for i=0 upto 10:
drawarrow p shifted -(i*A/10) withcolor red;
endfor;
for i=0 upto 10:
drawarrow p shifted -A rotated (i*a/10) withcolor green;
endfor;
for i=0 upto 10:
drawarrow p shifted -A rotated a shifted (i*A/10) withcolor blue;
endfor;
endfig;
data:image/s3,"s3://crabby-images/99951/99951b49aaf4c675e71a6bf22c46da3c858d13fb" alt=""
beginfig(81)
pair A,B,C,AA,BB,CC,H;
A=(0,0); B=(3cm,0); C=(1cm,2cm);
AA - A = whatever * (B-C) rotated 90;
AA = whatever [B,C];
BB - B = whatever * (A-C) rotated 90;
BB = whatever [A,C];
CC - C = whatever * (A-B) rotated 90;
CC = whatever [A,B];
H = whatever [A,AA];
H = whatever [B,BB];
draw A--B--C--cycle;
draw A--AA;
draw B--BB;
draw C--CC;
draw H withpen pencircle scaled 4bp;
endfig;
data:image/s3,"s3://crabby-images/80367/80367a253b74c18f3d92e45b9c4781e3aa9d5821" alt=""
beginfig(82)
pair A,B,C,H;
A=(0,0); B=(3cm,0); C=(1cm,2cm);
H - A = whatever * (B-C) rotated 90;
H - B = whatever * (A-C) rotated 90;
draw A--B--C--cycle;
draw H withpen pencircle scaled 4bp;
endfig;
data:image/s3,"s3://crabby-images/a635f/a635fc457b64de420cce286932a6323e8640991b" alt=""
beginfig(83)
pair A,B,C,O;
A=(0,0); B=(3cm,0); C=(1cm,2cm);
O - 1/2[B,C] = whatever * (B-C) rotated 90;
O - 1/2[A,B] = whatever * (A-B) rotated 90;
draw A--B--C--cycle;
draw O withpen pencircle scaled 4bp;
draw fullcircle scaled 2abs(O-A) shifted O;
endfig;
data:image/s3,"s3://crabby-images/7ccca/7ccca50f34f41ef1bb711bc7b52973c696fdea04" alt=""
beginfig(84)
pair A,B,C,D;
u:=2cm;
A=(0,0); B=(u,0); C=(u,u); D=(0,u);
transform T;
A transformed T = 1/5[A,B];
B transformed T = 1/5[B,C];
C transformed T = 1/5[C,D];
path p;
p = A--B--C--D--cycle;
draw p;
draw p transformed T;
endfig;
data:image/s3,"s3://crabby-images/57dda/57ddaf10a5f17e7f38b79efe86481be9949eed35" alt=""
beginfig(85)
pair A,B,C,D;
u:=2cm;
A=(0,0); B=(u,0); C=(u,u); D=(0,u);
transform T;
A transformed T = 1/5[A,B];
B transformed T = 1/5[B,C];
C transformed T = 1/5[C,D];
path p;
p = A--B--C--D--cycle;
for i=0 upto 100:
draw p;
p:= p transformed T;
endfor;
endfig;
data:image/s3,"s3://crabby-images/32aa8/32aa8a2d72b7a96b8376351abd67501017293887" alt=""
beginfig(86)
u:=1cm;
pair A,B,C,D,E;
A := (0,u);
B := A rotated 72;
C := B rotated 72;
D := C rotated 72;
E := D rotated 72;
transform T;
A transformed T = 1/5[A,B];
B transformed T = 1/5[B,C];
C transformed T = 1/5[C,D];
path p;
p := A--B--C--D--E--cycle;
draw p;
p := p transformed T; draw p;
p := p transformed T; draw p;
p := p transformed T; draw p;
endfig;
data:image/s3,"s3://crabby-images/34195/341951afe5ce728b86c078457966832746cb5e65" alt=""
beginfig(87)
u:=3mm;
fill fullcircle scaled 2u withcolor .8white;
fill fullcircle scaled u shifted (u*dir30)
withcolor .8white;
fill fullcircle scaled u shifted (u*dir150)
withcolor .8white;
endfig;
data:image/s3,"s3://crabby-images/9a059/9a059d243e56977c4a181cae49731e48633613d9" alt=""
beginfig(88)
u:=3mm;
transform T;
(0,0) transformed T = (0,0);
(1,0) transformed T = (1,1);
(0,1) transformed T = (1,0);
fill fullcircle scaled 2u transformed T withcolor .8white;
fill fullcircle scaled u shifted (u*dir30) transformed T
withcolor .8white;
fill fullcircle scaled u shifted (u*dir150) transformed T
withcolor .8white;
endfig;
data:image/s3,"s3://crabby-images/59fd7/59fd7a04aa00a9474746c137aa0f143ed2ae6f74" alt=""
beginfig(89)
u:=3mm;
transform T;
xpart T = ypart T = 0;
xxpart T = 1;
yxpart T = 2;
xypart T = 3;
yypart T = 4;
fill fullcircle scaled 2u transformed T withcolor .8white;
fill fullcircle scaled u shifted (u*dir30) transformed T
withcolor .8white;
fill fullcircle scaled u shifted (u*dir150) transformed T
withcolor .8white;
endfig;
data:image/s3,"s3://crabby-images/72bd3/72bd348cf05346ce9a88ed68ebcc412f5f189e5e" alt=""
beginfig(90)
draw fullcircle scaled 1cm;
draw fullcircle scaled 5mm shifted (1cm*dir45);
draw fullcircle scaled 5mm shifted (1cm*dir135);
picture mypicture;
mypicture := currentpicture;
currentpicture := nullpicture;
draw mypicture;
draw mypicture shifted (1mm,1mm);
draw mypicture shifted (2mm,2mm);
endfig;
data:image/s3,"s3://crabby-images/667a3/667a336cc61749baa44976b79c7b950d1f08eafe" alt=""
beginfig(91)
picture pic;
pic := nullpicture;
addto pic contour fullcircle scaled 1cm
withcolor .8white;
addto pic doublepath fullcircle scaled 1cm
withpen pencircle scaled .5bp;
addto pic also pic shifted (1mm,1mm);
draw pic;
endfig;
data:image/s3,"s3://crabby-images/152b4/152b45a450bb3898a29b69b76774ab08be7f81db" alt=""
beginfig(92)
u:=3mm;
picture mickey;
mickey := nullpicture;
addto mickey contour fullcircle scaled 2u
withcolor .8white;
addto mickey contour fullcircle scaled u
shifted (u*dir30) withcolor .8white;
addto mickey contour fullcircle scaled u
shifted (u*dir150)
withcolor .8white;
draw mickey;
endfig;
data:image/s3,"s3://crabby-images/852fb/852fba758a46f07631cf051efee8cd978dfb95de" alt=""
beginfig(93)
u:=3mm;
picture mickey;
mickey := nullpicture;
addto mickey contour fullcircle scaled 2u
withcolor .8white;
addto mickey contour fullcircle scaled u
shifted (u*dir30) withcolor .8white;
addto mickey contour fullcircle scaled u
shifted (u*dir150) withcolor .8white;
transform T;
(0,0) transformed T = (0,0);
(1,0) transformed T = (1,1);
(0,1) transformed T = (1,0);
draw mickey transformed T;
endfig;
data:image/s3,"s3://crabby-images/d47e7/d47e7c683c63790e4d298c3208ef44849c7e7171" alt=""
beginfig(94)
u:=3mm;
picture mickey;
fill fullcircle scaled 2u withcolor .8white;
fill fullcircle scaled u shifted (u*dir30)
withcolor .8white;
fill fullcircle scaled u shifted (u*dir150)
withcolor .8white;
mickey := currentpicture;
currentpicture := nullpicture;
transform T;
(0,0) transformed T = (0,0);
(1,0) transformed T = (1,1);
(0,1) transformed T = (1,0);
draw mickey transformed T;
endfig;
data:image/s3,"s3://crabby-images/6588e/6588e481adddd500695edd5fdf831a5e868b4daf" alt=""
beginfig(95)
pair A,B;
path p;
A = (0,1cm);
B = A rotated 120;
p = A{dir 0} .. tension 2 .. B{dir 120};
draw p;
draw p rotated 120;
draw p rotated -120;
endfig;
data:image/s3,"s3://crabby-images/f6bee/f6bee7e433c18910b03e04cb6af0ad3ed406be10" alt=""
beginfig(96)
pair A,B;
path p;
numeric n;
n:=5;
A = (0,1cm);
B = A rotated (2*360/n);
p = A{dir 180} .. tension 4 .. B{dir (180+2*360/n)};
draw p withcolor red;
draw p rotated (1*360/n);
draw p rotated (2*360/n);
draw p rotated (3*360/n);
draw p rotated (4*360/n);
endfig;
data:image/s3,"s3://crabby-images/f9fbe/f9fbe5cb12215cc631befcac3f610f460a9243eb" alt=""
beginfig(97)
path c[], l[];
c[0] = fullcircle xscaled 1cm yscaled .5cm
shifted (0,1cm);
c[1] = c[0] rotated 120;
c[2] = c[1] rotated 120;
pair A;
A = (-.5cm,1cm);
l[0] = A{down} ..
(A xscaled -1 rotated 120){-down rotated 120};
l[1] = l[0] rotated 120;
l[2] = l[1] rotated 120;
draw c[0]; draw c[1]; draw c[2];
draw l[0]; draw l[1]; draw l[2];
endfig;
data:image/s3,"s3://crabby-images/73b72/73b72de66894f07f82f4891dd8bc8a616b7af05d" alt=""
beginfig(98)
path c[], l[];
c[0] = fullcircle xscaled 1cm yscaled .5cm
shifted (0,1cm);
c[1] = c[0] rotated (360/4);
c[2] = c[1] rotated (360/4);
c[3] = c[2] rotated (360/4);
pair A;
A = (-.5cm,1cm);
l[0] = A{down} ..
(A xscaled -1 rotated (360/4))
{-down rotated (360/4)};
l[1] = l[0] rotated (360/4);
l[2] = l[1] rotated (360/4);
l[3] = l[2] rotated (360/4);
draw c[0]; draw c[1]; draw c[2]; draw c[3];
draw l[0]; draw l[1]; draw l[2]; draw l[3];
endfig;
data:image/s3,"s3://crabby-images/6f486/6f486853902ac1a3f946300a6241eaee1b417ba9" alt=""
beginfig(99)
pair A, B;
A := (0,0); B := (2cm,1cm);
draw A withpen pencircle scaled 4bp;
draw B withpen pencircle scaled 4bp;
draw fullcircle scaled abs(B-A) shifted 1/2[A,B];
endfig;
data:image/s3,"s3://crabby-images/67e1e/67e1eec9d5b69c6daae1083065283007f9ff8452" alt=""
beginfig(100)
pair A;
A:=(2cm,2cm);
drawarrow origin--A;
drawarrow (origin--A) rotated -1/3 angle(A);
drawarrow (origin--A) rotated -2/3 angle(A);
drawarrow (origin--A) rotated -angle(A);
endfig;
data:image/s3,"s3://crabby-images/0c642/0c6427e93208d8e6c6ed7d33ac483b5f3484c1cc" alt=""
beginfig(101)
pair A,B;
A:=(1cm,2cm); B:=(2cm,1cm);
numeric alpha;
alpha = angle(A) - angle(B);
drawarrow origin--A;
drawarrow origin--B;
drawarrow (origin--A) rotated -1/3 alpha;
drawarrow (origin--A) rotated -2/3 alpha;
drawarrow (origin--A) rotated -alpha;
endfig;
data:image/s3,"s3://crabby-images/3d91b/3d91b78878dab00717a7150d93263f20a2f461c0" alt=""
beginfig(102)
pair A,B,C;
A=(0,0); B=(3cm,0); C=(1cm,2cm);
draw A--B--C--cycle;
label.llft(TEX decimal(angle(C-A)-angle(B-A)), A);
label.lrt(TEX decimal(angle(A-B)-angle(C-B)), B);
label.urt(TEX decimal(angle(B-C)-angle(A-C)), C);
endfig;
data:image/s3,"s3://crabby-images/616e2/616e20cad0d50184ddf4dccd0b3cc36fb37060cd" alt=""
beginfig(103)
pair A,AA,B,BB,C,CC,O,H;
A=(0,0); B=(3cm,0); C=(1cm,2cm);
AA = 1/2[B,C];
BB = 1/2[A,C];
CC = 1/2[A,B];
O - 1/2[BB,CC] = whatever * (BB-CC) rotated 90;
O - 1/2[AA,BB] = whatever * (AA-BB) rotated 90;
draw A--B--C--cycle;
draw AA withpen pencircle scaled 4bp;
draw BB withpen pencircle scaled 4bp;
draw CC withpen pencircle scaled 4bp;
draw fullcircle scaled 2abs(O-AA) shifted O;
% Il faut aussi tracer les hauteurs
pair AA,BB,CC;
AA - A = whatever * (B-C) rotated 90;
AA = whatever [B,C];
BB - B = whatever * (A-C) rotated 90;
BB = whatever [A,C];
CC - C = whatever * (A-B) rotated 90;
CC = whatever [A,B];
draw A--AA; draw B--BB; draw C--CC;
draw AA withpen pencircle scaled 4bp;
draw BB withpen pencircle scaled 4bp;
draw CC withpen pencircle scaled 4bp;
% Il passe aussi par le milieu de HA, HB, HC
H = whatever [A,AA];
H = whatever [B,BB];
draw 1/2 [A,H] withpen pencircle scaled 4bp;
draw 1/2 [B,H] withpen pencircle scaled 4bp;
draw 1/2 [C,H] withpen pencircle scaled 4bp;
endfig;
data:image/s3,"s3://crabby-images/5b1fe/5b1fea237bbe9732a83a6cea53009d5e08a05602" alt=""
beginfig(104)
pair A,B,C,M,h;
u:=2cm;
A=(0,0); B=(2u,-.5u); C=(u,u);
draw A--B--C--cycle;
(M-A) = whatever * (
(A-C) rotated 1/2( angle(B-A) - angle(C-A)) );
(M-B) = whatever * (
(B-A) rotated 1/2( angle(C-B) - angle(A-B)) );
draw M--A; draw M--B; draw M--C;
M-h = whatever * (B-C) rotated 90;
h = whatever[B,C];
draw fullcircle scaled 2 abs(M-h) shifted M;
endfig;
data:image/s3,"s3://crabby-images/5fbdb/5fbdb24af9e567a1fd1bb3c03e567f289bbc4b8e" alt=""
beginfig(105)
path p;
p = (0,0){up} .. (2cm,0){down};
draw p;
draw point 0 of p withpen pencircle scaled 4bp;
draw point .5 of p withpen pencircle scaled 4bp;
draw point 1 of p withpen pencircle scaled 4bp;
endfig;
data:image/s3,"s3://crabby-images/03f47/03f4770b200bded0f50018d3b3d6c47cf579035b" alt=""
beginfig(106)
path p;
p = (0,0){up} .. (2cm,0){down};
draw p;
pair A;
A := point 0 of p;
B := A + 1cm*unitvector(direction 0 of p);
drawarrow A--B withpen pencircle scaled 1bp;
A := point .5 of p;
B := A + 1cm*unitvector(direction .5 of p);
drawarrow A--B withpen pencircle scaled 1bp;
A := point 1 of p;
B := A + 1cm*unitvector(direction 1 of p);
drawarrow A--B withpen pencircle scaled 1bp;
endfig;
data:image/s3,"s3://crabby-images/e336a/e336a1eebb02be0bf476f6f6e693cf79ce326e0d" alt=""
beginfig(107)
u:=5mm;
path p;
p = (0,0) {curl 0} .. (u,2u) .. (2u,1.5u)
.. (3u,2u) .. {curl 0} (4u,0);
draw subpath(0,1) of p withcolor red;
draw subpath(1,2) of p withcolor green;
draw subpath(2,3) of p withcolor blue;
draw subpath(3,3.5) of p dashed evenly;
draw subpath(3.5,4) of p dashed withdots;
endfig;
data:image/s3,"s3://crabby-images/b8404/b84043d1686650362ab68be8357ce847882ab46f" alt=""
beginfig(108)
u:=1cm;
path p,q;
p := (0,0){up} .. (u,2u){up};
q := (u,0){up} .. (0,2u){up};
draw p;
draw subpath(0,.4) of q withpen pencircle scaled 1bp;
draw subpath(.6,1) of q withpen pencircle scaled 1bp;
endfig;
data:image/s3,"s3://crabby-images/3331d/3331d4816bcad260ac1903ae50367c7daba5654a" alt=""
beginfig(109)
u:=1cm;
path a,b,c,d;
a = (-u,-.2u){up} .. tension 1.2 .. (u,-.2u){down};
b = a rotated 90;
c = b rotated 90;
d = c rotated 90;
fill buildcycle(a,b,c,d) withcolor .8white;
draw a; draw b; draw c; draw d;
endfig;
data:image/s3,"s3://crabby-images/33045/33045f9a814273ef2665f85aa49b995e02b55469" alt=""
beginfig(110)
u:=1cm;
path c[];
c[1] := fullcircle scaled u;
c[2] := c[1] shifted (0,.5u);
draw c[1] dashed evenly;
draw c[2] dashed evenly;
draw buildcycle(c[1],c[2]) withpen pencircle scaled 1bp;
endfig;
data:image/s3,"s3://crabby-images/dbf6b/dbf6b0b537fc4a80728e8f8112c67233183c25af" alt=""
beginfig(111)
path a,b,c;
a = fullcircle scaled 2u shifted (.5u,0);
b = a rotated (360/3);
c = b rotated (360/3);
fill a withcolor red;
fill b withcolor green;
fill c withcolor blue;
fill buildcycle(a,b) withcolor red + green;
fill buildcycle(b,c) withcolor green + blue;
fill buildcycle(c,a) withcolor blue + red;
fill buildcycle(a,b,c) withcolor white;
draw a; draw b; draw c;
endfig;
data:image/s3,"s3://crabby-images/2839c/2839c17f3742a630b41e1e1da80f94aee543ce2d" alt=""
beginfig(112)
def compute_curve(suffix f)(expr xmin, xmax, xinc) =
( (xmin,f(xmin))
for x=xmin+xinc step xinc until xmax:
.. (x,f(x))
endfor )
enddef;
vardef f(expr x) = x**2 + 1 enddef;
vardef g(expr x) = 2 - (x-1)**2 enddef;
path p, q;
p := compute_curve(f, -1, 1.5, .1) scaled 1cm;
q := compute_curve(g, -.5, 2, .1) scaled 1cm;
fill buildcycle(p,reverse q) withcolor red+green;
draw p withpen pencircle scaled 1bp;
draw q withpen pencircle scaled 1bp;
draw (-1cm,0) -- (2cm,0);
draw (0,g(-.5)*1cm) -- (0,f(1.5)*1cm);
endfig;
data:image/s3,"s3://crabby-images/03a03/03a038d8190fc8e069ecd360b582cc702adbd772" alt=""
beginfig(113)
path p, q;
p = (0,0){up} .. (2cm,0){up};
q = (0,1cm){dir -60}..(1cm,-1cm)..{dir 60}(2cm,1cm);
draw p; draw q;
draw p intersectionpoint q withpen pencircle scaled 4bp;
endfig;
data:image/s3,"s3://crabby-images/e7bd6/e7bd66432b6df08e07463e2872a12acc51296fd1" alt=""
beginfig(114)
path p, q;
p = (0,0){up} .. (2cm,0){up};
q = (0,1cm){dir -60}..(1cm,-1cm)..{dir 60}(2cm,1cm);
draw p; draw q;
numeric a,b;
(a,whatever) = p intersectiontimes q;
draw point a of p withpen pencircle scaled 4bp;
endfig;
data:image/s3,"s3://crabby-images/a24c3/a24c3624126bc61ff79e63fbfac6ca1c23990947" alt=""
beginfig(115)
pair A,B;
path p;
A = (0,1cm);
B = A rotated 120;
p = A{dir 0} .. tension 2 .. B{dir 120};
numeric a;
(a,whatever) = p intersectiontimes (p rotated 120);
draw subpath(0,a-.02) of p;
draw subpath(a+.02,1) of p;
draw subpath(0,a-.02) of p rotated 120;
draw subpath(a+.02,1) of p rotated 120;
draw subpath(0,a-.02) of p rotated -120;
draw subpath(a+.02,1) of p rotated -120;
endfig;
data:image/s3,"s3://crabby-images/d832a/d832a485a069b67f86fcd57e8fb65892ff55b5c3" alt=""
beginfig(116)
u:=2cm;
pair A[], B[], C[], D[], E[];
path p[];
A[0] = u*up;
for i=1 upto 10:
A[i] := A[i-1] rotated 72;
endfor;
for i=0 upto 4:
p[i] := A[i]--A[i+1];
draw p[i];
draw (point 1 of p[i]) --
( (point 1 of p[i]) + 4mm*unitvector(direction 1 of p[i]));
draw (point 0 of p[i]) --
( (point 0 of p[i]) - 4mm*unitvector(direction 0 of p[i]));
endfor
for i=0 upto 9:
B[i] := 1/2[ A[i], A[i+1] ];
endfor;
B[5]:=B[0];
for i=0 upto 9:
C[i] := .8*B[i];
endfor;
for i=0 upto 4:
p[i] := B[i] --- C[i] .. C[i+2]{dir 72i};
draw p[i];
draw (point 2 of p[i]) --
( (point 2 of p[i]) + 4mm*unitvector(direction 2 of p[i]));
draw (point 0 of p[i]) --
( (point 0 of p[i]) - 4mm*unitvector(direction 0 of p[i]));
endfor;
for i=0 upto 4:
draw subpath(1,1.4) of p[i] withpen pencircle scaled 4bp withcolor white;
draw subpath(0,1.5) of p[i];
endfor;
for i=0 upto 4:
draw A[i] withpen pencircle scaled 4bp;
draw B[i] withpen pencircle scaled 4bp;
draw C[i] withpen pencircle scaled 4bp;
endfor;
endfig;
data:image/s3,"s3://crabby-images/9df15/9df15538d1f5ec61ea6395ffd40c7f86f57c6dd0" alt=""
beginfig(117)
u:=2cm;
pair A, B, C, D, E;
path p, q, r;
A = u*up;
p := (-.2)[ A, A rotated 72 ] -- (1.2)[ A, A rotated 72 ];
for i=0 upto 5:
draw p rotated 72i;
endfor;
B := 1/2[ A, A rotated 72 ];
C := .8*B;
p := B --- C .. (C rotated (2*72)){right};
% On allonge le chemin p
p := ( (point 0 of p) - 4mm*unitvector(direction 0 of p))
--
(point 0 of p)
& p &
(point 2 of p)
--
( (point 2 of p) + 4mm*unitvector(direction 2 of p));
E = p intersectionpoint (p rotated 72);
q := p cutbefore fullcircle scaled -2mm shifted E;
r := p cutafter fullcircle scaled 2mm shifted E;
for i=0 upto 4:
draw q rotated 72i;
draw r rotated 72i;
draw A rotated 72i withpen pencircle scaled 4bp;
draw B rotated 72i withpen pencircle scaled 4bp;
draw C rotated 72i withpen pencircle scaled 4bp;
endfor;
endfig;
data:image/s3,"s3://crabby-images/e7ee7/e7ee7537d32807c7c48b9cd80f7ba5fc8fd3e0ae" alt=""
beginfig(118)
for i=0 step 1 until 3:
draw 1cm*right rotated (i*90)
withpen pencircle scaled 4bp;
endfor;
endfig;
data:image/s3,"s3://crabby-images/3a0f7/3a0f78675f1dbcd88978dfde276bf0d886f79341" alt=""
beginfig(119)
draw for i=0 step 1 until 3:
1cm*right rotated (i*90) --
endfor cycle;
endfig;
data:image/s3,"s3://crabby-images/25484/254847c641ee6d201dbc443fe914948154378e05" alt=""
beginfig(120)
n:=5;
draw for i=0 step 1 until n-1:
1cm*up rotated (i*360/n) --
endfor cycle;
endfig;
data:image/s3,"s3://crabby-images/cc13d/cc13d2f113c6acc227f6136adc761947feed814b" alt=""
beginfig(121)
n:=7;
draw for i=0 step 1 until n-1:
1cm*up rotated (i*360/n) --
endfor cycle;
endfig;
data:image/s3,"s3://crabby-images/060e0/060e02e8591b79eed154774a022828efb106882c" alt=""
beginfig(122)
path p;
p = (0,0) .. (-1cm,2cm) .. (2cm,1cm) .. (1cm,0);
draw p;
n:=10;
for i=0 step 1 until n:
draw point (i/n*length(p)) of p
withpen pencircle scaled 4bp;
endfor;
endfig;
data:image/s3,"s3://crabby-images/88449/88449311cbb2ccca3dc14595e3598d3c0f78faa7" alt=""
beginfig(123)
path p;
p = (0,0) .. (-1cm,2cm) .. (2cm,1cm) .. (1cm,0);
draw p;
n:=10;
for i=0 step length(p)/n until length(p):
drawarrow (point i of p) --
1cm * unitvector(direction i of p)
shifted point i of p;
endfor;
endfig;
data:image/s3,"s3://crabby-images/40fc7/40fc740624df082372d9a0bd044fb57a741b184a" alt=""
beginfig(124)
u:=1cm;
draw (-2u,0)--(2u,0);
draw (0,-2u)--(0,2u);
for i=-2u step u until 2u:
draw (i,u/20)--(i,-u/20);
draw (u/20,i)--(-u/20,i);
endfor;
endfig;
data:image/s3,"s3://crabby-images/c818f/c818fae47d3546ff8f73faaa51ef89aead913c2e" alt=""
beginfig(125)
u:=1cm;
draw (-2u,0)--(2u,0);
draw (0,-2u)--(0,2u);
for i=-2u step u until 2u:
draw (i,u/10)--(i,-u/10);
draw (u/10,i)--(-u/10,i);
endfor;
for i=-2u step u/5 until 2u:
draw (i,u/20)--(i,-u/20);
draw (u/20,i)--(-u/20,i);
endfor;
endfig;
data:image/s3,"s3://crabby-images/383ca/383ca163f1978d7741db9de5c26d07e0efe4f6fc" alt=""
beginfig(126)
u:=1cm;
draw (-2u,0)--(2u,0);
draw (0,-2u)--(0,2u);
for i=-2u step u until 2u:
draw (i,2u)--(i,-2u);
draw (2u,i)--(-2u,i);
endfor;
endfig;
data:image/s3,"s3://crabby-images/f5cf7/f5cf7701ec4a5b180db26edc7e05fad1e0d29cea" alt=""
beginfig(127)
u:=1cm;
draw (-2u,0)--(2u,0);
draw (0,-2u)--(0,2u);
for i=-2u step u until 2u:
draw (i,2u)--(i,-2u);
draw (2u,i)--(-2u,i);
endfor;
for i=-2u step u/5 until 2u:
draw (i,2u)--(i,-2u) withpen pencircle scaled .2bp;
draw (2u,i)--(-2u,i) withpen pencircle scaled .2bp;
endfor;
endfig;
data:image/s3,"s3://crabby-images/351b8/351b8263719931058f6de21957e8dd36147c5361" alt=""
beginfig(128)
u := 5mm;
% vardef est nécessaire pour pouvoir passer f en argument
vardef f(expr x) = x**2 -.1 enddef;
def axes(expr xmin,xmax,ymin,ymax) =
draw ( (xmin,0) -- (xmax,0) ) scaled u;
draw ( (0,ymin) -- (0,ymax) ) scaled u;
enddef;
def courbe(suffix f)(expr xmin, xmax, M) =
draw ( ( xmin, f(xmin) )
for i=1 upto M:
-- ( xmin + (i/M)*(xmax - xmin), f( xmin + (i/M)*(xmax - xmin) ))
endfor ) scaled u;
enddef;
vardef newton(suffix f)(expr y, h, M) =
save x,t;
numeric x,t; x:=y;
for i=1 upto M:
t := x - f(x)/( (f(x+h) - f(x))/h );
draw ( (x,f(x)) -- (t,0) -- (t,f(t)) ) scaled u;
x := t;
endfor;
enddef;
axes(-.5,2,-.5,4);
courbe(f,-.5,2, 100);
newton(f, 2, .01, 10);
endfig;
data:image/s3,"s3://crabby-images/f580e/f580ed4d4914c5728264878bcf2eada3a849d66f" alt=""
beginfig(129)
transform T;
u:=1cm;
z0=(0,0); z1=(2u,0); z3 = z1 rotated 90; z2 = z1+z3;
z0 transformed T = .1[z0,z1];
z1 transformed T = .1[z1,z2];
z2 transformed T = .1[z2,z3];
path p;
p = z0--z1--z2--z3--cycle;
fill p withcolor .8*white;
fill p transformed T withcolor white;
endfig;
data:image/s3,"s3://crabby-images/850ad/850adf95ba26f985977e61d3d73b89b37e681ae4" alt=""
beginfig(130)
transform T;
u:=1cm;
z0=(0,0); z1=(2u,0); z3 = z1 rotated 90; z2 = z1+z3;
z0 transformed T = .1[z0,z1];
z1 transformed T = .1[z1,z2];
z2 transformed T = .1[z2,z3];
path p;
p = z0--z1--z2--z3--cycle;
for i=0 upto 100:
fill p withcolor .8*white;
p := p transformed T;
fill p withcolor white;
p := p transformed T;
endfor;
endfig;
data:image/s3,"s3://crabby-images/090fd/090fd2844492221812cde57ed7810bbf3bd515e7" alt=""
beginfig(131)
transform T;
u:=1cm;
z1=(0,2u);
n := 5;
for i=1 upto n-1:
z[i+1] = z1 rotated (360*i/n);
endfor;
z1 transformed T = .1[z1,z2];
z2 transformed T = .1[z2,z3];
z3 transformed T = .1[z3,z4];
path p;
p = for i=1 upto n: z[i] -- endfor cycle;
for i=0 upto 100:
fill p withcolor .8*white;
p := p transformed T;
fill p withcolor white;
p := p transformed T;
endfor;
endfig;
data:image/s3,"s3://crabby-images/ae6f1/ae6f1899c85613a7f49d97ff2beb2b1813f06cba" alt=""
beginfig(132)
u:=1cm;
pair A[];
numeric n; n:=7;
A[0] = (u,0);
for i=1 upto n-1:
A[i] = A[0] rotated (360/n*i);
endfor;
for i=0 upto n-1:
draw A[i] withpen pencircle scaled 4bp;
for j=0 upto n-1:
if i<>j: draw A[i]--A[j] fi;
endfor;
endfor;
endfig;
data:image/s3,"s3://crabby-images/e5e27/e5e27ae66336a5271802a61f2637edccfca6b441" alt=""
beginfig(133)
u:=2cm;
numeric n,m; n:=4; m:=5;
pair A[], B[];
for i=1 upto n-1: A[i+1]-A[i] = (0,.2u); endfor;
for j=1 upto m-1: B[j+1]-B[j] = (0,.2u); endfor;
(0,0) for i=1 upto n: + A[i] endfor = (0,0);
(0,0) for j=1 upto m: + B[j] endfor = (4u,0);
for i=1 upto n:
draw A[i] withpen pencircle scaled 4bp;
endfor;
for j=1 upto m:
draw B[j] withpen pencircle scaled 4bp;
endfor;
for i=1 upto n:
for j=1 upto m:
draw A[i]--B[j];
endfor;
endfor;
endfig;
data:image/s3,"s3://crabby-images/da10c/da10c64a1409885ef84e94120221d3955cda07b9" alt=""
beginfig(134)
u:=1cm;
numeric n,m; n:=3; m:=3;
pair A[], B[];
for i=1 upto n-1: A[i+1]-A[i] = (.5u,0); endfor;
for j=1 upto m-1: B[j+1]-B[j] = (.5u,0); endfor;
(0,0) for i=1 upto n: + A[i] endfor = (0,0);
(0,0) for j=1 upto m: + B[j] endfor = (0,4u);
for i=1 upto n:
draw A[i] withpen pencircle scaled 4bp;
endfor;
for j=1 upto m:
draw B[j] withpen pencircle scaled 4bp;
endfor;
for i=1 upto n:
for j=1 upto m:
draw A[i]--B[j];
endfor;
endfor;
endfig;
data:image/s3,"s3://crabby-images/59f6f/59f6fbcefa629b6be17a964627f8ca1fed9d4e14" alt=""
beginfig(135)
pair A[], B[];
numeric n; n:=6;
for i=0 upto n-1:
A[i] = 1cm * right rotated (i*360/n);
B[i] = 2cm * right rotated (i*360/n);
endfor;
A[n] = A[0]; B[n] = B[0];
for i=0 upto n-1:
draw A[i] -- A[i+1] -- B[i+1] -- B[i];
draw A[i] withpen pencircle scaled 4bp;
draw B[i] withpen pencircle scaled 4bp;
endfor;
endfig;
data:image/s3,"s3://crabby-images/1bfcf/1bfcf9198d721b07ac8f3c87dc55b1e0357b8515" alt=""
beginfig(136)
numeric n; n:=5;
pair O,A,B,C,D;
O = (0,0);
A = 1cm*up;
B = 2cm*up rotatedabout(A,30);
C = 2cm*up;
D = 2cm*up rotatedabout(A,-30);
for i=0 upto n-1:
draw (O--A--C) rotated (i*360/n);
draw (B--A--D) rotated (i*360/n);
draw A rotated (i*360/n) withpen pencircle scaled 4bp;
draw B rotated (i*360/n) withpen pencircle scaled 4bp;
draw C rotated (i*360/n) withpen pencircle scaled 4bp;
draw D rotated (i*360/n) withpen pencircle scaled 4bp;
endfor;
draw O withpen pencircle scaled 4bp;
endfig;
data:image/s3,"s3://crabby-images/e4236/e4236c4d4621d58b3ea71b3b7e3ed9565cceee65" alt=""
beginfig(137)
path p; u:=1cm;
p = fullcircle xscaled -u yscaled 3u;
draw p;
for i=2 step .5 until 6:
draw (point 2 of p){down} .. (point i of p);
endfor;
endfig;
data:image/s3,"s3://crabby-images/c9134/c9134a6b08cae976cb01a103909435a72b9c02d2" alt=""
beginfig(138)
pair P[], Q[], R[], S[];
u:=.5cm;
for i=0 upto 4:
P[i] = u* down rotated (i*360/5);
endfor;
P[5] = P[0];
for i=0 upto 4:
Q[i] = 3*( 1/2[ P[i], P[i+1] ] );
endfor;
Q[5] = Q[0];
for i=0 upto 4:
R[i] = 1/3( Q[i] + Q[i+1] + P[i+1] );
endfor;
R[5] = R[0];
for i=0 upto 5:
S[i] = 1.5*Q[i];
endfor;
for i=0 upto 4:
draw P[i] -- P[i+1];
draw P[i+1] -- R[i];
draw Q[i] -- R[i];
draw R[i] -- Q[i+1];
draw Q[i] -- S[i];
draw S[i] -- S[i+1];
endfor;
endfig;
data:image/s3,"s3://crabby-images/d0e3e/d0e3e751432ce324a57c44d8bec7b44db25e52eb" alt=""
beginfig(139)
pair P[], Q[], R[], S[];
u:=.5cm;
for i=0 upto 4:
P[i] = u* down rotated (i*360/5);
endfor;
P[5] = P[0];
for i=0 upto 4:
Q[i] = 3*( 1/2[ P[i], P[i+1] ] );
endfor;
Q[5] = Q[0];
for i=0 upto 4:
R[i] = 1/3( Q[i] + Q[i+1] + P[i+1] );
endfor;
R[5] = R[0];
for i=0 upto 5:
S[i] = 1.5*Q[i];
endfor;
for i=0 upto 4:
draw P[i] -- P[i+1];
draw P[i+1] -- R[i];
draw Q[i] -- R[i];
draw R[i] -- Q[i+1];
draw Q[i] -- S[i];
draw S[i] -- S[i+1];
endfor;
draw P[2] -- P[3] -- P[4] -- P[0] -- P[1] --
R[0] -- Q[0] -- R[4] -- Q[4] -- R[3]
-- Q[3] -- R[2] -- Q[2] --
S[2] -- S[3] -- S[4] -- S[0] -- S[1] --
Q[1] -- R[1] -- cycle
withpen pencircle scaled 2bp;
endfig;
data:image/s3,"s3://crabby-images/3c4cb/3c4cbb891d7f8ca7c8ca083be82eb53886c0032d" alt=""
beginfig(140)
for i=1 step -.01 until 0:
fill fullcircle scaled (i*2cm) withcolor i*white;
endfor;
draw fullcircle scaled 2cm withpen pencircle scaled 2bp;
endfig;
data:image/s3,"s3://crabby-images/f854a/f854a65ec407188d16e5179ddcbcba8faf223bd9" alt=""
beginfig(141)
u:=5mm;
path p;
p = (0,0) .. (-1,1) .. (2,0) .. (0,-3) .. cycle;
p := p shifted (-1,0);
for i=1 step -.01 until 0:
fill p scaled (i*u) withcolor i*white;
endfor;
draw p scaled u withpen pencircle scaled 2bp;
endfig;
data:image/s3,"s3://crabby-images/e92fe/e92fec6183887144edddba26780f97547a03e299" alt=""
beginfig(142)
z0 = (50,50);
z1 = z0 rotated 90;
z2 = z1 rotated 90;
z3 = z2 rotated 90;
path carre;
carre = z0--z1--z2--z3--cycle;
s := .01;
path rect;
z4 = s [z2,z3]; z5 = s [z1,z0];
rect = z1--z2--z4--z5--cycle;
for i=0 step s until 1:
fill rect shifted (i*(z0-z1)) withcolor i*white;
endfor;
draw carre withpen pencircle scaled 2bp;
endfig;
data:image/s3,"s3://crabby-images/afe3c/afe3c5205db1e6925818234eb65d8bc3f3907288" alt=""
beginfig(143)
z0 = (50,50);
z1 = z0 rotated 90;
z2 = z1 rotated 90;
z3 = z2 rotated 90;
path carre;
carre = z0--z1--z2--z3--cycle;
s := .01;
for i=1 step -s until s:
fill carre scaled i withcolor i*white;
endfor;
endfig;
data:image/s3,"s3://crabby-images/b93d3/b93d3049789fe5db75c649c4feef2f5e82586077" alt=""
beginfig(144)
u:=1cm;
vardef degrade(expr p,q,M,N) =
save a,b;
numeric a,b;
a := length(p);
b := length(q);
for i=0 upto M:
draw (i/M) [ point 0 of p, point 0 of q ]
for j=1 upto N:
.. (i/M) [ point (j/N*a) of p, point (j/N*b) of q ]
endfor;
endfor;
enddef;
degrade(
(-.1u,-.1u) .. (.1u,.1u) .. cycle,
(-u,-u) -- (u,-u) -- (u,u) -- (-u,u) -- cycle,
10,
100);
endfig;
data:image/s3,"s3://crabby-images/94148/94148ca54cc2eae8cab2e15d08fe8b2065cf975a" alt=""
beginfig(145)
u:=1cm;
def couleur(expr c) = c*white enddef;
vardef degrade(expr p,q,M,N) =
save a,b;
numeric a,b;
a := length(p);
b := length(q);
for i=0 upto M:
draw (i/M) [ point 0 of p, point 0 of q ]
for j=1 upto N:
.. (i/M) [ point (j/N*a) of p, point (j/N*b) of q ]
endfor
withcolor couleur(i/M);
endfor;
enddef;
degrade(
(-.5u,-.5u) .. (.5u,.5u) .. cycle,
(-u,-u) -- (u,-u) -- (u,u) -- (-u,u) -- cycle,
255,
100);
endfig;
data:image/s3,"s3://crabby-images/1e531/1e5310b773b8b9623c0f7f5e8794d26fe82d70c8" alt=""
beginfig(146)
def degrade(expr p, q, N) =
begingroup
save n, m, M;
numeric n, m, M;
n := length(p);
m := length(q);
M := n*m; % Il faudrait prendre le ppcm
for i=0 upto N:
draw
(i/N)[ point 0 of p, point 0 of q ]
{ (i/N)[ direction 0 of p, direction 0 of q ] }
for j=1 upto M-1:
..
{ (i/N) [ direction 1 of subpath((j-1)*n/M,j*n/M) of p,
direction 1 of subpath((j-1)*m/M,j*m/M) of q ] }
(i/N)[ point (j*n/M) of p, point (j*m/M) of q ]
{ (i/N) [ direction 0 of subpath(j*n/M,(j+1)*n/M) of p,
direction 0 of subpath(j*m/M,(j+1)*m/M) of q ] }
endfor
..
{ (i/N)[ direction n of p, direction m of q ] }
(i/N)[ point n of p, point m of q ]
;
endfor;
endgroup;
enddef;
numeric u;
u := 2cm;
path p, q;
p := fullcircle scaled u;
q := (-u,-u)--(u,-u)--(u,u)--(-u,u)--cycle;
degrade(p,q,10);
endfig;
data:image/s3,"s3://crabby-images/05cb0/05cb02d99b81f1489e333428da326857c2a93390" alt=""
beginfig(147)
draw for i=0 step 10 until 360:
2cm* (sind(2*i), cosd(3*i)) ..
endfor cycle;
endfig;
data:image/s3,"s3://crabby-images/f7f82/f7f82b2f81af4159fc7002dad983edf83772a8b0" alt=""
beginfig(148)
for i=0 step .1 until 360:
col := i/360;
draw 2cm* (sind(2*i), cosd(3*i))
withpen pencircle scaled 2bp
withcolor
if col>.5: (2*(1-col)) [red, blue]
else: (1-2col) [blue, red]
fi;
endfor;
endfig;
data:image/s3,"s3://crabby-images/3095a/3095a7c6eb321e59061c6977040904e36e487400" alt=""
beginfig(149)
def couleur(expr x) =
if x>.5: (2*(1-x)) [red, blue];
else: (1-2x) [blue, red]
fi
enddef;
for i=0 step .1 until 360:
draw 2cm* (sind(2*i), cosd(3*i))
withpen pencircle scaled 2bp
withcolor couleur(i/360);
endfor;
endfig;
data:image/s3,"s3://crabby-images/d5a53/d5a53ff4533ec6fc1d498c7ef4b7df57e45bba54" alt=""
beginfig(150)
for i=0 step 1 until 360:
pair P;
P = 2cm* (sind(2*i), cosd(3*i));
fill fullcircle scaled 4mm shifted P withcolor white;
draw fullcircle scaled 4mm shifted P;
endfor;
endfig;
data:image/s3,"s3://crabby-images/49bb0/49bb0d704a5af95db65221470b5b6fa09d52aaaf" alt=""
beginfig(151)
for i=0 step 1 until 360:
pair P;
P = 2cm* (sind(2*i), cosd(3*i));
fill fullcircle scaled 4mm shifted P withcolor white;
draw fullcircle scaled 4mm shifted P;
endfor;
picture p;
p:=nullpicture;
for i=-180 step 1 until 180:
pair P;
P = 2cm* (sind(2*i), cosd(3*i));
addto p contour fullcircle scaled 4mm shifted P withcolor white;
addto p doublepath fullcircle scaled 4mm shifted P
withpen pencircle scaled .5bp;
endfor;
clip p to (.5cm,2.5cm) -- (.5cm,1.5cm)--
(-.5cm,1.5cm) -- (-.5cm,2.5cm)--cycle;
draw p;
endfig;
data:image/s3,"s3://crabby-images/c4e8b/c4e8b10b971a83b8c146a0120257a427a019a3b1" alt=""
beginfig(152)
u:=5mm;
vardef project(expr x,y,z) =
x*(-1,-1) + y*(1,0) + z*(0,1)
enddef;
vardef f(expr x,y) = sind(x/u*180)*sind(y/u*180)*u enddef;
numeric m,M;
m:=-2u; M:=2u;
for i=m step .1u until M:
path p;
p =
for j=m step .1u until M:
project(i,j,f(i,j)) --
endfor
project(i,M,f(i,M));
fill (project(i,m,f(i,m)) - (0,3u)) -- p --
(project(i,M,f(i,M)) - (0,3u)) -- cycle
withcolor white;
draw (project(i,m,f(i,m)) - (0,3u)) -- p --
(project(i,M,f(i,M)) - (0,3u)) -- cycle;
draw p;
endfor;
endfig;
data:image/s3,"s3://crabby-images/f16c0/f16c0a34acccc3bcdff9ee08b56f98fb40e85c40" alt=""
beginfig(153)
vardef project(expr x,y,z) =
x*(-1,-1) + y*(1,0) + z*(0,1)
enddef;
vardef f(expr x,y) = sind(x/u*180)*sind(y/u*180)*u enddef;
m:=-2u; M:=2u; inc:=.1u;
for i=m step inc until M:
for j=m step inc until M:
path p;
p = project(i,j,f(i,j)) --
project(i,j+inc,f(i,j+inc)) --
project(i+inc,j+inc,f(i+inc,j+inc)) --
project(i+inc,j,f(i+inc,j)) --
cycle;
fill p withcolor white;
draw p;
endfor
endfor;
endfig;
data:image/s3,"s3://crabby-images/ae107/ae107ba8f4b1bf8ae7da826c9b795bbf00b7ce08" alt=""
beginfig(154)
vardef project(expr x,y,z) =
x*(-1,-1) + y*(1,0) + z*(0,1)
enddef;
vardef f(expr x,y) = sind(x/u*180)*sind(y/u*180)*u enddef;
numeric m,M,inc,couleur;
m:=-2u; M:=2u; inc:=.1u;
for i=m step inc until M:
for j=m step inc until M:
path p;
p = project(i,j,f(i,j)) --
project(i,j+inc,f(i,j+inc)) --
project(i+inc,j+inc,f(i+inc,j+inc)) --
project(i+inc,j,f(i+inc,j)) --
cycle;
dfdx := (f(i,j) - f(i+inc,j))/inc;
dfdy := (f(i,j) - f(i,j+inc))/inc;
couleur := 1/sqrt( dfdx**2 + dfdy**2 + 1);
fill p withcolor couleur*(red+green);
endfor
endfor;
endfig;
data:image/s3,"s3://crabby-images/cd442/cd442071802d40f4474c5c7a65080286f2db9810" alt=""
beginfig(155)
vardef f(expr x,y) = sind(x/u*180)*sind(y/u*180)*u enddef;
boolean dessine_fil_de_fer; dessine_fil_de_fer := false;
color dessine_couleur; dessine_couleur := red+green;
vardef dessine(suffix f)(expr xmin, xmax, xinc, ymin, ymax, yinc) =
save i,j,p,dfdx,dfdy,project;
vardef project(expr x,y,z) =
x*(-1,-1) + y*(1,0) + z*(0,1)
enddef;
for i=m step inc until M:
for j=m step inc until M:
path p;
p = project(i,j,f(i,j)) --
project(i,j+inc,f(i,j+inc)) --
project(i+inc,j+inc,f(i+inc,j+inc)) --
project(i+inc,j,f(i+inc,j)) --
cycle;
dfdx := (f(i,j) - f(i+inc,j))/inc;
dfdy := (f(i,j) - f(i,j+inc))/inc;
couleur := 1/sqrt( dfdx**2 + dfdy**2 + 1);
fill p withcolor couleur*dessine_couleur;
if dessine_fil_de_fer: draw p fi;
endfor
endfor;
enddef;
% Il faudrait pouvoir choisir différents
% types d'« éclairage ».
vardef f(expr x,y) = sind(x/u*180)*sind(y/u*180)*u enddef;
dessine(f,-2u,2u,.1u, -2u,2u,.1u);
endfig;
data:image/s3,"s3://crabby-images/5ec42/5ec423db47c478307f0e1f02d121b935ea8e86e7" alt=""
beginfig(156)
vardef random_path (expr n) =
save i, A ; numeric i; pair A[];
for i=0 upto n:
A[i] = (uniformdeviate(2u), uniformdeviate(2u));
endfor;
A[0]
for i=1 upto n:
.. A[i]
endfor
enddef;
vardef intersections(expr p,q) =
save a,b,N,i,j;
numeric N,i,j;
N:=10;
for i=0 step length(p)/N until length(p):
for j=0 step length(q)/N until length(p):
numeric a,b;
pair A;
(a,b) = (subpath(i,i+length(p)/N) of p)
intersectiontimes
(subpath(j,j+length(q)/N) of q);
if a <> -1:
A = point a of subpath(i,i+length(p)/N) of p;
show A;
draw A withpen pencircle scaled 4bp;
fi;
endfor;
endfor;
enddef;
path p,q;
p:=random_path(4);
q:=random_path(4);
draw p withcolor red;
draw q withcolor blue;
intersections(p,q);
endfig;
data:image/s3,"s3://crabby-images/dfeda/dfedaa70fb2876ff4533bf895d29153dbb7ba855" alt=""
beginfig(157)
vardef auto_intersections(expr p) =
save a,b,N,i,j;
numeric N,i,j;
N:=100;
for i=0 step length(p)/N until length(p):
for j=i+2*length(p)/N
step length(p)/N
until length(p):
numeric a,b;
pair A;
(a,b) = (subpath(i,i+length(p)/N) of p)
intersectiontimes
(subpath(j,j+length(p)/N) of p);
if a <> -1:
A = point a of subpath(i,i+length(p)/N) of p;
show A;
draw A withpen pencircle scaled 4bp;
fi;
endfor;
endfor;
enddef;
u:=2cm;
path p,q;
p:=random_path(12);
draw p;
auto_intersections(p);
endfig;
data:image/s3,"s3://crabby-images/76578/76578aac165599301d7d391521da47c0166d7738" alt=""
beginfig(158)
path p;
p := (0,0){up} .. (1cm,1cm) .. (1cm,0);
draw p;
draw point 1/2length(p) of p
withpen pencircle scaled 4bp withcolor red;
draw point (arctime (1/2 arclength(p)) of p) of p
withpen pencircle scaled 4bp;
endfig;
data:image/s3,"s3://crabby-images/280d7/280d77addf1634e5621b5714997f08032ccdfba9" alt=""
beginfig(159)
vardef milieu(expr p) =
save l,i,tot,A,B;
numeric l,tot,i;
pair A,B;
tot := longueur(p);
l:=0;
B := point 0 of p;
for i:=0 step .01 until length(p):
A := B;
B := point i of p;
l := l+abs(B-A);
exitif l > 1/2 tot;
endfor;
1/2[A,B]
enddef;
path p;
p := (0,0){up} .. (1cm,1cm) .. (1cm,0);
draw p;
draw point 1/2length(p) of p withpen pencircle scaled 4bp withcolor red;
draw milieu(p) withpen pencircle scaled 4bp;
endfig;
data:image/s3,"s3://crabby-images/070ac/070ac42ade4b99d755580cc2712d7955345dd2fb" alt=""
beginfig(160)
vardef milieu_time(expr p) =
save l,i,tot,A,B,t;
numeric l,tot,i,t;
pair A,B;
tot := longueur(p);
l:=0;
B := point 0 of p;
for i:=0 step .01 until length(p):
t:=i;
A := B;
B := point i of p;
l := l+abs(B-A);
exitif l > 1/2 tot;
endfor;
t % Pas de point-virgule
enddef;
save arrowhead;
vardef arrowhead expr p =
save A,u; pair A,u;
A := milieu(p);
u := unitvector(direction milieu_time(p) of p);
A -- (A - ahlength*u rotated 15) --
(A - ahlength*u rotated -15) -- cycle
enddef;
u:=1cm;
drawarrow (0,0) .. (-u,u) .. (u,u);
endfig;
data:image/s3,"s3://crabby-images/57190/571903f694e7c64429f39ff1dbe8348c9cffe2e3" alt=""
beginfig(161)
save arrowhead;
vardef arrowhead expr p =
save A,B,u; pair A,B,u;
A := milieu(p);
B := p intersectionpoint
(fullcircle scaled ahlength shifted A);
u := unitvector(direction milieu_time(p) of p);
A -- (A - ahlength*u rotated 30) -- B --
(A - ahlength*u rotated -30) -- cycle
enddef;
u:=1cm;
drawarrow (0,0) .. (-u,u) .. (u,u);
endfig;
data:image/s3,"s3://crabby-images/748c4/748c4ee779e8489bff71d59a30eafc5bb5fee89c" alt=""
beginfig(162)
save arrowhead;
vardef arrowhead expr p =
save A,u; pair A,u;
A := milieu(p);
u := unitvector(direction milieu_time(p) of p);
A -- (A - ahlength*u rotated 30) -- A --
(A - ahlength*u rotated -30) -- cycle
enddef;
u:=1cm;
drawarrow (0,0) .. (-u,u) .. (u,u);
endfig;
data:image/s3,"s3://crabby-images/201e3/201e36497a022e2c6f93dcab855c4ea632c6adce" alt=""
beginfig(163)
save arrowhead;
vardef arrowhead expr p =
save A,u,a,b; pair A,u; path a,b;
A := milieu(p);
u := unitvector(direction milieu_time(p) of p);
a := A{-u} .. (A - ahlength*u rotated 30);
b := A{-u} .. (A - ahlength*u rotated -30);
( a & reverse(a) & b & reverse(b) ) --cycle
enddef;
u:=1cm;
drawarrow (0,0) .. (-u,u) .. (u,u);
endfig;
data:image/s3,"s3://crabby-images/f37b2/f37b2d7ea16413bf109bd730077947222d7f983e" alt=""
beginfig(164)
pair A,B,C;
C = 3mm*up;
A = C rotated 120;
B = C rotated -120;
picture pic ;
pic:=nullpicture;
addto pic doublepath A--B--C--cycle withpen currentpen;
addto pic doublepath A withpen pencircle scaled 4bp;
addto pic doublepath B withpen pencircle scaled 4bp;
addto pic doublepath C withpen pencircle scaled 4bp;
for i=-3 upto 3:
for j=-3 upto 3:
draw pic shifted( i*(B-A) + j*(C-A) );
endfor;
endfor;
clip currentpicture to (-2cm,-2cm)--(2cm,-2cm)--(2cm,2cm)--(-2cm,2cm)--cycle;
endfig;
data:image/s3,"s3://crabby-images/624a7/624a7c8e88fbe00e99d309f87dde29e9bfaafef2" alt=""
beginfig(165)
pair A,B,C;
C = 3mm*up;
A = C rotated 120;
B = C rotated -120;
picture pic ;
pic:=nullpicture;
path p;
p := A{(C-A) rotated 30} .. C{(C-A) rotated 30};
addto pic doublepath p withpen currentpen;
addto pic doublepath p rotated 120 withpen currentpen;
addto pic doublepath p rotated -120 withpen currentpen;
for i=-3 upto 3:
for j=-3 upto 3:
draw pic shifted( i*(B-A) + j*(C-A) );
endfor;
endfor;
clip currentpicture to (-2cm,-2cm)--(2cm,-2cm)--(2cm,2cm)--(-2cm,2cm)--cycle;
endfig;
data:image/s3,"s3://crabby-images/2af6e/2af6e1a957996918954b0181d811c8aaa902ebb6" alt=""
beginfig(166)
ux:=2mm;
uy:=5mm;
numeric xmin, xmax, ymin, ymax, M;
xmin := -6.3; xmax := 12.6;
ymin := -2; ymax := 2;
M := 100;
draw (ux*xmin,0) -- (ux*xmax,0);
draw (0,uy*ymin) -- (0,uy*ymax);
pair a[];
for i=0 upto M:
a[i] := (
xmin + (i/M)*(xmax-xmin),
sind(180/3.14*( xmin + (i/M)*(xmax-xmin) ))
) xscaled ux yscaled uy;
endfor;
draw a[0] for i=1 upto M: --a[i] endfor;
endfig;
data:image/s3,"s3://crabby-images/a884b/a884b075f2745e1b4b3596403f445b397952ce1c" alt=""
beginfig(167)
ux:=5mm;
uy:=2mm;
numeric xmin, xmax, ymin, ymax, M;
xmin := -2; xmax := 2;
ymin := -.1; ymax := 8;
M := 100;
draw (ux*xmin,0) -- (ux*xmax,0);
draw (0,uy*ymin) -- (0,uy*ymax);
pair a[];
for i=0 upto M:
a[i] := (
xmin + (i/M)*(xmax-xmin),
mexp(256*( xmin + (i/M)*(xmax-xmin) ))
) xscaled ux yscaled uy;
endfor;
draw a[0] for i=1 upto M: --a[i] endfor;
endfig;
data:image/s3,"s3://crabby-images/31c2f/31c2f59d154b5f4db93d7481f2c90831254c1deb" alt=""
beginfig(168)
ux:=5mm;
uy:=5mm;
numeric xmin, xmax, ymin, ymax, M;
xmin := .2; xmax := 3;
ymin := -1.6; ymax := 1.2;
M := 100;
draw (ux*-.1,0) -- (ux*xmax,0);
draw (0,uy*ymin) -- (0,uy*ymax);
pair a[];
for i=0 upto M:
a[i] := (
xmin + (i/M)*(xmax-xmin),
(1/256)*mlog(( xmin + (i/M)*(xmax-xmin) ))
) xscaled ux yscaled uy;
endfor;
draw a[0] for i=1 upto M: --a[i] endfor;
endfig;
data:image/s3,"s3://crabby-images/04070/04070f4e64eb7609da29965223dae8a865493bd5" alt=""
beginfig(169)
path p;
p = fullcircle scaled 2cm;
z0 = (-1cm,0);
draw p;
draw z0 withpen pencircle scaled 2pt;
pair A[];
for i=0 step length(p)/100 until length(p):
pair M,N;
M = point i of p;
N-M = whatever * direction i of p;
N-z0 = whatever * direction i of p rotated 90;
A[i] := N;
endfor;
draw for i=0 step length(p)/100 until length(p):
A[i] ..
endfor cycle;
endfig;
data:image/s3,"s3://crabby-images/0435c/0435ca853cab174c98b5eb19e969c3823dc81466" alt=""
beginfig(170)
vardef cardiodide(expr p, O) =
save i,M,N;
numeric i;
for i=0 step length(p)/100 until length(p):
hide(
pair M,N;
M = point i of p;
N-M = whatever * direction i of p;
N-O = whatever * direction i of p rotated 90;
)
N ..
endfor cycle
enddef;
path p;
p = fullcircle scaled 2cm;
z0 = (-1cm,0);
draw p;
draw z0 withpen pencircle scaled 2pt;
draw cardiodide(p,z0);
endfig;
data:image/s3,"s3://crabby-images/557b7/557b717a347363c25773ce9334e3dddeb858f1c9" alt=""
beginfig(171)
vardef cardiodide(expr p, O) =
save i,M,N;
numeric i;
for i=0 step length(p)/100 until length(p):
hide(
pair M,N;
M = point i of p;
N-M = whatever * direction i of p;
N-O = whatever * direction i of p rotated 90;
)
N ..
endfor cycle
enddef;
path p;
p = fullcircle scaled 2cm;
z0 = (-1cm,0);
pickup pencircle scaled 1pt
draw p;
draw z0 withpen pencircle scaled 3pt;
draw cardiodide(p,z0);
pickup pencircle scaled .4pt
pair M,N;
i:=1.5;
M = point i of p;
N-M = whatever * direction i of p;
N-z0 = whatever * direction i of p rotated 90;
draw z0--N;
draw (-1/2)[N,M]--(3/2)[N,M];
draw N withpen pencircle scaled 3pt;
draw M withpen pencircle scaled 3pt;
endfig;
data:image/s3,"s3://crabby-images/a030e/a030e8baf1458d5096e7d95543dc4e1a48d50de7" alt=""
beginfig(172)
path p;
p := (-1cm,0) .. (1cm,-1cm) .. (8mm,0)
.. (1cm,1cm) .. (-1cm,1cm) .. cycle;
z0 = (-2cm,0);
draw p withpen pencircle scaled 1bp;
draw z0 withpen pencircle scaled 3pt;
draw cardiodide(p,z0);
endfig;
data:image/s3,"s3://crabby-images/259f9/259f97bcad0f99057a343fd8dabae8a3510aca77" alt=""
beginfig(173)
vardef inversion (expr O,k,M) =
if pair M:
(O + k*unitvector(M-O)/abs(M-O))
elseif path M:
for i=0 step length(M)/100 until length(M):
inversion(O,k,point i of M) ..
endfor
cycle
fi
enddef;
u:=4cm;
path p[],A,B;
z0 = (5u,0) rotated 10;
A = fullcircle scaled 2u;
B = A scaled 3;
draw inversion( z0, 2 (u**2), A )
withpen pencircle scaled 1pt;
draw inversion( z0, 2 (u**2), B )
withpen pencircle scaled 1pt;
p0 = fullcircle scaled 2u shifted (2u,0);
for i=0 upto 5:
if i<>0:
p[i] = p[i-1] rotated (360/6);
fi;
draw inversion( z0, 2 (u**2), p[i] );
endfor;
endfig;
data:image/s3,"s3://crabby-images/e0422/e0422c4a075bd0de21819a14c7ccfb9bae701ba1" alt=""
beginfig(174)
def curve(expr p,i,q,j,t) =
point i of p {direction i of p} ..
tension t ..
point j of q {direction j of q}
enddef;
vardef sphere_with_holes (expr n) =
save i;
c[0] = fullcircle xscaled u yscaled 2u
shifted (4u,0) rotated (360/(2n)) ;
draw c[0];
for i=1 upto n-1:
c[i] = c[i-1] rotated (360/n);
draw c[i];
endfor;
l[0] = curve(c[0], 2, c[1], -2, 1);
draw l[0];
for i=1 upto n-1:
l[i] = l[i-1] rotated (360/n);
draw l[i];
endfor;
enddef;
u:=3mm;
path c[], l[];
sphere_with_holes(5);
endfig;
data:image/s3,"s3://crabby-images/217a3/217a3e153baae407c7a0664393f83f39b08db332" alt=""
beginfig(175)
def curve(expr p,i,q,j,t) =
point i of p {direction i of p} ..
tension t ..
point j of q {direction j of q}
enddef;
vardef sphere_with_holes (expr n) =
save i;
c[0] = fullcircle xscaled u yscaled 2u
shifted (4u,0) rotated (360/(2n)) ;
for i=1 upto n-1:
c[i] = c[i-1] rotated (360/n);
endfor;
l[0] = curve(c[0], 2, c[1], -2, 1);
for i=1 upto n-1:
l[i] = l[i-1] rotated (360/n);
endfor;
fill for i=0 upto n-1:
( reverse subpath(2,6) of c[i] ) &
l[i] &
endfor
% To turn it into a cycle (ugly)
point length(l[n-1]) of l[n-1] -- cycle
withcolor .8white;
for i=0 upto n-1:
draw c[i]; draw l[i];
endfor;
enddef;
u:=3mm;
path c[], l[];
sphere_with_holes(5);
endfig;
data:image/s3,"s3://crabby-images/f4b84/f4b84d613e14af3700e174aa455b1e0771f52e64" alt=""
beginfig(176)
path c[], l[];
sphere_with_holes(6);
def ellipse(expr a,b,c,d,e) =
draw curve(a,b,c,d,e) ;
draw curve(c,d,a,b,e) dashed evenly;
enddef;
ellipse (l[0], 2/3, l[2], 1/3, 4);
ellipse (l[1], 2/3, l[3], 1/3, 4);
ellipse (l[2], 2/3, l[4], 1/3, 4);
ellipse (l[3], 2/3, l[5], 1/3, 4);
ellipse (l[4], 2/3, l[0], 1/3, 4);
ellipse (l[5], 2/3, l[1], 1/3, 4);
endfig;
data:image/s3,"s3://crabby-images/6774b/6774b9fc2e7ec67c2d0e297a4180a19e285d3acc" alt=""
beginfig(177)
vardef bar(expr m,a,b,c) =
m = 1/3a + 1/3b + 1/3c
enddef;
vardef dbar(expr m,a,b,c) =
draw m--a; draw m--b; draw m--c;
draw m withpen pencircle scaled 4bp;
enddef;
pair P[], A,B,C;
for i=0 upto 4:
P[i] = 1cm * up rotated (i*360/5);
draw P[i] withpen pencircle scaled 4bp;
endfor;
bar(A, P[0], P[4], B);
bar(B, A, P[1], C);
bar(C, B, P[2], P[3]);
draw fullcircle scaled 2cm dashed evenly;
dbar(A, P[0], P[4], B);
dbar(B, A, P[1], C);
dbar(C, B, P[2], P[3]);
endfig;
data:image/s3,"s3://crabby-images/fc335/fc3359e29c323611a2266fdc695636411e3634f7" alt=""
beginfig(178)
% M est sur la bissectrice de l'angle A
vardef bissectrice(expr M,A,B,C) =
(M-A) = whatever * (
(A-C) rotated 1/2(angle(B-A) - angle(C-A)))
enddef;
% Le cercle inscrit
vardef cercle_inscrit(expr A,B,C) =
save M, h; pair M, h;
bissectrice(M,A,B,C);
bissectrice(M,B,C,A);
M-h = whatever * (B-C) rotated 90;
h = whatever[B,C];
fullcircle scaled 2 length(M-h) shifted M
enddef;
pair A,B,C,M;
u:=2cm;
A=(0,0); B=(2u,-.5u); C=(u,u);
draw A--B--C--cycle;
bissectrice(M, A,B,C);
bissectrice(M, B,C,A);
draw M--A; draw M--B; draw M--C;
draw cercle_inscrit(A,B,C);
endfig;
data:image/s3,"s3://crabby-images/dd97b/dd97b6b97ef43ae34264a583ced408665a598d45" alt=""
beginfig(179)
vardef premiere_trisectrice (expr M, A,B,C) =
(M-A) = whatever * ( (A-B) rotated 1/3 (angle(C-A) - angle(B-A)) )
enddef;
vardef deuxieme_trisectrice (expr M, A,B,C) =
(M-A) = whatever * ( (A-B) rotated 2/3 (angle(C-A) - angle(B-A)) )
enddef;
pair A,B,C,M[];
u:=2cm;
A=(0,0); B=(2u,-.5u); C=(u,u);
draw A--B--C--cycle;
premiere_trisectrice(M1,A,B,C);
deuxieme_trisectrice(M1,B,C,A);
premiere_trisectrice(M2,B,C,A);
deuxieme_trisectrice(M2,C,A,B);
premiere_trisectrice(M3,C,A,B);
deuxieme_trisectrice(M3,A,B,C);
draw M1--A; draw M1--B;
draw M2--B; draw M2--C;
draw M3--C; draw M3--A;
draw M1--M2--M3--cycle;
endfig;
data:image/s3,"s3://crabby-images/3cedd/3cedd891e55f706b7568bc71df2f2e1ced44c606" alt=""
beginfig(180)
save arrowhead;
vardef arrowhead expr p =
save A,u; pair A,u;
A := point length(p) of p;
u := unitvector(direction length(p) of p);
A -- (A - ahlength*u rotated 15) --
(A - ahlength*u rotated -15) -- cycle
enddef;
u:=1cm;
drawarrow (0,0) .. (-u,u) .. (u,u);
endfig;
data:image/s3,"s3://crabby-images/f35ad/f35ad418b10d41b6455a728903845edadb28e96a" alt=""
beginfig(181)
save arrowhead;
vardef arrowhead expr p =
save A,B,u; pair A,B,u;
A := point length(p) of p;
B := p intersectionpoint
(fullcircle scaled ahlength shifted A);
u := unitvector(direction length(p) of p);
A -- (A - ahlength*u rotated 30) -- B --
(A - ahlength*u rotated -30) -- cycle
enddef;
u:=1cm;
drawarrow (0,0) .. (-u,u) .. (u,u);
endfig;
data:image/s3,"s3://crabby-images/ad691/ad6914454b0c00bc9dfb83f51fa9598699b956bd" alt=""
beginfig(182)
save arrowhead;
vardef arrowhead expr p =
save A,u; pair A,u;
A := point length(p) of p;
u := unitvector(direction length(p) of p);
A -- (A - ahlength*u rotated 30) -- A --
(A - ahlength*u rotated -30) -- cycle
enddef;
u:=1cm;
drawarrow (0,0) .. (-u,u) .. (u,u);
endfig;
data:image/s3,"s3://crabby-images/4ee6f/4ee6faa29bc94bc38b1bbb3d5383d7ec3240a4fb" alt=""
beginfig(183)
save arrowhead;
vardef arrowhead expr p =
save A,u,a,b; pair A,u; path a,b;
A := point length(p) of p;
u := unitvector(direction length(p) of p);
a := A{-u} .. (A - ahlength*u rotated 30);
b := A{-u} .. (A - ahlength*u rotated -30);
( a & reverse(a) & b & reverse(b) ) --cycle
enddef;
u:=1cm;
drawarrow (0,0) .. (-u,u) .. (u,u);
endfig;
data:image/s3,"s3://crabby-images/485f7/485f7a7ef502f0e37425d739d762e585f563f2bd" alt=""
beginfig(184)
save arrowhead;
vardef arrowhead expr p =
save A,u; pair A,u;
A := point 1/2length(p) of p;
u := unitvector(direction 1/2length(p) of p);
A -- (A - ahlength*u rotated 15) --
(A - ahlength*u rotated -15) -- cycle
enddef;
u:=1cm;
drawarrow (0,0) .. (-u,u) .. (u,u);
endfig;
data:image/s3,"s3://crabby-images/2b38e/2b38e635e2e43673d55354a5c7bfa6dde34efc7c" alt=""
beginfig(185)
save arrowhead;
vardef arrowhead expr p =
save A,B,u; pair A,B,u;
A := point 1/2length(p) of p;
B := p intersectionpoint
(fullcircle scaled ahlength shifted A);
u := unitvector(direction 1/2length(p) of p);
A -- (A - ahlength*u rotated 30) -- B --
(A - ahlength*u rotated -30) -- cycle
enddef;
u:=1cm;
drawarrow (0,0) .. (-u,u) .. (u,u);
endfig;
data:image/s3,"s3://crabby-images/d4502/d4502394346dedb81ab3ac5e1b9524312ef302b8" alt=""
beginfig(186)
save arrowhead;
vardef arrowhead expr p =
save A,u; pair A,u;
A := point 1/2length(p) of p;
u := unitvector(direction 1/2length(p) of p);
A -- (A - ahlength*u rotated 30) -- A --
(A - ahlength*u rotated -30) -- cycle
enddef;
u:=1cm;
drawarrow (0,0) .. (-u,u) .. (u,u);
endfig;
data:image/s3,"s3://crabby-images/8bbbb/8bbbbdaa51c819195a539a811352bb2ced61573c" alt=""
beginfig(187)
save arrowhead;
vardef arrowhead expr p =
save A,u,a,b; pair A,u; path a,b;
A := point 1/2length(p) of p;
u := unitvector(direction 1/2length(p) of p);
a := A{-u} .. (A - ahlength*u rotated 30);
b := A{-u} .. (A - ahlength*u rotated -30);
( a & reverse(a) & b & reverse(b) ) --cycle
enddef;
u:=1cm;
drawarrow (0,0) .. (-u,u) .. (u,u);
endfig;
data:image/s3,"s3://crabby-images/05e49/05e49f240f2c940425de0821b50bcf7b330bde07" alt=""
beginfig(188)
def drawwhitearrow expr p = _apth:=p; _finwhitearr enddef;
def _finwhitearr text t =
draw _apth t;
fill arrowhead _apth t withcolor white;
draw arrowhead _apth t
enddef;
u:=1cm;
drawwhitearrow (0,0) .. (-u,u) .. (u,u);
endfig;
data:image/s3,"s3://crabby-images/2450e/2450e809c363071dc5f9987da43ad6bcfa4cdd66" alt=""
beginfig(189)
def draw_white_arrow expr p = _apth:=p; _fin_white_arr enddef;
def _fin_white_arr text t =
draw _apth t;
fill arrowhead _apth withcolor white;
draw arrowhead _apth t
enddef;
def draw_middle_arrow expr p = _apth:=p; _fin_middle_arr enddef;
def _fin_middle_arr text t =
draw _apth t;
filldraw arrowhead_middle _apth t
enddef;
vardef arrowhead_middle expr p =
save A,u; pair A,u;
A := point (arctime (.5arclength p) of p) of p;
u := unitvector(direction (arctime (.5arclength p) of p) of p);
A -- (A - ahlength*u rotated (.5ahangle) ) --
(A - ahlength*u rotated (-.5ahangle) ) -- cycle
enddef;
def draw_middle_white_arrow expr p = _apth:=p; _fin_middle_white_arr enddef;
let draw_white_middle_arrow = draw_middle_white_arrow;
def _fin_middle_white_arr text t =
draw _apth t;
fill arrowhead_middle _apth t withcolor white;
draw arrowhead_middle _apth t
enddef;
def draw_other_arrow expr p = _apth:=p; _fin_other_arr enddef;
def _fin_other_arr text t =
draw _apth t;
draw arrowhead_other _apth t
enddef;
vardef arrowhead_other expr p =
save A,u,a,b; pair A,u; path a,b;
A := point (length p) of p;
u := unitvector(direction (length p) of p);
a := A{-u} .. (A - ahlength*u rotated 30);
b := A{-u} .. (A - ahlength*u rotated -30);
( a & reverse(a) & b & reverse(b) ) --cycle
enddef;
def draw_other_middle_arrow expr p = _apth:=p; _fin_other_middle_arr enddef;
let draw_middle_other_arrow = draw_other_middle_arrow;
def _fin_other_middle_arr text t =
draw _apth t;
draw arrowhead_other_middle _apth t
enddef;
vardef arrowhead_other_middle expr p =
save A,u,a,b; pair A,u; path a,b;
A := point (arctime (.5arclength p) of p) of p;
u := unitvector(direction (arctime (.5arclength p) of p) of p);
a := A{-u} .. (A - ahlength*u rotated 30);
b := A{-u} .. (A - ahlength*u rotated -30);
( a & reverse(a) & b & reverse(b) ) --cycle
enddef;
path p;
p := halfcircle scaled 2cm;
p := (0,0) .. (3cm,1cm) .. (-1cm,3cm);
p := p scaled .3;
draw_middle_arrow p;
draw_white_arrow p scaled 1.3 withpen pencircle scaled 1bp;
draw_white_middle_arrow p scaled 1.6;
draw_other_middle_arrow p scaled 1.8 withpen pencircle scaled 1bp;
draw_other_arrow p scaled 2 withpen pencircle scaled 1bp;
endfig;
data:image/s3,"s3://crabby-images/6f96c/6f96cc4ddc98271a1b1d66f2b9695a1451570020" alt=""
beginfig(190)
vardef mylabel(expr pic, p, t) =
save A; pair A;
A = point t of p +
8bp * unitvector(direction t of p) rotated 90;
label(pic, A);
enddef;
path p; u:=1cm;
p = (0,0)..(-u,u)..(u,u);
draw p;
for i=0 step .2 until length(p):
draw point i of p withpen pencircle scaled 4bp;
mylabel(btex $A$ etex,p,i);
endfor;
endfig;
data:image/s3,"s3://crabby-images/44462/4446255fecde38f31773f2ff20cb7977fef3b1eb" alt=""
beginfig(191)
vardef mylabel(expr pic, p, t) =
save A; pair A;
A = point t of p +
8bp * unitvector(direction t of p) rotated 90;
label(pic, A);
enddef;
path p; u:=1cm;
p = (0,0)..(-u,u)..(u,u);
draw p;
for i=0 step .2 until length(p):
draw point i of p withpen pencircle scaled 4bp;
mylabel(TEX decimal(i),p,i);
endfor;
endfig;
data:image/s3,"s3://crabby-images/9459a/9459a60693147fc7ec8068359c744e2517624930" alt=""
beginfig(192)
vardef mylabel(expr pic, p, t) =
save A,a; pair A; numeric a;
a := angle(direction t of p rotated 90);
show(a);
a := a + 45/2;
if a>180: a := a - 360 fi;
save ll, lr, ul, ur;
pair ul,ur,ll,lr;
ll := llcorner pic;
lr := lrcorner pic;
ul := ulcorner pic;
ur := urcorner pic;
A = point t of p +
8bp * unitvector(direction t of p) rotated 90;
label(pic shifted ll, A +
if (a >= 0) and (a <= 45): 1/2(ur-ul)
elseif (a >= 45) and (a <= 90): 1/2(ur-ul) + 1/2(ur-lr)
elseif (a >= 90) and (a <= 135): 1/2(ur-lr)
elseif (a >= 135) and (a <= 180): 1/2(ll-lr) + 1/2(ur-lr)
elseif (a >= -180) and (a <= -135): 1/2(ll-lr)
elseif (a >= -135) and (a <= -90): 1/2(ll-ul) + 1/2(ll-lr)
elseif (a >= -90) and (a <= -45): 1/2(ll-ul)
elseif (a >= -45) and (a <= 0): 1/2(ll-ul) - 1/2(ll-lr)
else: hide(show "BUG") (0,0)
fi);
draw A withpen pencircle scaled 2bp withcolor red;
enddef;
path p; u:=1cm;
p = (0,0)..(-u,u)..(u,u);
p := reverse fullcircle scaled 2u;
draw p;
for i=0 step length(p)/10 until length(p):
draw point i of p withpen pencircle scaled 4bp;
mylabel(TEX decimal(i),p,i);
endfor;
endfig;
data:image/s3,"s3://crabby-images/472ed/472ed6573a39dfe658feb799ff88fa9ae110044d" alt=""
beginfig(193)
n:=8;
u:=5mm;
for i=0 upto n-1:
for j=0 upto n-1:
if odd(i+j):
fill (0,0)--(u,0)--(u,u)--(0,u)--cycle
shifted (i*u,j*u) withcolor .8white;
fi;
endfor;
endfor;
for i=0 upto n:
draw (0,i*u)--(n*u,i*u);
draw (i*u,0)--(i*u,n*u);
endfor;
endfig;
data:image/s3,"s3://crabby-images/6facd/6facd173af8fb40b290b65a933b795e3189c1159" alt=""
beginfig(194)
n:=8;
u:=5mm;
for i=0 upto n-1:
for j=0 upto n-1:
if odd(i+j):
for k=0 step u/5 until u:
draw ( (k,0)--(u,u-k) )
shifted (i*u,j*u);
draw ( (0,k)--(u-k,u) )
shifted (i*u,j*u);
endfor;
fi;
endfor;
endfor;
for i=0 upto n:
draw (0,i*u)--(n*u,i*u);
draw (i*u,0)--(i*u,n*u);
endfor;
endfig;
data:image/s3,"s3://crabby-images/dc893/dc893a5d78a3ef4c6f022702152db8720ce88618" alt=""
beginfig(195)
n:=8;
u:=5mm;
for i=0 upto n-1:
for j=0 upto n-1:
if odd(i+j):
for k=0 step u/5 until 4/5 u:
if odd(k*5/u):
fill ( (k,0)--(u,u-k)--(u,u-k-u/5)--
(k+u/5,0)--cycle )
shifted (i*u,j*u) withcolor .8white;
else:
fill ( (0,k)--(u-k,u)--(u-k-u/5,u)--
(0,k+u/5)--cycle )
shifted (i*u,j*u) withcolor .8white;
fi;
endfor;
fi;
endfor;
endfor;
for i=0 upto n:
draw (0,i*u)--(n*u,i*u);
draw (i*u,0)--(i*u,n*u);
endfor;
endfig;
data:image/s3,"s3://crabby-images/38302/38302ea23075302c1bc678294db6cf7c401544f1" alt=""
beginfig(196)
vardef trace (suffix f)(expr a,b,inc) =
save i; numeric i;
for i=a step inc until b:
(i*1cm, f(i)*1cm) ..
endfor (b*1cm, f(b)*1cm)
enddef;
vardef axes =
save p; picture p;
p:=nullpicture;
addto p doublepath (-infinity,0)--(infinity,0) withpen currentpen;
addto p doublepath (0,-infinity)--(0,infinity) withpen currentpen;
clip p to bbox currentpicture;
draw p;
enddef;
vardef trace_rectangles_left (suffix f)(expr a,b,inc) =
save i; numeric i;
for i=a step inc until b-inc:
path p;
p = (i,0)--(i+inc,0)--(i+inc,f(i))--(i,f(i))--cycle;
p := p scaled 1cm;
fill p withcolor .8*white;
draw p;
endfor;
enddef;
vardef f(expr x) = 2 ** x enddef;
trace_rectangles_left(f,-2,2,.5);
draw trace(f, -2,2,.1);
axes;
endfig;
data:image/s3,"s3://crabby-images/a44b0/a44b08ef48b453ec26838fe2350fc360948b329a" alt=""
beginfig(197)
vardef trace_trapezes (suffix f)(expr a,b,inc) =
save i; numeric i;
for i=a step inc until b-inc:
path p;
p = (i,0)--(i+inc,0)--(i+inc,f(i+inc))--(i,f(i))--cycle;
p := p scaled 1cm;
fill p withcolor .8*white;
draw p;
endfor;
enddef;
vardef f(expr x) = 4 - x**2 enddef;
trace_trapezes(f,-2,2,.5);
draw trace(f, -2,2,.1);
axes;
endfig;
data:image/s3,"s3://crabby-images/5996b/5996b3d4929b774d878217005b838a77f455687b" alt=""
beginfig(198)
vardef trace_rectangles_right (suffix f)(expr a,b,inc) =
save i; numeric i;
for i=a step inc until b-inc:
path p;
p = (i,0)--(i+inc,0)--(i+inc,f(i+inc))--(i,f(i+inc))--cycle;
p := p scaled 1cm;
fill p withcolor .8*white;
draw p;
endfor;
enddef;
trace_rectangles_right(f,-2,2,.5);
draw trace(f, -2,2,.1);
axes;
endfig;
data:image/s3,"s3://crabby-images/c9ccc/c9ccc64b3aa82a133a2d16ba5ce999f2a89c5f9a" alt=""
beginfig(199)
vardef maxf(suffix f)(expr a,b) =
save m,i; numeric m,i;
m:=f(a);
for i=a step (b-a)/100 until b:
if m
data:image/s3,"s3://crabby-images/11f5e/11f5eeeb9d51730577e5a73b533f2dc9b49b8f70" alt=""
beginfig(200)
vardef minf(suffix f)(expr a,b) =
save m,i; numeric m,i;
m:=f(a);
for i=a step (b-a)/100 until b:
if m>f(i): m:=f(i); fi;
endfor;
m
enddef;
vardef trace_rectangles_min (suffix f)(expr a,b,inc) =
save i; numeric i;
for i=a step inc until b-inc:
path p; numeric m;
m:=minf(f,i,i+inc);
p = (i,0)--(i+inc,0)--(i+inc,m)--(i,m)--cycle;
p := p scaled 1cm;
fill p withcolor .8*white;
draw p;
endfor;
enddef;
vardef f(expr x) = 4 - x**2 enddef;
trace_rectangles_min(f,-2,2,.5);
draw trace(f, -2,2,.1);
axes;
endfig;
data:image/s3,"s3://crabby-images/16cb0/16cb00549c4ad9cea234ef3be254bd8df3c6b013" alt=""
beginfig(201)
u:=2cm;
vardef koch(expr A,B,n) =
save C; pair C;
C = A rotatedaround(1/3[A,B], 120);
if n>0:
koch( A, 1/3[A,B], n-1);
koch( 1/3[A,B], C, n-1);
koch( C, 2/3[A,B], n-1);
koch( 2/3[A,B], B, n-1);
else:
draw A--1/3[A,B]--C--2/3[A,B]--B;
fi;
enddef;
z0=(u,0);
z1=z0 rotated 120;
z2=z1 rotated 120;
koch( z0, z1, 4 );
koch( z1, z2, 4 );
koch( z2, z0, 4 );
endfig;
data:image/s3,"s3://crabby-images/4066b/4066b14a92dbf2456fd267f5e600d9c5b9c843d5" alt=""
beginfig(202)
u:=2cm;
vardef koch(expr A,B,n) =
save C; pair C;
C = A rotatedaround(1/3[A,B], -120);
if n>0:
koch( A, 1/3[A,B], n-1);
koch( 1/3[A,B], C, n-1);
koch( C, 2/3[A,B], n-1);
koch( 2/3[A,B], B, n-1);
else:
draw A--1/3[A,B]--C--2/3[A,B]--B;
fi;
enddef;
z0=(u,0);
z1=z0 rotated 120;
z2=z1 rotated 120;
koch( z0, z1, 4 );
koch( z1, z2, 4 );
koch( z2, z0, 4 );
endfig;
data:image/s3,"s3://crabby-images/d10e5/d10e5e8a8d985bfe2d85b3c2c43e856984adfd54" alt=""
beginfig(203)
pair A,B,C,D;
u := 3cm;
A := (0,0);
B := (u,0);
D := B rotated 72;
C := (u,0) + D;
draw A--B--C--D--cycle;
draw A--C;
draw btex $B'$ etex shifted 1/3 (A+B+C);
draw btex $B$ etex shifted 1/3 (A+D+C);
endfig;
data:image/s3,"s3://crabby-images/fac16/fac16ad0a0c0d3a8219830f2449996c69455e933" alt=""
beginfig(204)
pair A,B,C,D,E,F;
numeric d[];
u := 3cm;
A := (0,0);
B := (u,0);
D := B rotated 72;
C := (u,0) + D;
d[0] := 1;
d[1] := sqrt( 2*(1+cosd(72)) );
d[2] := sqrt( 2*(1-cosd(36)) );
A := A;
B := C;
C := D;
draw A--B--C--cycle;
E := (d1/(d0+d1)) [A,C];
F := (d0/(d0+d2)) [A,B];
draw E--C--F--cycle;
draw btex $A$ etex shifted 1/3(E+C+F);
draw B--C--F--cycle;
draw btex $B$ etex shifted 1/3(B+C+E);
draw E--F--A--cycle;
draw btex $B'$ etex shifted 1/3(E+F+A);
endfig;
data:image/s3,"s3://crabby-images/26955/269555b7bf21523484528fe48a3d6f43e3f3638e" alt=""
beginfig(205)
pair A,B,C,D,E,F;
numeric d[];
u := 3cm;
A := (0,0);
B := (u,0);
D := B rotated 72;
C := (u,0) + D;
draw A--B--C--cycle;
d[0] := 1;
d[1] := sqrt( 2*(1+cosd(72)) );
d[2] := sqrt( 2*(1-cosd(36)) );
E := (d1/(d0+d1)) [A,C];
F := (d0/(d0+d2)) [A,B];
draw E--F--B--cycle;
draw btex $A'$ etex shifted 1/3(E+F+B);
draw E--A--F--cycle;
draw btex $B$ etex shifted 1/3(E+A+F);
draw C--E--B--cycle;
draw btex $B'$ etex shifted 1/3(C+E+B);
endfig;
data:image/s3,"s3://crabby-images/bc1e9/bc1e9160473ba22b0027b34dc4be52f6f0cd807b" alt=""
beginfig(206)
pair A,B,C,D,E,F;
numeric d[];
u := 3cm;
A := (0,0);
B := (u,0);
D := B rotated 72;
C := (u,0) + D;
d[0] := 1;
d[1] := sqrt( 2*(1+cosd(72)) );
d[2] := sqrt( 2*(1-cosd(36)) );
A := A;
B := C;
C := D;
E := (d1/(d0+d1)) [A,C];
F := (d0/(d0+d2)) [A,B];
B := 3*(C-E);
C := 3*(F-E);
draw A--B--C--cycle;
D := (d0/(d0+d2)) [C,A];
draw B--C--D--cycle;
draw btex $A$ etex shifted 1/3(B+C+D);
draw B--D--A--cycle;
draw btex $B'$ etex shifted 1/3(B+D+A);
endfig;
data:image/s3,"s3://crabby-images/900ce/900ced3958cb5109ba94a6c3a75e00ccc8ef2d35" alt=""
beginfig(207)
pair A,B,C,D,E,F;
numeric d[];
u := 3cm;
A := (0,0);
B := (u,0);
D := B rotated 72;
C := (u,0) + D;
d[0] := 1;
d[1] := sqrt( 2*(1+cosd(72)) );
d[2] := sqrt( 2*(1-cosd(36)) );
% B'
E := (d1/(d0+d1)) [A,C];
F := (d0/(d0+d2)) [A,B];
% A'
A := 2*(E-E);
C := 2*(B-E);
B := 2*(F-E);
draw A--B--C--cycle;
D := (d0/(d0+d2)) [A,B];
draw C--D--B--cycle;
draw btex $A'$ etex shifted 1/3(C+D+B);
draw C--A--D--cycle;
draw btex $B$ etex shifted 1/3(C+A+D);
endfig;
data:image/s3,"s3://crabby-images/eb868/eb8680ef906f2b1c6439f19dc9d124f40edd961e" alt=""
beginfig(208)
vardef pave(expr t, A, B, C, n) =
save D, E, d;
pair D,E;
numeric d[];
d[0] := 1;
d[1] := sqrt( 2*(1+cosd(72)) );
d[2] := sqrt( 2*(1-cosd(36)) );
if n>0:
if t=1:
D := (d0/(d0+d2)) [A,C];
pave(1,B,C,D,n-1);
pave(4,B,D,A,n-1);
elseif t=2:
D := (d0/(d0+d2)) [A,B];
pave(2,C,D,B,n-1);
pave(3,C,A,D,n-1);
elseif t=3:
D := (d1/(d0+d1)) [A,B];
E := (d0/(d0+d2)) [A,C];
pave(1,D,C,E,n-1);
pave(3,B,C,D,n-1);
pave(4,D,E,A,n-1);
elseif t=4:
D := (d1/(d0+d1)) [A,C];
E := (d0/(d0+d2)) [A,B];
pave(2,D,E,B,n-1);
pave(3,D,A,E,n-1);
pave(4,C,D,B,n-1);
fi;
else:
draw A--B--C--cycle;
if t=1:
fill A--B--C--cycle withcolor green + blue;
draw A--C withpen pencircle scaled 1bp;
draw A--B withpen pencircle scaled 1bp;
elseif t=2:
fill A--B--C--cycle withcolor green + blue;
draw A--B withpen pencircle scaled 1bp;
draw A--B withpen pencircle scaled 1bp;
elseif t=3:
fill A--B--C--cycle withcolor green + red;
draw A--C withpen pencircle scaled 1bp;
draw C--B withpen pencircle scaled 1bp;
elseif t=4:
fill A--B--C--cycle withcolor green + red;
draw B--C withpen pencircle scaled 1bp;
draw A--B withpen pencircle scaled 1bp;
fi;
fi;
enddef;
numeric M;
M := 6;
pair A,B,C,D;
u := 3cm;
A := (0,0);
B := (u,0);
D := B rotated 72;
C := (u,0) + D;
pave(3,A,C,D,M);
pave(4,A,B,C,M);
endfig;
data:image/s3,"s3://crabby-images/07629/0762937809424c70f9b4fb8eae605e786d1feb8c" alt=""
beginfig(209)
u:=1cm;
def milieu (expr s, ss, n) =
if n<>0:
for i="A","BA","BBA":
milieu(s&i, ss, n-1);
endfor;
else:
dessine(s&ss);
fi;
enddef;
def doit(expr N) =
for n=1 upto N:
for i="A","BA","BBA":
for j="","B","BB":
milieu(i,j,n-1);
endfor;
endfor;
endfor;
milieu("","",0);
enddef;
vardef A(expr a) =
save x,y,n;
numeric x,y,n;
x := xpart a;
y := ypart a;
n:=x*x+y*y;
(-x/n, y/n)
enddef;
vardef B(expr a) =
save x,y,n;
numeric x,y,n;
x := 1 + xpart a;
y := ypart a;
n := x*x+y*y;
(-x/n, y/n)
enddef;
def dessine(expr s) =
_dessine(s, dir(60), up, dir(120));
_dessine(s, dir(60), dir(31), dir(2));
_dessine(s, dir(120), dir(149), dir(178));
enddef;
def _dessine(expr s, a,b,c) =
pair p[];
p[0] := a;
p[1] := b;
p[2] := c;
for i=0 upto length(s)-1:
if (substring(i,i+1) of s) = "A":
for j=0 upto 2: p[j] := A( p[j] ); endfor;
elseif (substring(i,i+1) of s) = "B":
for j=0 upto 2: p[j] := B( p[j] ); endfor;
else: show("Ceci n'est pas un générateur : "&substring(i,i+1) of s)
fi;
endfor;
if (xpart p[0] < 2) and (xpart p[0] > -2) and
(xpart p[2] > -2) and (xpart p[2] < 2) and
(ypart p[0] < 2) and (ypart p[2] < 2):
draw ( p[0] .. p[1] .. p[2] ) scaled u;
fi;
enddef;
fill (dir(60) .. up .. dir(120) --
(dir120+up) -- (dir60+up) -- cycle) scaled u
withcolor red+green;
doit(7);
draw (u*dir(60)) withpen pencircle scaled 4bp;
draw (0,u) withpen pencircle scaled 4bp;
draw (u*dir(60) -- u*dir(60)+u*up) shifted (0u,0);
draw (u*dir(60) -- u*dir(60)+u*up) shifted (1u,0);
draw (u*dir(60) -- u*dir(60)+u*up) shifted (-u,0);
draw (u*dir(60) -- u*dir(60)+u*up) shifted (-2u,0);
endfig;
data:image/s3,"s3://crabby-images/bb1b5/bb1b5093791bf96f31c589c859d5781b7670b88f" alt=""
beginfig(210)
u:=5mm;
pickup pencircle scaled 1pt;
for i=0 upto 500:
draw (u*normaldeviate, u*normaldeviate);
endfor;
endfig;
data:image/s3,"s3://crabby-images/f4a60/f4a60451c34c1184ff5063d827916c19adcb07d7" alt=""
beginfig(211)
u:=2cm;
pickup pencircle scaled 1pt;
for i=0 upto 500:
draw (u*uniformdeviate(1), u*uniformdeviate(1));
endfor;
endfig;
data:image/s3,"s3://crabby-images/47069/4706980174aa77e2d497dd6b8672808421c245a7" alt=""
beginfig(212)
numeric n;
n:=10;
path p;
p := for i=0 upto n-1:
((1cm + 3mm*normaldeviate,0) rotated (i*360/n)) ..
endfor cycle;
fill p withcolor .8white;
draw p;
endfig;
data:image/s3,"s3://crabby-images/6c852/6c8529e0d63cd4a4f441bb6c031b2d3af3cdf38e" alt=""
beginfig(213)
m:=500;
u:=1cm;
pair A,B;
A:=(0,0);
for i=0 upto m:
B:=(i/m*3u, (ypart A)+normaldeviate/m*30u);
draw A--B;
A:=B;
endfor;
draw (0,0)--(3u,0);
endfig;
data:image/s3,"s3://crabby-images/39006/3900694e89619ea909fbf10ac49bab1dbdce9c89" alt=""
beginfig(214)
m:=50;
pair A[], B[];
A[0]=(0,0);
for i=0 upto m:
A[i+1]=(i/m*3u, (ypart A[i])+(uniformdeviate(2)-1)/m*30u);
endfor;
B[0]=A[0];
B[1]=A[1];
B[2]=A[2];
B[3]=A[3];
for i=4 upto m+1:
B[i] = ( A[i-4] + A[i-3] + A[i-2] + A[i-1] + A[i])/5;
endfor;
for i=0 upto m:
draw B[i]--B[i+1] withpen pencircle scaled 2pt
withcolor .5*white;
endfor;
for i=0 upto m:
draw A[i]--A[i+1];
endfor;
draw (0,0)--(3u,0);
endfig;
def rescale_currentpic :=
if xpart (lrcorner currentpicture - llcorner currentpicture) > 4cm:
currentpicture := currentpicture scaled ( 4cm /
xpart (lrcorner currentpicture - llcorner currentpicture) );
fi;
enddef;
data:image/s3,"s3://crabby-images/9f70e/9f70ea440e6d27fce54d1c43018b31e1a1018516" alt=""
beginfig(215)
vardef check_pascal =
save again;
boolean again;
again := false;
% Distance entre deux points sur le cercle : au moins 1mm
for i=0 upto 5:
for j=i+1 upto 5:
show( decimal(i) &" "& decimal(j) &" "& decimal(abs(A[i]-A[j])/2mm) );
if abs(A[i]-A[j]) < 2mm:
again := true;
fi;
endfor;
endfor;
% Distance entre deux des M[i] : au moins 2mm, au plus 10cm
for i=0 upto 2:
for j=i+1 upto 2:
if (abs(M[i]-M[j]) > 10cm) or (abs(M[i]-M[j]) < 2mm):
again := true;
fi;
endfor;
endfor;
% Distance entre un A[i] et un M[i] : au moins 2mm
for i=0 upto 5:
for j=0 upto 2:
if abs(A[i]-M[j]) < 2mm:
again := true;
fi;
endfor;
endfor;
% Distance entre le cercle et l'un des M[i] : au plus 10cm
if abs(M[0])>10cm:
again:=true;
fi;
show again;
not again
enddef;
forever:
path C;
C := fullcircle scaled 6cm;
pair A[], M[];
for i=0 upto 5:
A[i] := point uniformdeviate(length(C)) of C;
endfor;
M[0] = whatever[ A[0], A[1] ];
M[0] = whatever[ A[3], A[4] ];
M[1] = whatever[ A[1], A[2] ];
M[1] = whatever[ A[4], A[5] ];
M[2] = whatever[ A[2], A[3] ];
M[2] = whatever[ A[5], A[0] ];
exitif check_pascal;
endfor;
draw C;
draw A[0]--A[1] withcolor red;
draw A[3]--A[4] withcolor red;
draw A[0]--M[0] withcolor red dashed evenly;
draw A[3]--M[0] withcolor red dashed evenly;
draw A[1]--A[2] withcolor green;
draw A[4]--A[5] withcolor green;
draw A[1]--M[1] withcolor green dashed evenly;
draw A[4]--M[1] withcolor green dashed evenly;
draw A[2]--A[3] withcolor blue;
draw A[5]--A[0] withcolor blue;
draw A[2]--M[2] withcolor blue dashed evenly;
draw A[5]--M[2] withcolor blue dashed evenly;
draw M[0]--M[1]--M[2]--cycle withpen pencircle scaled 2bp;
for i=0 upto 2:
draw M[i] withpen pencircle scaled 6bp;
endfor;
for i=0 upto 5:
draw A[i] withpen pencircle scaled 6bp;
endfor;
rescale_currentpic;
endfig;
data:image/s3,"s3://crabby-images/5e92f/5e92f33114da9070a80387935a3abbefdf340bb7" alt=""
beginfig(216)
vardef pascal(expr C) =
forever:
pair A[], M[];
for i=0 upto 5:
A[i] := point uniformdeviate(length(C)) of C;
endfor;
M[0] = whatever[ A[0], A[1] ];
M[0] = whatever[ A[3], A[4] ];
M[1] = whatever[ A[1], A[2] ];
M[1] = whatever[ A[4], A[5] ];
M[2] = whatever[ A[2], A[3] ];
M[2] = whatever[ A[5], A[0] ];
exitif check_pascal;
endfor;
draw C;
draw A[0]--A[1] withcolor red;
draw A[3]--A[4] withcolor red;
draw A[0]--M[0] withcolor red dashed evenly;
draw A[3]--M[0] withcolor red dashed evenly;
draw A[1]--A[2] withcolor green;
draw A[4]--A[5] withcolor green;
draw A[1]--M[1] withcolor green dashed evenly;
draw A[4]--M[1] withcolor green dashed evenly;
draw A[2]--A[3] withcolor blue;
draw A[5]--A[0] withcolor blue;
draw A[2]--M[2] withcolor blue dashed evenly;
draw A[5]--M[2] withcolor blue dashed evenly;
draw M[0]--M[1]--M[2]--cycle withpen pencircle scaled 2bp;
for i=0 upto 2:
draw M[i] withpen pencircle scaled 6bp;
endfor;
for i=0 upto 5:
draw A[i] withpen pencircle scaled 6bp;
endfor;
enddef;
pascal(fullcircle xscaled 6cm yscaled 3cm);
rescale_currentpic;
endfig;
data:image/s3,"s3://crabby-images/0ada9/0ada979b91da208de757397432e3878bdfc10a25" alt=""
beginfig(217)
pascal((for i=-2cm step .1cm until 2cm:
(i, (i/1cm)**2 *1cm) ..
endfor (2.1cm,4.41cm)) rotated 30);
rescale_currentpic;
endfig;
data:image/s3,"s3://crabby-images/8a11a/8a11a00a173e21e3dded0b7e951d13e63a6ab215" alt=""
beginfig(218)
vardef pascal(expr C) =
forever:
pair A[], M[];
numeric t[];
for i=0 upto 5:
t[i] = uniformdeviate(length(C));
endfor;
for i=0 upto 5:
for j=0 upto 4:
if t[j]>t[j+1]:
tt:=t[j]; t[j]:=t[j+1]; t[j+1]:=tt;
fi;
endfor;
endfor;
for i=0 upto 5:
A[i] = point t[i] of C;
endfor;
M[0] = whatever[ A[0], A[1] ];
M[0] = whatever[ A[3], A[4] ];
M[1] = whatever[ A[1], A[2] ];
M[1] = whatever[ A[4], A[5] ];
M[2] = whatever[ A[2], A[3] ];
M[2] = whatever[ A[5], A[0] ];
exitif check_pascal;
endfor;
draw C;
draw A[0]--A[1] withcolor red;
draw A[3]--A[4] withcolor red;
draw A[0]--M[0] withcolor red dashed evenly;
draw A[3]--M[0] withcolor red dashed evenly;
draw A[1]--A[2] withcolor green;
draw A[4]--A[5] withcolor green;
draw A[1]--M[1] withcolor green dashed evenly;
draw A[4]--M[1] withcolor green dashed evenly;
draw A[2]--A[3] withcolor blue;
draw A[5]--A[0] withcolor blue;
draw A[2]--M[2] withcolor blue dashed evenly;
draw A[5]--M[2] withcolor blue dashed evenly;
draw M[0]--M[1]--M[2]--cycle withpen pencircle scaled 2bp;
for i=0 upto 2:
draw M[i] withpen pencircle scaled 6bp;
endfor;
for i=0 upto 5:
draw A[i] withpen pencircle scaled 6bp;
endfor;
enddef;
pascal(fullcircle scaled 6cm);
rescale_currentpic;
endfig;
data:image/s3,"s3://crabby-images/54fc2/54fc2e7ae11e3214c819860f74a8c7fb7498a6bd" alt=""
beginfig(219)
pascal(fullcircle xscaled 6cm yscaled 3cm);
rescale_currentpic;
endfig;
data:image/s3,"s3://crabby-images/014fb/014fbe4bec7a99e9a3ba6dbcb297a86984310290" alt=""
beginfig(220)
pascal(fullcircle xscaled 6cm yscaled 3cm);
rescale_currentpic;
endfig;
data:image/s3,"s3://crabby-images/937e2/937e28b9e602c4740749a934d39083e5ba501cf9" alt=""
beginfig(221)
vardef barycentre(text t) =
save n, G;
pair G; numeric n;
G := origin; n:=0;
for a=t:
G:=G+a;
n:=n+1;
endfor;
G/n
enddef;
pair A[];
n:=10;
for i=0 upto n:
A[i] = 1cm*(normaldeviate, normaldeviate);
draw A[i] withpen pencircle scaled 4bp;
endfor;
draw barycentre(A[0] for i=1 upto 10: ,A[i] endfor)
withpen pencircle scaled 4bp withcolor red;
endfig;
data:image/s3,"s3://crabby-images/ce428/ce428d07f627776e0c9fdb1efba13036108fbc80" alt=""
beginfig(222)
vardef barycentre(text t) =
save a, i, n, G, X;
pair G,X; numeric n,i;
G := origin; n:=0; i:=0;
for a=t:
show("i = "& decimal(i));
show a;
if odd(i):
show("odd");
n:=n+a;
G:= G + a*X;
else:
show("even");
X:=a;
fi;
i:=i+1;
endfor;
G/n
enddef;
pair A[];
n:=10;
for i=0 upto n:
A[i] = 1cm*(normaldeviate, normaldeviate);
draw A[i] withpen pencircle scaled 4bp;
endfor;
draw barycentre(A[0],0 for i=1 upto 10: ,A[i],i endfor)
withpen pencircle scaled 4bp withcolor red;
endfig;
data:image/s3,"s3://crabby-images/7d87d/7d87d85da735cb6ef260f550048a652fdfea25c2" alt=""
beginfig(223)
numeric n;
n:=10;
path p;
p := for i=0 upto n-1:
((1cm + 3mm*normaldeviate,0) rotated (i*360/n)) ..
endfor cycle;
for i=0 step 2mm until 3cm:
draw fullcircle scaled i;
endfor;
clip currentpicture to p;
draw p;
endfig;
data:image/s3,"s3://crabby-images/f8217/f8217f07ef3576a993cf72f8501df09a8f62f585" alt=""
beginfig(224)
u := 5mm;
draw (-2u,0) -- (2u,0);
draw (0,-u) -- (0,4u);
draw (-2u,4u) for i=-1.9 step .1 until 2.01: .. (i*u, i*i*u) endfor
withpen pencircle scaled 1bp;
draw bbox currentpicture withpen pensquare scaled 2bp withcolor .8white;
draw bbox currentpicture withpen pensquare scaled 2bp withcolor .8white;
endfig;
data:image/s3,"s3://crabby-images/66318/663185f87e9029138b5af6969f97cd01c73a1ea9" alt=""
beginfig(225)
path p;
p := (0,0) -- (2cm,0);
def doit (suffix p)(expr t) =
begingroup
interim linecap := t;
draw p withpen pencircle scaled 5mm withcolor .8white;
endgroup;
draw point 0 of p withpen pencircle scaled 4bp;
draw point 1 of p withpen pencircle scaled 4bp;
p := p shifted (0,-7mm)
enddef;
doit(p,rounded);
doit(p,butt);
doit(p,squared);
endfig;
data:image/s3,"s3://crabby-images/3e52a/3e52a927577ade8259ab000faf169f7e39a92290" alt=""
beginfig(226)
path p;
p := (0,0) -- (1cm,5mm) -- (2cm,0);
def doit (suffix p)(expr t) =
begingroup
interim linejoin := t;
draw p withpen pencircle scaled 5mm withcolor .8white;
endgroup;
draw point 0 of p withpen pencircle scaled 4bp;
draw point 1 of p withpen pencircle scaled 4bp;
draw point 2 of p withpen pencircle scaled 4bp;
p := p shifted (0,-7mm)
enddef;
doit(p,rounded);
doit(p,mitered);
doit(p,beveled);
endfig;
data:image/s3,"s3://crabby-images/c0489/c0489e6740f7d1e9e7a474f68cf661f7cf509359" alt=""
beginfig(227)
path p;
p := (0,0) -- (2cm,0);
vardef doit (suffix p)(expr t) =
interim linecap := t;
draw p withpen pencircle scaled 5mm withcolor .8white;
draw point 0 of p withpen pencircle scaled 4bp;
draw point 1 of p withpen pencircle scaled 4bp;
draw point 2 of p withpen pencircle scaled 4bp;
p := p shifted (0,-7mm)
enddef;
doit(p,rounded);
doit(p,butt);
doit(p,squared);
endfig;
data:image/s3,"s3://crabby-images/966aa/966aa63eaf73f740eb040816b328dd96a8bcf567" alt=""
beginfig(228)
draw fullcircle scaled 2cm;
special("0 0 moveto 10 10 rlineto -10 10 rlineto stroke");
endfig;
data:image/s3,"s3://crabby-images/b4f3c/b4f3c49083fd36ce7ee048045cdc928a8d041989" alt=""
beginfig(229)
draw fullcircle shifted (.5,.5) xscaled 18.2cm yscaled 4cm;
special(
"/Times-Roman findfont 150 scalefont setfont " &
"0 0 moveto (ABCabc) false charpath clip stroke " &
"gsave 300 0 translate " &
" 2 4 600 {dup 0 moveto 0 exch 0 exch 0 360 arc stroke} for " &
"grestore "
);
endfig;
data:image/s3,"s3://crabby-images/37ca9/37ca9bb06be2055042c0509b3b5dafd1bc6e5f14" alt=""
beginfig(230)
draw fullcircle shifted (.5,.5) xscaled 18.2cm yscaled 4cm;
special(
"gsave " &
"/Times-Roman findfont 150 scalefont setfont " &
"0 0 moveto (ABCabc) false charpath clip stroke " &
"gsave 300 0 translate " &
" 2 4 600 {dup 0 moveto 0 exch 0 exch 0 360 arc stroke} for " &
"grestore " &
"grestore "
);
endfig;
data:image/s3,"s3://crabby-images/7a635/7a6355165cb2f944a73c04388abce3d7ea4955b4" alt=""
beginfig(231)
path p;
p =
(0,u)
for i=.1 step .1 until 10:
hide( pair A; A = (i*u, (sind (i*180/3.14))/i *u);
draw A withpen pencircle scaled 2pt )
.. A
endfor;
draw p;
endfig;
data:image/s3,"s3://crabby-images/6a5e5/6a5e524eee15b1600225bb2891265cbb39b52eb3" alt=""
beginfig(232)
vardef inversion (expr O,k,M) =
if pair M:
(O + k*unitvector(M-O)/abs(M-O))
elseif path M:
for i=0 step length(M)/10 until length(M):
hide(
draw O--inversion(O,k,point i of M)--(point i of M);
draw inversion(O,k,point i of M) withpen pencircle scaled 2pt;
draw point i of M withpen pencircle scaled 2pt withcolor red;
draw O withpen pencircle scaled 2pt;
)
inversion(O,k,point i of M) ..
endfor
cycle
fi
enddef;
path p[];
p1=fullcircle scaled 2u shifted (u,0);
p2=fullcircle scaled 2u shifted (-u,0);
draw p1 dashed withdots scaled .25;
draw p2 dashed withdots scaled .25;
z0 = (.5u,2u);
draw inversion( z0, 2 (u**2), p1 );
draw inversion( z0, 2 (u**2), p2 );
endfig;
data:image/s3,"s3://crabby-images/87783/87783f60547507a17070b2ada389b82f3be079fa" alt=""
beginfig(233)
path p;
p := (0,0) -- (1cm,0);
show ahangle;
begingroup
interim ahangle := 30;
interim linejoin := mitered;
interim linecap := butt;
drawarrow p withpen pencircle scaled 2bp;
endgroup;
begingroup
interim ahangle := 60;
drawarrow p shifted (0,-5mm) withpen pencircle scaled 2bp;
endgroup;
endfig;
data:image/s3,"s3://crabby-images/baed2/baed2d59d655d82b67643f727ab5e8f464fcc938" alt=""
beginfig(234)
numeric x;
x = sind(60);
draw TEX("$\sin 60 = " & decimal(x) & "$");
endfig;
data:image/s3,"s3://crabby-images/7fdce/7fdce91a1a9b03b8a15fdb00d685f071c865bafb" alt=""
beginfig(235)
picture _TEX_pic;
def largeur(expr p) =
if picture p:
xpart( lrcorner(p) - llcorner(p) )
elseif string p:
hide(_TEX_pic := TEX(p);)
xpart( lrcorner(_TEX_pic) - llcorner(_TEX_pic) )
else:
hide( errmessage("largeur: wrong type"); 0)
fi
enddef;
def hauteur(expr p) =
if picture p:
ypart(ulcorner(p))
elseif string p:
hide(_TEX_pic := TEX(p);)
ypart(ulcorner(_TEX_pic))
else:
hide( errmessage("hauteur: wrong type"); 0)
fi
enddef;
def profondeur (expr p) =
if picture p:
-ypart(llcorner(p))
elseif string p:
hide(_TEX_pic := TEX(p);)
-ypart(llcorner(_TEX_pic))
else:
hide( errmessage("profondeur: wrong type"); 0)
fi
enddef;
picture p;
string s;
s := "\huge\LaTeX";
p := TEX(s);
drawarrow (0,0) -- (largeur(s),0) withcolor red;
drawarrow (0,0) -- (0,hauteur(s)) withcolor green;
drawarrow (0,0) -- (0,-profondeur(s)) withcolor blue;
draw p;
draw bbox p;
endfig;
data:image/s3,"s3://crabby-images/1aa7d/1aa7db101f8076df39a0dbfb06ca832405593aad" alt=""
beginfig(236)
def reddraw text t = draw t withcolor red enddef;
draw (0,0) -- (2cm,0);
reddraw (0,0) -- (2cm,5mm) withpen pencircle scaled 2bp;
endfig;
data:image/s3,"s3://crabby-images/0874e/0874e59010014d24d8991cbd823e80a3d99870f8" alt=""
beginfig(237)
path _myfill_p;
def myfill expr p =
_myfill_p := p;
_myfill
enddef;
def _myfill text t =
fill _myfill_p t;
draw _myfill_p t withcolor red;
enddef;
myfill fullcircle scaled 1cm withcolor .8white withpen pencircle scaled 2bp;
endfig;
data:image/s3,"s3://crabby-images/31517/31517c2f7519a9788b8a85c6be2f983cfa77de20" alt=""
beginfig(238)
boxit.a(btex Essai etex);
a.c = (0,0);
drawboxed(a);
endfig;
data:image/s3,"s3://crabby-images/1eb6e/1eb6e134d930a763c7bd54b8d84d65ce7671528a" alt=""
beginfig(239)
circleit.a(btex Essai etex);
a.c = (0,0);
drawboxed(a);
endfig;
data:image/s3,"s3://crabby-images/36ffd/36ffdf60482479265fc02acbe224710e930c1cb3" alt=""
beginfig(240)
rboxit.a(btex Essai etex);
a.c = (0,0);
drawboxed(a);
endfig;
data:image/s3,"s3://crabby-images/29e31/29e310f34ddd18be71d5d3a276e188225bd47357" alt=""
beginfig(241)
boxit.a(btex Essai etex);
a.c = (0,0);
drawunboxed(a);
endfig;
data:image/s3,"s3://crabby-images/7fcf0/7fcf00ee0d85e13d223dd240ad2121bf0c84fbea" alt=""
beginfig(242)
circleit.a(btex Essai etex);
a.c = (0,0);
a.dx = a.dy;
drawboxed(a);
endfig;
data:image/s3,"s3://crabby-images/64e2f/64e2f8bc4c7d3e2ef9bfaf4c580e1a58249ecb9c" alt=""
beginfig(243)
circleit.a(btex Essai etex);
a.c = (0,0);
a.dx = a.dy;
drawunboxed(a);
for i=0 step 10 until 360:
draw (0,0) -- 1cm*right rotated i cutbefore bpath.a;
endfor;
endfig;
data:image/s3,"s3://crabby-images/8f0a4/8f0a40e91cbe4a6f0756c2c3349f67bd23d6f728" alt=""
beginfig(244)
circleit.a(btex Début etex);
a.c = (0,0);
a.dx = a.dy;
circleit.b(btex Fin etex);
b.c = (2cm,0);
b.dx = b.dy;
drawboxed(a,b);
drawarrow a.c {dir 45} .. b.c {dir -45}
cutbefore bpath.a cutafter bpath.b;
drawarrow b.c {dir -135} .. a.c {dir 135}
cutbefore bpath.b cutafter bpath.a;
endfig;
data:image/s3,"s3://crabby-images/19dc9/19dc95bb9302961365c9f7839de94579bd165d71" alt=""
beginfig(245)
circleit.a(btex Début etex);
a.c = (0,0);
a.dx = a.dy;
circleit.b(btex Fin etex);
b.c = (2cm,0);
b.dx = b.dy;
drawunboxed(a,b);
drawarrow a.c {dir 45} .. b.c {dir -45}
cutbefore bpath.a cutafter bpath.b;
drawarrow b.c {dir -135} .. a.c {dir 135}
cutbefore bpath.b cutafter bpath.a;
endfig;
data:image/s3,"s3://crabby-images/8b7ab/8b7ab1b3b2d95166f97460ec178b245048e426af" alt=""
beginfig(246)
boxjoin(
a.dx = a.dy;
b.dx = b.dy;
a.e + (5mm,0) = b.w;
);
circleit.a(btex Début etex);
a.c = (0,0);
circleit.b(btex Fin etex);
drawboxed(a,b);
drawarrow a.c {dir 45} .. b.c {dir -45}
cutbefore bpath.a cutafter bpath.b;
drawarrow b.c {dir -135} .. a.c {dir 135}
cutbefore bpath.b cutafter bpath.a;
endfig;
data:image/s3,"s3://crabby-images/df5d8/df5d8794c6bd4de544c3b314c95fc9a8c99b9060" alt=""
beginfig(247)
% Toujours mettre la commande boxjoin au début.
boxjoin(a.e = b.w);
boxit.a(btex A etex);
boxit.b(btex B etex);
boxit.c(btex C etex);
boxit.d(btex D etex);
drawboxed(a,b,c,d);
endfig;
data:image/s3,"s3://crabby-images/379bb/379bb03b43ec4e6991659d4e9d325c5b67ddfafd" alt=""
beginfig(248)
boxjoin(a.e = b.w);
boxit.a(btex a etex);
boxit.b(btex b etex);
boxit.c(btex c etex);
boxit.d(btex d etex);
drawboxed(a,b,c,d);
endfig;
data:image/s3,"s3://crabby-images/041d2/041d29b49e3479274b3e0727aea5b4df21d85174" alt=""
beginfig(249)
boxjoin(a.se = b.sw; a.ne = b.nw);
boxit.a(btex a etex);
boxit.b(btex b etex);
boxit.c(btex c etex);
boxit.d(btex d etex);
drawboxed(a,b,c,d);
endfig;
data:image/s3,"s3://crabby-images/23ec7/23ec7aa6090b7c9626bbc7606dd534c07c96b334" alt=""
beginfig(250)
boxjoin(a.se = b.sw; a.ne = b.nw);
boxit.a1(btex a etex);
boxit.a2(btex b etex);
boxit.a3(btex c etex);
boxit.a4(btex d etex);
drawboxed(a1,a2,a3,a4);
endfig;
data:image/s3,"s3://crabby-images/fae06/fae067d2137fe5d3752f1a3afb705adffde3bbed" alt=""
beginfig(251)
draw (0,0) -- (5cm,0) withcolor red;
draw btex a etex ;
draw btex b etex shifted (1cm,0);
draw btex c etex shifted (2cm,0);
draw btex d etex shifted (3cm,0);
draw btex e etex shifted (4cm,0);
endfig;
data:image/s3,"s3://crabby-images/ffcf8/ffcf83ca2bb1318b9dc75564ae6825f2c02061c7" alt=""
beginfig(252)
draw (0,0) -- (5cm,0) withcolor red;
boxjoin(b.c - a.c = (1cm,0));
boxit a (btex a etex);
boxit b (btex b etex);
boxit c (btex c etex);
boxit d (btex d etex);
boxit e (btex e etex);
drawunboxed(a,b,c,d,e);
endfig;
data:image/s3,"s3://crabby-images/ef244/ef2449752cc6353aa70f57caf0e2fdde9a30d986" alt=""
beginfig(253)
vardef boxTEX expr s =
save p,h,l;
picture p;
numeric h,l;
p := TEX(s);
h := max(ypart ulcorner(p), abs(ypart llcorner(p)));
l := xpart lrcorner(p);
setbounds p to (0,-h)--(l,-h)--(l,h)--(0,h)--cycle;
p
enddef;
draw (0,0) -- (5cm,0) withcolor red;
boxjoin(b.c - a.c = (1cm,0));
boxit a (boxTEX "a");
boxit b (boxTEX "b");
boxit c (boxTEX "c");
boxit d (boxTEX "d");
boxit e (boxTEX "e");
drawunboxed(a,b,c,d,e);
endfig;
data:image/s3,"s3://crabby-images/f5303/f530308d82baae324316bbb0d92ffe855c9fe185" alt=""
beginfig(254)
draw (0,0) -- (5cm,0) withcolor red;
boxjoin(b.c - a.c = (1cm,0));
boxit a (boxTEX "a");
boxit b (boxTEX "b");
boxit c (boxTEX "c");
boxit d (boxTEX "d");
boxit e (boxTEX "e");
drawboxed(a,b,c,d,e);
endfig;
data:image/s3,"s3://crabby-images/a0298/a0298aba84a373c23acc34e17c26d20d28a5cced" alt=""
beginfig(255)
let OLD_beginbox_ = beginbox_;
def beginbox_(expr pp,sp)(suffix $)(text t) =
_n_ := str $;
generic_declare(pair) _n.off, _n.c;
generic_declare(string) pproc_._n, sproc_._n;
generic_declare(picture) pic_._n;
pproc_$:=pp; sproc_$:=sp;
pic_$ = nullpicture;
for _p_=t:
pic_$:=
if picture _p_: _p_
else: _p_ infont defaultfont scaled defaultscale
fi;
endfor
$c = $off + (.5[xpart llcorner pic_$, xpart urcorner pic_$], 0)
enddef;
draw (0,0) -- (5cm,0) withcolor red;
boxjoin(b.c - a.c = (1cm,0));
boxit a (btex a etex);
boxit b (btex b etex);
boxit c (btex c etex);
boxit d (btex d etex);
boxit e (btex e etex);
drawunboxed(a,b,c,d,e);
endfig;
data:image/s3,"s3://crabby-images/10110/10110cee7df26fb0a45b86246316ba8778bb9b84" alt=""
beginfig(256)
draw (0,0) -- (5cm,0) withcolor red;
boxjoin(b.c - a.c = (1cm,0));
boxit a (btex a etex);
boxit b (btex b etex);
boxit c (btex c etex);
boxit d (btex d etex);
boxit e (btex e etex);
drawboxed(a,b,c,d,e);
endfig;
data:image/s3,"s3://crabby-images/c0ba6/c0ba68fd3d5b72e7026b54df5aca2a0859ff1681" alt=""
beginfig(257)
let OLD_boxit = boxit;
let OLD_sizebox_ = sizebox_;
let OLD_clearb_ = clearb_;
vardef boxit@#(text tt) =
beginbox_("boxpath_","sizebox_",@#,tt);
generic_declare(pair) _n.sw, _n.s, _n.se, _n.e, _n.ne, _n.n, _n.nw, _n.w;
0 = xpart (@#nw-@#sw) = ypart(@#se-@#sw);
0 = xpart(@#ne-@#se) = ypart(@#ne-@#nw);
@#s = .5[@#sw,@#se];
@#n = .5[@#ne,@#nw];
xpart @#w = xpart @#nw;
xpart @#e = xpart @#ne;
ypart @#w = ypart @#c = ypart @#e;
@#ne-@#c = (@#dx,@#dy) +
(xpart(.5*(urcorner pic_@# - llcorner pic_@#)), ypart urcorner pic_@#);
@#c-@#sw = (@#dx,@#dy) +
(xpart(.5*(urcorner pic_@# - llcorner pic_@#)), -ypart lrcorner pic_@#);
endbox_(clearb_,@#);
enddef;
draw (0,0) -- (5cm,0) withcolor red;
boxjoin(b.c - a.c = (1cm,0));
boxit a (btex a etex);
boxit b (btex b etex);
boxit c (btex c etex);
boxit d (btex d etex);
boxit e (btex e etex);
drawboxed(a,b,c,d,e);
endfig;
data:image/s3,"s3://crabby-images/fd145/fd14564c6a8800e2b77e592e91b5c7902035d853" alt=""
beginfig(258)
draw (0,0) -- (5cm,0) withcolor red;
boxjoin(b.c - a.c = (1cm,0); b.ne - b.se = a.nw - a.sw);
boxit a (btex a etex);
boxit b (btex b etex);
boxit c (btex c etex);
boxit d (btex d etex);
boxit e (btex e etex);
drawboxed(a,b,c,d,e);
endfig;
data:image/s3,"s3://crabby-images/e98d7/e98d79b33b1057e8c89bfdb2cc5f4c0cd5b14640" alt=""
beginfig(259)
vardef boxit@#(text tt) =
beginbox_("boxpath_","sizebox_",@#,tt);
generic_declare(pair) _n.sw, _n.s, _n.se, _n.e, _n.ne, _n.n, _n.nw, _n.w;
0 = xpart (@#nw-@#sw) = ypart(@#se-@#sw);
0 = xpart(@#ne-@#se) = ypart(@#ne-@#nw);
@#s = .5[@#sw,@#se];
@#n = .5[@#ne,@#nw];
xpart @#w = xpart @#nw;
xpart @#e = xpart @#ne;
ypart @#w = ypart @#c = ypart @#e;
@#ne-@#c = (@#dx,@#dyup) +
(xpart(.5*(urcorner pic_@# - llcorner pic_@#)), ypart urcorner pic_@#);
@#c-@#sw = (@#dx,@#dydown) +
(xpart(.5*(urcorner pic_@# - llcorner pic_@#)), -ypart lrcorner pic_@#);
endbox_(clearb_,@#);
enddef;
def sizebox_(suffix $) =
if unknown $.dx: $.dx=defaultdx; fi
if unknown $.dyup:
if unknown $.dy:
$.dyup=defaultdy
else:
$.dyup=$.dy
fi;
fi;
if unknown $.dydown:
if unknown $.dy:
$.dydown=defaultdy
else:
$.dydown=$.dy
fi;
fi;
enddef;
vardef clearb_(suffix $) =
_n_ := str $;
generic_redeclare(numeric) _n.sw, _n.s, _n.se, _n.e, _n.ne, _n.n, _n.nw, _n.w,
_n.c, _n.off, _n.dx, _n.dy, _n.dyup, _n.dy_down;
enddef;
draw (0,0) -- (5cm,0) withcolor red;
boxjoin(b.c - a.c = (1cm,0); ypart( b.ne - a.ne ) = 0; ypart( b.se - a.se ) = 0;);
boxit a (btex a etex);
boxit b (btex b etex);
boxit c (btex c etex);
boxit d (btex d etex);
boxit e (btex e etex);
drawboxed(a,b,c,d,e);
endfig;
data:image/s3,"s3://crabby-images/8e245/8e24520084a6224462487c8d5d965cc49cf60e5a" alt=""
beginfig(260)
draw (0,0) -- (5cm,0) withcolor red;
picture p;
numeric h;
p := btex b etex;
h = ypart ( ulcorner p - llcorner p );
boxjoin(
b.c - a.c = (1cm,0);
ypart( b.ne - a.ne ) = 0;
ypart( a.ne - a.se ) = h+2defaultdy;
);
boxit a (btex a etex);
boxit b (btex b etex);
boxit c (btex c etex);
boxit d (btex d etex);
boxit e (btex e etex);
drawboxed(a,b,c,d,e);
endfig;
data:image/s3,"s3://crabby-images/4a1d5/4a1d523d6e3bb7db1fe16ab7b7e1e8111f74be1d" alt=""
beginfig(261)
% Les lignes suivantes n'ont pas l'effet escompté...
let beginbox_ = OLD_beginbox_;
let boxit = OLD_boxit;
let sizebox_ = OLD_sizebox_;
let clearb_ = OLD_clearb_;
% On recopie donc les définitions initiales des macros que l'on a modifiées...
extra_beginfig := "";
extra_endfig := "";
input boxes;
% Et on regarde sur un exemple si ça marche...
draw (0,0) -- (5cm,0) withcolor red;
boxjoin(b.c - a.c = (1cm,0));
boxit a (btex a etex);
boxit b (btex b etex);
boxit c (btex c etex);
boxit d (btex d etex);
boxit e (btex e etex);
drawboxed(a,b,c,d,e);
endfig;
data:image/s3,"s3://crabby-images/bba8e/bba8eb572783e8611d4c8ececc5844690ecaa641" alt=""
beginfig(262)
boxit.a1(btex $a$ etex);
boxit.b1(btex etex);
boxit.a2(btex $b$ etex);
boxit.b2(btex etex);
boxit.a3(btex $c$ etex);
boxit.b3(btex etex);
boxit.a4(btex $d$ etex);
boxit.b4(btex etex);
for i=1 upto 4:
% Les boites a[i] et b[i] sont collées
a[i].e = b[i].w;
% Il y a un peu d'espace entre b[i] et a[i+1]
b[i].e + (5mm,0) = a[i+1].w;
% La hauteur des boites est la même
a[i].n - a[i].s = a[i+1].n - a[i+1].s = b[i].n - b[i].s ;
% Les b[i] ne sont pas très larges
b[i].e - b[i].w = (2mm,0);
endfor;
drawboxed(a1,b1,a2,b2,a3,b3,a4,b4);
for i=1 upto 3:
drawarrow b[i].c {up} .. a[i+1].c {down}
cutafter bpath.a[i+1];
endfor;
endfig;
data:image/s3,"s3://crabby-images/3430d/3430dd2ef5e8153a457371df986f5324b1c9930b" alt=""
beginfig(263)
boxit.a(btex A etex);
boxit.b(btex B etex);
boxit.c(btex C etex);
boxit.d(btex D etex);
boxit.e(btex E etex);
b.c-a.c = (1cm,0);
c.c-b.c = (b.c-a.c) rotated 72;
d.c-c.c = (c.c-b.c) rotated 72;
e.c-d.c = (d.c-c.c) rotated 72;
a.c-e.c = (e.c-d.c) rotated 72;
b.c-a.c = (a.c-e.c) rotated 72;
drawboxed(a,b,c,d,e);
drawarrow a.c -- b.c cutbefore bpath.a cutafter bpath.b;
drawarrow b.c -- c.c cutbefore bpath.b cutafter bpath.c;
drawarrow c.c -- d.c cutbefore bpath.c cutafter bpath.d;
drawarrow d.c -- e.c cutbefore bpath.d cutafter bpath.e;
drawarrow e.c -- a.c cutbefore bpath.e cutafter bpath.a;
endfig;
data:image/s3,"s3://crabby-images/804d3/804d3b2a379a2da01f2cf81feefef1e358663674" alt=""
beginfig(264)
boxit.a(btex A etex);
boxit.b(btex B etex);
boxit.c(btex C etex);
boxit.d(btex D etex);
boxit.e(btex E etex);
d.c = 1cm*up;
e.c = 1cm*up rotated (1*72);
a.c = 1cm*up rotated (2*72);
b.c = 1cm*up rotated (3*72);
c.c = 1cm*up rotated (4*72);
drawunboxed(a,b,c,d,e);
drawarrow a.c -- b.c cutbefore bpath.a cutafter bpath.b;
drawarrow b.c -- c.c cutbefore bpath.b cutafter bpath.c;
drawarrow c.c -- d.c cutbefore bpath.c cutafter bpath.d;
drawarrow d.c -- e.c cutbefore bpath.d cutafter bpath.e;
drawarrow e.c -- a.c cutbefore bpath.e cutafter bpath.a;
endfig;
data:image/s3,"s3://crabby-images/7bc21/7bc21b9b5b0c6d64b9e561f67b91b8dc83370772" alt=""
beginfig(265)
def linkboxes(suffix a,b) =
drawarrow a.c -- b.c cutbefore bpath.a cutafter bpath.b;
enddef;
boxit.a(btex A etex);
boxit.b(btex B etex);
boxit.c(btex C etex);
boxit.d(btex D etex);
boxit.e(btex E etex);
d.c = 1cm*up;
e.c = 1cm*up rotated (1*72);
a.c = 1cm*up rotated (2*72);
b.c = 1cm*up rotated (3*72);
c.c = 1cm*up rotated (4*72);
drawunboxed(a,b,c,d,e);
linkboxes(a,b);
linkboxes(b,c);
linkboxes(c,d);
linkboxes(d,e);
linkboxes(e,a);
endfig;
data:image/s3,"s3://crabby-images/ac7a0/ac7a0ef913377928e3e24e26d72269a491dc4b7a" alt=""
beginfig(266)
boxit a(btex Essai etex);
fill bpath a withcolor .5[red,white];
drawboxed(a);
endfig;
data:image/s3,"s3://crabby-images/14285/14285af4b8d8ea3096f7ffda84342a8aed85cbd7" alt=""
beginfig(267)
def drawredboxed(text t) =
forsuffixes a=t:
fill bpath a withcolor .5[red,white];
endfor;
drawboxed(t);
enddef;
circleit.a(btex Début etex);
a.c = (0,0);
a.dx = a.dy;
circleit.b(btex Fin etex);
b.c = (2cm,0);
b.dx = b.dy;
drawredboxed(a,b);
drawarrow a.c {dir 45} .. b.c {dir -45}
cutbefore bpath.a cutafter bpath.b;
drawarrow b.c {dir -135} .. a.c {dir 135}
cutbefore bpath.b cutafter bpath.a;
endfig;
data:image/s3,"s3://crabby-images/80529/80529dbcf9d824344882bd7c91fe6645b02e47d5" alt=""
beginfig(268)
def drawcoloredboxed(expr c)(text t) =
forsuffixes a=t:
fill bpath a withcolor c;
endfor;
drawboxed(t);
enddef;
circleit.a(btex Début etex);
a.c = (0,0);
a.dx = a.dy;
circleit.b(btex Fin etex);
b.c = (2cm,0);
b.dx = b.dy;
drawcoloredboxed(.5[red,white], a);
drawcoloredboxed(.5[blue,white], b);
drawarrow a.c {dir 45} .. b.c {dir -45}
cutbefore bpath.a cutafter bpath.b;
drawarrow b.c {dir -135} .. a.c {dir 135}
cutbefore bpath.b cutafter bpath.a;
endfig;
data:image/s3,"s3://crabby-images/b02eb/b02ebd6c79a0c1b93642f0110aad3d5c2b31ce71" alt=""
beginfig(269)
def begindiag =
begingroup;
save _diag_x, _diag_x_max, _diag_y, _diag_y_max, _diag;
numeric _diag_x, _diag_x_max, _diag_y, _diag_y_max;
string _diag[][];
% Numéro de ligne et de colonne courrants
_diag_x = -1; _diag_y = 0;
% Numéro de ligne et de colonne maximaux
_diag_x_max = _diag_y_max = 0;
save _diag_ar_n, _diag_ar_source, _diag_ar_but, _diag_ar_up, _diag_ar_down;
% Nombre de flèches
numeric _diag_ar_n; _diag_ar_n=-1;
% Source et but de la flèche
pair _diag_ar_source[], _diag_ar_but[];
% Ce qu'il faut écrire au dessus ou au dessous
string _diag_ar_up[], _diag_ar_down[];
save _diag_ar_curved, _diag_ar_shape, _diag_ar_color, _diag_ar_width;
% « courbure » (c'est une distance)
numeric _diag_ar_curved[];
% Forme de la flèche
string _diag_ar_shape[];
% Couleur, épaisseur, pointillés
color _diag_ar_color[];
numeric _diag_ar_width[];
picture _diag_ar_dashed[];
enddef;
def node expr A =
_diag_x := _diag_x + 1;
_diag_x_max := max(_diag_x,_diag_x_max);
_diag[_diag_x][_diag_y] := A;
enddef;
def nextline =
_diag_x := -1;
_diag_y := _diag_y + 1;
_diag_y_max := max(_diag_y, _diag_y_max);
enddef;
tertiarydef a => b = a, b enddef;
def even (expr a) = not odd(a) enddef;
vardef rarrowto(expr a,b)(text t) =
save i,p;
_diag_ar_n := _diag_ar_n + 1;
_diag_ar_source[_diag_ar_n] = (_diag_x, _diag_y);
_diag_ar_but[_diag_ar_n] = (_diag_x + a, _diag_y + b);
numeric i; i:=0;
string current;
for p=t:
if even(i):
current := p;
else:
if current = "above":
_diag_ar_up[_diag_ar_n] = p;
elseif current = "below":
_diag_ar_down[_diag_ar_n] = p;
elseif current = "shape":
_diag_ar_shape[_diag_ar_n] = p;
elseif current = "curved":
_diag_ar_curved[_diag_ar_n] = p;
elseif current = "color":
_diag_ar_color[_diag_ar_n] = p;
elseif current = "width":
_diag_ar_width[_diag_ar_n] = p;
elseif current = "dashed":
_diag_ar_dashed[_diag_ar_n] = p;
else:
errmessage("rarrowto: Wrong argument "&ditto¤t&ditto);
fi;
fi;
i := i + 1;
endfor;
if odd i:
errmessage("rarrowto: Odd number of arguments "&decimal(i));
fi;
enddef;
%% Les têtes de flèches
picture withsmalldots, notdashed;
withsmalldots := withdots scaled .3;
notdashed := dashpattern(on 50cm);
vardef diag_arrow_head (expr p, t) =
save A,B,C,u; pair A,B,C,u;
B := point t of p;
u := -unitvector(direction t of p);
A := B + ahlength*u rotated(-ahangle);
C := B + ahlength*u rotated(+ahangle);
A .. {-u} B {u} .. C
enddef;
vardef diag_arrow_bar (expr p, t) =
save A,B,C,u; pair A,B,C,u;
B := point t of p;
u := unitvector(direction t of p);
A := B + ahlength*sind(ahangle)*u rotated(90);
C := B + ahlength*sind(ahangle)*u rotated(-90);
A .. B .. C
enddef;
%% Les flèches
def diag_draw_arrow_default(suffix a,b)(expr curved, w, col, dash) =
p = a.c ..
(1/2 [a.c,b.c] + curved*unitvector(b.c-a.c) rotated 90)
.. b.c;
pp := p cutbefore bpath.a cutafter bpath.b;
draw pp
withcolor col withpen pencircle scaled w dashed dash;
draw diag_arrow_head (pp, length(pp))
withcolor col withpen pencircle scaled w;
enddef;
def diag_draw_arrow_middle(suffix a,b)(expr curved, w, col, dash) =
p = a.c ..
(1/2 [a.c,b.c] + curved*unitvector(b.c-a.c) rotated 90)
.. b.c;
pp := p cutbefore bpath.a cutafter bpath.b;
draw pp
withcolor col withpen pencircle scaled w dashed dash;
draw diag_arrow_head(p,1)
withcolor col withpen pencircle scaled w;
enddef;
def diag_draw_arrow_epi(suffix a,b)(expr curved, w, col, dash) =
p = a.c ..
(1/2 [a.c,b.c] + curved*unitvector(b.c-a.c) rotated 90)
.. b.c;
pp := p cutbefore bpath.a cutafter bpath.b;
draw pp
withcolor col withpen pencircle scaled w dashed dash;
draw diag_arrow_head (pp, length(pp))
withcolor col withpen pencircle scaled w;
path ppp;
ppp := pp cutafter (fullcircle scaled 1mm shifted point length(pp) of pp);
draw diag_arrow_head(ppp, length(ppp))
withcolor col withpen pencircle scaled w;
enddef;
def diag_draw_arrow_mono(suffix a,b)(expr curved, w, col, dash) =
p = a.c ..
(1/2 [a.c,b.c] + curved*unitvector(b.c-a.c) rotated 90)
.. b.c;
pp := p cutbefore bpath.a cutafter bpath.b;
path ppp;
ppp := pp cutbefore (fullcircle scaled 1mm shifted point 0 of pp);
draw ppp
withcolor col withpen pencircle scaled w dashed dash;
draw diag_arrow_head (pp, length(pp))
withcolor col withpen pencircle scaled w;
draw diag_arrow_head(ppp, 0)
withcolor col withpen pencircle scaled w;
enddef;
vardef diag_draw_arrow_inj(suffix a,b)(expr curved, w, col, dash) =
p = a.c ..
(1/2 [a.c,b.c] + curved*unitvector(b.c-a.c) rotated 90)
.. b.c;
pp := p cutbefore bpath.a cutafter bpath.b;
path ppp;
ppp := pp cutbefore (fullcircle scaled 1mm shifted point 0 of pp);
draw ppp
withcolor col withpen pencircle scaled w dashed dash;
draw diag_arrow_head (pp, length(pp))
withcolor col withpen pencircle scaled w;
save u,A,B,C;
pair u,A,B,C;
A := point 0 of ppp;
u := unitvector(direction 0 of ppp);
B := A + ahlength*(-u) rotated (-ahangle);
C := A + 2 ahlength*sind(ahangle)*u rotated 90;
draw C {-u} .. B .. A {u}
withcolor col withpen pencircle scaled w dashed dash;
enddef;
def diag_draw_arrow_mapsto(suffix a,b)(expr curved, w, col, dash) =
p = a.c ..
(1/2 [a.c,b.c] + curved*unitvector(b.c-a.c) rotated 90)
.. b.c;
pp := p cutbefore bpath.a cutafter bpath.b;
draw pp
withcolor col withpen pencircle scaled w dashed dash;
draw diag_arrow_head (pp, length(pp))
withcolor col withpen pencircle scaled w;
draw diag_arrow_bar (pp, 0)
withcolor col withpen pencircle scaled w;
enddef;
def diag_draw_arrow_half_dotted(suffix a,b)(expr curved, w, col, dash) =
p = a.c ..
(1/2 [a.c,b.c] + curved*unitvector(b.c-a.c) rotated 90)
.. b.c;
pp := p cutbefore bpath.a cutafter bpath.b;
draw subpath(0,1) of pp
withcolor col withpen pencircle scaled w dashed withsmalldots;
draw subpath(1,2) of pp
withcolor col withpen pencircle scaled w;
draw diag_arrow_head (pp, length(pp))
withcolor col withpen pencircle scaled w;
enddef;
%% Fin des flèches
def color_to_string (expr a) =
"("&
decimal(redpart a)
&","&
decimal(greenpart a)
&","&
decimal(bluepart a)
&")"
enddef;
def enddiag =
save i,j,k,l,mm,a,A,p,b;
for i=0 upto _diag_x_max:
for j=0 upto _diag_y_max:
if known _diag[i][j]:
circleit.a[i][j]( _diag[i][j] );
a[i][j].dx = a[i][j].dy;
a[i][j].c = 1cm * (i,-j);
drawunboxed( a[i][j] );
fi;
endfor;
endfor;
for m=0 upto _diag_ar_n:
% Vérifier que le but existe
i := xpart _diag_ar_source[m];
j := ypart _diag_ar_source[m];
k := xpart _diag_ar_but[m];
l := ypart _diag_ar_but[m];
% On trace la flèche. Le chemin est mis dans la variable p.
path p,pp;
if unknown _diag_ar_shape[m]: _diag_ar_shape[m] := "default" fi;
if unknown _diag_ar_color[m]: _diag_ar_color[m] := black fi;
if unknown _diag_ar_width[m]: _diag_ar_width[m] := .5bp fi;
if unknown _diag_ar_curved[m]: _diag_ar_curved[m] := 0 fi;
if unknown _diag_ar_dashed[m]: _diag_ar_dashed[m] := notdashed fi;
% On ne peut PAS utiliser m dans une chaîne ce caractères que l'on donne
% à scantokens, car m est une variable de boucle. C'est vraiment spécial,
% une variable de boucle.
mm := m;
scantokens(
"diag_draw_arrow_"& _diag_ar_shape[m]
&"("
&"a[i][j], a[k][l],_diag_ar_curved[mm],_diag_ar_width[mm],"
&"_diag_ar_color[mm],_diag_ar_dashed[mm]"
&");"
);
% On écrit des choses au dessus ou au dessous des flèches
pair A;
A = point 1/2 length(p) of p;
if known _diag_ar_up[m]:
boxit.b[m](_diag_ar_up[m]);
b[m].c = A + 4bp*unitvector(direction 1/2 length(p) of p rotated 90);
drawunboxed(b[m]);
fi;
if known _diag_ar_down[m]:
boxit.c[m](_diag_ar_down[m]);
c[m].c = A + 4bp*unitvector(direction 1/2 length(p) of p rotated -90);
drawunboxed(c[m]);
fi;
endfor;
endgroup;
enddef;
begindiag;
node "A";
rarrowto(1,0, "above" => "a",
"shape" => "middle",
"curved" => 3mm,
"dashed" => withsmalldots);
rarrowto(0,1, "below" => "b",
"color" => blue,
"shape" => "mapsto",
"dashed" => evenly);
node "A";
rarrowto(1,0, "above" => "c", "width" => 1bp, "shape" => "inj");
rarrowto(0,1, "below" => "d", "shape" => "mono");
node "A";
nextline;
node "A";
rarrowto(1,0, "below" => "e", "shape" => "epi");
node "A";
rarrowto(1,-1, "below" => "f", "curved" => -3mm, "shape" => "half_dotted");
enddiag;
endfig;
data:image/s3,"s3://crabby-images/87adc/87adc205ff21243454cc32a13835aae866570522" alt=""
beginfig(270)
draw begingraph(3cm,2cm)
gdraw "data1";
endgraph;
endfig;
data:image/s3,"s3://crabby-images/81042/81042bc811e2946948f49621f6ae259404d27336" alt=""
beginfig(271)
draw begingraph(3cm,2cm)
gdraw "data1" withpen pencircle scaled 2bp;
endgraph;
endfig;
data:image/s3,"s3://crabby-images/f885a/f885a8ab9c9a83928c8fd01702dcc693365f6b5f" alt=""
beginfig(272)
draw begingraph(3cm,2cm)
gdraw "data1" dashed evenly;
endgraph;
endfig;
data:image/s3,"s3://crabby-images/5a272/5a2721742e70be34dbb51df1166af213181bc7cf" alt=""
beginfig(273)
draw begingraph(3cm,2cm)
gdraw "data1" withcolor red;
endgraph;
endfig;
data:image/s3,"s3://crabby-images/13643/1364397b20d7c33a9c4bad9ca70000fa3eb64972" alt=""
beginfig(274)
draw begingraph(3cm,2cm)
gdraw "data1" withpen pencircle scaled 2bp;
gdraw "data2" ;
endgraph;
endfig;
data:image/s3,"s3://crabby-images/407ba/407bae655e8c8c7d13ca412a41b579461447c1c0" alt=""
beginfig(275)
draw begingraph(3cm,2cm)
gdraw "data1" ;
gdraw "data2" dashed evenly;
gdraw "data3" dashed withdots;
endgraph;
endfig;
data:image/s3,"s3://crabby-images/ca6d7/ca6d7d86b5d2d72d173c0decee8952de51766205" alt=""
beginfig(276)
draw begingraph(3cm,2cm)
gdraw "data1" withcolor red;
gdraw "data2" withcolor blue;
endgraph;
endfig;
data:image/s3,"s3://crabby-images/eb52d/eb52d3a61438783add4d7da67b89faf0a2083ce7" alt=""
beginfig(277)
draw begingraph(3cm,2cm)
gdraw "data1" plot btex $\bullet$ etex;
endgraph;
endfig;
data:image/s3,"s3://crabby-images/a3d5b/a3d5bea16657609831ccd48ab4e2709c23391efd" alt=""
beginfig(278)
picture gros_point;
draw (0,0) withpen pencircle scaled 4bp;
gros_point := currentpicture;
currentpicture := nullpicture;
draw begingraph(3cm,2cm)
gdraw "data1" plot gros_point;
endgraph;
endfig;
data:image/s3,"s3://crabby-images/d4250/d42504baecc58dac80360be3796068c00a56d5dc" alt=""
beginfig(279)
picture gros_point;
gros_point := nullpicture;
addto gros_point doublepath (0,0)
withpen pencircle scaled 4bp;
draw begingraph(3cm,2cm)
gdraw "data1" plot gros_point;
endgraph;
endfig;
data:image/s3,"s3://crabby-images/3f420/3f4208f196e1fdd504524bb5d0aec4222bd1f167" alt=""
beginfig(280)
picture croix;
croix := nullpicture;
addto croix doublepath (-2bp,2bp)--(2bp,-2bp)
withpen pencircle scaled 1bp;
addto croix doublepath (-2bp,-2bp)--(2bp,2bp)
withpen pencircle scaled 1bp;
picture gros_carre;
gros_carre := nullpicture;
addto gros_carre contour unitsquare shifted (-.5,-.5) scaled 2bp;
draw begingraph(3cm,2cm)
gdraw "data1";
gdraw "data1" plot croix;
gdraw "data2";
gdraw "data2" plot gros_carre;
endgraph;
endfig;
data:image/s3,"s3://crabby-images/9752d/9752dde6e154f044cb05d807c96e0490d8a7f44f" alt=""
beginfig(281)
draw begingraph(3cm,2cm)
gdata("data1",
v,
glabel(gros_point, v1, v2);
);
endgraph;
endfig;
data:image/s3,"s3://crabby-images/dba42/dba4286ce19e1db0d98da1d74073f52bc23ee94d" alt=""
beginfig(282)
draw begingraph(3cm,2cm)
path p;
gdata("data1",
v,
augment.p(v1,v2);
);
gdraw p;
endgraph;
endfig;
data:image/s3,"s3://crabby-images/346f0/346f0ac3a05604d6768928d642f54b996d63d440" alt=""
beginfig(283)
interim linecap := squared;
interim linejoin := mitered;
draw begingraph(3cm,2cm)
path p;
gdata("data1",
v,
augment.p(v1,v2);
);
gdraw p withpen pencircle scaled 2bp;
gdraw p withpen pencircle scaled 1bp withcolor .8white;
endgraph;
endfig;
data:image/s3,"s3://crabby-images/0e7a9/0e7a9dd26f56848e4f2b0f84b5b36ee44c606507" alt=""
beginfig(284)
draw begingraph(3cm,2cm)
gdata("data1",
v,
path p;
augment p (v1,0);
augment p (v1,v2);
gdraw p;
);
endgraph;
endfig;
data:image/s3,"s3://crabby-images/afd1e/afd1e06e968ff208af1e0e8ed8d28a1d0190c600" alt=""
beginfig(285)
draw begingraph(3cm,2cm)
gdata("data1",
v,
path p;
augment p (v1,0);
augment p (v1,v2);
gdraw p withpen pencircle scaled 4bp;
);
endgraph;
endfig;
data:image/s3,"s3://crabby-images/a9b71/a9b71f143c73e9008d66b849051c53b2d8a45a3d" alt=""
beginfig(286)
interim linecap:=2;
draw begingraph(3cm,2cm)
gdata("data1",
v,
path p;
augment p (v1,0);
augment p (v1,v2);
gdraw p withpen pencircle scaled 4bp;
);
endgraph;
endfig;
data:image/s3,"s3://crabby-images/d9652/d965287cc881e00ba698579e9a7a464987a95bba" alt=""
beginfig(287)
draw begingraph(3cm,2cm)
gdata("data1", v,
path p;
augment p (v1,0);
augment p (v1,v2);
augment p (v1 Sadd "1",v2);
augment p (v1 Sadd "1",0);
gdraw p--cycle;
);
endgraph;
endfig;
data:image/s3,"s3://crabby-images/695a9/695a9fe71316e29aeab434bdd9e5274677a1df9f" alt=""
beginfig(288)
draw begingraph(3cm,2cm)
gdata("data1", v,
path p;
augment p (v1,0);
augment p (v1,v2);
augment p (v1 Sadd "1",v2);
augment p (v1 Sadd "1",0);
gfill p--cycle withcolor .8white;
gdraw p--cycle;
);
endgraph;
endfig;
data:image/s3,"s3://crabby-images/1ea5a/1ea5a45d4bd19ba62d8f9bc6af44b8adb07fa1d2" alt=""
beginfig(289)
draw begingraph(3cm,2cm)
gdata("data1", v,
% Le dessus
path p;
augment p (v1,v2);
augment p (v1 Sadd "1",v2);
augment p (v1 Sadd "1.5", v2 Sadd "10");
augment p (v1 Sadd ".5", v2 Sadd "10");
gfill p--cycle withcolor white;
gdraw p--cycle;
% Le côté
path p;
augment p (v1 Sadd "1",0);
augment p (v1 Sadd "1",v2);
augment p (v1 Sadd "1.5", v2 Sadd "10");
augment p (v1 Sadd "1.5", "10");
gfill p--cycle withcolor .5white;
gdraw p--cycle;
% Le devant
path p;
augment p (v1,0);
augment p (v1,v2);
augment p (v1 Sadd "1",v2);
augment p (v1 Sadd "1",0);
gfill p--cycle withcolor .8white;
gdraw p--cycle;
);
endgraph;
endfig;
data:image/s3,"s3://crabby-images/494b7/494b789c36e511fea5c214ca2e0213885ff05143" alt=""
beginfig(290)
draw begingraph(3cm,2cm)
path p,q;
gdata("data1", v,
augment.p(v1,v2);
);
q:= (xpart point 0 of p, 0) -- p --
(xpart point length(p) of p, 0) -- cycle;
gfill q withcolor .8white;
gdraw p withpen pencircle scaled 2bp;
endgraph;
endfig;
data:image/s3,"s3://crabby-images/4ff2e/4ff2e48846901bf6855e58edb513a86c1e008986" alt=""
beginfig(291)
draw begingraph(3cm,2cm)
gdata("data1",
v,
path p;
augment p ("0", i);
augment p (v2, i);
augment p (v2, i Sadd ".5");
augment p (0, i Sadd ".5");
gfill p--cycle withcolor .8white;
gdraw p--cycle;
);
autogrid(otick.bot,);
endgraph;
endfig;
data:image/s3,"s3://crabby-images/e5305/e530504f43e48e1c4830a1dd7d1563fef0a2a00c" alt=""
beginfig(292)
draw begingraph(3cm,2cm)
gdraw "data1";
glabel.bot(btex Abscisse etex, OUT);
glabel.lft(btex Ordonnée etex, OUT);
endgraph;
endfig;
data:image/s3,"s3://crabby-images/d564a/d564af1b0a5f087ce356fdd849e5b5087b08199c" alt=""
beginfig(293)
draw begingraph(3cm,2cm)
gdraw "data1" withcolor red;
glabel.lft(btex 1 etex, 8);
gdraw "data2" withcolor blue;
glabel.bot(btex 2 etex, 9);
endgraph;
endfig;
data:image/s3,"s3://crabby-images/349ce/349ce0289f12678836b56687a810c2b60219f278" alt=""
beginfig(294)
draw begingraph(3cm,2cm)
gdraw "data1";
glabel.bot(btex Abscisse etex, OUT);
glabel.lft(btex Ordonnée etex rotated 90, OUT);
endgraph;
endfig;
data:image/s3,"s3://crabby-images/af5b3/af5b323b936f3bcb5f3d0c81e5f412b847985d99" alt=""
beginfig(295)
% La légende
color couleur[];
couleur[0] := red;
couleur[1] := green;
couleur[2] := blue;
picture p[], legende;
legende := nullpicture;
for i=0 upto 2:
p[i] := nullpicture;
addto p[i] also TEX("Courbe " & decimal(i+1))
withcolor couleur[i];
addto legende doublepath ( (0,0)--(5mm,0) )
shifted (0, -5mm*i)
withpen currentpen withcolor couleur[i];
addto legende also p[i]
shifted 1/2(lrcorner p[i] - ulcorner p[i])
shifted (0, -5mm*i);
endfor;
% Les courbes
draw begingraph(3cm,2cm)
for i=1 upto 3:
gdraw "data" & decimal(i) withcolor couleur[i-1];
endfor;
glabel.top(legende,OUT);
endgraph;
endfig;
data:image/s3,"s3://crabby-images/94964/949648806ee43446f3add82754488140855f2fbf" alt=""
beginfig(296)
draw begingraph(3cm,2cm)
setcoords(-linear,log);
gdraw "data1";
endgraph;
endfig;
data:image/s3,"s3://crabby-images/ff39e/ff39e07fc0857645b76ced78e2ae3c0ce32b74e9" alt=""
beginfig(297)
draw begingraph(3cm,2cm)
gdraw "data1";
endgraph;
endfig;
data:image/s3,"s3://crabby-images/d4d09/d4d094c44497c0eabd866592f20cad635079e0ed" alt=""
beginfig(298)
draw begingraph(3cm,2cm)
setrange( (whatever,0), (whatever,whatever) );
gdraw "data1";
endgraph;
endfig;
data:image/s3,"s3://crabby-images/288f2/288f2d64a05db456bdaa22d9113dd85474869276" alt=""
beginfig(299)
draw begingraph(3cm,2cm)
setrange(whatever, 0, whatever, whatever);
gdraw "data1";
endgraph;
endfig;
data:image/s3,"s3://crabby-images/a7bd6/a7bd633b4ce2c316a4dacf01178916de18c92820" alt=""
beginfig(300)
vardef TEX primary s =
write "verbatimtex" to "mptextmp.mp";
write "\documentclass[12pt]{article}" to "mptextmp.mp";
write "\usepackage[T1]{fontenc}" to "mptextmp.mp";
write "\usepackage{amsmath,amssymb}" to "mptextmp.mp";
write "\begin{document}" to "mptextmp.mp";
write "etex" to "mptextmp.mp";
write "btex "&s&" etex" to "mptextmp.mp";
write EOF to "mptextmp.mp";
scantokens "input mptextmp"
enddef;
vardef mylabel(expr pic, p, t) =
save A; pair A;
A = point t of p +
8bp * unitvector(direction t of p) rotated 90;
label(pic, A);
enddef;
path p; u:=1cm;
p = (0,0)..(-u,u)..(u,u);
draw p;
for i=0 step .2 until length(p):
draw point i of p withpen pencircle scaled 4bp;
mylabel(TEX("$"&decimal(round(5*i))&"$"),p,i);
endfor;
endfig;
data:image/s3,"s3://crabby-images/f5bae/f5bae5251db1b0132a92186f61585ecb9a212f89" alt=""
beginfig(301)
path p;
p := subpath(1,3) of fullcircle scaled 2cm;
interim linejoin := mitered;
interim linecap := butt;
interim ahangle := 30;
drawarrow p withpen pencircle scaled 2bp;
interim ahangle := 45;
drawarrow p shifted (0,-5mm) withpen pencircle scaled 2bp;
interim ahangle := 60;
drawarrow p shifted (0,-10mm) withpen pencircle scaled 2bp;
endfig;
data:image/s3,"s3://crabby-images/ddfba/ddfba57fe51a3e2da37e5478796b8f6937bd4ee5" alt=""
beginfig(302)
path p;
p := subpath(1,3) of fullcircle scaled 2cm;
interim linejoin := mitered;
interim linecap := butt;
interim ahangle := 30;
interim ahlength := 2bp;
drawarrow p withpen pencircle scaled 2bp;
interim ahlength := 4bp;
drawarrow p shifted (0,-5mm) withpen pencircle scaled 2bp;
interim ahlength := 6bp;
drawarrow p shifted (0,-10mm) withpen pencircle scaled 2bp;
endfig;
data:image/s3,"s3://crabby-images/6b669/6b6697fca4d8e74acb09edd4bbed86def30ea56c" alt=""
beginfig(303)
draw TEX( "Nous sommes le "&
decimal(day) &"/"&
decimal(month) &"/"&
decimal(year) &"." );
endfig;
data:image/s3,"s3://crabby-images/e1fc9/e1fc91648524ae7728382cb20007c489f7581465" alt=""
beginfig(304)
path p;
p := (0,0) -- (2cm,0);
def doit (suffix p)(expr t) =
begingroup
interim linecap := t;
draw p withpen pencircle scaled 5mm withcolor .8white;
endgroup;
draw point 0 of p withpen pencircle scaled 4bp;
draw point 1 of p withpen pencircle scaled 4bp;
p := p shifted (0,-7mm)
enddef;
doit(p,rounded);
doit(p,butt);
doit(p,squared);
endfig;
data:image/s3,"s3://crabby-images/ef7a0/ef7a01736a8e03c819024ff0671ee107d2ee85e7" alt=""
beginfig(305)
path p;
p := (0,0) -- (1cm,5mm) -- (2cm,0);
def doit (suffix p)(expr t) =
begingroup
interim linejoin := t;
draw p withpen pencircle scaled 5mm withcolor .8white;
endgroup;
draw point 0 of p withpen pencircle scaled 4bp;
draw point 1 of p withpen pencircle scaled 4bp;
draw point 2 of p withpen pencircle scaled 4bp;
p := p shifted (0,-7mm)
enddef;
doit(p,rounded);
doit(p,mitered);
doit(p,beveled);
endfig;
bye;