Đồ án Phương pháp sai phân giải gần đúng phương trình vi phân tuyến tính

Bài toán biên có phương trình vi phân cấp lớn hơn hoặc bằng hai và điều kiện bổ sung được cho tại nhiều hơn một điểm. Chẳng hạn bài toán biên đối với phương trình vi phân tuyến tính cấp hai có dạng: Bài toán trên được gọi là bài toán biên loại một. Nếu điều kiện biên được thay thế bởi điều kiện biên: thì ta có bài toán biên loại ba nếu . Còn nếu thì ta có bài toán biên loại hai. Trong thực tế ta còn gặp những bài toán mà tại và có điều kiện biên khác nhau (chẳng hạn tại ta có điều kiện biên loại 1 còn tại ta có điều kiện biên loại hai hoặc ba) khi đó ta có bài toán biên hỗn hợp. Sau đây ta sẽ xem xét các khái niệm về phương pháp sai phân thông qua bài toán biên loại một.

doc84 trang | Chia sẻ: oanh_nt | Lượt xem: 1434 | Lượt tải: 0download
Bạn đang xem trước 20 trang tài liệu Đồ án Phương pháp sai phân giải gần đúng phương trình vi phân tuyến tính, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
Mục lục Lời nói đầu ……………………………………………………………….. 3 Chương 1. Khái niệm mở đầu về phương pháp sai phân …………….. 5 1.1. Mở đầu ………………………………………………………………… 5 1.2. Khái niệm về bài toán biên ……………………..…………………….. 5 1.3. Bài toán vi phân ………………………………………………………. 5 1.4. Lưới sai phân …………………………………………………………. 6 1.5. Hàm lưới …………………………………………………….………… 6 1.6. Đạo hàm lưới ………………………………………………………….. 6 1.7. Qui ước viết vô cùng bé ……………………………………………….. 7 1.8. Công thức Taylor ……………………………………………………… 7 1.9. Liên hệ giữa đạo hàm và đạo hàm lưới …………………………... 8 1.10. Phương pháp sai phân ………………………………………………... 9 1.11. Giải bài toán sai phân bằng phương pháp truy đuổi …. 9 1.11.1. Phương pháp truy đuổi từ phải ……………………...10 1.11.2. Phương pháp truy đuổi từ trái ………………………11 1.12. Sự ổn định của bài toán sai phân ………………………………… 12 1.13. Sự xấp xỉ ……………………………………………………………. 12 1.14. Sự hội tụ …………………………………………………………….. 13 1.15. Trường hợp điều kiện biên loại ba ……………………………… 14 Chương 2. Phương pháp sai phân giải gần đúng phương trình vi phân cấp bốn …… 18 2.1. Bài toán vi phân ……………………………………………………… 18 2.2. Lưới sai phân ………………………………………………………… 19 2.3. Hàm lưới …………………………………………………………….. 19 2.4. Đạo hàm lưới ………………………………………………………… 19 2.5. Phương pháp sai phân ………………………………………………... 20 2.6. Cách giải bài toán sai phân …………………………………………... 27 2.6.1. Phương pháp lặp Seidel co dãn ……………………………… 27 2.6.2. Phương pháp truy đuổi ……………………………………… 28 2.6.2.1. Phương pháp truy đuổi từ phải ……………………... 28 2.6.2.2. Phương pháp truy đuổi từ trái ………………………. 31 2.6.2.3. Sự ổn định ………………………………………….. 34 2.7. Sự xấp xỉ ……………………………………………………………... 37 2.8. Sự ổn định của bài toán sai phân …………………………………….. 37 2.9. Bài toán sai phân đối với sai số ……………………………………… 49 2.10. Sự hội tụ và sai số ………………………………………………….. 50 Phụ lục ……………………………………………………………….. … 58 Tài liệu tham khảo ……………………………………………………… 84 Lời nói đầu Trong lĩnh vực toán ứng dụng thường gặp rất nhiều bài toán có liên quan tới phương trình vi phân thường. Việc nghiên cứu phương trình vi phân thường vì vậy đóng một vai trò quan trọng trong lý thuyết toán học. Nhiều hiện tượng khoa học và kỹ thuật dẫn đến các bài toán biên của phương trình vật lý toán. Giải các bài toán đó đến đáp số bằng số là một yêu cầu quan trọng của thực tiễn. Trong một số ít trường hợp, thật đơn giản việc đó có thể làm được nhờ vào nghiệm tường minh của bài toán dưới dạng các công thức sơ cấp, các tích phân hoặc các chuỗi hàm. Còn trong đại đa số trường hợp khác, đặc biệt là đối với các bài toán có hệ số biến thiên, các bài toán phi tuyến, các bài toán trên miền bất kỳ thì nghiệm tường minh của bài toán không có hoặc có nhưng rất phức tạp. Chính vì vậy chúng ta phải nhờ tới các phương pháp xấp xỉ để tìm nghiệm gần đúng. Do nhu cầu của thực tiễn và của sự phát triển lý thuyết toán học, các nhà toán học đã tìm ra rất nhiều phương pháp để giải gần đúng các phương trình vi phân thường (các phương pháp giải tích như phương pháp chuỗi Taylo, phương pháp xấp xỉ liên tiếp Pica, các phương pháp số như phương pháp một bước, phương pháp Ađam, phương pháp Runghe-Kuta,…). Đề tài: "Phương pháp sai phân giải gần đúng phương trình vi phân tuyến tính" Trong phạm vi đồ án của mình, em xin trình bày một phương pháp gần đúng để giải phương trình vi phân cấp bốn tổng quát là phương pháp sai phân. Đây là một trong hai lớp phương pháp gần đúng quan trọng được nghiên cứu nhiều là phương pháp sai phân và phương pháp phần tử hữu hạn. Cả hai phương pháp đều tìm cách đưa bài toán đã cho về một bài toán đại số, thường là một hay nhiều hệ đại số tuyến tính. Trong phương pháp này miền trong đó ta tìm nghiệm của phương trình thường được phủ bằng một lưới gồm một số hữu hạn điểm (nút), còn các đạo hàm trong phương trình được thay bằng các sai phân tương ứng của các giá trị của hàm tại các nút lưới. Em xin cám ơn thầy Lê Trọng Vinh đã tận tình hướng dẫn em trong thời gian làm đồ án vừa qua. Hà nội 12 - 2003 Sinh viên thực hiện Nguyễn Đức Dũng Chương 1 Khái niệm mở đầu về phương pháp sai phân Mở đầu Trong chương này để trình bày những khái niệm cơ bản của phương pháp sai phân ta sẽ xét bài toán biên đối với phương trình vi phân cấp hai. Khái niệm về bài toán biên Bài toán biên có phương trình vi phân cấp lớn hơn hoặc bằng hai và điều kiện bổ sung được cho tại nhiều hơn một điểm. Chẳng hạn bài toán biên đối với phương trình vi phân tuyến tính cấp hai có dạng: Bài toán trên được gọi là bài toán biên loại một. Nếu điều kiện biên được thay thế bởi điều kiện biên: thì ta có bài toán biên loại ba nếu . Còn nếu thì ta có bài toán biên loại hai. Trong thực tế ta còn gặp những bài toán mà tại và có điều kiện biên khác nhau (chẳng hạn tại ta có điều kiện biên loại 1 còn tại ta có điều kiện biên loại hai hoặc ba) khi đó ta có bài toán biên hỗn hợp. Sau đây ta sẽ xem xét các khái niệm về phương pháp sai phân thông qua bài toán biên loại một. Bài toán vi phân Cho hai số và với . Tìm hàm xác định tại thỏa mãn: trong đó là những hàm số cho trước đủ trơn thỏa mãn: còn là những số cho trước. Giả sử bài toán có nghiệm duy nhất đủ trơn trên . 1.4 Lưới sai phân Ta chia đoạn thành đoạn con bằng nhau, mỗi đoạn con dài bởi các điểm . Mỗi điểm gọi là một nút lưới, gọi là bước lưới. Tập gọi là tập các nút trong. Tập gọi là tập các nút biên. Tập gọi là một lưới trên . Hàm lưới Đó là những hàm số xác định tại các nút của lưới . Giá trị của hàm lưới tại nút viết là . Một hàm số xác định tại mọi sẽ tạo ra hàm lưới có giá trị tại nút là . Đạo hàm lưới Xét hàm lưới . Đạo hàm lưới tiến cấp một của . Ký hiệu là , có giá trị tại nút là: Đạo hàm lưới lùi cấp một của , ký hiệu là , có giá trị tại nút là: Sau đây ta sẽ thấy rằng khi bé thì đạo hàm lưới “xấp xỉ” được đạo hàm thường (xem các công thức ). Do đó có đạo hàm lưới cấp hai : Nếu là một hàm lưới thì: 1.7 Qui ước viết vô cùng bé Khái niệm “xấp xỉ” liên quan đến khái niệm vô cùng bé. Để viết các vô cùng bé một cách đơn giản ta sẽ áp dụng qui ước sau đây: Giả sử đại lượng là một vô cùng bé khi . Nếu tồn tại số và hằng số không phụ thuộc sao cho: thì ta viết: Viết như trên có nghĩa là: khi nhỏ thì là một đại lượng nhỏ và khi thì tiến đến số không chậm hơn . Công thức Taylor Ta nhắc lại công thức Taylor ở đây vì nó là công thức quan trọng được sử dụng để xấp xỉ bài toán vi phân bởi bài toán sai phân. Giả sử là một hàm số xác định và có đạo hàm đến cấp trong một khoảng chứa , có thể dương hay âm. Khi đó theo công thức Taylor ta có: trong đó là một điểm ở trong khoảng từ đến . Có thể viết: . Ta giả thiết thêm: Khi đó là một vô cùng bé khi . Tức là tồn tại hằng số không phụ thuộc vào sao cho: Công thức Taylor ở trên có thể viết gọn hơn như sau: Liên hệ giữa đạo hàm và đạo hàm lưới Giả sử hàm đủ trơn. Theo công thức Taylor ta có: Ta suy ra Ngoài ra với qui ước: Ta còn có Ta suy ra Do đó Đồng thời Phương pháp sai phân Ta tìm cách tính gần đúng giá trị của nghiệm đúng tại các nút . Gọi các giá trị gần đúng đó là . Muốn có ta thay bài toán vi phân bởi bài toán sai phân: trong đó: Giải bài toán sai phân (1.9) – (1.10) bằng phương pháp truy đuổi Viết cụ thể bài toán ta có: Đó là một hệ đại số tuyến tính dạng ba đường chéo có thể giải bằng phương pháp truy đuổi. Xét hệ ba đường chéo tổng quát: trong đó: Như vậy hệ là trường hợp riêng của hệ khi: 1.11.1 Phương pháp truy đuổi từ phải Ta tìm nghiệm của hệ ở dạng: Khi đã biết các và thì cho phép tính các lùi từ phải sang trái. Vì lẽ đó phương pháp mang tên phương pháp truy đuổi từ phải. Để tính các ta viết trong đó thay bởi : Thay này vào , ta được: Do Điều kiện này được thỏa mãn nhờ giả thiết . Vì ta có: Theo giả thiết , ta có nên . Do đó: Một cách tương tự, giả sử . Ta chứng minh đúng với . Điều này rõ ràng vì Ta suy ra: Giả thiết cũng là điều kiện đảm bảo cho công thức truy đuổi ổn định. Với điều kiện thì cho: Đối chiếu với , ta suy ra: Tại , công thức viết: Đối chiếu với công thức thứ nhất của , ta suy ra: Sau đó từ cho phép tính tất cả các . Bây giờ công thức tại viết: Kết hợp với công thức thứ hai của , ta được: Do giả thiết và các đã được chỉ ra ở trên nên ta luôn có . Suy ra cho: Sau đó cho phép tính ra các . Vậy có thuật toán: 1.11.2 Phương pháp truy đuổi từ trái Ta tìm nghiệm ở dạng: Ta có thuật toán sau: Sự ổn định của bài toán sai phân Trước hết để đo độ lớn của hàm lưới và hàm lưới , ta sử dụng các chuẩn: Định nghĩa. Nói bài toán sai phân là bài toán ổn định nếu nó có nghiệm duy nhất với mọi vế phải và điều kiện biên, đồng thời nghiệm thỏa mãn: ý nghĩa của bài toán ổn định là: Bài toán sai phân có nghiệm duy nhất, đồng thời nghiệm đó phụ thuộc liên tục vào vế phải của phương trình sai phân và điều kiện biên, nghĩa là khi vế phải của phương trình sai phân và điều kiện biên thay đổi ít thì nghiệm cũng thay đổi ít. Bất đẳng thức nói lên ý nghĩa đó, ta gọi đó là bất đẳng thức ổn định của bài toán . Sự xấp xỉ Bằng công thức Taylor , ta có: Một cách tương tự: Ta suy ra: Do đó: Vì lẽ đó ta nói toán tử sai phân xấp xỉ toán tử vi phân tới cấp . Hơn nữa, vì và nên ta cũng nói: bài toán sai phân xấp xỉ bài toán vi phân . Sự hội tụ Định nghĩa. Gọi là nghiệm của bài toán vi phân và là nghiệm của bài toán sai phân . Nói phương pháp sai phân hội tụ nếu: khi tức là: khi hay: khi Nói phương pháp sai phân có cấp chính xác nếu: Định lý. Phương pháp sai phân là phương pháp hội tụ với cấp chính xác . Chứng minh. Đặt ta có: Theo : Theo và : Vậy thỏa mãn: Do đó, áp dụng bất đẳng thức ổn định ta được: Suy ra: Định lý được chứng minh. Trường hợp điều kiện biên loại ba - là những hằng số . Ta có: Như vậy, ta thấy nếu thay thì sai số địa phương tại biên chỉ đạt cấp do đó sẽ ảnh hưởng đến sai số trên toàn lưới. Để đạt được sai số tại biên cấp , ta sử dụng thêm chính phương trình tại . Thay đẳng thức này vào : Bỏ qua và thay hàm cần tìm bởi , ta nhận được đẳng thức xấp xỉ của điều kiện biên tại , đạt sai số : Hoàn toàn tương tự với biên , ta có: Vậy ta có hệ phương trình sau đối với bài toán biên loại ba: Đây là hệ đại số tuyến tính có ma trận hệ số dạng ba đường chéo, giải được bằng công thức truy đuổi. Thí dụ : Xét bài toán Giải : Ta chọn , nghĩa là chia đoạn làm 4 phần bằng nhau bởi các điểm chia. Ta có thể viết lại phương trình đã cho như sau: Suy ra: Nghiệm gần đúng là nghiệm của hệ phương trình sau: Tính các hệ số: Thay số vào ta được: Đây là hệ đại số tuyến tính dạng ba đường chéo được giải theo phương pháp truy đuổi đã nêu ở trên. Sau khi giải ra ta được kết quả: . Ta có thể tìm được nghiệm tổng quát của phương trình đã cho là: Dựa vào các điều kiện biên, ta tìm được . Suy ra nghiệm riêng tương ứng của phương trình là: So sánh với các nghiệm gần đúng tại các nút lưới, ta có bảng kết quả sau: Nghiệm gần đúng Nghiệm đúng 0 -0.5 0 0 1 -0.25 -0.19943 -0.21031 2 0 -0.26393 -0.27415 3 0.25 -0.20295 -0.21031 4 0.5 0 0 Sai số đạt: Chương 2 Phương pháp sai phân giải gần đúng phương trình vi phân cấp bốn Trong chương một ta đã xét các khái niệm của phương pháp sai phân thông qua bài toán biên đối với phương trình vi phân cấp hai nhằm hiểu được tư tưởng của phương pháp. Chương này sẽ đi vào nội dung chính của đồ án là dùng phương pháp sai phân để giải gần đúng phương trình vi phân cấp bốn tổng quát một cách chi tiết. Bài toán vi phân Cho hai số và với . Tìm hàm xác định tại thỏa mãn: trong đó: liên tục và các đạo hàm liên tục liên tục và đạo hàm liên tục là những hàm số liên tục đồng thời là những hàm số cho trước là những hàm số liên tục cho trước. Định lý về sự tồn tại và duy nhất nghiệm Phương trình có dạng: Nếu liên tục trong một miền nào đó trong và nếu là một điểm thuộc thì trong một lân cận nào đó của điểm , tồn tại một nghiệm duy nhất của phương trình thỏa mãn các điều kiện: Xem [5] phần tài liệu tham khảo. Lưới sai phân Ta chia đoạn thành đoạn con bằng nhau, mỗi đoạn con dài bởi các điểm . Mỗi điểm gọi là một nút lưới, gọi là bước lưới Tập gọi là tập các nút trong Tập gọi là tập các nút biên Tập gọi là một lưới trên Hàm lưới Đó là những hàm số xác định tại các nút của lưới . Giá trị của hàm lưới tại nút viết là . Một hàm số xác định tại mọi sẽ tạo ra hàm lưới có giá trị tại nút là . Đạo hàm lưới Giả sử hàm đủ trơn. Theo công thức Taylor, ta có Ta suy ra và như ta đã biết gọi là đạo hàm lưới tiến và lùi cấp một của . Qui ước: Ta còn có Ta suy ra Do đó Đồng thời Phương pháp sai phân Giả sử bài toán vi phân thỏa mãn định lý về sự tồn tại và duy nhất nghiệm, ta tìm cách tính gần đúng giá trị của nghiệm đúng tại các nút . Gọi các giá trị gần đúng đó là . Muốn có ta thay bài toán vi phân bởi bài toán sai phân tương ứng. Đặt Từ ta suy ra Theo ta có Ta có: Cộng vế với vế hai đẳng thức trên ta được: Suy ra Hay Thay vào ta được Thay vào ta được Đặt Cũng từ ta suy ra trong đó Thật vậy (giả thiết: ) Vậy: Tương tự, ta có thể chỉ ra rằng: Bằng cách khai triển các tới đạo hàm cấp 5 theo công thức Taylor, với giả thiết Đặt , coi là nghiệm gần đúng của và bỏ qua các vô cùng bé của ta được phương trình sau: Viết lại: trong đó: Có thể tính: Đặt Ta có phương trình sau: Kết hợp với các điều kiện biên , ta có: Bây giờ, ta cần xấp xỉ đạo hàm tại điểm : Nhân cả hai vế của đẳng thức với (-2) sau đó cộng với hai đẳng thức và ở trên, ta được: mà Vậy: trong đó: Thay vào, ta có: Thay bởi và bỏ qua sai số địa phương cấp 2 , ta được: Tương tự với điều kiện biên , ta có: Ta cần xấp xỉ đạo hàm cấp 2 tại : Nhân cả hai vế của đẳng thức ứng với với (-2) sau đó cộng với hai đẳng thức , ta được: mà Vậy: trong đó: Thay vào, ta có: Cũng thay bởi và bỏ qua sai số địa phương cấp 2 , ta được: Như vậy ta có hệ phương trình sau: Hệ cũng được gọi là lược đồ sai phân đối với bài toán biên đã cho. Thay cho bài toán vi phân đối với ẩn hàm ta có bài toán sai phân đối với ẩn hàm . là hệ phương trình đại số bậc nhất tuyến tính có dạng năm đường chéo. Cách giải bài toán sai phân (I) Phương pháp lặp Seidel co dãn Hệ có thể viết lại ở dạng ma trận Từ suy ra: Phương pháp lặp xuất phát từ xấp xỉ đầu cho trước Tăng cường tốc độ hội tụ bằng phép co dãn Quá trình lặp co dãn dừng khi sai số tương đối: trong đó là mức độ chính xác tương đối định trước. Phương pháp truy đuổi Bài toán sai phân có dạng: Đó là một hệ đại số tuyến tính năm đường chéo. Bây giờ ta sẽ xét phương pháp truy đuổi giải hệ năm đường chéo tổng quát sau: Phương pháp truy đuổi từ phải Ta tìm nghiệm của hệ ở dạng: Khi đã biết các hệ số thì cho phép tính các lùi từ phải sang trái. Vì lẽ đó phương pháp mang tên phương pháp truy đuổi từ phải. Từ các công thức và các hệ số là chưa biết. Để tính các hệ số . Từ ta thay bởi và ta được: Thay và vào phương trình , ta được: Đối chiếu với ta suy ra: trong đó: Từ ta thấy để xác định được và ta phải biết được và . Như vậy, trước hết ta cần xác định các và với . Sau đó từ ta tính được các và với . Từ ta suy ra: Từ với , ta có: Suy ra: Tương tự, từ với và ta có: Từ với , ta có: Suy ra: Như vậy, từ ta tính được các hệ số và với . Tiếp theo, ta cần xác định và theo công thức . Bây giờ, ta cần sử dụng các phương trình trong hệ. Từ và với kết hợp với phương trình và sử dụng công thức , ta có: Suy ra: Ta thấy rằng ở trên chính là giá trị được tính theo công thức ứng với , trong đó mẫu số chính là . Để tính , ta sử dụng với và với phương trình Với được tính từ tại . Như vậy, ta có thể tóm tắt lại qui trình giải hệ năm đường chéo theo phương pháp truy đuổi từ phải như sau: Tính các hệ số trong đó: Tính các theo công thức Phương pháp truy đuổi từ trái Ta tìm nghiệm hệ ở dạng: Từ và các hệ số là chưa biết. Từ thay , ta được: Từ thay , ta được: Thay vào : Đối chiếu với ta suy ra: trong đó: Từ ta thấy, để xác định được các hệ số ta phải biết được . Như vậy, trước hết ta cần xác định và với . Sau đó từ ta tính được các hệ số với . Từ , ta suy ra: Từ tại , ta có: Suy ra: Tương tự, từ và tại ta có: Từ tại , ta có: Suy ra: Như vậy, từ ta tính được các hệ số với Tiếp theo ta cần xác định và theo công thức . Từ với và : Thay ở trên vào cho ta: Đối chiếu với ta suy ra: Ta thấy rằng ở trên trùng với các giá trị suy ra từ công thức ứng với . Để tính , ta sử dụng tại và rồi thay vào phương trình ta có: Suy ra: Tóm lại, qui trình giải hệ theo phương pháp truy đuổi từ trái như sau: Tính các hệ số trong đó: Tính các theo công thức 2.6.2.3 Sự ổn định Nhận xét rằng, các công thức chỉ có nghĩa khi và chỉ khi: Để đảm bảo rằng việc giải hệ theo các công thức là ổn định thì các hệ số của hệ phương trình phải thỏa mãn các điều kiện của định lý sau: Định lý. Khi tìm nghiệm hệ theo công thức truy đuổi ta sẽ gặp phải sai số quy tròn, vì vậy có thể dẫn đến sự mất ổn định của công thức tính. Quá trình tính sẽ ổn định nếu các điều kiện sau đây được thỏa mãn: đồng thời có ít nhất một bất đẳng thức mạnh trong các bất đẳng thức dưới đây: Khi đó ta có: Chứng minh. Thật vậy, từ và ta có: (do giả thiết: ) Do vì (giả thiết) Mà Suy ra: Tương tự, ta có thể chứng minh được: Nếu thì Bây giờ, ta sẽ chỉ ra rằng: và Thật vậy, từ ta có: Từ , suy ra: ( do ) Tương tự, với dựa vào ta suy ra: (Sử dụng giả thiết và ) Do đó: Cuối cùng, ta cần chỉ ra rằng . Như vậy, với giả thiết đã cho cùng với các điều kiện và đã được chứng minh ở trên ta cần giả thiết thêm là các bất đẳng thức thứ này không đồng thời xảy ra dấu bằng. Khi đó, ta có . Định lý được chứng minh đầy đủ. Với cách đánh giá hoàn toàn tương tự như định lý trên, nếu các giả thiết của định lý được thỏa mãn thì ta cũng chỉ ra được rằng: . Sự xấp xỉ Ta có: với . Do đó: Vì lẽ đó ta nói toán tử sai phân xấp xỉ toán tử vi phân tới cấp . Sự ổn định của bài toán sai phân Định lý. Bài toán sai phân là bài toán ổn định: Chứng minh. ở trên, bài toán sai phân đã đưa về dạng với các hệ số thỏa mãn định lý về sự ổn định của hệ năm đường chéo. Để đánh giá ta đặt , trong đó: thỏa mãn thỏa mãn Khi đó thỏa mãn . Công thức truy đuổi từ phải áp dụng vào bài toán cho: Ta có: Do định lý về sự ổn định của hệ năm đường chéo, ta có nên suy ra sao cho thỏa mãn bất đẳng thức . trong đó các hệ số chính là số hạng thứ của dãy số Fibonacci Dãy số thể hiện ứng với các giá trị , có dạng: Viết lại: Ta có: trong đó: Với Xét quan hệ giữa các hệ số và . Suy ra: và ta có: (định lý về sự ổn định của hệ năm đường chéo). Bây giờ ta đánh giá Ta có: Do đó: Ta suy ra: Đặt: Suy ra: Cộng vế với vế các bất đẳng thức trên, ta được: Từ , ta có: Do đó: Đặt: Suy ra: Do giả thiết Ta có: Tương tự, ta có: Suy ra: Tiếp theo ta đánh giá các hệ số Nhận xét rằng: Do các nên ta có: Với mục đích đánh giá để thấy được nghiệm của bài toán phụ thuộc chặt vào vế phải của phương trình sai phân và điều kiện biên, do các hệ số đã chỉ ra ở trên chỉ phụ thuộc vào các hằng số ( và ) nên để đơn giản ta có thể đánh giá như sau: trong đó: Suy ra: Với Vậy: trong đó là số hạng thứ của dãy số Fibonacci ở trên. Ta có thể tính theo công thức sau: Ta nhận thấy, với mỗi xác định đánh giá ở trên chỉ phụ thuộc vào điều kiện đầu và vế phải của phương trình sai phân. Một cách tương tự đối với , áp dụng công thức truy đuổi từ trái ta có: do nên sao cho thỏa mãn ( với thì ). Ta có: trong đó: với Suy ra: trong đó: Ta có: Cộng vế với vế các bất đẳng thức trên ta được: Dựa vào điều kiện biên của bài toán , ta có: Suy ra: Do đó: trong đó: Tương tự như ở phần trên đối với ta sẽ chỉ ra được nên suy ra: Và cũng tương tự, ta cũng dễ dàng chứng tỏ rằng các . Khi đó có thể đánh giá như sau: Suy ra: Với Vậy: Rõ ràng ta thấy rằng tương tự bài toán nghiệm của bài toán cũng chỉ phụ thuộc vào vế phải của phương trình sai phân và điều kiện biên của nó. Như vậy từ ta suy ra: Tức là: . Trong đó: với . Định lý được chứng minh. Bài toán sai phân đối với sai số Gọi là nghiệm của bài toán vi phân và là nghiệm của bài toán sai phân . Đặt (- biểu thị sai số tại nút khi ta lấy ). Ta có bài toán sai phân đối với sai số . Suy ra: Vậy ta có hệ Sự hội tụ và sai số Định lý. Phương pháp sai phân là phương pháp hội tụ với cấp chính xác . Chứng minh. Với mọi hàm lưới xác định trên , ta định nghĩa chuẩn áp dụng định lý về sự ổn định vào bài toán sai phân đối với sai số, ta suy ra: Bất đẳng thức này chứng tỏ , tức là khi . Hơn nữa bất đẳng thức trên còn là một ước lượng của sai số . Cỡ của sai số là (tức là ). Định lý chứng minh xong. Chú ý: Từ chứng minh trên của định lý ta có thể phát biểu gọn: Xấp xỉ + ổn định = Hội tụ Xấp xỉ cấp 2 + ổn định = Hội tụ cấp 2 Thí dụ 1: Để kiểm tra sự đúng đắn của phương pháp, ta xét thí dụ sau: trong đó: chưa biết Bây giờ ta sẽ “mò” lấy một nghiệm và coi là nghiệm đúng của phương trình đã cho, sau đó tính các đạo hàm và thay vào phương trình để tính ra hàm . Khi đó áp dụng phương pháp sai phân đã trình bày ở trên để tính ra nghiệm gần đúng rồi so sánh với nghiệm đúng . Từ đó ta có thể đưa ra nhận xét về sự phù hợp của phương pháp. Nhận xét rằng phương trình đã cho là phương trình vi phân cấp 4 tuyến tính không thuần nhất hệ số hằng. Ta có thể tìm được nghiệm tổng quát của phương trình thuần nhất tương ứng là: Để tìm nghiệm tổng quát của phương trình không thuần nhất đã cho, ta sử dụng phương pháp biến thiên hằng số, nghĩa là coi các hắng số tùy ý là các hàm số. Ta tìm để cho nghiệm tìm được ở trên là một nghiệm của phương trình không thuần nhất. Sau khi tính các đạo hàm và thay vào phương trình đã cho, ta sẽ chọn các hệ số thỏa mãn hệ phương trình sau: trong đó: Giải ra ta có: Do là hàm chưa biết (cần tìm) nên các hệ số chưa xác định được Như vậy dựa vào dạng của nghiệm tìm được ở trên ta có thể chọn: và coi là nghiệm đúng của phương trình không thuần nhất. Sau khi tính các đạo hàm và thay vào phương trình đã cho, ta được: Bây giờ đã biết . Ta cần giải bài toán sau: Với các điều kiện biên: Chọn , nghĩa là chia đoạn làm 10 phần bằng nhau bởi các điểm chia: Dựa vào phương pháp sai phân đã nêu ở phần lý thuyết, ta đưa về hệ năm đường chéo sau đây để tính nghiệm gần đúng của phương trình vi phân đã cho trong đó: Giải ra ta được các , đồng thời so sánh với các nghiệm đúng cho trong bảng sau: Nghiệm gần đúng Nghiệm đúng 0 0 -0.9998 -1 1 0.025 -1.2589 -1.2588 2 0.05 -1.5362 -1.5361 3 0.075 -1.8327 -1.8326 4 0.1 -2.1493 -2.1494 5 0.125 -2.4871 -2.4873 6 0.15 -2.8470 -2.8474 7 0.175 -3.2303 -3.2307 8 0.2 -3.6380 -3.6384 9 0.225 -4.0714 -4.0716 10 0.25 -4.5317 -4.5316 Sai số đạt: Thí dụ 2. Giải gần đúng phương trình vi phân sau: ở đây: Do ta không thể tìm được dạng nghiệm tổng quát của phương trình đã cho nên ta phải lấy tùy ý và coi là nghiệm đúng của phương trình. Giả sử ta có dạng như sau: (Coi là nghiệm đúng) Sau khi tính các đạo hàm và thay vào phương trình đã cho, ta được: Tương tự như ở thí dụ 1, bây giờ đã biết các hàm ta dùng phương pháp sai phân để tìm nghiệm gần đúng của phương trình. Với các điều kiện biên: Ta chọn , tức là chia đoạn làm 25 phần bằng nhau bởi các điểm chia Như vậy ta có bài toán sai phân tương ứng với bài toán vi phân đã cho là: Tính các hệ số rồi thay vào hệ trên và giải ra được các nghiệm gần đúng đồng thời so sánh với các nghiệm đúng ta được bảng kết quả sau: 0 0 0.9998 1 1 0.02 1.0004 1.0006 2 0.04 1.0024 1.0025 3 0.06 1.0056 1.0058 4 0.08 1.0103 1.0105 5 0.1 1.0166 1.0167 6 0.12 1.0245 1.0246 7 0.14 1.034 1.0342 8 0.16 1.0454 1.0456 9 0.18 1.0587 1.0589 10 0.2 1.0741 1.0742 11 0.22 1.0915 1.0917 12 0.24 1.1111 1.1114 13 0.26 1.1331 1.1333 14 0.28 1.1575 1.1578 15 0.3 1.1845 1.1847 16 0.32 1.2141 1.2144 17 0.34 1.2466 1.2468 18 0.36 1.2819 1.2822 19 0.38 1.3203 1.3205 20 0.4 1.3618 1.3621 21 0.42 1.4067 1.4069 22 0.44 1.455 1.4552 23 0.46 1.5069 1.5071 24 0.48 1.5625 1.5627 25 0.5 1.6220 1.6221 Sai số đạt: Chú ý 1. Runge xem: (tồn tại nhưng chưa biết). Tính sai số: Chú ý 2. Xét bài toán Giả sử khi tính không được các giá trị đúng của mà chỉ được với ( là hai số dương bé) Khi đó thay cho bài toán ban đầu, ta có là bài toán mà vế phải và bị nhiễu một chút. Bài toán sai phân đối với sai số (tính toán): áp dụng bất đẳng thức ổn định Phụ lục Chương trình minh họa phương pháp sai phân giải gần đúng phương trình vi phân cấp bốn (Sử dụng ngôn ngữ Visual Basic) Tập tin PPSP.BAS Public a As Double Public b As Double Public N As Integer '---------------------------------------- ' Nhap ham p(x) '---------------------------------------- Public Function p(X As Double) As Double Dim a As Double Dim b As Double Dim c As Double a = Val(frmBTVP.txtAp.Text) b = Val(frmBTVP.txtBp.Text) c = Val(frmBTVP.txtCp.Text) p = a * X * X + b * X + c End Function '---------------------------------------- ' Nhap ham q(x) '---------------------------------------- Public Function q(X As Double) As Double Dim a As Double Dim b As Double Dim c As Double a = Val(frmBTVP.txtAq.Text) b = Val(frmBTVP.txtBq.Text) c = Val(frmBTVP.txtCq.Text) q = a * X * X + b * X + c End Function '---------------------------------------- ' Nhap ham g(x) '---------------------------------------- Public Function g(X As Double) As Double Dim a As Double Dim b As Double Dim c As Double a = Val(frmBTVP.txtAg.Text) b = Val(frmBTVP.txtBg.Text) c = Val(frmBTVP.txtCg.Text) g = a * X * X + b * X + c End Function '---------------------------------------- ' Nhap ham f(x) '---------------------------------------- Public Function f(X As Double) As Double Dim a As Double Dim b As Double Dim c As Double a = Val(frmBTVP.txtAf.Text) b = Val(frmBTVP.txtBf.Text) c = Val(frmBTVP.txtCf.Text) f = a * X * X + b * X + c End Function '----------------------------------------------------------------------- ' Phuong phap truy duoi tu phai giai he 5 duong cheo '----------------------------------------------------------------------- Public Sub TDP(Y() As Double, N As Integer) ReDim hsa(0 To N) As Double ReDim hsb(0 To N) As Double ReDim hsc(0 To N) As Double ReDim hsd(0 To N) As Double ReDim hse(0 To N) As Double ReDim fvp(0 To N) As Double ReDim Alpha(1 To N) As Double ReDim Beta(1 To N) As Double ReDim Gama(1 To N + 1) As Double ReDim Delta(1 To N) As Double Dim i As Integer Call Tinh_HS(hsa(), hsb(), hsc(), hsd(), hse(), fvp(),N) '1------ Tinh cac he so Alpha, Beta, Gama ------' Alpha(1) = hsd(0) / hsc(0) Delta(1) = hsc(1) - hsb(1) * Alpha(1) Beta(1) = hse(0) / hsc(0) Alpha(2) = (hsd(1) - Beta(1) * hsb(1)) / Delta(1) Beta(2) = hse(1) / Delta(1) Gama(1) = fvp(0) / hsc(0) Gama(2) = (fvp(1) + hsb(1) * Gama(1)) / Delta(1) For i = 2 To N - 2 Step 1 Delta(i) = hsc(i) - hsa(i) * Beta(i - 1) + Alpha(i) * (hsa(i) * Alpha(i - 1) - hsb(i)) Alpha(i + 1) = (hsd(i) + Beta(i) * (hsa(i) * Alpha(i - 1) - hsb(i))) / Delta(i) Beta(i + 1) = hse(i) / Delta(i) Gama(i + 1) = (fvp(i) - hsa(i) * Gama(i - 1) - Gama(i) * (hsa(i) * Alpha(i - 1) - hsb(i))) / Delta(i) Next i Delta(N - 1) = hsc(N - 1) - hsa(N - 1) * Beta(N - 2) + Alpha(N - 1) * (hsa(N - 1) * Alpha(N - 2) - hsb(N - 1)) Alpha(N) = (hsd(N - 1) + Beta(N - 1) * (hsa(N - 1) * Alpha(N - 2) - hsb(N - 1))) / Delta(N - 1) Gama(N) = (fvp(N - 1) - hsa(N - 1) * Gama(N - 2) - Gama(N - 1) * (hsa(N - 1) * Alpha(N - 2) - hsb(N - 1))) / Delta(N - 1) Delta(N) = hsc(N) - hsa(N) * Beta(N - 1) + Alpha(N) * (hsa(N) * Alpha(N - 1) - hsb(N)) Gama(N + 1) = (fvp(N) - hsa(N) * Gama(N - 1) - Gama(N) * (hsa(N) * Alpha(N - 1) - hsb(N))) / Delta(N) '2------ Tinh nghiem theo phuong phap truy duoi tu phai ------' Y(N) = Gama(N + 1) Y(N - 1) = Alpha(N) * Y(N) + Gama(N) For i = N - 2 To 0 Step -1 Y(i) = Alpha(i + 1) * Y(i + 1) - Beta(i + 1) * Y(i + 2) + Gama(i + 1) Next i End Sub '---------------------------------------------------------------- ' Phuong phap truy duoi tu trai giai he 5 duong cheo '---------------------------------------------------------------- Public Sub TDT(Y() As Double, N As Integer) ReDim hsa(0 To N) As Double ReDim hsb(0 To N) As Double ReDim hsc(0 To N) As Double ReDim hsd(0 To N) As Double ReDim hse(0 To N) As Double ReDim fvp(0 To N) As Double ReDim Delta(1 To N) As Double ReDim Gsi(1 To N) As Double ReDim Deta(1 To N) As Double ReDim T0(0 To N) As Double Dim i As Integer Call Tinh_HS(hsa(), hsb(), hsc(), hsd(), hse(), fvp(), N) '1---------- Tinh cac he so Gsi, Deta, T0 ----------' Gsi(N) = hsb(N) / hsc(N) Deta(N) = hsa(N) / hsc(N) T0(N) = fvp(N) / hsc(N) Delta(N) = hsc(N - 1) - hsd(N - 1) * Gsi(N) Gsi(N - 1) = (hsb(N - 1) - hsd(N - 1) * Deta(N)) / Delta(N) Deta(N - 1) = hsa(N - 1) / Delta(N) T0(N - 1) = (fvp(N - 1) + hsd(N - 1) * T0(N)) / Delta(N) For i = N - 2 To 1 Step -1 Delta(i + 1) = hsc(i) - hse(i) * Deta(i + 2) + Gsi(i + 1) * (hse(i) * Gsi(i + 2) - hsd(i)) Gsi(i) = (hsb(i) + Deta(i + 1) * (hse(i) * Gsi(i + 2) - hsd(i))) / Delta(i + 1) Deta(i) = hsa(i) / Delta(i + 1) T0(i) = (fvp(i) - hse(i) * T0(i + 2) - T0(i + 1) * (hse(i) * Gsi(i + 2) - hsd(i))) / Delta(i + 1) Next i Delta(1) = hsc(0) - hse(0) * Deta(2) + Gsi(1) * (hse(0) * Gsi(2) - hsd(0)) T0(0) = (fvp(0) - hse(0) * T0(2) - T0(1) * (hse(0) * Gsi(2) - hsd(0))) / Delta(1) '2---------- Tinh nghiem theo cong thuc truy duoi tu trai ----------' Y(0) = T0(0) Y(1) = Gsi(1) * Y(0) + T0(1) For i = 2 To N Step 1 Y(i) = Gsi(i) * Y(i - 1) - Deta(i) * Y(i - 2) + T0(i) Next i End Sub '----------------------------------------------------------------- ' Phuong phap truy duoi ket hop giai he 5 duong cheo '----------------------------------------------------------------- Public Sub TDKH(Y() As Double, N As Integer) ReDim U(0 To N) As Double ReDim V(0 To N) As Double Dim i As Integer Call TDT(U(), N) Call TDP(V(), N) For i = 0 To N Step 1 Y(i) = (U(i) + V(i)) / 2 Next i End Sub Public Sub Tinh_HS(hsa() As Double, hsb() As Double, hsc() As Double, hsd() As Double, hse() As Double, fvp() As Double, N As Integer) Dim h As Double Dim i As Integer ReDim X(0 To N) As Double X(0) = a h = (b - a) / N For i = 1 To N Step 1 X(i) = X(i - 1) + h Next i hsa(0) = 0: hsa(1) = 0 hsa(N - 1) = 0: hsa(N) = 0 hsb(0) = 0: hsb(1) = 3 hsb(N - 1) = 1: hsb(N) = 0 hsc(0) = 1: hsc(1) = 4 hsc(N - 1) = 4: hsc(N) = 1 hsd(0) = 0: hsd(1) = 1 hsd(N - 1) = 3: hsd(N) = 0 hse(0) = 0: hse(1) = 0 hse(N - 1) = 0: hse(N) = 0 fvp(0) = Val(frmBTVP.txtYa.Text): fvp(1) = 2 * h * Val(frmBTVP.txtYpa.Text) fvp(N - 1) = -2 * h * Val(frmBTVP.txtYpb.Text): fvp(N) = Val(frmBTVP.txtYb.Text) For i = 2 To N - 2 Step 1 hsa(i) = p(X(i - 1)) hsb(i) = 2 * p(X(i)) + 2 * p(X(i - 1)) - h * h * q(X(i) - h / 2) hsc(i) = p(X(i + 1)) + 4 * p(X(i)) + p(X(i - 1)) - h * h * (q(X(i) + h / 2) + q(X(i) - h / 2)) + h*h*h*h* g(X(i)) hsd(i) = 2 * p(X(i + 1)) + 2 * p(X(i)) - h * h * q(X(i) + h / 2) hse(i) = p(X(i + 1)) fvp(i) =h*h* h * h * f(X(i)) Next i End Sub '---------------------------------------------------------- 'Phuong phap lap co dan giai he 5 duong cheo '---------------------------------------------------------- Public Sub LCD(V() As Double, N As Integer) Dim i As Integer ReDim hsa(0 To N) As Double ReDim hsb(0 To N) As Double ReDim hsc(0 To N) As Double ReDim hsd(0 To N) As Double ReDim hse(0 To N) As Double ReDim fvp(0 To N) As Double ReDim Vt(0 To N) As Double Dim Ya As Double, Yb As Double Dim Ypa As Double, Ypb As Double Dim Delta As Double Dim max As Double Dim solan As Double Dim h As Double Call Tinh_HS(hsa(), hsb(), hsc(), hsd(), hse(), fvp(), N) Ya = Val(frmBTVP.txtYa.Text) Yb = Val(frmBTVP.txtYb.Text) Ypa = Val(frmBTVP.txtYpa.Text) Ypb = Val(frmBTVP.txtYpb.Text) '------ Cho xap xi dau V(i) buoc 0 ------' For i = 0 To N Step 1 Vt(i) = 0 Next i '------ Tinh V(i) buoc thu m theo cong thuc lap Seidel ------' If frmLCD.txtDelta "" Then Delta = Val(frmLCD.txtDelta.Text) Else Delta = 0.01 End If h = (b - a) / N w = 1.5 ' 1 < w < 2 solan = 1 Do V(0) = Ya V(2) = ((-hsa(2) + 0.75 * hsb(2)) * Ya + hsd(2) * Vt(3) - hse(2) * Vt(4) + fvp(2) + 0.5 * hsb(2) * h * Ypa) / (hsc(2) - 0.25 * hsb(2)) V(1) = 0.25 * (3 * Ya + V(2) + 2 * h * Ypa) V(2) = w * V(2) + (1 - w) * Vt(2) For i = 3 To N - 2 Step 1 V(i) = (-hsa(i) * V(i - 2) + hsb(i) * V(i - 1) + hsd(i) * Vt(i + 1) - hse(i) * Vt(i + 2) + fvp(i)) / hsc(i) V(i) = w * V(i) + (1 - w) * Vt(i) Next i V(N) = Yb V(N - 1) = 0.25 * (V(N - 2) + 3 * V(N) - 2 * h * Ypb) max = Abs((V(1) - Vt(1)) / V(1)) For i = 2 To N - 1 Step 1 If Abs((V(i) - Vt(i)) / V(i)) > max Then max = Abs((V(i) - Vt(i)) / V(i)) Next i Call BangLap For i = 1 To N - 1 Step 1 frmLCD.grdLcd.TextMatrix(solan, i) = Round(V(i), 5) Next i solan = solan + 1 If solan >= frmLCD.grdLcd.Rows Then frmLCD.grdLcd.Rows = solan + 1 End If For i = 0 To N Step 1 Vt(i) = V(i) Next i Loop While max > Delta And solan < 100 End Sub Public Sub BangLap() Dim i As Integer frmLCD.grdLcd.Cols = N frmLCD.grdLcd.FormatString = " Buoc lap " For i = 1 To frmLCD.grdLcd.Rows - 1 Step 1 frmLCD.grdLcd.TextMatrix(i, 0) = Str$(i) Next i For i = 1 To N - 1 frmLCD.grdLcd.TextMatrix(0, i) = " V(" & Str$(i) & ")" Next i End Sub Public Sub HienBangLap() ReDim V(0 To N) As Double Dim M As Integer frmLCD.Show Call BangLap M = N Call LCD(V(), M) End Sub Public Function SaiSo() As Double ReDim V(0 To N) As Double ReDim W(0 To 2 * N) As Double Dim Error As Double Dim M As Integer Dim i As Integer M = N Call TDP(V(), M) Call TDP(W(), 2 * M) Error = Abs(V(0) - W(0)) For i = 1 To N Step 1 If Abs(V(i) - W(2 * i)) > Error Then Error = Abs(V(i) - W(2 * i)) End If Next i SaiSo = 4 * Error / 3 End Function Tập tin BTVP.frm Thiết kế giao diện Mã lệnh Private Sub Form_Load() frmBTVP.Height = 6710 frmBTVP.Width = 7530 frmBTVP.Left = (Screen.Width - frmBTVP.Width) / 2 frmBTVP.Top = (Screen.Height - frmBTVP.Height) / 2 mnuDel.Enabled = False mnuPopupDel.Enabled = False cmdSph.Enabled = False End Sub Private Sub Form_MouseUp(Button As Integer, Shift As Integer, X As Single, Y As Single) If Button = vbRightButton Then PopupMenu mnuPopup, vbPopupMenuLeftAlign End If End Sub Private Sub cmdExit_Click() End End Sub Private Sub cmdSph_Click() frmBTVP.Hide frmBTSP.Show End Sub Private Sub Frame1_MouseUp(Button As Integer, Shift As Integer, X As Single, Y As Single) Call Form_MouseUp(Button, Shift, X, Y) End Sub Private Sub lblbt_MouseUp(Button As Integer, Shift As Integer, X As Single, Y As Single) Call Form_MouseUp(Button, Shift, X, Y) End Sub Private Sub mnuAbout_Click() frmDATN.Show End Sub Private Sub mnuDel_Click() txtAp.Text = "": txtBp.Text = "": txtCp.Text = "" txtAq.Text = "": txtBq.Text = "": txtCq.Text = "" txtAg.Text = "": txtBg.Text = "": txtCg.Text = "" txtAf.Text = "": txtBf.Text = "": txtCf.Text = "" txtYa.Text = "": txtYb.Text = "" txtYpa.Text = "": txtYpb.Text = "" End Sub Private Sub mnuExit_Click() End End Sub Private Sub mnuInput_Click() Dim i As Integer Dim NextLine As String Dim S() As Double CommonDialog1.Filter = "Text files(*.TXT)|*.TXT" CommonDialog1.ShowOpen If CommonDialog1.FileName "" Then Open CommonDialog1.FileName For Input As #1 i = 1 ReDim S(1) As Double Do While Not EOF(1) Line Input #1, NextLine If NextLine "" Then S(i) = Val(NextLine) i = i + 1 ReDim Preserve S(i) As Double End If Loop Close #1 '------ He so cua ham p(x) ------' txtAp.Text = S(1) txtBp.Text = S(2) txtCp.Text = S(3) '------ He so cua ham q(x) ------' txtAq.Text = S(4) txtBq.Text = S(5) txtCq.Text = S(6) '------ He so cua ham g(x) ------' txtAg.Text = S(7) txtBg.Text = S(8) txtCg.Text = S(9) '------ He so cua ham f(x) ------' txtAf.Text = S(10) txtBf.Text = S(11) txtCf.Text = S(12) '------ Dieu kien bien ya,yb,y'a,y'b ------' txtYa.Text = S(13) txtYb.Text = S(14) txtYpa.Text = S(15) txtYpb.Text = S(16) End If End Sub Private Sub mnuPopupAbout_Click() Call mnuAbout_Click End Sub Private Sub mnuPopupDel_Click() Call mnuDel_Click End Sub Private Sub mnuPopupExit_Click() End End Sub Private Sub mnuPopupInput_Click() Call mnuInput_Click End Sub Private Sub mnutContents_Click() frmContents.Show End Sub Private Sub picBt_MouseUp(Button As Integer, Shift As Integer, X As Single, Y As Single) Call Form_MouseUp(Button, Shift, X, Y) End Sub Private Sub tmrTimer_Timer() Dim OK As Boolean Dim OK1 As Boolean Dim OK2 As Boolean Dim OK3 As Boolean Dim OK4 As Boolean If txtAp.Text "" And txtBp.Text "" And txtCp.Text "" Then OK1 = True Else: OK1 = False End If If txtAq.Text "" And txtBq.Text "" And txtCq.Text "" Then OK2 = True Else: OK2 = False End If If txtAg.Text "" And txtBg.Text "" And txtCg.Text "" Then OK3 = True Else: OK3 = False End If If txtAf.Text "" And txtBf.Text "" And txtCf.Text "" Then OK4 = True Else: OK4 = False End If If txtYa.Text "" And txtYb.Text "" And txtYpa.Text "" And txtYpb.Text "" Then OK = True Else: OK = False End If If OK1 = True And OK2 = True And OK3 = True And OK4 = True And OK = True Then cmdSph.Enabled = True mnuDel.Enabled = True mnuPopupDel.Enabled = True Else cmdSph.Enabled = False mnuDel.Enabled = False mnuPopupDel.Enabled = False End If End Sub Private Sub txtAf_KeyPress(KeyAscii As Integer) Dim i As Integer For i = 65 To 90 Step 1 If KeyAscii = i Or KeyAscii = i + 32 Then txtAf.Text = "" End If Next i End Sub Private Sub txtAg_KeyPress(KeyAscii As Integer) Dim i As Integer For i = 65 To 90 Step 1 If KeyAscii = i Or KeyAscii = i + 32 Then txtAg.Text = "" End If Next i End Sub Private Sub txtAp_KeyPress(KeyAscii As Integer) Dim i As Integer For i = 65 To 90 Step 1 If KeyAscii = i Or KeyAscii = i + 32 Then txtAp.Text = "" End If Next i End Sub Private Sub txtAq_KeyPress(KeyAscii As Integer) Dim i As Integer For i = 65 To 90 Step 1 If KeyAscii = i Or KeyAscii = i + 32 Then txtAq.Text = "" End If Next i End Sub Private Sub txtBf_KeyPress(KeyAscii As Integer) Dim i As Integer For i = 65 To 90 Step 1 If KeyAscii = i Or KeyAscii = i + 32 Then txtBf.Text = "" End If Next i End Sub Private Sub txtBg_KeyPress(KeyAscii As Integer) Dim i As Integer For i = 65 To 90 Step 1 If KeyAscii = i Or KeyAscii = i + 32 Then txtBg.Text = "" End If Next i End Sub Private Sub txtBp_KeyPress(KeyAscii As Integer) Dim i As Integer For i = 65 To 90 Step 1 If KeyAscii = i Or KeyAscii = i + 32 Then txtBp.Text = "" End If Next i End Sub Private Sub txtBq_KeyPress(KeyAscii As Integer) Dim i As Integer For i = 65 To 90 Step 1 If KeyAscii = i Or KeyAscii = i + 32 Then txtBq.Text = "" End If Next i End Sub Private Sub txtCf_KeyPress(KeyAscii As Integer) Dim i As Integer For i = 65 To 90 Step 1 If KeyAscii = i Or KeyAscii = i + 32 Then txtCf.Text = "" End If Next i End Sub Private Sub txtCg_KeyPress(KeyAscii As Integer) Dim i As Integer For i = 65 To 90 Step 1 If KeyAscii = i Or KeyAscii = i + 32 Then txtCg.Text = "" End If Next i End Sub Private Sub txtCp_KeyPress(KeyAscii As Integer) Dim i As Integer For i = 65 To 90 Step 1 If KeyAscii = i Or KeyAscii = i + 32 Then txtCp.Text = "" End If Next i End Sub Private Sub txtCq_KeyPress(KeyAscii As Integer) Dim i As Integer For i = 65 To 90 Step 1 If KeyAscii = i Or KeyAscii = i + 32 Then txtCq.Text = "" End If Next i End Sub Private Sub txtYa_Keypress(KeyAscii As Integer) Dim i As Integer For i = 65 To 90 Step 1 If KeyAscii = i Or KeyAscii = i + 32 Then txtYa.Text = "" End If Next i End Sub Private Sub txtYb_KeyPress(KeyAscii As Integer) Dim i As Integer For i = 65 To 90 Step 1 If KeyAscii = i Or KeyAscii = i + 32 Then txtYb.Text = "" End If Next i End Sub Private Sub txtYpa_KeyPress(KeyAscii As Integer) Dim i As Integer For i = 65 To 90 Step 1 If KeyAscii = i Or KeyAscii = i + 32 Then txtYpa.Text = "" End If Next i End Sub Private Sub txtYpb_KeyPress(KeyAscii As Integer) Dim i As Integer For i = 65 To 90 Step 1 If KeyAscii = i Or KeyAscii = i + 32 Then txtYpb.Text = "" End If Next i End Sub Tập tin BTSP.frm Thiết kế giao diện Mã lệnh Private Sub Form_Load() frmBTSP.Left = (Screen.Width - frmBTSP.Width) / 2 frmBTSP.Top = (Screen.Height - frmBTSP.Height) / 2 cmdCal.Enabled = False mnuSeidel.Enabled = False frmLCD.grdLCD.Rows = 10 End Sub Private Sub Form_MouseUp(Button As Integer, Shift As Integer, X As Single, Y As Single) If Button = vbRightButton Then PopupMenu mnuRelaxtion, vbPopupMenuLeftAlign End If End Sub Private Sub cmdCal_Click() a = Val(frmBTSP.txtA.Text) b = Val(frmBTSP.txtB.Text) N = Val(frmBTSP.txtN.Text) Dim i As Integer, M As Integer ReDim Y(0 To N) As Double Dim Response as Integer grdTable.Rows = 2 grdTable.Cols = N + 2 M = N For i = 1 To N + 1 Step 1 grdTable.TextMatrix(0, i) = " V(" & Str$(i - 1) & ")" Next i If N >= 4 Then ' Call TDT(Y(),M) ' Call TDP(Y(), M) Call TDKH(Y(),M) For i = 0 To N Step 1 grdTable.TextMatrix(1, i + 1) = Round(Y(i), 8) Next i txtError.Text = Round(SaiSo, 9) Else Response = Msgbox (“Chú ý: Số đIểm chia của lưới phải không được nhỏ hơn bốn (N >= 4)!”, vbOkOnly + vbExclamation, “Thông báo”) If Response = vbYes then ' Call TDT(Y(),M) ' Call TDP(Y(), M) Call TDKH(Y(),M) End If End If End Sub Private Sub cmdQuit_Click() frmBTSP.Hide frmBTVP.Show End Sub Private Sub mnuExit_Click() frmBTSP.Hide frmBTVP.Show End Sub Private Sub mnuSeidel_Click() ReDim V(0 To N) As Double Dim M As Integer frmLCD.Show frmLCD.txtDelta = "" M = N Call LCD(V(), M) End Sub Private Sub tmrTimer_Timer() If txtA.Text "" And txtB.Text "" And txtN.Text "" Then cmdCal.Enabled = True mnuRelaxtion.Enabled = True mnuSeidel.Enabled = True Else cmdCal.Enabled = False mnuRelaxtion.Enabled = False mnuSeidel.Enabled = False End If End Sub Private Sub txtA_Change() Dim i As Integer grdTable.Cols = N + 2 If txtA.Text = "" Then For i = 1 To N + 1 Step 1 grdTable.TextMatrix(0, i) = "" Next i For i = 1 To N + 1 Step 1 grdTable.TextMatrix(1, i) = "" Next i End If grdTable.Rows = 5 grdTable.Cols = 5 End Sub Private Sub txtB_Change() 'Call txtA_Change Dim i As Integer grdTable.Cols = N + 2 If txtA.Text = "" Then For i = 1 To N + 1 Step 1 grdTable.TextMatrix(0, i) = "" Next i For i = 1 To N + 1 Step 1 grdTable.TextMatrix(1, i) = "" Next i End If grdTable.Rows = 5 grdTable.Cols = 5 End Sub Private Sub txtN_Change() Call txtA_Change End Sub Tập tin LCD.frm Thiết kế giao diện Mã lệnh Private Sub Form_Load() frmLCD.Height = 3990 frmLCD.Width = 6240 frmLCD.Left = (Screen.Width - frmLCD.Width) / 2 frmLCD.Top = (Screen.Height - frmLCD.Height) / 2 End Sub Private Sub cmdExit_Click() frmLCD.Hide End Sub Private Sub grdLcd_Click() Call HienBangLap End Sub Private Sub grdLcd_DblClick() Dim i As Integer Dim j As Integer For i = 0 To 100 Step 1 For j = 0 To N - 3 Step 1 grdLcd.TextMatrix(i, j) = "" Next j Next i End Sub Tập tin AboutDATN.frm Thiết kế giao diện Mã lệnh Private Sub Form_Load() frmDATN.Left = (Screen.Width - frmDATN.Width) / 2 frmDATN.Top = (Screen.Height - frmDATN.Height) / 2 frmDATN.Width = 7425 frmDATN.Height = 4545 End Sub Private Sub Form_Click() Call Frame1_Click End Sub Private Sub Frame1_Click() frmDATN.Hide End Sub Private Sub imgLogo_Click() Call Frame1_Click End Sub Private Sub lblCompany_Click() Call Frame1_Click End Sub Private Sub lblCompanyProduct_Click() Call Frame1_Click End Sub Private Sub lblCopyright_Click() Call Frame1_Click End Sub Private Sub lblDatn_Click() Call Frame1_Click End Sub Private Sub lblDt_Click() Call Frame1_Click End Sub Private Sub lblProductName_Click() Call Frame1_Click End Sub Private Sub lblSubject_Click() Call Frame1_Click End Sub Private Sub lblWarning_Click() Call Frame1_Click End Sub Tập tin ContentsDATN.frm Thiết kế giao diện Mã lệnh Private Sub Form_Load() frmContents.Left = (Screen.Width - frmContents.Width) / 2 frmContents.Top = (Screen.Height - frmContents.Height) / 2 frmContents.Width = 7920 frmContents.Height = 6630 End Sub Private Sub cmdTDP_Click() frmTDP.Show End Sub Tập tin ContentsTDP.frm Thiết kế giao diện Mã lệnh Private Sub Form_Load() frmTDT.Left = (Screen.Width - frmTDT.Width) / 2 frmTDT.Top = (Screen.Height - frmTDT.Height) / 2 End Sub Private Sub cmdExit_Click() Unload Me End Sub Tập tin ContentsTDT.frm Thiết kế giao diện Mã lệnh Private Sub Form_Load() frmTDT.Left = (Screen.Width - frmTDT.Width) / 2 frmTDT.Top = (Screen.Height - frmTDT.Height) / 2 End Sub Private Sub cmdExit_Click() Unload Me End Sub Ví Dụ minh họa TàI liệu tham khảo [1] Phan Văn Hạp, Lê Đình Thịnh Phương pháp tính và các thuật toán. NXB GD – 2000. [2] Tạ Văn Đĩnh Phương pháp sai phân và phương pháp phần tử hữu hạn. NXB KHKT Hà nội – 2002. [3] Lê Trọng Vinh Giải tích số. NXB KHKT Hà nội – 2000. [4] Phạm Phú Triêm, Nguyễn Bường Giải tích số. NXB ĐHQG Hà nội – 2000. [5] Nguyễn Đình Trí, Tạ Văn Đĩnh, Nguyễn Hồ Quỳnh Toán học cao cấp. Tập III – Phép tính giải tích nhiều biến số. NXB GD – 1998. [6] Edwin F. Beckenbach Toán học hiện đại cho kỹ sư. Tập I - Hồ Thuần, Nguyễn Lãm, Lê Thiện Phố, Phạm Văn ất dịch. NXB ĐH và THCN Hà nội – 1987. [7] Michael D. Greenberg Advanced Engineering Mathematics.

Các file đính kèm theo tài liệu này:

  • docDAN310.doc