Định nghĩa: Đa giác đơn là đa giác không có hai cạnh nào cắt nhau. Đa
giác không đơn (còn gọi là đa giác tự cắt) là đa giác tồn tại một cặp cạnh
cắt nhau.
Chú ý: Cạnh của đa giác là đoạn thẳng có hai đầu mút là hai đỉnh liên tiếp của đa
giác, chứ không phải đường thẳng chứa cạnh đó. Vì vậy, khái niệm hai cạnh cắt
nhau phải hiểu là hai đoạn thẳng cắt nhau.
85 trang |
Chia sẻ: lylyngoc | Lượt xem: 3730 | Lượt tải: 3
Bạn đang xem trước 20 trang tài liệu Luận văn Sử dụng Maple giải một số bài toán hình học, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
|
được gọi là phương tích của điểm M đối với đường tròn O.
28
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
ii) Cho hai đường tròn, tập hợp các điểm có cùng phương tích đối với hai đường tròn là một đường thẳng.
Hai đường tròn đồng tâm thì không có trục đẳng phương
iii) Ba đường tròn có tâm không thẳng hàng thì ba trục đẳng phương đồng quy, gọi là tâm đẳng phương.
2.1. ĐIỂM
Một điểm A trong mặt phẳng được khai báo bởi cú pháp point(A,x,y) hoặc point(A,*x,y+), trong đó A là
tên điểm, x, y, tương ứng là hoành độ, tung độ của điểm A.
Trung điểm M của đoạn thẳng AB, có cú pháp midpoint(M,A,B).
Muốn xem tọa độ của M ta dùng lệnh:
Tọa độ điểm M: [> coordinates(M).
Hoành độ điểm M: [> HorizontalCoord(M);
Tung độ điểm M: [> VerticalCoord(M);
2.2. ĐƯỜNG THẲNG
-) Khai báo đường thẳng đi qua 2 điểm [> line(l,[A,B]); ở đây l là tên đường thẳng, A và B là 2 điểm đã
cho.
-) Phương trình đường thẳng l đi qua điểm P cho trước và vuông góc với đường thẳng có tên d cho trước:
[> PerpendicularLine(l,P,d);
-) Phương trình đường thẳng l đi qua điểm P cho trước và song song với đường thẳng có tên d cho trước:
[> ParallelLine(l,P,d);
-) Ký hiệu biến hoành độ và biến tung độ: _EnvHorizontalName := x: _EnvVerticalName := y:
-) Để nhập đường thẳng l có phương trình ax+by+c=0, dùng lệnh [> line(l, ax+by+c=0);
-) Đường thẳng có tên là l, muốn biết phương trình của nó, dùng lệnh [> equation(l);
-) Khoảng cách từ một điểm M đến một đường thẳng có tên là l: [> distance(M,l);
-) Hình chiếu của điểm P lên đường thẳng l: [> projection(H,P,l); với H là tên của hình chiếu.
-) Điểm đối xứng của điểm P qua đường thẳng l: [> reflection(Q,P,l);
-) Tìm giao điểm A của 2 đường thẳng l, d: [>intersection(A,l,d);
-) Tính độ lớn của góc giữa hai đường thẳng d1 và d2: [> FindAngle(d1,d2);
29
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
2.3. ĐOẠN THẲNG
-) Cho trước 2 điểm A và B: point(A,0,0),point(B,1,1):
-) Đoạn thẳng với 2 đầu mút: [> segment(AB,[A,B]); với AB là tên của đoạn thẳng, A và B là 2 đầu mút.
-) Để tính độ dài của đoạn AB, ta dùng lệnh [> distance(A,B);
-) Trung trực của đoạn thẳng: [> PerpenBisector(l,A,B); l là tên đoạn thẳng, A và B là 2 điểm cho trước.
2.4. TAM GIÁC VÀ CÁC ĐƯỜNG ĐẶC BIỆT
2.4.1. KHAI BÁO TAM GIÁC
-) Khai báo một tam giác có tên là T với A, B, C cho trước: Ta dùng lệnh [> triangle(T,[A,B,C]);
-) Tam giác có tên là T, tạo bởi 3 đường thẳng d1, d2, d3. Ta dùng lệnh [> triangle(T,[d1,d2,d3]);
-) Tam giác T, biết độ dài 3 cạnh là a, b, c. Ta dùng lệnh [> triangle(T, [a,b,c]);
-) Tam giác T, khi biết 2 cạnh a,b và góc C xen giữa. Ta dùng lệnh [> triangle(T,[a,`angle`= C, b]);
-) Tọa độ các đỉ nh của tam giác ABC: [> map(coordinates,DefinedAs(ABC));
-) Tính diện tích tam giác: [> area(T); T là tên của tam giác
Thí dụ
Cho 3 điểm A(0;0), B(5;5), C(0;10); cho 3 cạnh a=3, b=7,c=9 và 3 góc A1=π/6; C1=π/3. Hãy khai báo các
tam giác sau:
1) Có 3 đỉ nh là ABC;
2) Nhận 3 cạnh là a,b,c;
3) Có cạnh a, cạnh b và góc C1;
Giải
> point(A, [0, 0]); point(B, [5, 5]); point(C, [0, 10]); a := 3; b := 7; c := 9; line(AB, x+21*y-22 = 0, [x, y]);
line(BC, 5*x-12*y+7 = 0, [x, y]); line(CA, 4*x-33*y+146 = 0, [x, y]);
> triangle(T1, [A, B, C]), triangle(T2, [a, b, c]), triangle(T3, [AB, BC, CA]), triangle(T4, [a, 'angle' = (1/2)*Pi,
b]);
2.4.2. CÁC ĐƯỜNG ĐẶC BIỆT TRONG TAM GIÁC
30
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
-) Đường cao, có 2 cách khai báo:
Cách thứ nhất [> altitude(hA, A,T);
Cách thứ hai [> altitude(hA, A,T,H); với hA là tên đường cao, A là đỉ nh của tam giác T mà đường cao đi
qua, còn H là chân đường cao. Muốn xem chi tiết về hA ta dùng lệnh [> detail(hA); trong lệnh deail, nếu
khai báo theo cách thứ nhất sẽ cho ta biết phương trình đường cao; nếu khai báo theo cách thứ 2 sẽ cho
ta tọa độ chân đường cao.
-) Đường trung tuyến: *> median(AM, A, ABC); AM là tên đường trung tuyến, A là đỉ nh của tam giác ABC
mà đường trung tuyến đi qua. Muốn xem chi tiết về AM ta dùng lệnh [> detail(AM).
-) Đường trung trực của một cạnh: [> PerpenBisector(l,A,B);
-) Đường phân giác trong: *> bisector(AD,A,ABC); AD là tên đường phân giác, A là đỉ nh của tam giác ABC
mà đường phân giác đi qua. Muốn xem chi tiết về AD ta dùng lệnh [> detail(AD).
-) Đường phân giác ngoài: *> ExternalBisector(AE,A,ABC); AE là tên đường phân giác, A là đỉ nh của tam
giác ABC mà đường phân giác đi qua. Muốn xem chi tiết về AE ta dùng lệnh [> detail(AE).
Thí dụ
Cho tam giác ABC, với A(1,1), B(1,-2), C(3,3). Hãy viết phương trình đường cao, trung tuyến, trung trực,
phân giác trong và phân giác ngoài của tam giác ABC xuất phát từ đỉ nh A; viết phương trình đường trung
trực của cạnh AB.
Giải:
> point(A, [1, 1]), point(B, [1, -2]), point(C, [3, 3]), triangle(ABC, [A, B, C]);
> altitude(hA, A, ABC);
> median(AM, A, ABC); detail(AM);
> bisector(AD, A, ABC); detail(AD);
> ExternalBisector(AE, A, ABC); detail(AE);
> PerpenBisector(l, A, B); detail(l);
2.4.3. CÁC ĐIỂM ĐẶC BIỆT TRONG TAM GIÁC
-) Trọng tâm của tam giác: [> centroid(G,T); G là trên trọng tâm, T tên là tam giác.
-) Trực tâm của tam giác: [> orthocenter(H,T);
-) Tâm đường tròn nội tiếp.
-) Tâm đường tròn ngoại tiếp.
31
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
-) Tâm đường tròn bàng tiếp.
2.5. ĐƯỜNG TRÒN
-) Đường tròn đi qua 3 điểm A,B,C; dùng lệnh [> circle(c1, [A, B, C], n, 'centername'=m); ở đây c1 là tên
đường tròn, m là ký hiệu tâm của đường tròn.
-) Đường tròn đi qua 3 điểm A,B,C; dùng lệnh [> circle(c1, [A, B, C], [x,y]); ở đây c1 là tên đường tròn.
-) Đường tròn có tâm là điểm A, với bán kính r:
[> circle(C, [A, r]); hay là: [> circle(C, [A, r], [x, y]);
-) Đường tròn C có phương trình cho trước:
[> circle(C,
" x^(2)+y^(2)-2*a*x-2*b*y+c=0,[x,y]);"
-) Tìm ký hiệu tâm của đường tròn C: [> center(c);
-) Tìm tọa độ tâm của đường tròn C: [> coordinates(center(c));
-) Tính bán kính của đường tròn C: [> radius(c);
-) Phương tích của điểm M đối với đường tròn C: [> powerpc(M,C);
-) Trục đẳng phương của hai đường tròn.
-) Tâm đẳng phương của 3 đường tròn.
-) Tìm giao điểm của 2 đường (một đường tròn một đường thẳng hoặc hai đường tròn) C1 và C2: [>
intersection(H,C1, C2, [M,N]); ở đây M và N là 2 giao điểm, H là tập hợp các thông tin về hai giao điểm
mà ta có thể tìm bởi lệnh [> detail(H);
2.6. TIẾP TUYẾN CỦA ĐƯỜNG TRÒN
-) Tiếp tuyến tại một điểm M thuộc đường tròn c: [>tangentpc(t,M,c); ở đây t là tên của tiếp tuyến. M là
tiếp điểm đã biết.
-) Tiếp tuyến với đường tròn c và đi qua điểm M cho trước: [>TangentLine(T,M,c,[t1,t2]); ở đây T là tập
hợp các thông tin về tiếp tuyến, có thể tra cứu bởi lệnh [> detail(T); t1, t2 là tên của mỗi tiếp tuyến.
-) Đường tròn c có tâm O nội tiếp tam giác T: [> incircle(c,T,'centername'=O);
32
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
-) Ba đường tròn bàng tiếp tam giác: [> excircle(H,T, [c1(o1),c2(o2),c3(o3)]); H là tập hợp các thông tin về
3 vòng tròn bàng tiếp, T là tam giác đã cho, *c1(o1),c2(o2),c3(o3)+ là 3 đường tròn bàng tiếp với tâm là
O1, O2, O3.
Chú ý: có thể chỉ dùng lệnh thứ 2 mà không cần đến lệnh thứ nhất.
2.7. MỘT SỐ ĐIỂM, ĐƯỜNG THẲNG, ĐƯỜNG TRÒN.
1) Điểm Gecgon: [>GergonnePoint(G, ABC); ở đây G là tên của điểm, ABC là tên tam giác. Điểm Gecgon là
điểm đồng quy của 3 đường thẳng AA1, BB1, CC1. A1, B1, C1 là các tiếp điểm của đường tròn nội tiếp với
3 cạnh.
2) Điểm Nagel : [> NagelPoint(N, T); ở đây N là tên của điểm, ABC là tên tam giác. Điểm Nagel là điểm
đồng quy của 3 đường thẳng AA1, BB1, CC1. A1, B1, C1 là các tiếp điểm của đường tròn bàng tiếp với 3
cạnh.
3) Đường thẳng Simpson: *> SimpsonLine(sl,N,T); sl là tên đường thẳng Simson, N là điểm hạ từ đường
tròn ngoại tiếp tam giác T.
>
2.8. NHÓM LỆNH KIỂM TRA
Nhóm lệnh kiểm tra bắt đầu bằng Are hoặc Is dùng để kiểm tra tính đúng hoặc sai của một tính chất nào
đó.
Số thứ tự
Cú pháp
Chức năng
1
[> ArePrallrel (l1,l2,cond);
Kiểm tra tính song song của hai đường thẳng l1, l2.
2
[> Areconcurrent(l1,l2,l3,cond);
Kiểm tra tính đồng quy của 3 đường thẳng l1, l2, l3.
3
[> ArePerpendicular(l1,l2,cond);
Kiểm tra tính vuông góc của hai đường thẳng l1, l2.
33
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
4
[> AreTangent(f,g);
Kiểm tra tính tiếp xúc giữa hai đường f và g (một đường thẳng với một đường tròn hoặc hai đường tròn.
5
[> IsOnCircle(A,c,cond);
Kiểm tra xem điểm F có nằm trên đường tròn c hay không?
6
[> IsOnline(A,l,cond);
Kiểm tra xem điểm F có nằm trên đường thẳng l hay không?
7
[> IsRightTriangle(ABC,cond);
Kiểm tra tính vuông của tam giác có tên là ABC
8
[> AreConcyclic(P1,P2,P3,P4);
Kiểm tra 4 điểm P1, P2, P3, P4 thuộc 1 đường tròn
9
[> AreSimilar(T1, T2, cond);
Kiểm tra tính đồng dạng của hai tam giác
10
[> AreCollinear(A,B,C);
Kiể m tra tính thẳng hàng của ba điểm A,B,C
Chú ý:
-) Có thể bỏ điều kiện cond hoặc sử dụng trong trường hợp có chứa tham số.
-) Khi kết thúc các lệnh này và enter, kết quả sẽ là true hoặc false.
-) Lệnh 4 và lệnh 8 có thể thay thế cho nhau.
34
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
-) Trong một số trường hợp phải dùng lệnh [> assume(logic);
HÌNH HỌC KHÔNG GIAN
TÓM TẮT LÝ THUYẾT
1) Khoảng cách giữa hai điểm:
"d="
"sqrt((x[2]-x[1])^(2)+(y[2]-y[1])^(2)+(z[2]-z[1])^(2))"
Điểm M(x,y,z) chia đoạn
35
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
M[1]
M[2]
theo tỷ số λ, có tọa độ biểu diễn theo công thức:
x[1] + λx[2]
x = -------------------;
1 + lambda
y[1] + λy[2]
y = -------------------;
1 + lambda
z[1] + λz[2]
z = -------------------;
1 + lambda
Trường hợp riêng λ=1, ta được tọa độ trung điểm:
"x= (x[1]+x[2] )/(2), y=(y[1]+y[2] )/(2),z=(z[1]+z[2] )/(2)."
2) Đường thẳng:
i) Phương trình đường thẳng đi qua hai điểm
M[1](x[1], y[1], z[1])
và
M[2](x[2], y[2], z[2])
36
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
:
x - x[1] y - y[1] y - y[1] z - z[1]
----------- = ----------- and ----------- = -----------
x[2] - x[1] y[2] - y[1] y[2] - y[1] z[2] - z[1]
trong cách viết trên, có quy ước nếu mẫu số nào bằng không, thì tử số của phân số đó phải bằng không.
Vector chỉ phương:
#mover(mi("v"),mo("→")) = (x[2] - x[1], y[2] - y[1],
z[2] - z[1])
ii) Phương trình dạng tham số
x = x[0] + at; y = y[0] + bt; z = z[0] + ct;
Đường thẳng đi qua điểm
"M[0](x[0],y[0],z[0]), "
có vector chỉ phương
"(v)=(a,b,c). "
Có thể khử tham số t và được phương trình
x - x[0] y - y[0] y - y[0] z - z[0]
-------- = -------- and -------- = --------
a b b c
iii) Phương trình tổng quát của đường thẳng:
piecewise(P[1], A[1] x + B[1] y + C[1] z + D[1] = 0, P[2],
A[2] x + B[2] y + C[2] z + D[2] = 0)
4) Hệ hai mặt phẳng
37
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
-) Điều kiện song song của
P[1]
và
P[2]
là:
A[1] B[1] B[1] C[1] C[1] D[1]
---- = ---- and ---- = ---- and ---- ----
A[2] B[2] B[2] C[2] C[2] D[2]
-) Điều kiện trùng nhau của
P[1]
và
P[2]
là:
A[1] B[1] B[1] C[1] C[1] D[1]
---- = ---- and ---- = ---- and ---- = ----
A[2] B[2] B[2] C[2] C[2] D[2]
-) Điều kiện cắt nhau của
P[1]
và
P[2]
là:
A[1] B[1]
38
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
---- ----
A[2] B[2]
hoặc
B[1] C[1]
---- ----
B[2] C[2]
hoặc
C[1] A[1]
---- ----
C[2] A[2]
hay là
A[1] B[2] A[2] B[1]
hoặc
B[1] C[2] B[2] C[1]
hoặc
A[2] B[1] A[1] B[2]
5) Chùm mặt phẳng:
Cho 2 mặt phẳng cắt nhau
A[1] x + B[1] y + C[1] = 0
và
A[2] x + B[2] y + C[2] = 0
, khi đó, tập hợp tất cả các mặt phẳng có dạng
alpha(A[1] x + B[1] y + C[1] z + D[1]) + beta
39
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
A[2] x + B[2] y + C[2] z + D[2] = 0
Với α và β là những hằng số tùy ý, không đồng thời bằng không, được gọi là chùm mặt phẳng.
6) Góc giữa hai mặt phẳng là góc nhọn tạo bởi hai vector pháp tuyến
7) Khoảng cách từ điểm
M[0](x[0], y[0], z[0])
tới mặt phẳng Ax+By+Cz+D=0 là:
|Ax[0] + By[0] + Cz[0] + D|
d = ---------------------------
/ 2 2 2\
sqrt\A + B + C /
Ý nghĩa của biểu thức:
rho = Ax + By + Cz + D
Không gian được chia thành 3 tập con:
i) Tập hợp những điểm mà ρ=Ax+By+Cz+D=0, đó là mặt phẳng với phương trình
Ax+By+Cz+D=0,
ii) Tập hợp những điểm mà ρ=Ax+By+Cz+D>0, đó là nửa không gian có bờ là mặt phẳng
rho = 0
iii) Tập hợp những điểm mà ρ=Ax+By+C<0, đó là nửa mặt phẳng có bờ là đường thẳng
rho = 0
7) Mặt cầu:
i) Phương trình chính tắc:
2 2 2 2
40
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
(x - x[0]) + (y - y[0]) + (z - z[0]) = R
ii) Phương trình tổng quát:
"x^(2)+y^(2)+z^(2)-2 a[]x-2 by-2 cz+d=0, "
với điều kiện:
/ 2 2 2 \
>\a + b + c - d, 0/
8) Điều kiện mặt phẳng là tiếp diện của mặt cầu: khoảng cách từ tâm mặt cầu đến mặt phẳng bằng bán
kính mặt cầu.
9) Một số bài toán
1) Phương trình mặt phẳng đi qua ba điểm:
M[1](x[1], y[1], z[1]);
M[2](x[2], y[2], z[2]);
M[3](x[3], y[3], z[3]);
Typesetting[delayDotProduct](det, Matrix(3, 3, {(1, 1) = `+`(x,
`-`(x[1])), (1, 2) = `+`(y, `-`(y[1])), (1, 3) = `+`(z,
`-`(z[1])), (2, 1) = `+`(x[2], `-`(x[1])), (2, 2) =
`+`(y[2], `-`(y[1])), (2, 3) = `+`(z[2], `-`(z[1])), (3, 1)
= `+`(x[3], `-`(x[1])), (3, 2) = `+`(y[3], `-`(y[1])), (3,
41
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3) = `+`(z[3], `-`(z[1]))}), true) = 0
2) Phương trình mặt phẳng đi qua điểm
M[0](x[0], y[0], z[0])
và song song với hai vector
#mover(mi("a"),mo("→")) = (a[1], a[2], a[3]),
#mover(mi("b"),mo("→")) = (b[1], b[2], b[3])
cho trước.
Typesetting[delayDotProduct](det, Matrix(3, 3, {(1, 1) = `+`(x,
`-`(x[0])), (1, 2) = `+`(y, `-`(y[0])), (1, 3) = `+`(z,
`-`(z[0])), (2, 1) = a[1], (2, 2) = a[2], (2, 3) = a[3], (3,
1) = b[1], (3, 2) = b[2], (3, 3) = b[3]}), true) = 0
3) Vị trí tương đối giữa mặt phẳng P và đường thẳng l:
Giả sử có mặt phẳng P cho bởi phương trình: Ax+By+Cz+D=0
và đường thẳng l có phương trình:
x = x[0] + at; y = y[0] + bt; z = z[0] + ct;
i) Điều kiện cắt nhau: Vector chỉ phương của đường thẳng không trực giao với vector pháp tuyến của
mặt phẳng:
42
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Ab + Bb + Cc 0
ii) Điều kiện song song:
Ab + Bb + Cc = *(0, v¢) Ax[0] + By[0] + Cz[0] + D and *(0, v¢) Ax
[0] + By[0] + Cz[0] + D 0
iii) Điều kiện l thuộc P:
Ab + Bb + Cc = *(0, v¢) Ax[0] + By[0] + Cz[0] + D and *(0, v¢) Ax
[0] + By[0] + Cz[0] + D = 0
4) Điều kiện chéo nhau của 2 đường thẳng
Cho hai đường thẳng
x - x[1] y - y[1] y - y[1] z - z[1]
-------- = -------- and -------- = --------
a[1] b[1] b[1] c[1]
và
x - x[2] y - y[2] y - y[2] z - z[2]
-------- = -------- and -------- = --------
a[2] b[2] b[2] c[2]
Điều kiện để hai đường thẳng chéo nhau là:
Typesetting[delayDotProduct](det, Matrix(3, 3, {(1, 1) =
`+`(x[2], `-`(x[1])), (1, 2) = `+`(y[2], `-`(y[1])), (1, 3)
43
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
= `+`(z[2], `-`(z[1])), (2, 1) = a[1], (2, 2) = b[1], (2, 3)
= c[1], (3, 1) = a[2], (3, 2) = b[2], (3, 3) = c[2]}), true)
0
5) Điều kiện đồng phẳng của 3 vector:
Typesetting[delayDotProduct](det, Matrix(3, 3, {(1, 1) = a[1],
(1, 2) = b[1], (1, 3) = c[1], (2, 1) = a[2], (2, 2) = b[2],
(2, 3) = c[2], (3, 1) = a[3], (3, 2) = b[3], (3, 3) = c[3]}),
true) = 0
5') Điều kiện đồng phẳng của 4 điểm
M[0](x[0], y[0], z[0]);
M[1](x[1], y[1], z[1]);
M[2](x[2], y[2], z[2]);
M[3](x[3], y[3], z[3]);
Typesetting[delayDotProduct](det, Matrix(3, 3, {(1, 1) =
44
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
`+`(x[1], `-`(x[0])), (1, 2) = `+`(y[1], `-`(y[0])), (1, 3)
= `+`(z[1], `-`(z[0])), (2, 1) = `+`(x[2], `-`(x[0])), (2,
2) = `+`(y[2], `-`(y[0])), (2, 3) = `+`(z[2], `-`(z[0])),
(3, 1) = `+`(x[3], `-`(x[0])), (3, 2) = `+`(y[3],
`-`(y[0])), (3, 3) = `+`(z[3], `-`(z[0]))}), true) = 0
6) Phương trình mặt cầu đi qua 4 điểm không đồng phẳng
MỘT SỐ LỆNH CỦA MAPLE 16
1.1. Điểm
1) Điểm M trong không gian được khai báo bởi lệnh [> point(M,x,y,z) hoặc point(M,*x,y,z+), trong đó M là
tên điểm, x, y, z tương ứng là hoành độ, tung độ và cao độ của điểm M.
Tọa độ của điểm có thể chọn ngẫu nhiên:
Lệnh 1 *> randpoint(Tên điểm, khoảng 1, khoảng 2, khoảng 3);
Lệnh 2 *> randpoint(Tên điểm, đối tượng, khoảng 1, khoảng 2, khoảng 3);
Đối tượng là đường thẳng, mặt phẳng, mặt cầu, ý nghĩa là điểm được chọn ngẫu nhiên trên các đối tượng
đó
2) Tương tự như trong hình học phẳng, ta cũng có:
Trung điểm của đoạn thẳng AB, có cú pháp midpoint(M,A,B).
Muốn xem tọa độ của M ta dùng lệnh:
Tọa độ điểm M: [> coordinates(M).
45
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Đoạn thẳng
1) Đoạn thẳng không đị nh hướng: [> segment(tên, [P1,P2]) hoặc [> segment(tên, P1,P2);
2) Đoạn thẳng có đị nh hướng: [> dsegment(tên, [P1,P2]) hoặc [> dsegment(tên, P1,P2).
1.2. Đường thẳng
1) Đường thẳng d đi qua điểm M(x0,y0,z0) và có vector chỉ phương V(a1,a2,a3), muốn nhập dưới dạng
tham số {x=x0+a1.t, y=y0+a2.t, z=z0+a3.t}, ta dùng lệnh:
[> line(d,[x0+a1.t, y0+a2.t, z0+a3.t],t);
2) Đường thẳng d đi qua điểm M(x0,y0,z0) và có vector chỉ phương V(a1,a2,a3), muốn nhập chính tắc
x - x0 y - y0 y - y0 z - z0
------ = ------ and ------ = ------
a1 a2 a2 a3
ta dùng lệnh: [> line(d,[point(M,2,3,4),[3,2,1]],t);
3) Đường thẳng d có dạng tổng quát:
giả sử có 2 mặt phẳng P1 và P2, được cho bởi hai phương trình mặt phẳng:
"{[[a1.x+b1.y+c1.z+d1=0,],[a2.x+b2.y+c2.z+d2=0,]]"
Ta khai báo hai mặt phẳng P1, P2 bởi các lệnh:
[> plane(P1,[a1.x+b1.y+c1.z+d1=0,[x,y,z]);
[> plane(P2,[a2.x+b2.y+c2.z+d2=0,[x,y,z]);
46
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Khi đó đường thẳng d là giao tuyến của P1 và P2 được khai báo bởi lệnh:
[> line(d,[P1,P2]);
4) Khai báo vector: Muốn nhập vector u=(x,y,z) ta dùng lệnh:
[> u:=([x,y,z]); hoặc [> u := ;
hai lệnh này cho ta vector hàng,
[> u:=; lệnh này cho ta vector cột.
5) Tích có hướng của 2 vector: trước hết phải mở gói lệnh *> with(linalg); sau đó dùng lệnh
[> crossprod(u,v);
6) Tích vô hướng của 2 vector:
[> dotprod(u,v); hoặc [> dotprod(u,v,orthogonal);
7) Vector chỉ phương của đường thẳng d:
[> ParallelVector(d);
8) Trục trong không gian (đường thẳng có đị nh hướng):[>
line(d, [x[1] + at, y[1] + bt, z[1] + ct], t)
d là tên của trục, [
x[1]
+at,
y[1]
+bt,
z[1]
+ct] là phương trình trục viết dạng tham số, t là tham số.
Mặt phẳng
Mặt phẳng trong maple được khai báo với các lệnh như sau:
47
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Số thứ tự
Lệnh
Chức năng
1
[> plane(P, [A,n],[x,y,z]);
Mặt phẳng P, đi qua điểm A và có vector pháp tuyến n.
2
[> plane(P, [d1,d2]);
Mặt phẳng P đi qua 2 đường thẳng d1 và d2.
3
[>plane(P, [A,B,C]);
Mặt phẳng P đi qua 3 điểm A, B, C.
4
[> plane(P, [A,d1,d2]);
Mặt phẳng P đi qua điểm A và song song với 2 đường thẳng d1 và d2.
5
[>plane(P, ax+by+cz+d=0);
Mặt phẳng P có phương trình là ax+by+cz+d=0.
6
[> parallel(P, M, alpha);
Mặt phẳng P đi qua điểm M và song song mặt phẳng alpha.
7
"[> NormalVector(P);"
Tìm vector pháp tuyến của mặt phẳng P.
8
48
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
TAM GIÁC
1) Tam giác biết ba đỉ nh là A, B, C: [> triangle(T,[A,B,C]);
2) Tam giác biết phương trình 3 cạnh a,b,c: [> triangle(T,[a,b,c], [x,y,z]);
Nếu các trục là u,v,w thì thay [x,y,z] bởi [u,v,w]
MẶT CẦU
1) Mặt cầu đi qua 4 điểm A, B, C, D: [> sphere(S,[A,B,C,D], n, `centername`=J);
Trong đó:
-) S là tên của mặt cầu.
-) n=[x,y,z] -tên các trục tọa độ
-) J là tên tâm mặt cầu.
2) Mặt cầu có đường kính là AB, với A và B là hai điểm: [> sphere(S,[A,B], n, `centername`=J);
3) Mặt cầu có tâm J và bán kính r: [> sphere(S,[J,r], n, `centername`=J);
J là tên của tâm.
4) Mặt cầu có tâm J và tiếp xúc mặt phẳng P: [> sphere(S,[J,P], n, `centername`=J);
J là tên của tâm.
5) Các yếu tố liên quan đến mặt cầu:
a) Tiếp diện P tại A của mặt cầu S: [> TangentPlane(P,A,S);
b) Phương tích của điểm M đối với mặt cầu S: [> powerps(M,s);
c) Mặt đẳng phương P của hai mặt cầu
S[1]
và
S[2]
: [> RadicalPlane(P,
49
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
S[1]
,
S[2]
);
d) Trục đẳng phương d của ba mặt cầu: [> RadicalLine(d, s1, s2, s3);
e) Tâm đẳng phương J của 4 mặt cầu: [> RadicalCenter(J, s1, s2, s3, s4);
f) Tính bán kính mặt cầu S: [> radius(S);
g) Tìm tâm mặt cầu S: [> center(S);
KHỐI ĐA DIỆN
1) Khối tứ diện biết bốn đỉ nh A, B, C, D: [> gtetrahedron(Ten, [A,B,C,D]);
2) Khối tứ diện biết bốn mặt: [> gtetrahedron(Ten, [
P[1], P[2], P[3], P[4]
]);
3) Hình hộp chữ nhật: [> parallelepiped(ten,[
d[1], d[2], d[3]
]);
d[1], d[2], d[3]
là 3 cạnh xuất phát từ một đỉ nh.
CÁC PHÉP BIẾN HÌNH TRONG KHÔNG GIÁN
1) Phép tị nh tiến: N là ảnh của M qua phép tị nh tiến theo vector
"(AB: )"
[> translation(N,M,AB;
Chú ý: AB là đoạn thẳng có hướng.
2) Phép đối xứng:
50
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
a) Qua đường thẳng: N là ảnh của N của phép đối xứng qua mặt phẳng P:
[> reflection(N,M,P);
b) Qua một đường thẳng: N là ảnh của M của phép đối xứng qua đường thẳng l:
[> reflection(N,M,l);
c) Qua một tâm: N là ảnh của M của phép đối xứng qua tâm C:
[> reflection(N,M,C);
3) Phép quay: N là ảnh của M qua phép quay với góc quay α, trục quay là l:
*> rotation(N, M, α, l);
Chú ý: góc quay có thể âm, có thể dương; trục quay l là đường thẳng có hướng.
4) Phép vị tự: N là ảnh của M qua phép vị tự tâm C, tỷ số k:
[> homothety(N,M,k,C);
5) Phép chiếu vuông góc:
a) Chiếu điểm A lên đường thẳng l, điểm ảnh là Q: [> projection(Q, A, l);
b) Chiếu điểm A lên mặt phẳng P, điểm ảnh là Q: [> projection(Q, A, P);
c) Chiếu đoạn thẳng l (hoặc đường thẳng l) lên mặt phẳng P, ảnh là d: [>projection(d, l, P);
TÌM GIAO CỦA CÁC ĐỐI TƯỢNG HÌNH HỌC
1) [> intersection(Tên, l[1], l[2]);
Tìm giao của hai đường thẳng, kết quả là điểm nếu chúng cắt nhau, ngược lại là "Null"
2) [> intersection(Tên, P[1], P[2]);
Tìm giao của hai mặt phẳng, kết quả là đường nếu chúng cắt nhau, ngược lại là "Null"
3) [> intersection(Tên, l, P);
Tìm giao của đường thẳng và mặt phẳng, kết quả là điểm nếu chúng cắt nhau, ngược lại là "Null"
4) [> intersection(Tên, l, S);
Tìm giao của đường thẳng và mặt cầu, kết quả là điểm nếu chúng cắt nhau, ngược lại là "Null"
5) [> intersection(Tên, P[1], P[2],P[3]);
51
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Tìm giao của ba mặt phẳng, kết quả là đường nếu chúng cắt nhau, ngược lại là "Null"
TÍNH GÓC
1) [> FindAngle(l[1],l[2]); Tính góc của hai đường thẳng cắt nhau.
2) [> FindAngle(P[1],P[2]); Tính góc của hai mặt phẳng cắt nhau.
3) [> FindAngle(S[1],S[2]); Tính góc của hai mặt phẳng cắt nhau.
4) [> FindAngle(l,P); Tính góc của đường thẳng và mặt phẳng cắt nhau.
5) [> FindAngle(A,T); Tính góc A của tam giác T.
KHOẢNG CÁCH
Nhóm lệnh về khoảng cách được tính trong maple
STT
Lệnh
Chức năng
Chú thích
1
[> distance(A,B)
Khoảng cách giữa hai điểm A và B
2
[> distance(l1,l2)
Khoảng cách giữa hai đường thẳng l1 và l2
Đường thẳng viết dạng tham số
3
[> distance(P1,P2)
Khoảng cách giữa hai mặt phẳng P1 và P2
52
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
4
[> distance(A,P)
Khoảng cách từ điểm A đến mặt phẳng P
5
[> distance(A,l)
Khoảng cách từ điểm A đến đường thẳng l
6
[> distance(l,P)
Khoảng cách từ đường thẳng l đến mặt phẳng P
>
1.8. Nhóm lệnh kiểm tra
Nhóm lệnh kiểm tra bắt đầu bằng Are hoặc Is dùng để kiểm tra tính đúng hoặc sai của một tính chất nào
đó.
Số thứ tự
Lệnh
Chức năng
1
[> AreConcurrent (P,Q,R, cond);
Kiểm tra tính thẳng hàng của 3 điểm P, Q, R.
2
[> ArePrallrel (l1,l2,cond);
Kiểm tra tính song song của hai đường thẳng l1, l2.
53
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
3
[> Areconcurrent(l1,l2,l3,cond);
Kiểm tra tính đồng quy của 3 đường thẳng l1, l2, l3.
4
[> ArePerpendicular(l1,l2,cond);
Kiểm tra tính vuông góc của hai đường thẳng l1, l2.
5
[> ArePerpendicular(l,P,cond);
Kiểm tra tính vuông góc của đường thẳng l với mặt phẳng P.
6
[> ArePerpendicular(P1,P2,cond);
Kiểm tra tính vuông góc của hai mặt phẳng P1 và P2.
7
[> AreCoplanar(A,B,C,D)
Kiểm tra tính đồng phẳng của bốn điểm A,B,C,C
8
[> AreCoplanar(l1,l2)
Kiểm tra tính đồng phẳng của hai đường thẳng
9
[> AreParallel(l1,l2)
Kiểm tra tính song song của hai đường thẳng l1 và l2
10
[> AreParallel(P1,P2)
Kiểm tra tính song song của hai mặt phẳng P1 và P2
11
54
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
[> AreParallel(l,P)
Kiểm tra tính song song của đường thẳng l và mặt phẳng P
12
[> IsOnCircle(A,c,cond);
Kiểm tra xem điểm A có thuộc đường tròn c hay không?
13
[> IsOnline(A,l,cond);
Kiểm tra xem điểm A có thuộc đường thẳng l hay không?
14
[> IsRightTriangle(ABC,cond);
Kiểm tra tính vuông của tam giác có tên là ABC
ĐIỂM TRONG CỦA ĐA GIÁC LỒI
BÀI TOÁN
Khi giải bài toán hình học đôi khi ta gặp khái niệm điểm M nằm trong một hình
nào đó, chẳng hạn, điểm M bên tronggóc xOy, điểm M bên trong tam giác
ABC...Gặp những trường hợp như thế này, người ta thường vẽ điểm Mmột cách
trực giác.
Vậy khái niệm chính xác điểm trong là gì? Làm thế nào để biết điểm Mở trong hay
ở ngoài một hình F
55
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Nếu hình Flà hình tròn hay hình elip, đã có điều kiện cần và đủ để kết luận điểm M
thuộc hay không thuộc hình F. Tuy nhiên, trường hợp F là một đa giác, khẳng định
điểm M thuộc hay không thuộc đa giác là bài toán
Trong khuôn khổ Luận văn này ta giả thiết hình F là một đa giác lồi, được định
nghĩa như sau:
Định nghĩa:Đa giác F được gọi là lồi, nếu mọi đoạn thẳng AB có hai đầu mút
thuộc biên của đa giác F thì cả đoạn thẳng AB thuộc đa giác F.
Bài toán:Trên mặt phẳng cho một đa giác lồi và điểm M. Hãy kiểm tra xem điểm
Mcó thuộc miền trong của đa giác hay không?
LỜI GIẢI
Trước hết ta có nhận xét: điểm M thuộc miền trong của đa giác, nếu tồn tại một
đoạn thẳng chứa điểm M và có hai đầu mút thuộc biên của đa giác.
Giả sử n đỉnh của đa giác đã cho Ta thực hiện các bước sau đây:
i) Viết phương trình các cạnh của đa giác
ii) Viết phương trình đường thẳng đi qua đỉnh nào đó (đỉnh chẳng hạn) và qua
M, giả sử đường thẳng này cắt biên của đa giác tại điểm B.
iii) Kiểm tra điểm M có thuộc đoạn ?
Nếu điểm M thuộc đoạn và không là một trong hai đầu mút, thì M là điểm
trong đa giác; nếu M là một trong hai đầu mút thì M là điểm trên biên; nếu M
thuộc phần kéo dài của thì M là điểm ngoài của đa giác
Nhập dữ liệu
>
>
> n:=6:
> a:=[1,2,5/2,2,1,1/2];
b:=[0,0,sqrt(3)/2,2*sqrt(3)/2,2*sqrt(3)/2,sqrt(3)/2];
56
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
>
point(M,[2,0.5]),point(A0,[0,0]),point(A1,[a[1],b[1]]),
point(A2,[a[2],b[2]]),point(A3,[a[3],b[3]]),point(A4,[a
[4],b[4]]),point(A5,[a[5],b[5]]),point(A6,[a[6],b[6]]);
>
segment(A0A1,[A0,A1]),segment(A1A2,[A1,A2]),segment(A2A
3,[A2,A3]),segment(A3A4,[A3,A4]),segment(A4A5,[A4,A5]),
segment(A5A6,[A5,A6]),segment(A6A1,[A6,A1]);
> segment(A1M,[A1,M]),line(d,[A1,M]),line(l34,[A3,A4]);
> intersection(N, l34, d);segment(MN,[M,N]);
> draw([M,N,A1M,MN,
A1A2,A2A3,A3A4,A4A5,A5A6,A6A1],printtext=true,title="ĐA
GIÁC");
57
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
>
Phương trình tham số các cạnh đa giác
> for i to n-1 do
print(`Phuong trinh tham so canh [`,i,i+1,`]`);
x[i,i+1] := t[i,i+1]*a[i]+(1-t[i,i+1])*a[i+1];
y[i,i+1] := t[i,i+1]*b[i]+(1-t[i,i+1])*b[i+1];
`------------------------------------`
end do;
print(`Phuong trinh tham so cua duong thang A1M`);
x:= (1-t)*a[1]+t*HorizontalCoord(M);
y:= (1-t)*b[1]+t*VerticalCoord(M);
58
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
>
Giải hệ phương trình tìm giao điểm của đường thẳng với các cạnh của đa
giác. Hệ phương trình cho nghiệm t và Nếu hệ phương trình cho nghiệm t>1, chứng tỏ
59
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
điểm M là điểm trong của đoạn thẳng . Từ đó suy ra điểm M là điểm trong của đa giác.
Nếu t=1, suy ra điểm M thuộc biên đa giác. Nếu t<1, chứng tỏ điểm M là điểm ngoài đa iác.
>
for i from 2 to n-1 do
if 1=1 then
Delta[i]:=a[i]*VerticalCoord(M)-HorizontalCoord(M)*b[i]:
end if;
if (Delta[i]0) then
N[i]:=solve({(1-t)*a[1]+t*HorizontalCoord(M)=t[i,i+1]*a[i]+(1-
t[i,i+1])*a[i+1],(1-t)*b[1]+t*VerticalCoord(M)=t[i,i+1]*b[i]+(1-
t[i,i+1])*b[i+1]},{t,t[i,i+1]});
end if;
if (rhs(N[i][1])>1)and(rhs(N[i][2])>0)and (rhs(N[i][2])<1) then
print(N[i][1],N[i][2],`Delta[`,i,`]=`,Delta[i]);
print(` ĐIỂM M LÀ ĐIỂM TRONG ĐA GIÁC`);
end if;
end do;
>
60
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
TỨ GIÁC ĐẦY ĐỦ
> restart:with(geometry):with(student):
ĐỀ BÀI:
Tứ giác đầy đủ là tứ giác có các cặp cạnh đối cắt nhau. Tứ giác đầy đủ có nhiều
tính chất hay. Trong bài này ta kiểm tra một số tính chất nhờ Maple.
a) ABCD là tứ giác đầy đủ (có thể lồi hoặc lõm), E là giao điểm của hai đường
thẳng AB và CD;F là giao điểm của AC và BD. M1, M2 và M3 lần lượt là trung
điểm của AC, BD và EF; khi đó M1, M2 và M3 thuộc một đường thẳng, ký hiệu
đường thẳng này là l1.
b) Trực tâm các tam giác ABF, DCF, BCE, ADE thuộc một đường thẳng, ký hiệu
đường thẳng này là l2.
c) Chứng minh rằng l1 vuông góc với l2.
d) Bốn đường tròn ngoại tiếp bốn tam giác ABF, DCF, BCE, ADE đồng quy tại
điểm J.
e) Bốn tâm đường tròn ở ý d) và điểm J thuộc một đường tròn.
LỜI GIẢI:
>
point(A,[0,0]),point(B,[2,0]),point(C,[4,2]),point(D,[1
,5]);
>
line(d1,[A,B]),line(d2,[B,C]),line(d3,[C,D]),line(d4,[D
,A]);
> intersection(E,d2,d4),intersection(F,d1,d3);
line(d5,[E,F]),line(d6,[B,D1]);
segment(AB,[A,B]),segment(BC,[B,C]),segment(CD1,[C,D]),
segment(DA,[D,A]);
segment(AC,[A,C]),segment(EF,[E,F]),segment(BD,[B,D]);
segment(AE,[A,E]),segment(EB,[E,B]),segment(BF,[B,F]),s
egment(FC,[F,C]);
61
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
>
midpoint(M1,AC),midpoint(M2,BD1),midpoint(M3,EF);segmen
t(M1M2,[M1,M2]),segment(M2M3,[M2,M3]),segment(M1M3,[M1,
M3]);
Kiểm tra tính thẳng hàng của 3 điểm M1, M2, M3
> AreCollinear(M1,M2,M3);line(l1,[M1,M2]);
>
triangle(ABE,[A,B,E]),triangle(BCF,[B,C,F]),triangle(AD
1F,[A,D,F]),triangle(CDE,[C,D,E]);
orthocenter(H1,ABE),orthocenter(H2,BCF),orthocenter(H3,
ADF),orthocenter(H4,CDE);
segment(H1H2,[H1,H2]),segment(H2H3,[H2,H3]),segment(H3H
4,[H3,H4]),segment(H1H4,[H1,H4]);
>
> AreCollinear(H1,H2,H3,H4);line(l2,[H3,H2]);
Kiểm tra sự vuông góc của l1 và l2
>
Bốn đường tròn ngoại tiếp bốn tam giác:
>
circle(C1,[A,B,E],[x,y]):circle(C2,[B,C,F],[x,y]):circl
e(C3,[A,D1,F],[x,y]):circle(C4,[C,D1,E],[x,y]):
Equation(C1):
62
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Kiểm tra tính đồng quy của 4 đường tròn
>
solve({Equation(C1),Equation(C2),Equation(C3),Equation(C
4)},{x,y});
>
draw([AB(color=green),BC(color=green),CD1(color=green),
D1A(color=green),AE(color=green),EB(color=green),
BF(color=green),FC(color=green),AC(color=blue),
BD1(color=blue),EF(color=blue),M1(color=red),M2(color=r
ed),
M3(color=red),M1M2(color=red),M2M3(color=red),
M1M3(color=red),H1H2(color=red),H2H3(color=green),C1,C2
,C3,C4
],#axes=none,
printtext=true,
title="TỨ GIÁC ĐẦY ĐỦ");
63
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
TÍNH DIỆN TÍCH ĐA GIÁC BẤT KỲ
ĐỀ BÀI: Trên mặt phẳng cho n điểm , nối các điểm
theo thứ tự đó ta được đa giác lồi hoặc lõm. Hãy tính diện tích đa
giác
LỜI GIẢI
Định nghĩa: Đa giác được gọi là định hướng dương, nếu đi theo
thứ tự sẽ thấy miền đa giác ở phía tay trái.
) Trưa títíác O với O là gốc tọa độ. Giả sử tọa độ các điểm là
, khi đó diện tích tam giác được tính bởi công
thức:
Chú ý rằng với công thức này diện tích tam giác có thể nhận giá trị dương hoặc
âm, tùy theo tam giác được định hướng dương hay âm.
Khi đó diện tích của đa giác ... được tính theo công thức (xem [4], trang
14).
Nhận xét: Công thức nhận được ở trên đúng với đa giác lồi và lõm không tự cắt.
CHƢƠNG TRÌNH TÍNH DIỆN TÍCH ĐA GIÁC
> restart:with(student): with(geometry):
n:=1000:
64
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
################################################################
#####
for i from 1 to n do
a[i]:=i;
b[i]:=i^2;
end do:
#a[1]:=2:
#a[2]:=4:
#a[3]:=6:
#a[4]:=8:
#a[5]:=10:
#a[6]:=9:
#a[7]:=7:
#a[8]:=5:
#a[9]:=3:
#a[10]:=1:
#b[1]:=1:
#b[2]:=4:
#b[3]:=9:
#b[4]:=16:
#b[5]:=25:
#b[6]:=7:
#b[7]:=5:
#b[8]:=5:
#b[9]:=3:
#b[10]:=1:
################################################################
L:=[seq(dt[i],i=1..n-1)]:
for i to n-1 do
dt[i] := evalf((a[i]*b[i+1]-a[i+1]*b[i])*(1/2));
end do:
##########################################################
Dt:=add(dt[i],i=1..n-1);
S:=evalf(Dt-(a[1]*b[n]-a[n]*b[1])*(1/2));
>
>
65
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
THUẬT TOÁN KIỂM TRA TÍNH LỒI CỦA ĐA
GIÁC
ĐA GIÁC LỒI
Đa giác lồi là đối tượng quan trọng của hình học, trong hầu hết các đa giác mà toán
học nghiên cứu là đa giác lồi, như hình tam giác, hình thang, hình bình hành,...
Tính lồi của đa giác không những chỉ có ý nghĩa trong hình học phẳng mà còn cả
trong hình học không gian, chẳng hạn như: hình chóp, chóp cụt là lồi khi và chỉ khi
đa giác đáy của nó là đa giác lồi. Điều này vẫn còn đúng cho hình lăng trụ.
KIỂM TRA TÍNH CHẤT LỒI CỦA ĐA GIÁC
Định nghĩa: Đa giác lồi là đa giác mà nếu ta kéo dài bất cứ cạnh của nó thì
toàn bộ đa giác thuộc về một nửa mặt phẳng có bờ là cạnh kéo dài đó.
Đa giác lõm là đa giác không lồi, hay nói cách khác là, tồn tại một cạnh nếu
ta kéo dài cạnh đó thì đa giác thuộc về cả hai nửa mặt phẳng có bờ là cạnh
kéo dài đó.
BÀI TOÁN:Trên mặt phẳng cho n điểm A[1], A[2],...,A[n], với tọa độ tương ứng
là (a[i],b[i]), i=1..n. Cần kiểm tra tính chất lồi của đa giác A[1]A[2]...A[n].
LỜI GIẢI
) NhậHai điểm M(x1, y1) và N(x2, y2) ở cùng một phía của đường thẳng
ax+by+c=0, nếu và chỉ nếu thỏa mãn điều kiện
(ax1+by1+c).(ax2+by2+c)>0.
2) Lập một danh sách a:=[a[1], a[2],..., a[n], a[1]] và một danh sách b= [b[1],
b[2],..., b[n], b[1]] .
3) Viết phương trình đường thẳng các cạnh l[i,i+1]của đa giác đi qua 2 đỉnh liên
tiếp A[i] và A[i+1], riêng đường thẳng cuối cùng ký hiệu là l[n,1] đi qua hai
đỉnh A[n] và A[1]. Giả sử các đường thẳng đó có dạng:
l[i,i+1]:=m[i]x[j]+n[i].y[j]+c[i]=0, j=1..n.
-) Tính các đại lượng d[j,i]=m[i]x[j]+n[i].y[j]+c[i], j=1..n.
Nếu tồn tại i0 và tồn tại j0 và j1 sao cho d[j0,i0].d[j1,i0]<0, chứng tỏ có hai đỉnh
thuộc về hai phía của đường thẳng l[i0,i0+1], từ đó kết luận đa giác đã cho là đa
giác lõm.
Vẽ đa giác
Nhập đa giác:
66
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Có nhiều cách xác định một đa giác, nhưng có 2 cách thông dụng nhất thường
được sử dụng, đó là:
-) Cho tập hợp tọa độ các đỉnh.
-) Cho phương trình đường thẳng chứa các cạnh của đa giác.
>
>
> n:=8:
> a:=array(1..n);b:=array(1..n);
> a:=[1,3,2,-2,-3,-3,-2,2,3];b:=[0,2,3,3,2,-2,-3,-3,-2];
> A[1]:=point(A1,[a[1],b[1]]):
A[2]:=point(A2,[a[2],b[2]]):
A[3]:=point(A3,[a[3],b[3]]):
A[4]:=point(A4,[a[4],b[4]]):
A[5]:=point(A5,[a[5],b[5]]):
A[6]:=point(A6,[a[6],b[6]]):
A[7]:=point(A7,[a[7],b[7]]):
A[8]:=point(A8,[a[8],b[8]]):
67
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
>
segment(A1A2,[A[1],A[2]]),segment(A2A3,[A[2],A[3]]),seg
ment(A3A4,[A[3],A[4]]),segment(A4A5,[A[4],A[5]]),
segment(A5A6,[A[5],A[6]]),segment(A6A7,[A[6],A[7]]),seg
ment(A7A8,[A[7],A[8]]),segment(A8A1,[A[8],A[1]]):
>
draw([A1A2,A2A3,A3A4,A4A5,A5A6,A6A7,A7A8,A8A1],printtex
t=true,title="ĐA GIÁC");
Kiểm tra tính chất lồi của đa giác
> for i to n do
l[i]:=(b[i+1]-b[i])*x-(a[i+1]-a[i])*y-
a[i]*b[i+1]+a[i+1]*b[i]:
end do:
> n:=8:
lom := 0;
for i to n do
68
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
duong := 0: am := 0:
for j to n do
d[j] := evalf(subs(x = a[j],y = b[j],l[i]));
if d[j] > 0 then duong := duong+1;
elif d[j] < 0 then am := am+1;
end if;
end do:
if (duong+am>0)and( duong*am>0) then
lom := lom+1;break;
end if;
end do:
if lom > 0 then print(`ĐA GIÁC ĐÃ CHO LÀ LÕM`);
else print(`ĐA GIÁC ĐÃ CHO LÀ LỒI`);
end if;
>
69
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
KIỂM TRA TÍNH LỒI CỦA ĐA GIÁC
Có nhiều tiêu chuẩn để khẳng định một đa giác là lồi hay lõm, ở bài trƣớc ta
đã sử dụng định nghĩa truyền thống về đa giác lồi. Trong bài này, ta sử dụng
một tiêu chuẩn khác để đa giác lồi, đó là:
Điều kiện cần và đủ đề đa giác lồi là mọi góc trong của nó nhỏ hơn π.
Áp dụng tiêu chuẩn trên, ta có thuật toán kiểm tra tính lồi của một đa giác khi
biết tọa độ các đỉnh
> restart: with(student):with(geometry):
NHẬP TỌA ĐỘ CÁC ĐỈNH
> n:=8:
a:=array[1..n]:
> a:=[1,2,3,3,2,1,0,0,1];
b:=[0,0,1,2,3,3,2,1,0];
VÍ DỤ VỀ ĐA GIÁC LỒI
Vẽ đa giác
>
point(A1,[a[1],b[1]]),point(A2,[a[2],b[2]]),point(A3,[a
[3],b[3]]),point(A4,[a[4],b[4]]),point(A5,[a[5],b[5]]),
point(A6,[a[6],b[6]]),point(A7,[a[7],b[7]]),point(A8,[a
[8],b[8]]);
>
segment(A1A2,[A1,A2]),segment(A2A3,[A2,A3]),segment(A3A
4,[A3,A4]),segment(A4A5,[A4,A5]),
segment(A5A6,[A5,A6]),segment(A6A7,[A6,A7]),segment(A7A
8,[A7,A8]),segment(A8A1,[A8,A1]):
>
draw([A1A2,A2A3,A3A4,A4A5,A5A6,A6A7,A7A8,A8A1],printtex
t=true,title="ĐA GIÁC");
70
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
>
Không giảm tính tổng quát, ta giả sử đa giác có hƣớng dƣơng, khi đó xuất
phát từ đỉnh A[1], đi tới các đỉnh A[2]...A[n], và cuối cùng về A[1]. Khi đi từ
cạnh A[i-1]A[i] sang cạnh A[i]A[i+1], ta phải quay một góc α[i]. Khi đó ba
mệnh đề sau đây là tƣơng đƣơng:
i) Góc thỏa mãn bất đẳng thức 0<α[i]<π.
ii) sinα[i]>0.
iii) Δ[i]=u[i].v[i+1]-u[i+1].v[i]>0,
ở đây (u[i], v[i]) và (u[i+1], v[i+1]) là tọa độ các vector A[i-1]A[i] và
A[i]A[i+1].
Sau đây ta sử dụng iii) để kiểm tra tính lồi của đa giác.
Ta có mệnh đề: Điều kiện cần và đủ để đa giác lồi là mọi góc trong của nó nhỏ
hơn π.
Tính tọa độ các vector cạnh của đa giác:
>
for i to n-1 do
u[i]:=a[i+1]-a[i]:
71
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
v[i]:=b[i+1]-b[i]:
end do;
u[n]:=a[1]-a[n];
v[n]:=b[1]-b[n];
Xét dấu các Δ[i], nếu Δ[i]>0 với mọi i=1..n thì đa giác lồi
> dem:=0:
for i to n-1 do
Delta[i]:=evalf(u[i]*v[i+1]-u[i+1]*v[i]);
if Delta[i]>0 then dem:=dem+1;
print(dem);
72
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
end if;
end do;
Delta[n]:=evalf(u[n]*v[1]-u[1]*v[n]);
if Delta[n]>0 then dem:=dem+1; end if;
if dem=n then
print(`ĐA GIÁC ĐÃ CHO LÀ ĐA GIÁC LỒI`);
else print(`ĐA GIÁC ĐÃ CHO LÀ ĐA GIÁC LÕM`);
end if;
73
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
>
################################################################
##################
################################################################
###################
################################################################
####################
VÍ DỤ VỀ ĐA GIÁC LÕM
> restart: with(student):with(geometry):
> n:=8:
a:=array[1..n]:
> a:=[1,2,1,3,2,1,0,0,1];
b:=[0,0,1,2,3,3,2,1,0];
>
Vẽ đa giác
>
point(A1,[a[1],b[1]]),point(A2,[a[2],b[2]]),point(A3,[a
[3],b[3]]),point(A4,[a[4],b[4]]),point(A5,[a[5],b[5]]),
point(A6,[a[6],b[6]]),point(A7,[a[7],b[7]]),point(A8,[a
[8],b[8]]);
>
segment(A1A2,[A1,A2]),segment(A2A3,[A2,A3]),segment(A3A
4,[A3,A4]),segment(A4A5,[A4,A5]),
segment(A5A6,[A5,A6]),segment(A6A7,[A6,A7]),segment(A7A
8,[A7,A8]),segment(A8A1,[A8,A1]):
>
draw([A1A2,A2A3,A3A4,A4A5,A5A6,A6A7,A7A8,A8A1],printtex
t=true,title="ĐA GIÁC");
74
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
>
Không giảm tính tổng quát, ta giả sử đa giác có hƣớng dƣơng, khi đó xuất
phát từ đỉnh A[1], đi tới các đỉnh A[2]...A[n], và cuối cùng về A[1]. Khi đi từ
cạnh A[i-1]A[i] sang cạnh A[i]A[i+1], ta phải quay một góc α[i]. Khi đó ba
mệnh đề sau đây là tƣơng đƣơng:
i) Góc thỏa mãn bất đẳng thức 0<α[i]<π.
ii) sinα[i]>0.
iii) Δ[i]=u[i].v[i+1]-u[i+1].v[i]>0,
ở đây (u[i], v[i]) và (u[i+1], v[i+1]) là tọa độ các vector A[i-1]A[i] và
A[i]A[i+1].
Sau đây ta sử dụng iii) để kiểm tra tính lồi của đa giác.
Ta có mệnh đề: Điều kiện cần và đủ để đa giác lồi là mọi góc trong của nó nhỏ
hơn π.
Tính tọa độ các vector cạnh của đa giác:
>
for i to n-1 do
u[i]:=a[i+1]-a[i]:
75
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
v[i]:=b[i+1]-b[i]:
end do;
u[n]:=a[1]-a[n];
v[n]:=b[1]-b[n];
Xét dấu các Δ[i], nếu Δ[i]>0 với mọi i=1..n thì đa giác lồi
> dem:=0:
for i to n-1 do
Delta[i]:=evalf(u[i]*v[i+1]-u[i+1]*v[i]);
if Delta[i]>0 then dem:=dem+1;
print(dem);
76
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
end if;
end do;
Delta[n]:=evalf(u[n]*v[1]-u[1]*v[n]);
if Delta[n]>0 then dem:=dem+1; end if;
if dem=n then
print(`ĐA GIÁC ĐÃ CHO LÀ ĐA GIÁC LỒI`);
else print(`ĐA GIÁC ĐÃ CHO LÀ ĐA GIÁC LÕM`);
end if;
77
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
TRỤC ĐẲNG PHƢƠNG-TÂM ĐẲNG
PHƢƠNG
Trong Maple đã có sẵn các lệnh tìm trục đẳng phương của hai đường tròn và tìm tâm đẳng
phương của 3 đường tròn. Trong bài này chúng ta xây dựng trục đẳng phương và tâm đẳng
phương từ các lệnh đơn giản của Maple.
TRỤC ĐẲNG PHƢƠNG CỦA 2 ĐƢỜNG TRÒN
> restart: with(student):with(geometry):
> Trucdangphuong := proc(a1,b1,c1,a2,b2,c2,a3,b3,c3)
local x,y,vt, L:=[op(L),vt[3]],truc12,truc23,truc31,N;
description "add a list of numbers and multiply by a
constant";
> vt[1]:=x^2+y^2-2*a1*x-2*b1*y+c1;
> vt[2]:=x^2+y^2-2*a2*x-2*b2*y+c2;
vt[3]:=x^2+y^2-2*a3*x-2*b3*y+c3;
if ((a1=a2) and (b1=b2))then print(`hai đường tròn vt1 và vt2
đồng tâm, không có trục đẳng phương`);
else
print(`Trục đẳng phương của hai đường tròn vt1 và vt2 là`,vt[1]-
vt[2]):
end if;
if ((a2=a3) and (b2=b3))then print(`hai đường tròn vt2 và vt3
đồng tâm, không có trục đẳng phương`);
else
print(`Trục đẳng phương của hai đường tròn vt2 và vt3 là`,vt[2]-
vt[3]):
end if;
if ((a3=a1) and (b3=b1))then print(`hai đường tròn vt3 và vt1
đồng tâm, không có trục đẳng phương`);
else
print(`Trục đẳng phương của hai đường tròn vt3 và vt1 là`,vt[3]-
vt[1]):
end if;
truc12:=vt[1]-vt[2];
truc23:=vt[2]-vt[3];
truc31:=vt[3]-vt[1];
print(` Tâm đẳng phương của ba đường tròn là `);
N:=solve({truc12,truc23,truc31},{x,y});
end proc:
78
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
> Trucdangphuong(0,0,-9,0,4,-16,7,0,4);
>
>
TỨ GIÁC NỘI TIẾP
ĐỀ BÀI:
Cho 4 đường tròn O1, O2, O3, O4. Biết rằng O1 tiếp xúc với O2 tại M12, O2 tiếp xúc với O3 tại
M23,O3 tiếp xúc với O4 tại M34,O4 tiếp xúc với O1 tại M41. Chứng minh rằng 4 điểm M12,
M23, M34, M41 thuộc một đường tròn.
LỜI GIẢI:
> restart: with(student):with(geometry):
> HaiDuongTron:= proc(a1,b1,R1,a2,b2,R2)
local x,y;
description "add a list of numbers and multiply by a constant";
point(C1,[a1,b1]); point(C2,[a2,b2]);
circle(vt1, [C1,R1],[x, y]);circle(vt2, [C2,R2],[x, y]);
intersection(M12,vt1, vt2);
end proc:
> HaiDuongTron(0,0,1,3,0,2);
> M12;
79
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
>
>
THUẬT TOÁN KIỂM TRA TÍNH ĐƠN CỦA ĐA
GIÁC
KIỂM TRA TÍNH CHẤT ĐƠN CỦA ĐA GIÁC
Định nghĩa: Đa giác đơn là đa giác không có hai cạnh nào cắt nhau. Đa
giác không đơn (còn gọi là đa giác tự cắt) là đa giác tồn tại một cặp cạnh
cắt nhau.
Chú ý: Cạnh của đa giác là đoạn thẳng có hai đầu mút là hai đỉnh liên tiếp của đa
giác, chứ không phải đường thẳng chứa cạnh đó. Vì vậy, khái niệm hai cạnh cắt
nhau phải hiểu là hai đoạn thẳng cắt nhau.
BÀI TOÁN:Trên mặt phẳng cho n điểm A[1], A[2],...,A[n], với tọa độ tương ứng
là (a[i],b[i]), i=1..n. Cần kiểm tra đường gấp khúc khép kín A[1]A[2]...A[n]A[1]
có tự cắt hay không?
LỜI GIẢI
1) Lập một danh sách a:=[a[1], a[2],..., a[n], a[1]] và một danh sách b= [b[1],
b[2],..., b[n], b[1]] .
) Viếtrìạ[i]A[i+1], riêhẳùng cómú đvà
Vẽ đa giác
Nhập đa giác: Nhập tập hợp tọa độ các đỉnh. của đa giác. Giả sử cho n
đỉnh A1, A2,...An cùng với tọa độ của chúng. Để tiện cho việc lập trình về
dau, ta lưu hoành độ vào một danh sách a và lưu tung độ vào danh sách b,
nhưng mỗi danh sách có n+1 thành phần, thành phần thứ n+1 bẳng thành
phần thứ 1. Nói rõ hơn:
80
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
tương tự như vậy, ta có danh
sách b chứa các tung độ của các đỉnh, và cũng có (n+1) phần tử và phần tử cuối
cùng bằng phần tử đầu tiên.
> restart: with(student): with(geometry): n:=8;
> a:=[0,1,0,2.5,3,3,1,-1,0]; b:=[0,-1,4,1,3,4,4,1,0];
>
point(A1,[a[1],b[1]]),point(A2,[a[2],b[2]]),point(A3,[a[3],b[3]]
),point(A4,[a[4],b[4]]),point(A5,[a[5],b[5]]),
point(A6,[a[6],b[6]]),point(A7,[a[7],b[7]]),point(A8,[a[8],b[8]]
);
>
segment(A1A2,[A1,A2]),segment(A2A3,[A2,A3]),segment(A3A4,[A3,A4]
),segment(A4A5,[A4,A5]),
segment(A5A6,[A5,A6]),segment(A6A7,[A6,A7]),segment(A7A8,[A7,A8]
),segment(A8A1,[A8,A1]):
>
draw([A1A2,A2A3,A3A4,A4A5,A5A6,A6A7,A7A8,A8A1],printtext=true,ti
tle="ĐA GIÁC TỰ CẮT"):
THUẬT TOÁN KIỂM TRA TÍNH CHẤT TỰ CẮT CỦA ĐA GIÁC
PHƯƠNG TRÌNH THAM SỐ CÁC CẠNH CỦA ĐA GIÁC
> for i to n-1 do
print(`Phuong trinh tham so canh A[`,i,i+1,`]`);
x[i,i+1]:=t[i,i+1]*a[i]+(1-t[i,i+1])*a[i+1];
y[i,i+1]:=t[i,i+1]*b[i]+(1-t[i,i+1])*b[i+1];
`------------------------------------`
end do;
>
LẬP HỆ PHƯƠNG TRÌNH TÌM GIAO ĐIỂM CÁC CẠNH CỦA ĐA GIÁC
> for i to n do
81
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
for j from i+2 to n do
print(x[i, i+1] = x[j, j+1], y[i, i+1] = y[j, j+1])
end do;
print(`----------------------------------------`)
end do;
GIẢI HỆ PHƯƠNG TRÌNH TÌM GIAO ĐIỂM CÁC CẠNH CỦA ĐA GIÁC
TỰ CẮT
> for i to n do
for j from i+2 to n do
N := solve({x[i,i+1] = x[j,j+1], y[i,i+1] = y[j,j+1],0
< t[i,i+1],0 <
t[j,j+1],t[i,i+1]<1,t[j,j+1]<1},{t[i,i+1],t[j,j+1]});
print(N);
end do:
end do:
>
>
ELIP
ĐỀ BÀI:
Tìm quỹ tích các điểm mà từ đó kẻ được 2 tiếp tuyến tới elip và
vuông góc với nhau.
LỜI GIẢI:
> restart:with(geometry):with(student):
a:=2;b:=3;
E:=x^2/a^2+y^2/b^2=1:
> tt1:=A1*(x-xM)+B1*(y-yM)=0;tt2:=A2*(x-xM)+B2*(y-yM)=0;
> tt1:=expand(A1*(x-xM)+B1*(y-yM)=0);
tt2:=expand(A2*(x-xM)+B2*(y-yM)=0);
82
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
> pt1:=simplify(expand(A1^2*a^2+B1^2*b^2=(-A1*xM-B1*yM)^2));
pt2:=expand(A2^2*a^2+B2^2*b^2=(-A2*xM-B2*yM)^2);
pt3:=A1*A2+B1*B2;
> solve({pt1,pt2,pt3,A1>0},{A1,A2,B1,B2});
>
>
83
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
KẾT LUẬN
Cũng như một số tác giả đi trước, luận văn đã sử dụng các lệnh có sẵn của Maple
giải các bài toán hình học. Giúp cho giáo viên và học sinh giải bài toán hình hiệu
quả hơn.
Luận văn đã đạt được một số kết quả sau:
-) Đã nêu một vài bài toán mà Maple chưa giải, sử dụng các lệnh có sẵn của Maple
giải chúng, đó là:
i) Kiểm tra tính lồi của một đa giác.
ii) Tính diện tích một đa giác bất kỳ.
iii) Kiểm tra một điểm có thuộc miền đa giác hay không.
iv) Viết phương trình mặt phẳng phân giác của nhị diện.
Vì thời gian có hạn, tác giả vẫn còn một số bài toán sau đây chưa thực hiện được:
-) Kiểm tra tính lồi của khối đa diện.
-) Kiểm tra một điểm thuộc miền trong của một đa giác lõm, không tự cắt.
-) Dựng thiết diện của khối đa diện
-) Sử dụng gói plots, plottools, draw giải bài toán quỹ tích.
Tác giả sẽ cố gắng giải chúng trong thời gian sớm nhất.
Luận văn còn nhiều hạn chế, chưa khai thác được nhiều thế mạnh của Maple. Rất
mong sự góp ý của các thầy các cô và các bạn
84
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
TÀI LIỆU THAM KHẢO
[1] Phạm Huy Điển,Phạm Cảnh Dương, Tạ Duy Phượng, Tính toán, lập trình &
Giảng dạy Toán học trên Maple, NXB Khoa học và Kỹ thuật, Hà nội 2002.
[2] Trịnh Thanh Hải, Giáo trình sử dụng phần mềm hỗ trợ dạy học toán, Thái
Nguyên, 2005, www.mathvn.com.
[3] Vũ Thanh Hiếu, Sách điện tử Môn giải tích toán học hàm số một biến, Luận
văn Thạc sĩ Toán học, Trường Đại học khoa học-ĐHTN, 2011.
[4] Β. Бляшке, круг и шар, наука, москва 1967. (Dịch từ nguyên bản tiếng Đức).
[5] ài liệu hướng dẫn sử dụng maple bằng tiếng việt
[6]
85
Số hóa bởi Trung tâm Học liệu – Đại học Thái Nguyên
Các file đính kèm theo tài liệu này:
- k2pi_net_su_dung_maple_giai_mot_so_dang_bai_toan_hinh_hoc_6882.pdf