PS
# GeometryDPV.m4
# Some constructions from
https://tex.stackexchange.com/
gen_init
maxpswid = 10
Fig1: [
# FourbarDPV.m4
#
https://tex.stackexchange.com/questions/563831/how-to-draw-four-bar-linkage-with-center-of-mass
ls = 1/25.4 # local scale
a = 18*ls
b = 73*ls
c = 47*ls
d = 72*ls
A0: Here
B0: A0+(d,0)
circlerad = 1*ls
define(`pivot',`[
C: circle
line down_ 4*ls from C+(2*ls,0)
arc from last line.start to C+(-2*ls,0) with .c at C
line down_ 4*ls
B: line thick 1.6 right 7*ls with .c at (C,Here)
thinlines_
sep = 0.9*ls
nhash = B.len/sep
for i=0 to nhash do { line down sep left sep from B.end-(i/nhash*B.len,0) }
thicklines_
]')
pivot with .C at A0; "A`'svg_sub(0)" at A0-(5,0)*ls
circle dashed rad a at A0
pivot with .C at B0; "B`'svg_sub(0)" at B0-(5,0)*ls
"d = A`'svg_sub(0)B`'svg_sub(0)" at 0.5<A0,B0>
B1: Cintersect(A0,a+b,B0,c)
B2: Cintersect(A0,b-a,B0,c)
arc dashed from B1 to B2 with .c at B0
A0B1: line thick 1.6 from A0 to B1 chop 2*ls chop 0
line thick 1.6 from B0 to B1 chop 2*ls chop 0 "c" ljust
circle fill_(1) at B1; "B`'svg_sub(1)" wid 3*ls at B1+(5,0)*ls
A1: circle fill_(1) at LCintersect(A0B1,A0,a,R)
"A`'svg_sub(1)" at A1+(5,0)*ls
A2: b/(b-a) between B2 and A0; "a" at 0.4<A2,A0> above rjust
"b" at 0.4<A1,B1> above rjust
A2B2: line thick 1.6 from A2 to B2
line thick 1.6 from B0 to B2 chop 2*ls chop 0
circle fill_(1) at B2; "B`'svg_sub(2)" at B2+(5,0)*ls
circle fill_(1) at A2; "A`'svg_sub(2)" at A2+(5,0)*ls
thinlines_
line from B0+(3*ls,0) right 4*ls
ArcAngle(Here,B0,B1,5*ls) ->; "svg_psi`'svg_sub(0)" at last arc.ne above ljust
ArcAngle(B1,B0,B2,8*ls) ->; "svg_psi" at last arc.n+(-3*ls,0) above
ArcAngle(A1,A0,B2,b*0.45) ->; "svg_theta" at last arc.start+(0,4*ls)
line from A0+(3*ls,0) right 8*ls
ArcAngle(Here,A0,B1,9*ls) ->; "svg_theta`'svg_sub(0)" \
at last arc.start+(2,2)*ls
]
Fig2: [
# FourbarDPV.m4
#
https://tex.stackexchange.com/questions/609452/help-drawing-a-more-sophisticated-right-triangle-with-tikz-or-something-else
textkht = 12/72
unit = 0.6
C: Here; { "C" at C rjust below }
B: C+(4*unit,0); { "B" at B ljust below }
A: C+(0,3*unit); { "A" at A rjust above }
H: PerpTo(C,A,B); { "H" at H ljust above }
line from C to H then to B then to C shaded rgbstring(0.5,0.8,0.9)
# line from C to H then to B then to C shaded "CornflowerBlue"
line from C to H then to A then to C shaded rgbstring(0.8,0.9,0.7)
# line from C to H then to A then to C shaded "SpringGreen"
ArcAngle(C,A,B,unit*0.4)
ArcAngle(C,A,B,unit*0.5)
ArcAngle(A,B,C,unit*0.5,,"svg_theta" rjust)
ArcAngle(B,C,H,unit*0.5); {"svg_theta" at C+(unit*0.3,unit*0.17) }
ArcAngle(B,C,A,unit*0.6)
RightAngle(B,C,A,unit*0.17)
RightAngle(C,H,A,unit*0.17)
] with .nw at Fig1.sw+(0.2,0)
Fig3: [ ls = 3/4 # local scale
#
https://tex.stackexchange.com/questions/593272/drawing-complex-geometry
P: dot(at Here); "P" at P.s below
N: dot(at P+(3.5*ls,1.5*ls)); "N" at N.se ljust below
O: dot(at (N,P)); "O" at O.s below
R: dot(at 1/3 between O and P);"R" at R.s below
M: dot(at (R,N)); "M" at M.se ljust below
Q: dot(at (M.x,M.y+distance(M,N)/distance(N,O)*distance(P,O)));"Q" at Q.e ljust
line from P to Q then to N then to O
B: line to P chop -0.3
line from M to N
Pu: line from R to Q chop 0 chop -0.3
H: line from P to N chop 0 chop -0.3
X: dot(at Intersect_(Pu,H)); "X" at X.se ljust below
thinlines_
RightAngle(Q,M,N)
RightAngle(Q,N,H.end)
RightAngle(N,O,B.start)
ArcAngle(N,P,Q,0.4); "svg_beta" at last arc.ne above ljust
ArcAngle(O,P,N,0.5); "svg_alpha" at last arc.start+(5bp__,8bp__)
ArcAngle(R,Q,N,0.5); "svg_alpha" at last arc.start+(8bp__,-5bp__)
] with .sw at Fig2.e+(-0.2,-0.7)
Fig4: [ ls = 2/3 # local scale
A: Here; "A" at A above
B: A+(-1*ls,-3.5*ls); "B" at B below rjust
C: B+(4.6*ls,0); "C" at C below ljust
AB: line from A to B
BC: line from B to C
CA: line from C to A
perpto(A,BC,L); "L" at L below
AL: line from A to L; RightAngle(A,L,C)
angleLAC = atan2(C.x-L.x,A.y-L.y)
S: move from A to (sin(angleLAC/2),-cos(angleLAC/2))
AW: line from A to Intersect_(S,BC)
W: Here; "W" at W below rjust
perpto(C,AB,N); "N" at N above rjust
CN: line from C to N; RightAngle(C,N,B)
perpto(B,CA,M); "M" at M above
CM: line from B to M; RightAngle(B,M,C)
H: Intersect_(CN,AL); "H" at H +(4bp__,10bp__)
thinlines_
Equidist3(B,L,N,CC1,c1rad); C1: circle rad c1rad at CC1
Equidist3(B,W,N,CC2,c2rad); C2: circle rad c2rad at CC2
Equidist3(B,C,N,CC3,c3rad); C3: circle rad c3rad at CC3
Equidist3(W,C,M,CC4,c4rad); C4: circle rad c4rad at CC4
thicklines_
Z: LCintersect(AW,CC2,C2.rad); "Z" at Z+(-5bp__,-5bp__)
HZ: move from H to Z
Y: LCintersect(HZ,CC4,C4.rad,R); "Y" at Y above
X: LCintersect(HZ,CC2,C2.rad); "X" at X above rjust
foreach_(`P',`dot(at P)',X,Y,Z)
line dashed from X to Y chop -linewid/2
RightAngle(A,Z,Y)
] with .sw at (Fig3.e,Fig2.s)
PE