Wyznaczanie ortocentrum trójkąta

Wyznaczanie ortocentrum trójkąta#

W tym pliku przestudiujemy problem wyznaczenia algebraicznie ortocentrum trójkąta. Wykorzystamy to następnie w zadaniu.

x,y,a,b=var('x,y,a,b')
punkt1=vector((0,0))
punkt2=vector((x,y))
punkt3=vector((a,b))
m1,m2,m3=var('m1,m2,m3')
#wysokosc na odcinek 1-2
wysokosc1=vector((-y,x))
#wysokosc na odcinek 1-3
wysokosc2=vector((-b,a))
#wysokosc na odcinek 2-3
wysokosc3=vector((-(b-y),a-x))

#boki
bok1=vector((a,b))
bok2=vector((x,y))
bok3=vector((a-x,b-y))
bok1-bok2-bok3
(0, 0)
c1=punkt1+m1*wysokosc3
c3=punkt3+m3*wysokosc1
c2=punkt2+m2*wysokosc2

print c1-c2
print c1-c3
print c2-c3
(-(b - y)*m1 + b*m2 - x, (a - x)*m1 - a*m2 - y)
(-(b - y)*m1 + m3*y - a, (a - x)*m1 - m3*x - b)
(-b*m2 + m3*y - a + x, a*m2 - m3*x - b + y)
v1=c1-c2;
v2=c1-c3;
v3=c2-c3;
#znalezienie ortocentrum
solve([v1[0]==0,v1[1]==0,v2[0]==0,v2[1]==0,v3[0]==0,v3[1]==0],(m1,m2,m3))
[[m1 == -(a*x + b*y)/(b*x - a*y), m2 == -(a*x - x^2 + b*y - y^2)/(b*x - a*y), m3 == -(a^2 + b^2 - a*x - b*y)/(b*x - a*y)]]
pretty_print(c1.subs(m1== -(a*x + b*y)/(b*x - a*y)).simplify())

Zadanie: Znaleźć równanie punktu ortocentrum, gdy wierzchołki trójkąta zadane są następująco: \((0,0)\), \((\cos(t),\sin(t))\) oraz \((0,1)\)

t=var('t')
c1.subs(m1== -(a*x + b*y)/(b*x - a*y)).subs(a=cos(t),b=sin(t),x=0,y=1)
(-(sin(t) - 1)*sin(t)/cos(t), sin(t))
graph2=parametric_plot((-(sin(t) - 1)*sin(t)/cos(t), sin(t)),(t,-(1/2*pi-0.2),3/2*pi-0.2));
graph2
_images/2d46216bd42e90693663eb357d8128f1184464acbeed2944bc4397597d33479b.png
#dynamiczne wyświetlanie
@interact
def Trojkat1(b = slider([a/10-0.1 for a in [0..13]],default = 0.2, label="krotność")):
    t=pi*b
    p1=(0,0)
    p2=(0,1)
    p3=(cos(t),sin(t))
    p4=(-(sin(t) - 1)*sin(t)/cos(t), sin(t))
    gra=Graphics()
    gra=gra+point(p1)+point(p2)+point(p3)+point(p4,size=30,rgbcolor=(1,0,0))
    gra=gra+line([p1,p3,p2,p1])
    show(graph2+gra,figsize=[3,3],xmin=-2,xmax=2,ymin=-2,ymax=2)
#Jak znaleźć równanie uwikłane zadanej krzywej?
x1=-(sin(t) - 1)*sin(t)/cos(t)
y1=sin(t)
((1/(x1/(y1-1)/y1))^2+y1^2-1).simplify_full()
0
x,y=var('x,y')
((1/(x/(y-1)/y))^2+y^2-1).factor()
(x^2*y + y^3 + x^2 - y^2)*(y - 1)/x^2
#Równanie (x^2*y + y^3 + x^2 - y^2)=0 zadaje postać uwikłaną
implicit_plot((x^2*y + y^3 + x^2 - y^2)==0,(x,-2,2),(y,-2,2))
_images/ae428d828b48822377d007c7b36a9d82d5d73d9f7681838ac51126def789fb18.png

Ta krzywa jest elementem rodziny konchoid opisanej przez René de Sluze w 1662.

\((X - 1) (X^2 + Y^2) = aX^2\) (nasza krzywa odpowiada dla a=2)

Sprawdź http://mathworld.wolfram.com/ConchoidofdeSluze.html

Zadanie: wyznacz parametryzację wymierną tej krzywej