Luận án Nghiên cứu xây dựng mô hình toán mô phỏng dõng chảy và vận chuyển bùn cát trên lưu vực vừa và nhỏ

Lƣu vực Phiêng Hiềng có 2 hệ thống núi chính chạy qua: Hệ thống núi tả ngạn sông Đà và hệ thống núi thấp xen kẽ, hầu hết các dãy núi trong tiểu vùng đều thấp dần theo hƣớng Tây Bắc - Đông Nam. - Hệ thống núi tả ngạn sông Đà: Ranh giới giữa Sơn La và Yên Bái, bắt nguồn từ Nậm Khan (Quỳnh Nhai) có độ cao 1.130m, chạy qua Mƣờng La, Bắc Yên đến Phù Yên với các đỉnh cao từ 1.000m đến 2.500m, hình thành lƣu vực tả ngạn sông Đà. - Hệ thống núi thấp xen kẽ: Tập trung chủ yếu tại các xã Hồng Ngài, thị trấn Bắc Yên, xã Suối Bau, xã Đá Đỏ, các đỉnh núi cao từ 1.000m đến 1.500m.

pdf157 trang | Chia sẻ: tueminh09 | Lượt xem: 477 | Lượt tải: 0download
Bạn đang xem trước 20 trang tài liệu Luận án Nghiên cứu xây dựng mô hình toán mô phỏng dõng chảy và vận chuyển bùn cát trên lưu vực vừa và nhỏ, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
hấp nhất dao động trong khoảng 160 - 210g/m3. 3.2.2.7. Yêu cầu số liệu đầu vào mô hình - Số liệu về khí tƣợng thủy văn của lƣu vực các năm 1973, 1976 bao gồm các số liệu mƣa (giờ), nhiệt độ, bốc hơi tại trạm Phù Yên và số liệu lƣu lƣợng dòng 101 chảy (giờ), lƣu lƣợng bùn cát (giờ) tại trạm Phiêng Hiềng. - Số liệu về tình hình sử dụng đất, về loại đất trên lƣu vực Phiêng Hiềng. - Các bản đồ địa hình, bản đồ mạng lƣới sông suối, lƣới trạm khí tƣợng thủy văn, bản đồ thổ nhƣỡng, bản đồ sử dụng đất. Hình 3-21. Các tiểu lưu vực của Phiêng Hiềng 102 - Sử dụng công cụ GIS để phân chia lƣu vực thành các tiểu lƣu vực khác nhau. Lƣu vực Phiêng Hiềng đƣợc chia thành 94 tiểu lƣu vực. Với mỗi tiểu lƣu vực xác định đƣợc: Diện tích, độ dốc v.v... Chi tiết về đặc tính của từng tiểu lƣu vực đƣợc thể hiện ở hình 3-21 và bảng 2 phần phụ lục. 3.2.2.8. Hiệu chỉnh, kiểm định mô hình 1. Hiệu chỉnh mô hình Sau khi thiết lập đƣợc mô hình, tác giả chọn trận lũ tháng 8/1973 để hiệu chỉnh bộ thông số của mô hình. Trong quá trình hiệu chỉnh luôn so sánh kết quả tính toán lƣu lƣợng dòng chảy và lƣu lƣợng bùn cát với số liệu thực đo để hiệu chỉnh bộ thông số của mô hình. Tiến hành hiệu chỉnh và so sánh tới khi nào đƣờng biểu diễn thực đo và đƣờng biểu diễn tính toán phù hợp cả về dạng đƣờng và đỉnh thì khi đó bộ thông số tìm đƣợc là đạt và có thể sử dụng để tính toán lƣu lƣợng dòng chảy và lƣu lƣợng bùn cát cho những năm không có số liệu thực đo. Kết quả hiệu chỉnh mô hình đƣợc thể hiện ở hình sau và bộ thông số của mô hình: STT Bộ thông số mô hình Giá trị 1 Hệ số xói mòn tách rời liên rãnh (ail) 5,3 e-05 2 Hệ số khả năng xói mòn đất (ket) 1,12 3 Hệ số vận chuyển bùn cát liên rãnh (acl) 2,5 e-04 4 Hệ số xói mòn rãnh (Ci) 0.321 5 Hệ số vận chuyển bùn cát rãnh (ac) 1.05 103 Hình 3-22. Đường quá trình lưu lượng tính toán và thực đo Hình 3-23. Đường quá trình hàm lượng bùn cát tính toán và thực đo 104 2. Kiểm định mô hình Dùng bộ thông số của mô hình đã đƣợc hiệu chỉnh với trận lũ 1973 để kiểm định mô hình với trận lũ 1976. Kết quả mô phỏng đƣờng quá trình lƣu lƣợng dòng chảy, hàm lƣợng bùn cát tính toán và thực đo tiệm cận nhau, đƣợc thể hiện ở hình: Hình 3-24. Đường quá trình lưu lượng tính toán và thực đo Hình 3-25. Đường quá trình hàm lượng bùn cát tính toán và thực đo 105 Kết quả tính toán hiệu chỉnh thông số của mô hình tính toán lƣu lƣợng dòng chảy lũ cho lƣu vực Phiêng Hiềng cho hệ số Nash đạt 83%, chênh lệch đỉnh lũ tính toán và thực đo là 16 m3/s. 3.2.3. Xây dựng phƣơng trình tƣơng quan 3.2.3.1. Phân tích độ nhạy của các thông số mô hình 1. Phương pháp phân tích độ nhạy các thông số Phân tích độ nhạy là sự nghiên cứu mối quan hệ giữa thông tin vào và ra của mô hình. Độ nhạy có thể tính toán bằng nhiều phƣơng pháp hay phân tích định tính hoặc định lƣợng. Có thể kể đến một số công trình phân tích độ nhạy nhƣ [18, 65]. Để phân tích độ nhạy các thông số trong mô hình toán, ngƣời ta đƣa ra khái niệm véc tơ ứng với mỗi thông số (ví dụ véc tơ x nhận các giá trị trong khoảng a  b, ta viết x[a,b]. Số lƣợng các trị nhân tố thuộc [a,b] nhiều hay ít tùy thuộc yêu cầu độ chính xác của phƣơng pháp. Giả sử có véc tơ x[a,b], dùng phƣơng pháp Monte - Carlo [66] để lấy ngẫu nhiên các giá trị nhân tố x k theo một hàm mật độ xác suất nhất định. Ứng với mỗi giá trị nhân tố x k, ngƣời ta sẽ nhận đƣợc một giá trị kết quả tính toán của mô hình, các giá trị của các hàm chỉ tiêu (ví dụ hàm Nash) đƣợc tính toán để so sánh giữa kết quả tính toán và giá trị quan trắc. Sắp xếp theo chiều giảm dần các giá trị của hàm chỉ tiêu, các giá trị x k đƣợc thay đổi theo. Các giá trị phân phối xác suất của x k đƣợc chia thành hai phần: Phần thứ nhất là tập hợp các giá trị “tốt” (A), phần thứ hai là tập hợp giá trị “không tốt” (B). Độ nhạy của thông số đang xét đƣợc đánh giá theo khoảng cách lớn nhất ,c cm nd theo phƣơng đứng của hai đƣờng phân phối xác suất. Giá trị tính toán của ,c cm nd sẽ so sánh với giá trị tiêu chuẩn, khi 106 ,c cm n d tính toán ≥ ,c cm nd tiêu chuẩn thì thông số x đang xét sẽ ảnh hƣởng nhiều đến kết quả tính toán của mô hình, ngƣợc lại sẽ không ảnh hƣởng nhiều. Giá trị tiêu chuẩn đƣợc tính theo công thức sau: , _ .c c c c m n tieu chuan c c m n d m n    (3-1) trong đó  là hệ số phụ thuộc vào mức độ chính xác để lấy giá trị chỉ số lƣợng tính toán “tốt” hay “không tốt”. Trên cơ sở so sánh giữa kết quả tính toán của mô hình và giá trị quan trắc thực tế, các giá trị thống kê đƣợc gán cho mỗi thông số. Thông qua các giá trị thống kê đƣợc tính thông qua các hàm tiêu chuẩn nhƣ hàm Nash. Với tập hợp các giá trị (giá trị khả dĩ) hàm tiêu chuẩn của các thông số, chúng ta có thể phân tích độ nhạy của mỗi thông số trong cùng một mô hình tính toán. 2. Kết quả phân tích độ nhạy các thông số Có nhiều thông số tham gia vào quá trình hình thành vận chuyển bùn cát trên lƣu vực vừa và nhỏ mà đã đƣợc mô hình hóa thông qua mô hình mô phỏng vận chuyển bùn cát trên lƣu vực. Phƣơng pháp phân tích độ nhạy có thể chỉ ra đƣợc thông số nào có vai trò quan trọng trong mô hình, thông số nào không quan trọng. Luận án phân tích độ nhạy tổ hợp các thông số: Cƣờng độ mƣa, hệ số xói mòn bong tách liên rãnh, độ dốc lƣu vực, mật độ rãnh, độ che phủ đất và khả năng xói mòn của đất. Kết quả phân tích độ nhạy của các thông số thể hiện nhƣ trên hình vẽ sau: 107 Hình 3-26. Đường biểu diễn kết quả khi thay đổi thông số mô hình Qua phân tích kết quả mô phỏng độ nhạy các thông số mô hình cho thấy, cƣờng độ mƣa ảnh hƣởng lớn nhất đến sự vận chuyển bùn cát trên lƣu vực. Cƣờng độ mƣa càng lớn thì mức vận chuyển bùn cát trên lƣu vực càng cao. Tiếp theo là 108 thông số độ dốc lƣu vực. Nếu độ dốc lƣu vực tăng lên 30% thì lƣợng bùn cát trên lƣu vực tăng lên khoảng 12%. Nhƣ vậy độ dốc càng lớn thì xói mòn mặt càng lớn và ngƣợc lại. Độ dốc càng lớn thì yêu cầu đối với cấu trúc thảm thực vật rừng phòng hộ càng cao. Nếu giảm độ tàn che từ 0,7 - 0,8 xuống mức 0,3 - 0,4 thì xói mòn đất sẽ tăng lên 42,2% và dòng chảy mặt tăng 30,4%. Tác giả đã thay đổi tỷ lệ che phủ của lƣu vực, từ đó chỉ ra độ che phủ càng cao thì bùn cát càng giảm, khả năng giữ nƣớc và đất càng tốt. 3.2.3.2. Phân tích tƣơng quan giữa xói mòn liên rãnh trên lƣu vực với độ dốc và cƣờng độ mƣa Lƣợng đất bị xói mòn liên rãnh trên lƣu vực là hàm số của cƣờng độ mƣa và độ dốc lƣu vực. Thử nghiệm tính toán với các cƣờng độ mƣa khác nhau trên lƣu vực Phiềng Hiềng và lƣu vực Nậm Sập cho ta kết quả tính toán xói mòn liên rãnh trên lƣu vực. Phƣơng trình cơ bản cho sự bong tách liên rãnh có dạng tổng quát nhƣ sau: Ei= a.i 2 .Io b (3-2) trong đó: a, b : Hệ số trong phƣơng trình tƣơng quan i : Cƣờng độ mƣa (mm/h) Io : Độ dốc lƣu vực (%). Kết quả phân tích tƣơng quan giữa xói mòn liên rãnh trên lƣu vực với độ dốc và cƣờng độ mƣa đƣợc chỉ ra trong hình vẽ sau: 109 Hình 3-27. Tương quan giữa xói mòn liên rãnh với độ dốc và cường độ mưa 110 Từ kết quả tính tác giả toán xây dựng đƣợc phƣơng trình cơ bản cho sự bong tách liên rãnh trên lƣu vực vừa và nhỏ thuộc tỉnh Sơn La dựa trên số liệu tính toán nhƣ sau: 2 1,60,0002i oE i I   (3-3) trong đó: i : Cƣờng độ mƣa (mm/h) I0 : Độ dốc lƣu vực (%). Nhƣ vậy với kết quả trên, trên cơ sở bản đồ địa hình lƣu vực, xác định đƣợc độ dốc lƣu vực tại các tiểu lƣu vực, khi có cƣờng độ mƣa, ta sẽ xác định đƣợc lƣợng đất bị xói mòn liên rãnh trên lƣu vực, từ đó đƣa ra các giải pháp để chống xói mòn, giảm thiểu vận chuyển bùn cát trên lƣu vực. 3.2.3.3. Phân tích tƣơng quan giữa xói mòn rãnh trên lƣu vực với độ dốc và cƣờng độ mƣa Lƣợng bùn cát xói mòn rãnh trên lƣu vực là hàm số của cƣờng độ mƣa và độ dốc lƣu vực. Thử nghiệm tính toán với các cƣờng độ mƣa khác nhau trên lƣu vực cho ta kết quả tính toán xói mòn rãnh trên lƣu vực. Phƣơng trình cơ bản cho xói mòn rãnh có dạng tổng quát nhƣ sau: Er = c.i 2 .Io d (3-4) trong đó: c, d : Hệ số trong phƣơng trình tƣơng quan i : Cƣờng độ mƣa (mm/h) I0 : Độ dốc lƣu vực (%). Kết quả phân tích tƣơng quan giữa xói mòn rãnh trên lƣu vực với độ dốc và cƣờng độ mƣa đƣợc chỉ ra trong hình vẽ sau: 111 Hình 3-28. Tương quan giữa xói mòn rãnh với độ dốc và cường độ mưa Từ kết quả tính toán tác giả xây dựng đƣợc phƣơng trình cơ bản xói mòn rãnh trên lƣu vực vừa và nhỏ thuộc tỉnh Sơn La dựa trên số liệu tính toán nhƣ sau: 1,670,00082 r o E i I   (3-5) 112 Từ bản đồ địa hình lƣu vực, xác định đƣợc độ dốc lƣu vực tại các tiểu lƣu vực, khi có cƣờng độ mƣa, ta sẽ xác định đƣợc lƣợng đất bị xói mòn rãnh trên lƣu vực dựa vào phƣơng trình 3-5, từ đó đƣa ra các giải pháp để chống xói mòn, giảm thiểu vận chuyển bùn cát trên lƣu vực. Kết luận chƣơng 3 Tác giả chọn hai lƣu vực để kiểm tra độ tin cậy của mô hình, kết quả cho thấy các đƣờng biểu diễn dòng chảy và đƣờng biểu diễn vận chuyển bùn cát trên hai lƣu vực giữa tính toán và thực đo tiệm cận nhau. Ngoài ra, tác giả xây dựng đƣợc phƣơng trình tƣơng quan giữa xói mòn liên rãnh với độ dốc và cƣờng độ mƣa, phƣơng trình tƣơng quan giữa xói mòn rãnh với độ dốc và cƣờng độ mƣa dựa trên quá trình phân tích độ nhạy của các thông số. 113 KẾT LUẬN VÀ KIẾN NGHỊ Các kết quả nghiên cứu của luận án trong việc nghiên cứu cơ sở khoa học xây dựng mô hình toán mô phỏng quá trình vận chuyển bùn cát trên lƣu vực vừa và nhỏ, áp dụng cho các lƣu vực miền núi phía Bắc thuộc tỉnh Sơn La trên quan điểm tiếp cận quá trình vật lý của quá trình vận chuyển bùn cát với các phƣơng pháp và công cụ tính toán tiên tiến, đặc biệt là việc giải phƣơng trình toán học, kết hợp với việc lập trình bằng ngôn ngữ C++ đã rút ra một số kết luận nhƣ sau: - Trên cơ sở tổng quan các mô hình mô phỏng quá trình vận chuyển bùn cát trên lƣu vực vừa và nhỏ đang đƣợc áp dụng trên thế giới và ở Việt Nam, trong điều kiện các lƣu vực có địa hình dốc, việc lựa chọn ngôn ngữ C++ làm công cụ để mô phỏng quá trình vận chuyển bùn cát trên lƣu vực vừa và nhỏ là hợp lý, thích hợp trong điều kiện hiện nay, xây dựng công cụ Để mô phỏng và phát triển công nghệ tính toán dòng chảy bùn cát trên lƣu vực vừa và nhỏ là có cơ sở khoa học. - Sơn La là tỉnh miền núi phía Bắc có địa hình dốc nên nguy cơ xảy ra xói mòn, thoái hóa đất do vận chuyển bùn cát bề mặt lƣu vực là lớn, các yếu tố ảnh hƣởng đến việc vận chuyển bùn cát trên lƣu vực gồm mƣa, thảm phủ thực vật, độ dốc, loại đất và các hoạt động khai thác của con ngƣời. Các yếu tố tạo nguồn vật chất cho việc vận chuyển bùn cát bề mặt lƣu vực là do thổ nhƣỡng. - Nghiên cứu lý luận và thực nghiệm số các sơ đồ giải bằng phƣơng pháp sai phân Lax - Friedrichs về quy mô không gian và thời gian nhằm nâng cao độ chính xác và độ ổn định của mô hình tính toán, có độ ổn định cao nhất. - Việc vận dụng mô hình tính toán mô phỏng vận chuyển bùn cát trên lƣu vực cho thấy mƣa là yếu tố chính gây nên vận chuyển bùn cát trên lƣu vực. Độ dốc là nhân tố quan trọng ảnh hƣởng đến xói mòn và dòng chảy mặt. Độ dốc càng lớn thì 114 xói mòn mặt càng lớn và ngƣợc lại. Nếu độ dốc lƣu vực tăng lên 30% thì lƣợng bùn cát bị cuốn trôi trên lƣu vực tăng lên khoảng 12%. - Từ lƣợng mƣa và độ dốc trên lƣu vực, thông qua phƣơng trình tƣơng quan giữa xói mòn rãnh, liên rãnh với lƣợng mƣa và độ dốc, có thể tính toán đƣợc lƣợng xói mòn rãnh và liên rãnh, từ đó tính đƣợc lƣợng bùn cát vận chuyển đến cửa ra của lƣu vực. Những đóng góp mới của luận án: - Xây dựng đƣợc mô hình toán mô phỏng xói mòn và vận chuyển bùn cát trên lƣu vực vừa và nhỏ, với thuật toán sơ đồ sai phân Lax - Friedrichs có thêm trọng số thời gian, không gian để giải phƣơng trình dòng chảy và phƣơng trình vận chuyển bùn cát trên lƣu vực. - Xây dựng đƣợc phƣơng trình tƣơng quan giữa tính toán xói mòn liên rãnh, xói mòn rãnh trên lƣu vực nghiên cứu: Lƣu vực Nậm Sập, lƣu vực Phiêng Hiềng của tỉnh Sơn La, từ đó có thể dự báo lƣợng bùn cát bị xói mòn và vận chuyển trên lƣu vực theo cƣờng độ mƣa. Kiến nghị: Việc tính toán mô phỏng vận chuyển bùn cát trong sông mới tính dựa trên cân bằng bùn cát, tính toán cho hạt bùn cát đồng nhất. Vì vậy trong thời gian tới cần tiếp tục nghiên cứu tính toán cho xói mòn đáy và xói mòn bờ. Việc thử nghiệm mô hình mới chỉ trên hai lƣu vực nghiên cứu thuộc tỉnh Sơn La, cần tiếp tục hoàn thiện mô hình, nghiên cứu thử nghiệm cho các lƣu vực khác. Cần kết nối công nghệ GIS để thiết lập mô hình trên cơ sở mô phỏng địa hình chi tiết của lƣu vực, nhƣ vậy sẽ tăng mức độ chính xác của mô hình. 115 DANH MỤC CÁC CÔNG TRÌNH CỦA TÁC GIẢ ĐÃ CÔNG BỐ 1. Đào Tấn Quy và Phạm Thị Hƣơng Lan. “Xây dựng bản đồ hiểm họa trƣợt lở đất tỉnh Sơn La”. Tạp chí khoa học kỹ thuật Thủy Lợi và Môi trường. Số 51 T12/2015). 2. Đào Tấn Quy. “Xây dựng mô hình toán mô phỏng quá trình vận chuyển bùn cát trên lƣu vực vừa và nhỏ. (Áp dụng cho lƣu vực suối Sập tỉnh Sơn La)”. Tạp chí Khí tượng thủy văn. Số 657 T9/2015. 3. Đào Tấn Quy. “Xây dựng mô đun tính toán dòng chảy trong mô hình mô phỏng quá trình vận chuyển bùn cát trên lƣu vực vừa và nhỏ (Áp dụng cho lƣu vực suối Sập tỉnh Sơn La)”. Tạp chí Khoa học kỹ thuật Thủy Lợi và Môi trường. Số 48 T3/2015. 4. Đào Tấn Quy, Trần Kim Châu, Phạm Thị Hƣơng Lan và Nguyễn Thế Toàn. “Ứng dụng hệ thông tin địa lý và quá trình phân tích cấp bậc để tiến hành xây dựng bản đồ hiểm họa trƣợt lở đất tỉnh Sơn La”. Hội nghị khoa học thường niên ĐHTL năm 2014. Trang 474- 476. 5. Đào Tấn Quy và Phạm Thị Hƣơng Lan. “Nghiên cứu cơ sở lý thuyết xây dựng mô hình toán mô phỏng vận chuyển bùn cát trên lƣu vực vừa và nhỏ”. Hội nghị khoa học thường niên ĐHTL năm 2013. Trang 175- 177. 6. Đào Tấn Quy và Phạm Thị Hƣơng Lan. “Nghiên cứu phân tích lựu chọn ngôn ngữ phần mềm mô hình toán mô phỏng dòng chảy và vận chuyển bùn cát trên lƣu vực vừa và nhỏ”. Tạp chí Khoa học kỹ thuật Thủy Lợi và Môi trường. Số 40 T3/2013. 116 TÀI LIỆU THAM KHẢO [1] Đinh Văn Hùng., Ứng dụng Viễn thám và GIS đánh giá xói mòn đất khu vực Yên Châu tỉnh Sơn La. Luận văn Thạc sĩ Khoa học, ĐHQG Hà Nội, 2009. [2] Ellison W. D., Studies of raindrop erosion. Agricultural Engineering 25, p 181-182, 1944. [3] FAO., The digital soil map of the world and derived soil properties. CDROM Version 3.5. Rome, 1994. [4] Hudson., Soil Conservation. London, Batsford, 1979. [5] Cao Đăng Dƣ., Đánh giá tốc độ xói mòn lưu vực sông Hồng theo lượng bùn cát trong sông. Báo cáo hội thảo khoa học, 2000. [6] Nguyễn Tử Xiêm và Thái Phiên., Cơ sở khoa học kỹ thuật về canh tác đất dốc . Tài liệu hội thảo khoa hoc̣ “Sƣ̉ duṇg đất và bảo vệ rừng”, 1996. [7] Bengt Carlsson., An introduction to sedimentation theory in wastewater treatment. System and Control Group Uppsala University, 1998. [8] Nguyễn Trọng Hà., Xác định các yếu tố gây xói mòn và khả năng dự báo xói mòn trên đất dốc. Luận án Phó Tiến sĩ KH-KT, Trƣờng Ðại học Thủy lợi. Hà Nội, 1996. [9] Phạm Ngọc Dũng., Nghiên cứu một số biện pháp chống xói mòn trên đất đỏ bazan trồng chè vùng Tây nguyên và xác định giá trị của các yếu tố gây xói mòn đất theo mô hình Wischmeier W. H and Smith D.D. Luận án Phó tiến sĩ khoa học Nông nghiệp. Hà Nội, 1991. [10] Nguyễn Văn Dũng, Nguyễn Văn Dũng, Nguyễn Đình Kỳ., Đánh giá định lượng xói mòn đất đồi núi vùng Thanh - Nghệ - Tĩnh bằng phương trình mất 117 đất phổ dụng và hệ thống thông tin địa lý. Tạp chí các khoa học về trái đất, NXB Viện KH&CN Việt Nam, tập 34, số 1, tr. 31 – 37, 2012. [11] Phạm Hùng., Nghiên cứu ứng dụng kỹ thuật mô hình toán trong tính toán xói mòn lưu vực ở Việt Nam. Luận án tiến sĩ kỹ thuật, Trƣờng Ðại học Thủy lợi. Hà Nội, 2001. [12] Nguyễn Văn Khiết., Nghiên cứu đặc điểm xói mòn mặt khởi đầu dưới một số thảm thực vật tại Lương Sơn - Hòa Bình. Luận văn thạc sỹ khoa học lâm nghiệp, Đại học Lâm nghiệp, 2009. [13] Phạm Hữu Tỵ và Hồ Kiệt., Mô phỏng rủi ro xói mòn vùng cảnh quan đồi núi trên cơ sở sử dụng số liệu viễn thám và mô hình mất đất phổ quát hiệu chính (RUSLE). Tạp chí khoa học đại học Huế số 48, 2008. [14] ASCE., Sediment Transportation Mechanics: Introduction and Properties of Sediment. ASCE. Journal of the Hydraulics Division, 1975. [15] Rattan Lal., Soil erosion in the tropics. Principles and management, 1990. [16] MacDonald L., Tài liệu tập huấn về thủy văn và quản lý lưu vực. Trƣờng Đại học Lâm Nghiệp, 2009. [17] Hudson., Bảo vệ đất và chống xói mòn (Đào Trọng Năng và Nguyễn Kim Dung dịch). NXB Khoa học kỹ thuật. Hà Nội, 1981. [18] Iman R. L and Helton J. C., An investigation of uncertainty and sensitivity analysis techniques for computer models. Risk Analysis, 8 (1), 71-90, 1988. [19] Nguyễn Văn Dũng và Trần Đức Viên., Ảnh hưởng của mưa và một số phương thức sử dụng đất đến xói mòn đất và thu nhập của người dân ở vùng đất dốc Tân Minh - Đà Bắc - Hoà Bình. Tạp chí Nông nghiệp và PTNT, Kỳ 1 tháng 12, Tr 36-38, 2003. [20] Trần Quốc Vinh., Nghiên cứu sử dụng viễn thám RS và hệ thống thông tin địa lý GIS để đánh giá xói mòn đất huyện Tam Nông tỉnh Phú Thọ. Luận án tiến sỹ nông nghiệp, 2012. 118 [21] Trƣơng Văn Cảnh., Nghiên cứu ảnh hưởng xói mòn đất của lưu vực sông Cu Đê đến sản xuất nông nghiệp. Đề tài cấp bộ Mã số: Đ2013-03-46-BS, 2014. [22] Lane and Nearing., Profil Model documentation. USDA Water Erosion Prediction project (WEEP) NSERL report NO. 2. Nation Soil erosion Laboratory, USDA- ARS. W. Lafayette. IN, 1989. [23] Rendon and Herredo., Unit sediment graph, 1978. [24] Schramm., Ein Erosionsmodell mit räumlich und zeitlich veränderlicher Rillenmorphologie. Mitteilung des Instituts für Wasserbauund Kulturtechnik, Universität Fridericana zu Karlsruhe, Heft 190, 1994. [25] Wischmeier W. H and Smith D. D., Relation of soil properties to its erodibility. Soil Science Society of America Proc. 33(1), 131-137, 1960. [26] Bennett., Concepts of mathematical modeling of sediment yield. Water Resources Research . Vol. 10, No. 3, June, p. 485-492, 1974. [27] CREAMS., Modeling developed coastal watersheds with theagricultural non- point source mode, 1980. [28] Croley T. E. II., Unsteady overland sedimentation. Journal of Hydrology, Elsevier, 56, 325-346, 1982. [29] Baver L. D., Soil Sci. Soc. Am. Proc. 3, 330 – 333, 1939. [30] Laws J. O., Measurements of the fall-velocity of water-drops and raindrops. Transactions, American Geophysical Union 22, 1941. [31] Zingg A. W., Degree and Length of Land Slope as it Affects Soil Loss in Runoff. Agric. Eng., 21(2), 59-64, 1940. [32] Nguyễn Văn Khiết., Nghiên cứu xác định vai trò của một số yếu tố liên quan đến xói mòn đất ở nước ta. Tạp chí khoa học Lâm nghiệp, Viện KH Lâm Nghiệp Việt Nam, 1, trang 3145 - 3153, 2014. 119 [33] Ellison W. D., Soil erosion studies. AGRICULTURAL ENGINEERING 28: 145-146, 197-201, 245-248, 297-300, 349-351, 402-405, 1947. [34] Musgrave., The causes and effects of sedimentation in lake Decatur. State Water Survey Division, 1947. [35] Smith D. D., A parameter-efficient hydrologic infiltration model. Water Resources Research 14 (3), 533 – 538, 1941. [36] Wischmeier, W. H and Smith D. D., Predicting rainfall erosion losses. A guide to conservation planning, agricultural Handbook No 537, US Dep. Of Agri. Washington, D. C, 1978. [37] Brown, L. C and Foster G. R., Storm erosivity using idealized intensity distributions. Trans. ASAE, 30, 379-386, 1987. [38] Renard K. G and Freimund J. R., Using monthly precipitation data to estimate the R-factor in the revised USLE. Journal of Hydrology, 157, 287–306, 1994. [39] Chu Đình Hoàng., Tác dụng xói mòn của đất giọt mưa. Kỹ thuật Thủy Lợi, số 5, 1963. [40] Williams J. R., Sediment Yield Predicting with Universal Equation Using Runoff Energy Factor. Present and Prospective Technology for Predicting Sediment Yield and Sources, USDA, ARS-S-40, 1975. [41] ANSWERS., A model for watershed planning. Transaction of the ASAE, Vol. 23, No. 4, p. 938-944, 1980. [42] AGNPS., Modelling sediment yield from agricultural watersheds. J. Soil Water Conserv., 37, p.113-117, 1980. [43] KINEROS., A kinematic runoff and erosion model. U. S. Department of Agriculture, Agricultural Research Service. ARS-77, 130 pp. In: Arnold, J.G., Srinivasan, R., Muttiah, R. S., Williams J. R., 1998. Large area hydrologic 120 modeling and assessment Part I: Modeldevelopment. Journal of American Water Resources Association 34 (1), 73–89, 1981. [44] Woolhiser et al., KINEROS, a kinematics runoff and erosion model. Documentation and user manual – U.S Dept. Of Agriculture, Agri. Res. Service ARS - 77, March, 1990. [45] WEPP., USDA – Water Erosion Prediction Project. Hillslope profile and watershed model documentation NSERL Rep. No. 10, USDA – ARS, West Lafayette, Indiana, 1995. [46] Foster and Meyer L. D., A closed- form soil erosion equation for upland areas. In: H.W. Shen (editor and publisher) sedimentation (Einstein) Colorado State University, Fort Colling, CO. Kapitel 12, 1972. [47] Morgan R. P. C., Quinton, J. N., Smith, R. E., Govers, G., Poesen, J. W. A., Auerswald, K., Chisci, G., Torri, D., Styczen, M. E., Folly, A. J. V., The European soil erosion modell (EUROSEM): documentation and user guide. Silsoe College, Cranfield University, 1998. [48] Morgan P. C., Soil erosion modelling with EUROSEM at Embori and Mukogodo catchments. Kenya, 2006. [49] Nguyễn Quang Mỹ., Xói mòn đất hiện đại và các biện pháp chống xói mòn. NXB Đại Học Quốc Gia, 2005. [50] Lại Vĩnh Cẩm., Soil erosion study in North West region of Viet Nam by intergrating waterhed analysis and universal soil loss equantion (USLE). Tạp chí khoa học ĐHQG HN, KHTN số XI, 2000. [51] Lê Mạnh Hùng và nnk., Kết quả ứng dụng mô hình SWAT trong tính toán xói mòn lưu vực Mekong. Tạp chí khoa học công nghệ và thủy lợi số 12, 2012. [52] Han F. et al., The WEPP Model Application in a Small Watershed in the Loess Plateau. 2016. 121 [53] Hunink J. E. et al., Targeting of intervention areas to reduce reservoir sedimentation in theTana catchment (Kenya) using SWAT. 2013. [54] Woolhiser D. A and J. A. Liggett., Unsteady, one dimensional flow over a plane – the rising hydrograph. Water Resources Research 3, 753-761, 1967. [55] Foster et al., Modeling the erosion process. Chapter 8. In: Hydrologic modeling of small watersheds, edited by C. T. Haan et al,. ASAE Monograph No. 5, 1981. [56] Rezzolla, L., Numerical methods for the solution of partial differential equations. Lecture notes for the COMPSTAR School of Computational Astrophysics, 8-13/02/2010. Caen, France, 2011. [57] Kibler, D. F and Woolhiser, D. A., The kinematic cascade as a hydrologic model. Hydrology Paper No. 39, Colorado State University, Fort Collins, Colorado, USA, 1970. [58] Einstein H. A., Deposition of Suspended Particles in a Gravel Bed, Jour. Hydraulics Division, American Society of Civil Engineers, p 6102, 1968. [59] Lane L. J. and Shirley E. D., Erosion and sediment yield equations: solutions for overland flow. Paper presented at the Workshop on USLE Replacement. NSEL, West Lafayette, IN, p. 22, 1985. [60] Harmon, W. C. and Meyer, L. D., Multiple-Intensity Rainfall Simulator for Erosion Research on Row Sideslopes. Transactions of the ASABE, 22, 100- 103, 1979. [61] Wischmeler W. H., Estimating thesoil loss equation's cover and management factor for undisturbed areas. In: Present and proslogy for predicting sediment yields and sources. ARS-5-40. USDA Agricultural Research Service, p. 118- 124, 1975. 122 [62] Meyer L. D and Wischmeier W. H., Mathematical simulation of the process of soil erosion by water. Trans. ASAE, 12, 754-758, 1969. [63] Parsons A.J., Abrahams, A.D., and Simanton, J.R., Microtopography and soil- surface materials on semi-arid piedmont hillslopes, southern Arizona. Journal of Arid Environments, v. 22, p. 107-115, 1992. [64] Engelund F. and Hansen E., Comparison Between Similarity Theory and Regime Formulae. Basic Research - Progress Report No. 13, Jan. 1967. Hydraulic Laboratory, Techn. Un. of Denmark, 1967. [65] Werner M. G. F., Hunter N. M. and Bates. P. D., Identifiability of distributed floodplain roughness values in flood extent estimation. Journal of Hydrology, 314, 139-157, 2005. [66] Harvey G. and Jan T., An Introduction to Computer Simulation Methods. Part 2, Applications to Physical Systems, 1988. 123 PHỤ LỤC 1. Các bảng phân chia lƣu vực Bảng 1: Phân chia các tiểu lƣu vực trong lƣu vực Nậm Sập Lƣu vực Diện tích (km 2 ) Chiều dài lƣu vực (km) Độ dốc Ix (%) Độ dốc Iy (%) Chiều dài sông chính (m) Độ cao trung bình (m) 1 14.08 12.02 141.18 271.8 1.171 806 2 37.76 29.85 85.09 437.6 1.265 439 8 13.44 106.67 8.16 33.8 126 661 3 2.56 2.70 185.32 532.1 947 601 4 15.36 12.58 101.30 474.2 1.221 640 6 10.88 47.30 36.28 187.7 230 829 5 12.80 11.69 98.60 503.8 1.095 779 7 7.68 60.95 17.30 94.1 126 691 9 35.20 40.14 54.35 449.5 877 639 12 7.04 12.87 92.04 379.5 547 280 16 9.60 56.14 566.65 452.3 171 308 14 4.48 6.71 107.35 327.6 668 760 13 8.32 9.31 102.80 375.4 894 493 11 12.16 11.45 82.33 349.2 1.062 785 15 13.44 11.39 156.23 359.2 1.180 302 17 7.68 12.21 87.57 263.1 629 363 20 73.60 93.88 35.57 264.0 784 408 25 9.60 10.16 114.73 394.8 945 714 22 7.04 9.51 105.44 349.4 740 347 27 3.20 5.32 130.43 268.9 602 633 21 10.24 14.34 99.81 282.9 714 815 18 16.64 20.10 59.03 211.3 828 410 24 7.04 8.35 134.92 273.2 843 258 30 1.28 4.83 91.93 335.4 265 836 19 7.04 8.08 79.94 204.3 871 435 10 48.00 77.42 26.72 261.4 620 868 26 24.32 21.28 96.02 305.1 1.143 353 23 11.52 12.37 79.21 283.2 931 557 29 28.16 40.81 34.44 344.8 690 1223 31 8.32 21.72 43.55 353.2 383 1170 33 17.92 75.93 13.93 241.1 236 789 37 7.04 12.55 62.44 360.1 561 849 35 5.76 6.58 149.06 406.8 875 826 124 Lƣu vực Diện tích (km 2 ) Chiều dài lƣu vực (km) Độ dốc Ix (%) Độ dốc Iy (%) Chiều dài sông chính (m) Độ cao trung bình (m) 39 11.52 26.61 430.45 301.0 433 836 38 1.92 4.24 144.74 443.8 453 723 28 14.72 20.70 50.02 265.5 711 902 34 22.40 51.03 29.48 295.4 439 1151 41 14.72 33.00 45.93 277.0 446 1038 32 16.00 79.21 15.05 286.8 202 1001 40 10.24 16.73 66.30 238.4 612 941 36 97.28 94.08 30.80 344.4 1.034 1081 48 60.80 182.58 582.17 481.5 333 1080 44 7.04 33.36 34.48 242.3 211 978 46 9.60 19.35 64.11 352.0 496 1128 45 5.76 8.29 93.62 297.3 695 775 43 10.88 27.41 44.02 305.7 397 1184 51 7.04 13.26 70.63 407.6 531 855 47 5.12 13.58 59.76 399.3 377 843 55 8.32 15.70 60.94 225.8 530 788 49 7.68 11.21 100.23 463.4 685 583 50 3.84 7.27 124.89 305.7 528 617 42 22.40 29.55 57.80 334.3 758 1.127 59 4.48 11.49 61.91 205.4 390 853 52 7.68 15.30 74.76 320.7 502 1081 56 4.48 7.74 106.37 346.3 579 816 58 5.12 11.77 91.29 326.3 435 685 53 20.48 57.37 36.79 335.0 357 1088 63 10.24 20.81 39.81 374.5 492 883 61 1.28 4.92 100.74 306.6 260 722 64 1.70 65.60 122.91 426.2 130 749 60 8.96 19.27 72.10 236.2 465 923 54 12.80 20.55 61.95 316.4 623 1135 57 26.24 64.47 25.30 196.0 407 967 65 16.64 28.30 43.31 282.2 588 942 62 7.04 14.49 64.68 280.1 486 917 66 7.68 20.43 56.78 183.3 376 732 69 8.96 14.18 72.41 284.9 632 922 68 6.40 11.57 71.42 286.3 553 847 67 24.96 43.48 41.60 280.5 574 1064 71 19.84 31.54 54.78 287.3 629 596 70 28.16 40.52 55.10 316.1 695 491 72 10.24 9.57 173.89 375.5 1.070 890 125 Bảng 2: Phân chia các tiểu lƣu vực trong lƣu vực Phiêng Hiềng Lƣu vực Diện tích (km 2 ) Chiều dài lƣu vực (km) Độ dốc Ix(%) Độ dốc Iy (%) Chiều dài sông chính (m) Độ cao trung bình (m) 1 3.00 2.40 66 114 1.251 564 2 2.00 2.47 270 113 809 440 4 2.00 2.06 242 111 969 442 3 3.00 2.18 364 133 1.379 1150 5 6.50 6.60 175 97 985 723 8 4.00 3.71 244 108 1.079 976 6 5.00 5.21 189 118 960 824 7 3.50 2.78 259 114 1.261 1050 11 2.50 2.85 244 102 876 944 10 2.50 2.65 214 105 945 732 9 3.50 2.90 299 95 1.207 1139 18 2.00 2.50 231 96 801 1188 14 4.00 3.25 229 96 1.232 1.265 13 2.50 3.42 176 72 730 1.103 17 0.50 1.31 253 91 382 1.111 15 1.50 1.62 236 88 926 1.255 19 2.50 2.81 239 99 889 1.212 22 22.50 57.69 278 76 390 980 23 3.50 3.05 224 89 1.148 1.016 20 3.00 3.46 176 95 866 1.481 21 2.00 1.97 348 113 1.015 1.366 16 2.00 2.11 222 94 950 1.521 26 4.00 4.15 169 101 963 1.343 25 1.00 2.30 149 72 435 971 29 3.00 3.40 163 111 882 1.202 27 2.50 2.70 218 106 927 1.236 12 12.00 8.33 138 99 1.440 1.433 33 3.00 4.11 155 71 730 1.714 34 3.50 3.76 196 68 931 1.488 24 6.00 6.06 175 93 990 1.051 35 2.00 2.13 235 80 940 1.484 28 3.00 2.28 341 113 1.314 1.455 37 0.50 1.31 194 74 381 1.097 38 3.00 3.32 152 81 904 1.416 36 4.00 3.70 202 110 1.082 907 40 0.50 2.42 119 74 207 1.021 32 5.00 4.76 160 69 1.050 1.800 39 2.50 3.07 185 77 814 1.229 30 7.50 4.87 188 102 1.541 1.829 31 5.00 3.49 285 111 1.431 1.695 41 2.00 2.22 173 71 901 1.347 42 3.50 3.41 184 87 1.026 1.079 45 34.50 157.53 278 64 219 833 44 3.00 3.53 198 91 850 1.193 126 Lƣu vực Diện tích (km 2 ) Chiều dài lƣu vực (km) Độ dốc Ix(%) Độ dốc Iy (%) Chiều dài sông chính (m) Độ cao trung bình (m) 46 3.50 2.89 293 80 1.209 2.248 43 11.50 7.30 164 88 1.575 1.370 47 2.00 3.39 167 92 590 1.068 49 19.00 863.64 62 44 22 697 50 4.50 4.20 171 74 1.071 1.178 51 19.50 80.58 307 91 242 711 52 2.50 3.24 140 73 771 1.189 48 4.00 2.43 225 95 1.647 1.255 54 11.50 5.66 182 96 2.033 1.733 58 3.00 1.71 324 88 1.751 1.377 57 6.00 5.72 141 85 1.049 683 53 4.50 4.56 223 93 986 583 60 1.00 2.19 216 94 457 384 56 15.00 7.67 191 90 1.956 1.087 55 2.00 1.98 283 104 1.011 775 61 5.50 6.54 143 92 841 792 59 5.50 3.35 273 90 1.643 1.039 62 9.50 8.23 130 102 1.155 727 64 4.00 3.89 204 114 1.028 692 63 5.00 4.73 213 101 1.057 573 66 2.00 1.91 256 76 1.049 806 67 2.00 1.61 319 98 1.245 580 65 4.00 3.68 187 77 1.087 812 69 5.00 3.98 250 95 1.257 656 71 0.50 1.34 217 100 374 505 70 1.50 1.24 420 90 1.208 442 68 4.00 3.78 208 87 1.057 411 76 1.50 4.59 116 93 327 291 73 2.50 4.48 169 84 558 361 77 2.00 2.71 190 84 737 447 75 0.50 1.01 231 83 495 226 72 4.50 5.88 174 78 765 782 79 1.50 2.34 248 80 641 213 81 1.00 2.15 201 64 465 170 82 3.00 3.38 241 104 888 519 74 2.50 2.81 203 82 891 801 78 11.50 9.64 156 89 1.193 301 80 2.50 2.66 178 82 940 878 84 7.00 9.20 130 82 761 322 87 6.00 74.07 210 47 81 154 85 2.00 2.01 223 92 993 621 86 2.00 2.36 322 113 849 652 89 5.00 8.88 98 71 563 681 83 2.50 2.83 214 85 882 456 92 1.00 1.79 263 76 560 327 88 2.00 2.13 233 105 940 599 93 4.50 4.69 221 110 960 779 127 Lƣu vực Diện tích (km 2 ) Chiều dài lƣu vực (km) Độ dốc Ix(%) Độ dốc Iy (%) Chiều dài sông chính (m) Độ cao trung bình (m) 90 5.00 6.51 116 68 768 571 91 4.50 4.57 202 86 984 510 94 4.50 5.81 178 83 774 205 2. Trích dẫn đoạn chƣơng trình mô phỏng vận chuyển bùn cát trên lƣu vực Mô đun mô phỏng vận chuyển bùn cát trên lƣu vực #ifdef _DEBUG void CErosion::AssertValid() const { CDocument::AssertValid(); } void CErosion::Dump(CDumpContext& dc) const { CDocument::Dump(dc); } #endif //_DEBUG BOOL CErosion::Init( ERGSETSTRUCT *pErgSet, VARSTRUCT *pVar, int typ ) { Empty(); int nr; m_Typ = typ; // 386 oder 387 if( m_Typ == 181 || m_Typ == 387 ) m_MaterTyp = ST_SEDIMENT; if( m_Typ == 289 ) m_MetabTyp = ST_PHOSPHORUS; if( typ != 386 && typ != 387 && typ != 289 ) { AfxMessageBox(“Error" ); 128 return FALSE; } m_pErgSet = pErgSet; delta_t = pErgSet->delta_t; // [thời gian h] m_pTfl = pErgSet->pTFL->tfl; m_pVar = pVar; CPCDData *pPCD = pErgSet->pPCD; m_NumbTfl = pErgSet->NumbTFL; m_pPcd = pErgSet->pPCD; CString strPfad = pErgSet->pfad; strPfad += "Erosion.ers"; BOOL bAddToMRU = FALSE; SetPathName( strPfad, bAddToMRU ); pErosion = new EROSSTRUCT[m_NumbTfl+1]; memset( pErosion, 0, (m_NumbTfl+1)*sizeof(EROSSTRUCT) ); for( nr=0; nr<=m_NumbTfl; nr++ ) { pErosion[nr].NumbHeadSeg = (int) ceil(m_pVar[nr].tx / pErgSet->delta_t); pErosion[nr].NumbNextSeg = (int) ceil(m_pVar[nr].txy / pErgSet->delta_t); if( pErosion[nr].NumbNextSeg > 0 ) { CGG::Initialize(); TFLNRLISTE *pList = new TFLNRLIST[pErgSet->numbTFL+1]; GGCreateFile( pErgSet, pList, FALSE, EROSION ); delete pList; m_StartMin = pErgSet->req _minutes; m_EndMin = pErgSet->end_minutes; if(Tak!= NULL ) { for( int i=0; i<=numb_Tak; i++ ) Tak[i].Time.FillEmpty( m_StartMin, m_EndMin, (MINUTES) (delta_t*60) ); 129 } if( m_Typ == 181 || m_Typ == 182 ) { for( nr=1; nr<=m_NumbTfl; nr++ ) { int pcdnr = m_pTfl[nr].Proc.ErosNr; if( pcdnr > 0 ) { pErosion[nr].SLFAC = m_pTfl[nr].iy/1000; pErosion[nr].SinALPHAW= (float) ( m_pTfl[nr].iy / sqrt( m_pTfl[nr].iy*m_pTfl[nr].iy + 1000*1000 ) ); pErosion[nr].CosALPHAW= (float) ( 1000 / sqrt( m_pTfl[nr].iy*m_pTfl[nr].iy + 1000*1000 ) ); pErosion[nr].LI = m_pTfl[nr].area*500000 / m_pTfl[nr].flength; pErosion[nr].AREA = m_pTfl[nr].area*1000000; pErosion[nr].I = m_pTfl[nr].ix / 1000; pErosion[nr].B = pErosion[nr].AREA / m_pTfl[nr].flength; pErosion[nr].Qf = m_pVar[nr].qo1 + m_pVar[nr].qi1 + m_pVar[nr].qu1; pErosion[nr].MQC = pPCD->GetPcdVar( 386, pcdnr, MP_MQC ); pErosion[nr].IRF = pPCD->GetPcdVar( 386, pcdnr, MP_IRF ); pErosion[nr].D50 = pPCD->GetPcdVar( 386, pcdnr, MP_D50 ) / 1000; , pErosion[nr].Visco = pPCD->GetPcdVar( 386, pcdnr, MP_VISCO ); pErosion[nr].CI = pPCD->GetPcdVar( 386, pcdnr, MP_CI ); pErosion[nr].RR = pPCD->GetPcdVar( 386, pcdnr, MP_RR ); pErosion[nr].KECG = pPCD->GetPcdVar( 386, pcdnr, MP_KECG ); pErosion[nr].Fs = pPCD->GetPcdVar( 386, pcdnr, MP_FS ); pErosion[nr].KET = pPCD->GetPcdVar( 386, pcdnr, MP_KET ); pErosion[nr].Cb = pPCD->GetPcdVar( 386, pcdnr, MP_RE ); pErosion[nr].Omega = pPCD->GetPcdVar( 386, pcdnr, MP_OMEGA ); pErosion[nr].Omega*= 0.01f * RhoW/(RhoS-RhoW); pErosion[nr].fdep = pPCD->GetPcdVar( 386, pcdnr, MP_FDEP ); pErosion[nr].BBG = 0.5f; 130 pErosion[nr].Kfac = 0.5f; // [đơn vị kgh/Nm2] pErosion[nr].Cfac = 0.5f; // pcdnr = m_pTfl[nr].Proc.UsleNr; if( pcdnr > 0 && pPCD->GetProc( 387, pcdnr ) ) { pErosion[nr].BBG = pPCD->GetPcdVar( 387, pcdnr, MP_BBG ); pErosion[nr].Kfak = pPCD->GetPcdVar( 387, pcdnr, MP_KFAC); pErosion[nr].Cfak = pPCD->GetPcdVar( 387, pcdnr, MP_CFAC ); pErosion[nr].KI = pPCD->GetPcdVar( 387, pcdnr, MP_KI ); } float delta = 0.0028; pErosion[nr].TAU0 = delta * G * ( RhoS - RhoW ) * pow( pErosion[nr].D50, 0.33 ); } } } if( m_Typ == 289 ) { for( nr=1; nr<=m_NumbTfl; nr++ ) { if( m_pTfl[nr].Proc.Matyp == 289 ) { pErosion[nr].AREA = m_pTfl[nr].area*1000000; int pcdnr = m_pTfl[nr].Proc.MatNr; } { int pcdnr = m_pTfl[nr].Proc.MatNr; pErosion[nr].t_ow = m_pPcd->GetPcdVar( 286, pcdnr, MP_T_O ); pErosion[nr].t_dr = m_pPcd->GetPcdVar( 286, pcdnr, MP_T_I ); pErosion[nr].t_gw = m_pPcd->GetPcdVar( 286, pcdnr, MP_T_U ); } else { } } } 131 m_bShowQC = TRUE; m_bShowF = FALSE; return TRUE; } Mô đun xói mòn liên rãnh void CErosion::PotentialRillErosion( int nr ) { float OFRQ = pErosion[nr].OFRQ; float RE = pErosion[nr].RE; pErosion[nr].EC = 1000 * 3600 * RE * RhoW * OFRQ; } void CErosion::DepositionRate( int nr ) { float VS = pErosion[nr].VS; float QSI = pErosion[nr].QSI; float OFRQ = pErosion[nr].OFRQ; float TC = pErosion[nr].TC; pErosion[nr].DEP = -0.5f * ( VS / OFRQ ) * ( TC - QSI ); } void CErosion::RillErosion( int nr ) { float TK = pErosion[nr].TC; float QSI= pErosion[nr].QSI; float EC = pErosion[nr].EC; float term1 = 1/sqrt( pErosion[nr].SLFAC ); float term2 = pErosion[nr].OFRQ * term1 * RFM; float OFRH = pow( term2, 0.6 ); float GammaW = RhoW * G; float TAUn = GammaW * OFRH * pErosion[nr].SLFAC; 132 float SLFAC = pErosion[nr].SLFAC; float OFRQ = pErosion[nr].OFRQ; float Kr = pErosion[nr].Kfac; float C = pErosion[nr].Cfac; float Cb = pErosion[nr].Cb; pErosion[nr].ER = 1000 * 3600 * Cb * OFRQ * SLFAC * Kr * C; if( pErosion[nr].ER < 0 ) int t=1; } void CErosion::sedimenttransport( int nr ) { float EI = pErosion[nr].EI; float ER = pErosion[nr].ER; float DEP = pErosion[nr].DEP; pErosion[nr].Phi = EI + ER + DEP; if( pErosion[nr].Phi < 0 ) pErosion[nr].Phi = 0; if( pErosion[nr].Phi > 0 ) int t=1; pErosion[nr].QSI = pErosion[nr].Phi * m_pTfl[nr].flength; } void CErosion::ChannelTransport181( int nr ) { if( pErosion[nr].OFRQ > 0 ) { float SLG = pErosion[nr].SLG; float D50 = pErosion[nr].D50; float Z = 0.3f; float term1 = (float) ( 1 / sqrt( SLG ) ); float term2 = pErosion[nr].OFRQ * term1 * RFM; 133 float OFRG = (float) pow( term2, 0.6 ); float VG = (float) ( (1 / RFM) * pow( OFRG, 0.666667 ) * sqrt( SLG ) pErosion[nr].WIDTH = 2.05 * pow( Z, -0.625) * pow( (1 + Z*Z), 0.125 ) * pow( pErosion[nr].Qab * m_pTfl[nr].kst * term1, 0.375 ); float qch = pErosion[nr].Qab / pErosion[nr].WIDTH; float VS = (float) ( RhoR * G * D50 * D50 / ( 18.0f * m_VISCO ) ); pErosion[nr].VS = VS; float delta = 0.000285; pErosion[nr].DEPTH = pErosion[nr].fdep * pow( qch * m_pTfl[nr].kst * (1/sqrt(SLG)), 0.6 ); pErosion[nr].TAUch = RhoW * G * pErosion[nr].DEPTH * SLG; float Ef = pErosion[nr].TAUch / ( D50 * (RhoS-RhoW)*G ); float nue = 0.7f * pow( Ef, 0.98 ); pErosion[nr].TCG = new * pErosion[nr].Omega * pErosion[nr].TAUch * 3.600 * (VG*VG/VS) * (1/G); } else pErosion[nr].TC = 0; } float D50 = pErosion[nr].D50; float GammaW= RhoW * G; float SLG = pErosion[nr].SLG; float term1 = (float) ( 1 / sqrt( SLG ) ); float term2 = pErosion[nr].OFRQ * term1 * RFM; float OFRG = (float) pow( term2, 0.6 ); float TAUch = pErosion[nr].TAUch; float US = (float) ( sqrt( TAUch / RhoS ) ); float RE = (float) ( US * D50 / m_VISCO ); float TAU0 = pErosion[nr].TAU0; 134 float kch = 300; pErosion[nr].EGR = (float) ( 3600 * pErosion[nr].WIDTH * kch * pow( ( 1.35 * TAUch - TAU0 ), 1.05 ) ); } { float t = 0.1f; float SLFAC = pErosion[nr].SLFAC; float Width= (float) ( 2.05 * pow( t, -0.625) * pow( (1 + t*t), 0.125) * pow( (QP*RFM)/sqrt(SLFAC), 0.375 ) ); } else { if( pErosion[nr].QSI > pErosion[nr].TC ) { Deposition( nr ); } else { RillErosion( nr ); } } } void CErosion::Erosion( int nr, int Timestep, VARSTRUCT *pVar ) { pErosion[nr].ER = pErosion[nr].EI = pErosion[nr].ET = pErosion[nr].QSI = 0; pErosion[nr].TC = pErosion[nr].DEP = pErosion[nr].Phi = 0; pErosion[nr].QSGR = pErosion[nr].WEIGHT = pErosion[nr].OFRQ = pVar[nr].qo1 / pErosion[nr].B; pErosion[nr].INTPH = pVar[nr]. rain / delta_t; 135 pErosion[nr].PD = pVar[nr].rain; pErosion[nr].Qab = pVar[nr].qab / pVar[nr].itseg; pErosion[nr].VAUQ = pVar[nr].qo1 * 3600 * delta_t; if( pErosion[nr].OFRQ > 0 ) int t=1; if( pErosion[nr].OFRQ < 0 ) int t=1; if( pErosion[nr].Qab > 0 ) int t=1; if( pErosion[nr].Qab < 0 ) int t=1; if( m_pTfl[nr].Proc.ErosTyp == 386 ) AreasOder 386 ( nr, timestep, pVar ); else if ( m_pTfl[nr].Proc.ErosTyp == 387 ) AreasOder 387( nr, timestep, pVar ); if( pErosion[nr].QSI > 0 ) if( pErosion[nr].Phi > 0 ) // [đơn vị g/m2*h] int t=1; if( pErosion[nr].Phi < 0 ) int t=1; float Freight = pErosion[nr].Phi * pErosion[nr].AREA; // [đơn vị g/h] if( pErosion[nr].Qab > 0 && Freight > 0 ) { if ( m_pTfl[nr].Proc.ErosTyp == 386 ) if ( m_pTfl[nr].Proc.ErosTyp == 387 ) } } Đoạn chƣơng trình mô tả vận chuyển bùn cát trong sông if(Tak != NULL && m_pTfl[nr]. LevelNr > 0 ) { CStation *pTak = GetTakPtr( m_pTfl[nr].LevelNr ); 136 if( pTak ) { int TakNr = pTak->nr; int t=1; } } if( pErosion[nr].EI || pErosion[nr].ET || pErosion[nr].ER || pErosion[nr].DEP || pErosion[nr].Phi ) { pErosion[nr].S_EI += pErosion[nr].EI * delta_t; // đơn vị g/m2 pErosion[nr].S_ET += pErosion[nr].ET * delta_t; // đơn vị g/m2 pErosion[nr].S_ER += pErosion[nr].ER * delta_t; // đơn vị g/m2 pErosion[nr].S_DEP+= pErosion[nr].DEP * delta_t; // đơn vị g/m2 pErosion[nr].S_PHI+= pErosion[nr].Phi * delta_t; // đơn vị g/m2 } } BOOL IsValid( float value ) { if( value 1E32 ) return FALSE; return TRUE; } void CErosion( int tflnr, int time ) { float Flow=0.0f, Fldr=0.0f, Flgw=0.0f; // [đơn vị g/s] float Qlow=0.0f, Qldr=0.0f, Qlgw=0.0f; // [đơn vị m3/s] float Inflowfoc = 0; float Inflow = 0; float InflowFreight = 0; if( pErosion[tflnr].MetabEntryLevelNr > 0 ) { 137 CStation *pTak = m_pErgSet->pOrgDoc->CGGC.GetTakPtr(pErosion[tflnr]. MetabEntryLevel Nr ); if( pTak ) { int TakNr = pTak->nr; MINUTES minute = (MINUTES) ( m_pErgSet->req_minutes + Timestep* delta_t * 60 ); Infoww *= pErosion[tflnr]. MetabEntryshare; } } if( time == 0 ) { pErosion[tflnr].Fow = pErosion[tflnr].CStartFloor * m_pVar[tflnr].qo1; pErosion[tflnr].Fdr = pErosion[tflnr].CStartFloor * m_pVar[tflnr].qi1; pErosion[tflnr].Fgw = pErosion[tflnr].CStartFloor * m_pVar[tflnr].qu1; Qlow = pErosion[tflnr].Qlow = pErosion[tflnr].Qow = m_pVar[tflnr].qo1; Qldr = pErosion[tflnr].Qldr = pErosion[tflnr].Qdr = m_pVar[tflnr].qi1; Qlgw = pErosion[tflnr].Qlgw = pErosion[tflnr].Qgw = m_pVar[tflnr].qu1; } float Nep = m_pVar[tflnr].Neo + m_pVar[tflnr].No + m_pVar[tflnr]. if( Nep > 0 ) { Qlow = m_pVar[tflnr].Neo * m_pTfl[tflnr].area * 1000 / 3600; Qldr = m_pVar[tflnr].No * m_pTfl[tflnr].area * 1000 / 3600; Qlgw = m_pVar[tflnr].New * m_pTfl[tflnr].area * 1000 / 3600; m_pVar[tflnr].New / Nep; } float mFlow = ( Fzow + pErosion[tflnr].Flow ) / 2; float mQlow = ( Qzow + pErosion[tflnr].Qlow ) / 2; float Qow = pErosion[tflnr].Qow; // [đơn vị m³/s] float Fow = pErosion[tflnr].Fow; IsValid( pErosion[tflnr].Qow ); IsValid( pErosion[tflnr].Fow ); 138 float kow = 1 - (float) exp( -delta_t / pErosion[tflnr].kow ); pErosion[tflnr].Fow = Fow + ( mFlow - Fow ) * kow; pErosion[tflnr].Flow = Flow; pErosion[tflnr].Qow = m_pVar[tflnr].qo1; pErosion[tflnr].Qlow = Qlow; pErosion[tflnr].S_Qlow += Qlow; pErosion[tflnr].S_Flow += Flow; pErosion[tflnr].S_Qow += pErosion[tflnr].Qow; pErosion[tflnr].S_Fow += pErosion[tflnr].Fow; float mFzdr = ( Fzdr + pErosion[tflnr].Fzdr ) / 2; float mQzdr = ( Qzdr + pErosion[tflnr].Qzdr ) / 2; float Qdr = pErosion[tflnr].Qdr; float Fdr = pErosion[tflnr].Fdr; IsValid( pErosion[tflnr].Qdr ); IsValid( pErosion[tflnr].Fdr ); float kdr = 1 - (float) exp( -delta_t / pErosion[tflnr].kdr ); pErosion[tflnr].Fdr = Fdr + ( mFzdr - Fdr ) * kdr; pErosion[tflnr].Fzdr = Fzdr; pErosion[tflnr].Qdr = m_pVar[tflnr].qi1; pErosion[tflnr].Qzdr = Qzdr; pErosion[tflnr].S_Qzdr += Qzdr; pErosion[tflnr].S_Fzdr += Fzdr; pErosion[tflnr].S_Qdr += pErosion[tflnr].Qdr; pErosion[tflnr].S_Fdr += pErosion[tflnr].Fdr; float mFzgw = ( Fzgw + pErosion[tflnr].Fzgw ) / 2; float mQzgw = ( Qzgw + pErosion[tflnr].Qzgw ) / 2; float Qgw = pErosion[tflnr].Qgw; float Fgw = pErosion[tflnr].Fgw; IsValid( pErosion[tflnr].Qgw ); 139 IsValid( pErosion[tflnr].Fgw ); float kgw = 1 - (float) exp( -delta_t / pErosion[tflnr].kgw ); pErosion[tflnr].Fgw = Fgw + ( mFzgw - Fgw ) * kgw; pErosion[tflnr].Fzgw = Fzgw; pErosion[tflnr].Qgw = m_pVar[tflnr].qu1; pErosion[tflnr].Qzgw = Qzgw; pErosion[tflnr].S_Qzgw += Qzgw; pErosion[tflnr].S_Fzgw += Fzgw; pErosion[tflnr].S_Qgw += pErosion[tflnr].Qgw; pErosion[tflnr].S_Fgw += pErosion[tflnr].Fgw; float Freight = pErosion[tflnr].Fow + pErosion[tflnr].Fdr + pErosion[tflnr].Fgw; if( Freight < 0 ) int t=1; pErosion[tflnr].QSI = 3600 * Freight / m_pTfl[tflnr].flength; if(Tak != NULL ) if(Tak!= NULL ) { int tflrec = m_pTfl[tflnr].LevelEzgRec; CStation *pTak = GetTakPtr( m_pTfl[tflrec].LevelNr ); if( pTak &&Concentration > 0) { int TakNr = pTak->nr; } } if(Tak!= NULL && m_pTfl[tflnr].LevelNr > 0 ) { CStation *pTak = GetTakPtr( m_pTfl[tflnr].LevelNr ); if( pTak ) { int TakNr = pTak->nr; int t=1; 140 else MINUTES minute = (MINUTES) ( m_pErgSet->inq_minutes + timestep * delta_t * 60 ); } } } float D50 = pErosion[nr].D50; float GammaW= RhoW * G; float SLG = pErosion[nr].SLG; float term1 = (float) ( 1 / sqrt( SLG ) ); float term2 = pErosion[nr].OFRQ * term1 * RFM; float OFRG = (float) pow( term2, 0.6 ); float TAUch = pErosion[nr].TAUch; float US = (float) ( sqrt( TAUch / RhoS ) ); float RE = (float) ( US * D50 / m_VISCO ); float TAU0 = pErosion[nr].TAU0; float kch = 300; pErosion[nr].EGR = (float) ( 3600 * pErosion[nr].WIDTH * kch * pow( ( 1.35 * TAUch - TAU0 ), 1.05 ) ); } { float t = 0.1f; float SLFAC = pErosion[nr].SLFAC; float Width= (float) ( 2.05 * pow( t, -0.625) * pow( (1 + t*t), 0.125) * pow( (QP*RFM)/sqrt(SLFAC), 0.375 ) ); } else { if( pErosion[nr].QSI > pErosion[nr].TC ) { 141 Deposition( nr ); } else { RillErosion( nr ); } } } void CErosion::ChannelDeposition( int nr ) { float FS = pErosion[nr].Fs; float D50 = pErosion[nr].D50; float BETA= 1.0f; float TCGR= pErosion[nr].TCGR; float QSGRN= pErosion[nr].QSGRN; float RhoF=RhoW; float Visco = pErosion[nr].Visco; float RhoR2 = ( RhoS - RhoF ) / RhoF; float D = D50 * (float) pow( (RhoR2 * G / (Visco*Visco) ), 0.333 ); float OFRQ = pErosion[nr].OFRQ; float VSG = (float) ( 11 * Visco * ( sqrt(1+0.01*D*D*D) -1 / D50) ); float ALPHAGR = (float) ( sqrt( 1.9f * sqrt(D50) ) * VSG * BETA / ( sqrt(FS) * sqrt(OFRQ) ) ); pErosion[nr].DEPGR = ALPHAGR * ( TCGR - QSGRN ); } void CErosion::ChannelErosion( int nr ) { float D50 = pErosion[nr].D50; float OFRQ = pErosion[nr].OFRQ; float KECG = pErosion[nr].KECG; 142 float FS = pErosion[nr].Fs; float Qab = pErosion[nr].Qab; float TO; if( B/h>= 30 ) TO = RhoW * G * h * J; else TO = RhoW * G * R * I; float VS = pErosion[nr].VS; float TOCDIMEN = (float) ( 0.4 * (VS*VS) / (G * D50) ); float TOC = (float) TOCDIMEN * (RhoS - RhoW) * G * D50; pErosion[nr].EGR = (float) ( F * sqrt( 1.9 * sqrt(D50*1000.0f) ) * sqrt(OFRQ) * KECG * ( TO-TOC ) / sqrt(FS) ); } void CErosion::( int nr ) { float QSI = pErosion[nr].QSI; float EGR = pErosion[nr].EGR; pErosion[nr].QSGRN = QSI + EGR; } void CErosion::( int nr ) { float QSI = pErosion[nr].QSI; float DEPGR = pErosion[nr].DEPGR; float LI = pErosion[nr].LI; pErosion[nr].QSGR = QSI + DEPGR * LI; } void CErosion::( int nr ) { float QSGRN = pErosion[nr].QSGRN; 143 float DEPGR = pErosion[nr].DEPGR; float LI = pErosion[nr].LI; pErosion[nr].QSGR = QSGRN + DEPGR * LI; } void CErosion::( int nr ) { pErosion[nr].QSGR = pErosion[nr].QSGRN; } void CErosion::( int nr ) { float Foc = pErosion[nr]. Freight; float Freight = pErosion[nr].Qab * Foc; if( pErosion[nr]. Freight - Freight < 0 ) Freight = pErosion[nr].Freight; pErosion[nr]. Freight -= Freight; } CErosionView* CErosion::GetActiveView() { CView *pView; POSITION pos = GetFirstViewPosition(); if( pos ) pView = GetNextView(pos); while( pos && !pView->IsWindowVisible() ) { pView = GetNextView(pos); } if( pView ) if( pView->IsWindowVisible() ) return (CErosionView*) pView; return ZERO; 144 } BOOL CErosion::AddView( BOOL bVisible, CString WindowText ) { class COrgDoc; class CMapView; class CZFD; class CZFDView; class CCompare; class CCompareDlg; class CErosion; class CShapeView; class CErosionView; class CDlgLandMap; class CMetab; class CEventDoc : public CDocument { protected: DECLARE_DYNCREATE(CEventDoc) public: CString m_EventName; COrgDoc *m_pOrgDoc; ERGSETSTRUCT *pErgSet; CGG CERG, ColdERG; CGG GGArea; CVARDateCVAR; CFormula vFormula; CMemory MEMORY; CNDate CN; CMapView *grid_flood_view; 145 CMapView *grid_w_view; CMapView *grid_damage_view; CMapView *grid_ damagesum_view; CGRID FloodGRID; CGRID FloodHeightGRID; CGRID WGRID; CGRID Damage GRID; CGRID DamageSumGRID; CMyPtrList *Damage List; CZFD *pZFD; CErosion *pErosion; CErosion *pMeta; CShapeView *pShapeLandMap; CDlgLandMap*pDlgLandMap; PEGELSTRUCT *Levelq; float delta_t; float rain; float rainsum; float etp,evaporation; public: CEventDoc(); BOOL GetTimeSeriesRange( CDate *MinTotal, CDate *MinOverlap, CDate *MaxOverlap, CDate *MaxTotal, CMyPtrList *pStatList=NULL ); BOOL createWGRID( CDate *Date, BOOL fMaxFlood ); BOOL createFloodGRID( CDate *Date, BOOL fMaxFlood ); void DeleteZFDWnd() { pZFD = NULL; }; void OnDeleteDisplayGrid( CMapView *View2delete ); BOOL UpdateViews(); void DeleteChildWindow( void **ptr ); 146 virtual void OnCloseDocument(); virtual BOOL OnSaveDocument(LPCTSTR lpszPathName); virtual BOOL OnOpenDocument(LPCTSTR lpszPathName); virtual BOOL OnNewDocument(); public: virtual ~CEventDoc(); #ifdef _DEBUG virtual void AssertValid() const; virtual void Dump(CDumpContext& dc) const; #endif protected: DECLARE_MESSAGE_MAP() }; CEventDoc_H

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

  • pdfluan_an_nghien_cuu_xay_dung_mo_hinh_toan_mo_phong_dong_chay.pdf
  • pdfThongtindonggopmoiLATS_ NCSDaoTanQuy(2017).pdf
  • pdfTom tat LATS_NCS_DaoTanQuy2017(TV).pdf
  • pdfTomtat LATS_NCS_DaoTanQuy(2017)(TA).pdf
Luận văn liên quan