Tap chi so 45A VN final pdf Tạp chí Khoa học và Công nghệ, Số 45A, 2020 © 2020 Trường Đại học Công nghiệp thành phố Hồ Chí Minh GIẢI PHƯƠNG TRÌNH ĐẠO HÀM RIÊNG SỬ DỤNG MẠNG NEURAL NHÂN TẠO HO DAC QUAN[.]
Tạp chí Khoa học Cơng nghệ, Số 45A, 2020 GIẢI PHƯƠNG TRÌNH ĐẠO HÀM RIÊNG SỬ DỤNG MẠNG NEURAL NHÂN TẠO HO DAC QUAN, HUYNH TRUNG HIEU Industrial University Of Ho Chi Minh City; hodacquan@iuh.edu.vn Tóm tắt Phương trình đạo hàm riêng ứng dụng rộng rãi lĩnh vực khác đời sống vật lý, hóa học, kinh tế, xử lý ảnh vv Trong báo chúng tơi trình bày phương pháp giải phương trình đạo hàm riêng (partial differential equation - PDE) thoả điều kiện biên Dirichlete sử dụng mạng neural truyền thẳng lớp ẩn (single-hidden layer feedfordward neural networks - SLFN) gọi phương pháp mạng neural (neural network method – NNM) Các tham số mạng neural xác định dựa thuật toán huấn luyện mạng lan truyền ngược (backpropagation - BP) Kết nghiệm PDE thu phương pháp NNM xác so với nghiệm PDE giải phương pháp sai phân hữu hạn Từ khố Phương trình đạo hàm riêng, Mạng neural truyền thẳng lớp ẩn, Thuật toán lan truyền ngược SOLVING PARTIAL DIFFERENTIAL EQUATIONS USING ARTICIFICAL NEURAL NETWORKS Abstract Partial differential equations have been widely applied in various fields of human knowledge, such as physics, chemistry, economics, image processing, etc In this paper, we presented a method for solving the problem of partial differential equations (PDEs) with Dirichlet boundary conditions (This method) using single-hidden layer feedforward neural network (SLFN) called neural network method (NNM) The parameters of SLFNs are determined by training the neural network with backpropagation The results show that NNM can obtain accuracy higher finite difference method Keywords Partial differential equations, Single hidden layer feedforward neural network - SLFN, Backpropagation GIỚI THIỆU Trong thực tế tượng khoa học kỹ thuật dẫn đến toán giải phương trình đạo hàm riêng (partial differential equation-PDE) PDE thường xuất toán ứng dụng thực tế vật lý, kỹ thuật, sinh học, kinh tế, xử lý ảnh v.v [1, 2] Vì việc tìm nghiệm PDE yêu cầu quan trọng khoa học thực tiễn Trong số trường hợp đơn giản, nghiệm tìm nhờ vào nghiệm tường minh toán dạng cơng thức sơ cấp, tích phân hay chuỗi hàm Tuy nhiên đại đa số toán thực tế toán phi tuyến, tốn có miền tính tốn phức tạp nghiệm tường minh tốn khơng tìm q phức tạp để tìm chúng Trong trường hợp việc tìm nghiệm PDE phải dựa vào phương pháp giải gần Các phương pháp số tìm nghiệm gần thông thường giải PDE phương pháp phần tử hữu hạn (finite element method - FEM), phương pháp sai phân hữu hạn (finite difference method - FDM) Phương pháp số xác định nghiệm gần cách thay miền xác định liên tục số hữu hạn điểm gọi nút lưới lưới sai phân tính tốn nghiệm PDE nút lưới [3, 4] Như để xác định nghiệm gần PDE điểm miền xác định phương pháp số đòi hỏi phải chia lưới miền tính tốn chứa nút lưới cần tính tính giá trị nút lưới lưới sai phân vừa chia dựa vào điều kiện biên điều kiện ban đầu cho trước PDE Để khắc phục việc giải PDE chia lưới miền tính tốn nêu trên, cách tiếp cận để tìm nghiệm gần PDE dạng hàm sử dụng mạng neural (artificial neural network - ANN) ANN cơng cụ tìm nghiệm PDE thích hợp dựa vào việc điều chỉnh tham số mạng cách tăng cường việc huấn luyện mạng [5] Ưu điểm sử dụng ANN để xác định nghiệm PDE không cần phải tính tốn lại giá trị nút lưới miền xác định dựa điểm chia lưới sai phân tính tốn trước [6] Ngồi ANN xấp xỉ hàm hàm truyền chọn cách thích hợp [7] © 2020 Trường Đại học Cơng nghiệp thành phố Hồ Chí Minh 24 GIẢI PHƯƠNG TRÌNH ĐẠO HÀM RIÊNG SỬ DỤNG MẠNG NEURAL NHÂN TẠO Trong báo chúng tơi trình bày mạng neural truyền thẳng lớp ẩn sử dụng thuật toán huấn luyện lan truyền ngược để xác định nghiệm phương trình đạo hàm riêng với điều kiện biên Dirichlet Nghiệm NNM PDE thu so sánh với nghiệm giải FDM Bố cục báo tổ chức sau: Mục trình bày phương pháp sai phân hữu hạn Mạng neural truyền thẳng lớp ẩn để giải PDE mô tả Mục Kết thực nghiệm mô tả Mục cuối kết luận PHƯƠNG PHÁP SAI PHÂN HỮU HẠN Cho phương trình đạo hàm riêng cấp với hai biến độc lập [8] ܩ൫ݔଵ ǡ ݔଶ ǡ ݑሺݔଵ ǡ ݔଶ ሻǡ ሺݔଵ ǡ ݔଶ ሻǡ ଶ ݑሺݔଵ ǡ ݔଶ ሻ൯ ൌ Ͳǡ ሺݔଵ ǡ ݔଶ ሻ אȳ ܴ ؿଶ (1) thoả điều kiện biên Dirichlet ݑሺݔଵ ǡ ݔଶ ሻ ൌ ݃ሺݔଵ ǡ ݔଶ ሻሺݔଵ ǡ ݔଶ ሻ ߲ אȳ G, ݃ hàm cho trước, toán tử vi phân, ݑሺݔଵ ǡ ݔଶ ሻ nghiệm (1), ߲ȳ biên ȳ Trong mặt phẳng (ݔଵ ǡ ݔଶ ) cho miền chữ nhật ȳ: ȳ ൌ ሼሺݔଵ ǡ ݔଶ ሻȁܽ ൏ ݔଵ ൏ ܾǡ ܿ ൏ ݔଶ ൏ ݀ሽ với a, b, c, d số cho trước, ߲ȳ nằm đường thẳng ݔଵ = a, ݔଵ = b, ݔଶ = c, ݔଶ = d FDM phương pháp số thường sử dụng tính đơn giản phổ dụng Ý tưởng phương pháp chia hình chữ nhật ȳ thành M đoạn theo trục ݔଵ ݔଶ xấp xỉ đạo hàm phương trình (1) sử dụng công thức sai phân Trong báo minh họa giải PDE FDM với phương trình Poisson sau: డమ ௨ሺ௫భ ǡ௫మ ሻ డమ ௨ሺ௫భ ǡ௫మ ሻ డ௫భమ డ௫మమ ൌ ݂ሺݔଵ ǡ ݔଶ ሻǡ ሺݔଵ ǡ ݔଶ ሻ אȳ ܴ ؿଶ (2) thoả điều kiện biên Dirichlet ݑሺݔଵ ǡ ݔଶ ሻ ൌ ݃ሺݔଵ ǡ ݔଶ ሻǡ ሺݔଵ ǡ ݔଶ ሻ ߲ אȳ, ݂ǡ ݃ hàm cho trước Khi xấp xỉ đạo hàm cấp hai phương trình Poisson sử dụng sai phân trung tâm biến đổi ta có hệ gồm (M+1)2 phương trình với (M+1)2 ẩn Giải hệ ta tính giá trị nút lưới lưới sai phân 2.1 Lưới sai phân hàm lưới Hình 1: Lưới sai phân hữu hạn Chọn số tự nhiên M>0 Chia miền ȳ thành ô lưới sau: ି Chia đoạn [a,b] thành M đoạn M+1 điểm chia có tọa độ ݔଵ ൌ ܽ ሺ݅ െ ͳሻ݄ଵ , ݄ଵ ൌ ெ độ dài đoạn chia, với i : ặ M+1 â 2020 Trng i hc Cụng nghip thành phố Hồ Chí Minh GIẢI PHƯƠNG TRÌNH ĐẠO HÀM RIÊNG SỬ DỤNG MẠNG NEURAL NHÂN TẠO 25 Chia đoạn [c,d] thành M đoạn M+1 điểm chia có tọa độ ݔଶ ൌ ܿ ሺ݅ െ ͳሻ݄ଶ , ݄ଶ ൌ ௗି ெ độ dài đoạn chia Mỗi điểm ൫ݔଵ ǡ ݔଶ ൯tương ứng với nút lưới ሺ݅ǡ ݆ሻ, với i, j : Ỉ M+1 Một hàm số xác định nút lưới gọi hàm lưới Giá trị hàm lưới nút lưới ൫ݔଵ ǡ ݔଶ ൯ ký hiệu ݑǡ xác định : ݑǡ ൌ ݑ൫ݔଵ ǡ ݔଶ ൯, i, j : ỈM+1 Tập ȳభǡ మ ൌ ሼ൫ݔଵ ǡ ݔଶ ൯ȁ൫ݔଵ ǡ ݔଶ ൯ אȳሽ gọi tập nút Tập ߲ȳభ ǡమ ൌ ሼ൫ݔଵ ǡ ݔଶ ൯ȁ൫ݔଵ ǡ ݔଶ ൯ ߲ אȳሽ gọi tập nút biên 2.2 Lược đồ sai phân Từ phương trình డమ ௨ሺ௫భ ǡ௫మ ሻ డమ ௨ሺ௫భ ǡ௫మ ሻ మ డ௫భ డ௫మమ ൌ ݂ሺݔଵ ǡ ݔଶ ሻǡ ܽ ൏ ݔଵ ൏ ܾǡ ܿ ൏ ݔଶ ൏ ݀, để xấp xỉ đạo hàm cấp hai theo biến ݔଵ ݔଶ điểm ൫ݔଵ ǡ ݔଶ ൯, sử dụng công thức sai phân trung tâm ta ݑିଵǡ െ ʹݑǡ ݑାଵǡ ݑǡିଵ െ ʹݑǡ ݑǡାଵ ൌ ݂ǡ ݄ଵଶ ݄ଶଶ (3) Thay (3) vào (2) biến đổi thành dạng toán sai phân hữu hạn hạn ݄ଶ ݑۓିଵǡ ݑାଵǡ ߣݑǡିଵ ߣݑǡାଵ െ ʹሺͳ ߣሻݑǡ ൌ ݄ଵଶ ݂ǡ ǡ ߣ ൌ ଵଶ ݄ଶ ۖ ۖ ݑଵǡ ൌ ݃ ൫ݔଶ ൯ǡ ݆ǣ ͳỈ ܯ ͳ (4) (5) ݑெାଵǡ ൌ ݃ ൫ݔଶ ൯ǡ ݆ǣ ͳỈ ܯ ͳ (6) ݑǡଵ ൌ ݃ ሺݔଵ ሻǡ ݅ǣ ͳỈ ܯ ͳ (7) ݑǡெାଵ ൌ ݃ௗ ሺݔଵ ሻǡ ݅ǣ ͳỈ ܯ ͳ (8) Từ phương trình (4) cho ta mối quan hệ ݑǡ bốn nút lưới xung quanh ݑǡ Giải hệ phương trình đại số tuyến tính (4-8) ta xác định giá trị hàm lưới ݑǡ với ݅ǡ ݆ ͳ Ỉ ܯ ͳ ۔ ۖ ۖ ە MẠNG NEURAL TRUYỀN THẲNG MỘT LỚP ẨN ĐỂ GIẢI PDE (NNM) 3.1 Mạng truyền thẳng lớp ẩn Nhiều kiến trúc khác mạng neural phát triển mạnh Tuy nhiên người ta chứng minh mạng neural truyền thẳng lớp ẩn (single hidden layer feedfordward neural network SLFN) xấp xỉ hàm số nút ẩn hàm truyền chọn cách thích hợp [7] Kiến trúc SLFN giải PDE với d nút lớp nhập, N nút lớp ẩn nút lớp xuất minh họa hình 2: Hình 2: Kiến trúc tiêu biểu mạng neural lớp ẩn (SLFN) giải PDE © 2020 Trường Đại học Cơng nghiệp thành phố Hồ Chí Minh 26 GIẢI PHƯƠNG TRÌNH ĐẠO HÀM RIÊNG SỬ DỤNG MẠNG NEURAL NHÂN TẠO Với࢞ ൌ ሾݔଵǡ ݔଶ ǡ ǥ ǡ ݔௗ ሿ் ܴ אௗ ngõ vào, ݓ véc tơ trọng số kết nối từ nút nhập j đến nút ẩn thứ m, ܟ୫ ൌ ሾݓଵǡ ݓଶ ǡ ǥ ǡ ݓௗ ሿ் , ܾ độ lệch (bias) nút ẩn thứ m, ߚ vector trọng số kết nối từ lớp ẩn thứ m đến nút xuất , ࢝ ή ࢞ tích vơ hướng hai vecto ࢝ ࢞ , ߪሺǤ ሻ hàm truyền (trong nghiên cứu này, tác giả sử dụng hàm sigmoid) Ứng với vector đầu vào ࢞ ngõ xuất ୨ xác định ே (9) ൌ ߚ ߪሺ࢝ ή ࢞ ܾ ሻ ୀଵ 3.2 Nghiệm PDE sử dụng SLFN Cho phương trình đạo hàm riêng cấp hai với có dạng tổng quát [9]: ܩ൫࢞ǡ ݑሺ࢞ሻǡ ሺ࢞ሻǡ ଶ ݑሺ࢞ሻ൯ ൌ Ͳǡ ࢞ אȳ ܴ ؿௗ ǡ ݀ ܰ א (10) thỏa điều kiện biên (boundary conditions – BCs) Dirichlete, với ࢞ ൌ ሺݔଵ ǡ ǥ ǡ ݔௗ ሻ ܴ אௗ ǡ ݑሺ࢞ሻ nghiệm phương trình (10)cần xác định Biên miền ȳ kí hiệu ߲ȳ Nghiệm ݑሺ࢞ሻ gần (10) xác định cách chia lưới miền ȳ ߲ȳ tìm giá trị ൌ ൛݆࢞ אȳǢ ݆ ൌ ͳǡ ǥ ǡ ݊ൟ Rõ ràng việc tìm giá trị u nút lưới ݑtại nút lưới thuộc miền ȳ đưa giải hệ phương trình (11) thuộc ȳ , ܩቀ࢞ ǡ ݑ൫࢞ ൯ǡ ൫࢞ ൯ǡ ଶ ݑ൫࢞ ൯ቁ ൌ Ͳǡ ࢞ אȳ (11) ݑphải thỏa điều kiện biên Dirichlet cách giải hệ phương trình, gọi ݑ௧ ሺ࢞ǡ ሻ Thay xác định giá trị nút lưới thuộc ȳ nghiệm gần phương trình (14), p tham số điều chỉnh cho cực tiểu hàm lỗi (12) ଶ ܧሺሻ ൌ ൫ܩሺ࢞ ǡ ݑ௧ ሺ࢞ ǡ ሻǡ ݑ௧ ሺ࢞ ǡ ሻǡ ଶ ݑ௧ ሺ࢞ ǡ ሻሻ൯ ǡ (12) ࢞ೕ אஐ ݑ௧ thỏa điều kiện biên Dirichlet Nghiệm gần ݑ௧ ሺ࢞ǡ ሻ xác định sử dụng SLFN thỏa điều kiện biên Dirichlet viết dạng tổng số hạng [9], trọng số SLFN thay ࢃǡ ࢼ (13) ݑ௧ ሺ࢞ǡ ࢃǡ ࢼሻ ൌ ܣሺ࢞ሻ ܨሺ࢞ሻܱሺ࢞ǡ ࢃǡ ࢼሻ, ܱሺ࢞ǡ ࢃǡ ࢼሻ ൌ ࢼࢀ ߪሺࢃ࢞ሻ, (14) ሾ࢝ଵ் ǡ ்࢝ଶ ǡ ǥ ǡ ்࢝ே ሿ் ǡ ் ୶ୢାଵ với ࢞ ൌ ሾ࢞ ǡ ͳሿ giá trị đầu vào, ܟൌ ࢈ ൌ ሾܾଵ ǡ ܾଶ ǡ ǥ ǡ ܾே ሿ ǡ ࢃ ൌ ሾ࢝ǡ ࢈ሿ א ǡࢼ ൌ ் ሾߚଵ ǡ ߚଶ ǡ ǥ ǡ ߚே ሿ trọng số SLFN, ܱሺ࢞ǡ ࢃǡ ࢼሻ ngõ xuất mạng neural, A(x) hàm không chứa trọng số SLFN thoả điều kiện biên Dirichlet, F(x) hàm không cần thoả điều kiện biên Dirichlet Trong báo nghiệm gần ݑ௧ ሺ࢞ǡ ࢃǡ ࢼሻcủa (10) xác định sử dụng SLFN với thuật toán lan truyền ngược để cực tiểu hàm lỗi (12) qua việc điều chỉnh trọng số ࢃǡ ࢼ mạng Như việc xác định nghiệm gần phương trình (10) tương ứng với việc xác định ݑ௧ ሺ࢞ǡ ࢃ כǡ ࢼ כሻ, vớiࢃ כൌ ܽܧ ࢃ݊݅݉݃ݎሺࢃǡ ࢼሻ, ࢼ כൌ ܽܧ ࢼ݊݅݉݃ݎሺࢃǡ ࢼሻ 3.3 Gradient ngõ xuất đầu vào, trọng số SLFN Để cực tiểu hàm lỗi (12) SLFN huấn luyện để điều chỉnh trọng số mạng cho với giá trị ࢞ ta có G(࢞ ሻ xấp xỉ với giá trị Một tiếp cận phổ biến để tìm ࢃǡ ࢼ thỏa điều kiện dựa giảm gradient Trong đó, ngõ xuất ܱሺ࢞ǡ ࢃǡ ࢼሻ đạo hàm ngõ xuất ngõ vào, trọng số mạng cần phải xác định 3.3.1 Gradient ngõ xuất ngõ vào SLFN Xét kiến trúc mạng neural SLFN hình 2, với đầu vào࢞ ൌ ሾݔଵǡ ݔଶ ǡ ǥ ǡ ݔௗ ሿ் ܴ אௗ , ngõ xuất mạng xác định ܱ ൌ σே ୀଵ ߚ ߪሺݖ ሻ, © 2020 Trường Đại học Cơng nghiệp thành phố Hồ Chí Minh (15) GIẢI PHƯƠNG TRÌNH ĐẠO HÀM RIÊNG SỬ DỤNG MẠNG NEURAL NHÂN TẠO 27 với ݖ ൌ σௗୀଵ ݓ ݔ ܾ Khi ta có: ௗ ே ே ߲ ߲ܱ ൌ ቌ ߚ ߪ ቌ ݓ ݔ ܾ ቍቍ ൌ ߚ ݓ ߪ ሺଵሻ ǡ ߲ݔ ߲ݔ với ߪ ሺଵሻ ୀଵ డఙሺ௫ሻ ൌ డ௫ (16) ୀଵ ୀଵ Tương tự với đạo hàm bậc k O theo biến ngõ vào ݔ tính theo cơng thức ߲ ܱ ߲ݔ ே ሺሻ ൌ ߚ ݓ ߪ (17) ୀଵ với ߪ ൌ ߪሺݖ ሻ, ߪ ሺሻ đạo hàm bậc k hàm sigmoid ߪ Hơn nữa, ta dễ dàng kiểm chứng [9] ߲ ఒభ ߲ ఒమ ఒ ఒ ߲ݔଵ భ ߲ݔଶ మ ǥ ߲ ఒ ఒ ߲ݔௗ ே (18) ሺஃሻ ܱ ൌ ߚ ܲ ߪ ఒ ୀଵ (19) ೖ với ܲ ൌ ςௗୀଵ ݓ ǡ Ȧ ൌ σௗୀଵ ߣ 3.3.2 Gradient ngõ xuất trọng số SLFN Dựa vào vế trái công thức (18) ta thấy đạo hàm ngõ xuất ܱđối với ngõ vào tương đương với mạng truyền thẳng lớp ẩn (SLFN) Ngõ xuất SLFN gọi ܱௗ với SLFN có trọng số kết nối từ lớp nhập đến nút ẩn thứ m ࢝ , độ dịch nút ẩn thứ m ܾ , trọng số kết nối nút ẩn thứ m đến ngõ xuất ሺஃሻ ሺஃሻ ߚ ܲ hàm truyền nút ẩn ߪ ǡnhư ܱௗ ൌ σே ୀଵ ߚ ܲ ߪ Khi từ cơng thức (18) ta có: ߲ܱௗ ሺஃሻ (20) ൌ ܲ ߪ ߲ߚ ߲ܱௗ ሺஃାଵሻ (21) ൌ ߚ ܲ ߪ ߲ܾ ߲ܱௗ ఒ ିଵ ሺஃାଵሻ ሺஃሻ ఒೖ ൌ ݔ ߚ ܲ ߪ ߚ ߣ ݓೕ ቌ ෑ ݓ ቍ ߪ ߲ݓ (22) ୀଵǡஷ 3.4 Các bước xác định nghiệm PDE NNM với điều kiện biên Dirichlet 3.4.1 Nghiệm phương trình Poisson sử dụng SLFN Để minh họa cho việc xác định nghiệm PDE NNM báo chọn phương trình Poisson hai chiều có dạng [9] : డమ ௨ሺ௫భ ǡ௫మ ሻ డమ ௨ሺ௫ ǡ௫ ሻ డ௫భమ మ డ௫భమ మ ൌ ݂ሺݔଵ ǡ ݔଶ ሻ, với ݔଵ אሾͲǡͳሿǡ ݔଶ אሾͲǡͳሿǡ (23) thoả điều kiện biên Dirichlet ݑሺͲǡ ݔଶ ሻ ൌ ݂ ሺݔଶ ሻǡ ݑሺͳǡ ݔଶ ሻ ൌ ݂ଵ ሺݔଶ ሻ, ݑሺݔଵ ǡ Ͳሻ ൌ ݃ ሺݔଵ ሻǡ ݑሺݔଵ ǡ ͳሻ ൌ ݃ଵ ሺݔଵ ሻ (24) Nghiệm NNM phương trình (23) xác định SLFN thỏa (24) có dạng [9]: ݑ௧ ሺݔଵ ǡ ݔଶ ǡ ࢃǡ ࢼሻ ൌ ܣሺݔଵ ǡ ݔଶ ሻ ݔଵ ሺͳ െ ݔଵ ሻݔଶ ሺͳ െ ݔଶ ሻܱሺݔଵ ǡ ݔଶ ǡ ࢃǡ ࢼሻǡ (25) © 2020 Trường Đại học Cơng nghiệp thành phố Hồ Chí Minh 28 GIẢI PHƯƠNG TRÌNH ĐẠO HÀM RIÊNG SỬ DỤNG MẠNG NEURAL NHÂN TẠO ዔܣሺݔଵ ǡ ݔଶ ሻ ൌ ሺͳ െ ݔଵ ሻ݂ ሺݔଶ ሻ ݔଵ ݂ଵ ሺݔଶ ሻ ሺͳ െ ݔଶ ሻሼ݃ ሺݔଵ ሻ (26) െ ሾሺͳ െ ݔଵ ሻ݃ ሺͲሻ ݔଵ ݃ ሺͳሻሿሽ ݕሼ݃ଵ ሺݔଵ ሻ െ ሾሺͳ െ ݔଵ ሻ݃ଵ ሺͲሻ ݔଵ ݃ଵ ሺͳሻሿሽ Để xác định nghiệm gần ݑ௧ ሺ࢞ǡ ࢃǡ ࢼሻ phương trình (23) tham sốࢃǡ ࢼ cần điều chỉnh cách huấn luyện SLFN cho hàm lỗi (27) đạt giá trị nhỏ ଵ ܧሺݔଵ ǡ ݔଶ ǡ ࢃǡ ࢼሻ ൌ ଶ σୀଵሼ డమ ௨ ሺ௫భ ǡ௫మ ሻ డమ ௨ ሺ௫భ ǡ௫మ ሻ െ డ௫భమ డ௫మమ với ሺݔଵ ǡ ݕଶ ሻ אሾͲǡͳሿሾͲǡͳሿ, డమ ௨ ሺ௫భ ǡ௫మ ሻ డ௫భమ డమ ௨ ሺ௫భ ǡ௫మ ሻ డ௫భమ ݂ሺݔଵ ǡ ݔଶ ሻሽଶ, ൌ (27) (28) ȁ௫భ ୀ௫భǡ௫మ ୀ௫మ, với n số mẫu huấn luyện mạng 3.4.2 Các bước xác định nghiệm NNM sử dụng thuật toán huấn luyện lan truyền ngược Bước Khởi tạo n mẫu ࢞ ൌ ሺݔଵ ǡ ݔଶ ሻ, j = 1,…,n Bước Khởi tạo giá trị ngẫu nhiên trọng số mạng neural ࢃǡ ࢼ Bước Tính giá trị ngõ xuất SLFN theo công thức (9) பாሺ௫భ ǡ௫మ ǡࢃǡࢼሻ பாሺ௫భ ǡ௫మ ǡࢃǡࢼሻ ǡ ப܅ பࢼ Bước Tính giá trị Bước Cập nhật vector trọng số mạng theo công thức (29) பாሺ௫భ ǡ௫మ ǡࢃǡࢼሻ ࢃ = ࢃିଵ - η , η hệ số học ିଵ ࢼ =ࢼ - ப܅ பாሺ௫భ ǡ௫మ ǡࢃǡࢼሻ ߠ பࢼ theo công thức (17), (20-22) , ߠ hệ số học (29) Wk , ࢼ k cập nhật trọng số bước lặp thứ k , ܧሺݔଵ ǡ ݔଶ ǡ ࢃǡ ࢼሻ hàm lỗi tính theo cơng thức (27) Bước Nếu ܧሺݔଵ ǡ ݔଶ ǡ ࢃǡ ࢼሻ< ߝ (ߝ số dương) nhảy đến Bước 7, ngược lại quay lại Bước Bước Thay trọng số tính Bước vào cơng thức (25) để tính nghiệm NNM phương trình (23) Bộ trọng số dùng kiểm tra để đánh giá nghiệm NNM so với nghiệm FDM phương trình (23) KẾT QUẢ THỰC NGHIỆM Trong phần minh họa cách xác định nghiệm NNM PDE thuật giải trình bày mục 3.32 so sánh với nghiệm FDM Lỗi nghiệm NNM xác định : Lỗi nghiệm NNM = Nghiệm giải tích – Nghiệm NNM Lỗi nghiệm FDM = Nghiệm giải tích – Nghiệm FDM (30) Xét phương trình PDE sau ߲ଶ߲ ݑଶݑ ൌͲ ߲ݔଵଶ ߲ݔଶଶ (31) với Ͳ ݔଵ ͳǡ Ͳ ݔଶ ͳ, với điều kiện biên Dirichlet ݑሺͲǡ ݔଶ ሻ ൌ ݔߨʹ݊݅ݏଶ ǡ ݑሺͳǡ ݔଶ ሻ ൌ Ͳ ݑሺݔଵ ǡ Ͳሻ ൌ ݔߨʹ݊݅ݏଵ ǡ ݑሺݔଵ ǡ ͳሻ ൌ Ͳ (32) Nghiệm giải tích phương trình (30) thỏa điều kiên biên Dirichlet (31): ͳ ሺሾʹߨሺͳ െ ݔଶ ሻሿ ݊ ݅ݏሺʹߨݔଵ ሻ ሾʹߨሺͳ െ ݔଵ ሻሿ ݊ ݅ݏሺʹߨݔଶ ሻ ʹߨ Dựa vào dạng nghiệm SLFN phương trình (25), nghiệm NNM (30) có dạng: ݑ௧ ሺݔଵ ǡ ݔଶ ǡ ࢃǡ ࢼሻ ൌ ܣሺ ͳݔǡ ʹݔሻ ݔଵ ሺͳ െ ݔଵ ሻݔଶ ሺͳ െ ݔଶ ሻܱሺ࢞ǡ ࢃǡ ࢼሻ ݑ ሺݔଵ ǡ ݔଶ ሻ ൌ Trong ܣሺݔଵ ǡ ݔଶ ሻ tính dự vào cơng thức (26) ܣሺݔଵ ǡ ݔଶ ሻ ൌ ሺͳ െ ݔଵ ሻݔߨʹ݊݅ݏଶ ሺͳ െ ݔଶ ሻݔߨʹ݊݅ݏଵ © 2020 Trường Đại học Cơng nghiệp thành phố Hồ Chí Minh (33) (34) (35) GIẢI PHƯƠNG TRÌNH ĐẠO HÀM RIÊNG SỬ DỤNG MẠNG NEURAL NHÂN TẠO 29 Hình 3: Nghiệm FDM phương trình (25) với điều kiên biên Dirichlet (26) Hình 4: Nghiệm NNM ݑ௧ ሺݔଵ ǡ ݔଶ ǡ ࢃǡ ࢼሻ phương trình (25) với điều kiên biên Dirichlet (26) © 2020 Trường Đại học Cơng nghiệp thành phố Hồ Chí Minh 30 GIẢI PHƯƠNG TRÌNH ĐẠO HÀM RIÊNG SỬ DỤNG MẠNG NEURAL NHÂN TẠO Hình 5: Lỗi nghiệm FDM nghiệm giải tích thuộc [-2.10-2, 5x10-3] Hình 5: Lỗi nghiệm NNM nghiệm giải tích ݑ ሺݔଵ ǡ ݔଶ ሻ െ ݑ௧ ሺݔଵ ǡ ݔଶ ǡ ࢃǡ ࢼሻthuộc [-1.5.10-4, 2.5.10-4] © 2020 Trường Đại học Cơng nghiệp thành phố Hồ Chí Minh GIẢI PHƯƠNG TRÌNH ĐẠO HÀM RIÊNG SỬ DỤNG MẠNG NEURAL NHÂN TẠO 31 Để xác định nghiệm gần phương trình (31-32) giải NNM sử dụng SLFN với 10 nút ẩn dựa thuật toán huấn luyện lan truyền ngược, tập huấn luyện cho SLFN chọn 121 điểm (bằng cách chia lưới [0,1]x[0,1] dọc theo ݔଵ ǡ ݔଶ ) Từ xác định trọng số (Wǡ ࢼ) SLFN xác định ݑ௧ ሺݔଵ ǡ ݔଶ ǡ ࢃǡ ࢼሻ Biểu đồ nghiệm FDM, nghiệm NNM, lỗi nghiệm giải tích so với FDM, lỗi nghiệm giải tích so với NNM thực nghiệm thể Hình 3, Hình 4, Hình 5, Hình tương ứng Dựa vào hình cho thấy lỗi nghiệm NNM PDE sử dụng NNM ݑ௧ ሺݔଵ ǡ ݔଶ ǡ ࢃǡ ࢼሻ so với nghiệm giải tích ݑ ሺݔଵ ǡ ݔଶ ሻthuộc đoạn [-1.5.10-4, 2.5.10-4] Dựa vào hình cho thấy lỗi nghiệm FDM PDE sử dụng FDM so với nghiệm giải tích ݑ ሺݔଵ ǡ ݔଶ ሻcó lỗi thuộc đoạn [-2.10-2, 5x10-3] Kết cho thấy nghiệm gần PDE giải NNM xác nghiệm gần giải FDM KẾT LUẬN Trong báo này, chúng tơi trình bày phương pháp NNM để giải phương trình Poisson hai chiều với điều kiện biên Dirichle sử dụng mạng truyền thẳng lớp ẩn với thuật toán huấn luyện mạng lan truyền ngược Các tham số SLFN cập nhật theo công thức (24) số bước lặp Với phương pháp sử dụng NNM nghiệm ݑ௧ ሺݔଵ ǡ ݔଶ ǡ ࢃǡ ࢼሻ cho kết xác so với phương pháp FDM Các tham số cần tìm NNM nhiều so với việc tính giá trị nút lưới lưới sai phân sử dụng FDM u cầu nhớ tính tốn hẳn so với FDM [10] Phương pháp NNM để giải PDE có dạng nghiệm tổng quát áp dụng cho phương trình vi phân, hệ phương trình vi phân PDE dạng khác [9] Hướng phát triển nghiên cứu sử dụng mạng tích chập (convolutional neural network) để giải PDE nhằm tăng độ xác nghiệm PDE sử dụng mạng học sâu (deep learning) để giải dạng PDE bậc cao LỜI CẢM ƠN Bài báo thực với hỗ trợ từ quỹ đề tài nghiên cứu khoa học trường đại học Công nghiệp TP HCM, mã số 182.CNTT01/HD-DHCN TÀI LIỆU THAM KHẢO [1] Ricardo, H.J., A modern introduction to differential equations2009: Academic Press [2] Boyce, W.E., R.C diprima, and D.B Meade, Elementary differential equations and boundary value problems Vol 1992: Wiley New York [3] Smith, G.D., Numerical solution of partial differential equations: finite difference methods1985: Oxford university press [4] Dill, E.H., The finite element method for mechanics of solids with ANSYS applications2011: CRC press [5] Demuth, H., M Beale, and M Hagan, MATLAB User’s Guide, version 4.0: Neural network toolbox Mathworks Inc.: Natick, MA, USA, 2005 [6] Shirvany, Y., M Hayati, and R Moradian, Multilayer perceptron neural networks with novel unsupervised training method for numerical solution of the partial differential equations Applied Soft Computing, 2009 9(1): p 20-29 [7] Huang, G.-B And H.A Babri, Upper bounds on the number of hidden neurons in feedforward networks with arbitrary bounded nonlinear activation functions IEEE Transactions on Neural Networks, 1998 9(1): p 224229 [8] Thomas, J.W., Numerical partial differential equations: finite difference methods Vol 22 2013: Springer Science & Business Media [9] Lagaris, I.E., A Likas, and D.I Fotiadis, Artificial neural networks for solving ordinary and partial differential equations IEEE transactions on neural networks, 1998 9(5): p 987-1000 © 2020 Trường Đại học Công nghiệp thành phố Hồ Chí Minh 32 GIẢI PHƯƠNG TRÌNH ĐẠO HÀM RIÊNG SỬ DỤNG MẠNG NEURAL NHÂN TẠO [10] Rudd, K., G Di Muro, and S Ferrari, A constrained backpropagation approach for the adaptive solution of partial differential equations IEEE transactions on neural networks and learning systems, 2014 25(3): p 571584 Ngày nhận bài: 03/05/2019 Ngày chấp nhận đăng: 20/06/2019 © 2020 Trường Đại học Cơng nghiệp thành phố Hồ Chí Minh ... hữu hạn Chọn số tự nhiên M>0 Chia miền ȳ thành ô lưới sau: ି Chia đoạn [a,b] thành M đoạn M+1 điểm chia có tọa độ ݔଵ ൌ ܽ ሺ݅ െ ͳሻ݄ଵ , ݄ଵ ൌ ெ độ dài đoạn chia, với i : Ỉ M+1 © 2020 Trường... ĐẠO HÀM RIÊNG SỬ DỤNG MẠNG NEURAL NHÂN TẠO 25 Chia đoạn [c,d] thành M đoạn M+1 điểm chia có tọa độ ݔଶ ൌ ܿ ሺ݅ െ ͳሻ݄ଶ , ݄ଶ ൌ ௗି ெ độ dài đoạn chia Mỗi điểm ൫ݔଵ ǡ ݔଶ ൯tương ứng với... kiện biên Dirichlet 3.4.1 Nghiệm phương trình Poisson sử dụng SLFN Để minh họa cho việc xác định nghiệm PDE NNM báo chọn phương trình Poisson hai chi? ??u có dạng [9] : డమ ௨ሺ௫భ ǡ௫మ ሻ డమ ௨ሺ௫ ǡ௫ ሻ