Các thao tác vùng đệm với GIS véc tơ

Một phần của tài liệu Hệ thống thông tin địa lý (gẻogaphic information sýtem – GIS) ra đời trên cơ sở phát triển của khoa học may tính và được ứng dụng rộng rãi trong nhiều nghành khoa học có liên quan đến xử lý dữ liệu không gian (Trang 32 - 38)

Chương 2 XÂY DỰNG VÙNG ĐỆM TRONG GIS

2.1. Các thao tác vùng đệm với GIS véc tơ

Một trong các thao tác cơ bản nhất của GIS là phát sinh vùng đệm theo một khoảng cách cho trước xung quanh điểm, chuỗi đoạn thẳng hay một đa giác.

Chức năng này thường xuyên được áp dụng trong công tác lập kế hoạch và phân tích. Đối với GIS véc tơ, thao tác vùng đệm chỉ được thực hiện với dữ liệu rừ, khụng ỏp dụng đối với hệ cơ sở dữ liệu mờ.

Vùng đệm của một điểm

Thí dụ, nhận biết những làng mạc ở cách một nguồn nước bị ô nhiễm khoảng 1 km. So sánh số người bị mắc bệnh do môi trường ô nhiễm với những làng ở cách xa đó. Như vậy, nguồn nước bị ô nhiễm được biểu diễn như đối tượng điểm trên bản đồ. Một vùng đệm là hình tròn có bán kính 1 km, tâm là toạ độ của nguồn nước. Trong hình tròn đó ta phải định vị được những làng mạc có người bị mắc bệnh. Vị trí của các làng bản và số liệu những người mắc bệnh được lưu trong cơ sở dữ liệu địa lý. Việc thực hiện vùng đệm này theo các bước sau:

1. Tâm O là toạ độ của nguồn nước và bán kính r cho truớc, ta có đường tròn làm đệm.

2. Tìm tất cả các toạ độ của làng mạc có khoảng cách đến tâm O nhỏ hơn r.

3. Hiển thị các làng mạc vừa tìm được và có người bị mắc bệnh.

Vùng đệm của một xâu đoạn thẳng

Giả sử ta có một đoạn đường quốc lộ được tạo bởi các đoạn thẳng như trên Hình 2.2. Hai bên đường quốc lộ người ta xây dựng các trạm bán xăng dầu.

Người lập kế hoạch muốn biết có bao nhiêu trạm xăng dầu dọc theo hai bên đường quốc lộ và khoảng cách tới đường cực đại là 500 m.

P4

P11 P3

P2

Theta P21

P12 P22

x

y

P1

Hình 2.2. Vùng đệm của xâu đoạn thẳng

Các trạm xăng dầu được coi là các tiện ích trong hệ thống. Trên bản đồ chúng là đối tượng điểm. Để trả lời được câu hỏi ta phải sử dụng chức năng buffering.

Xung quanh chuỗi các đoạn thẳng (đoạn đường) ta phải tạo ra một đa giác bao bọc. Các cạnh của đa giác phải cách đoạn đường một khoảng l cho trước.

Sau đó phải tìm được các đối tượng điểm là các trạm bán xăng nằm trong đa giác đó.

P1

P12

Theta P

Anpha a

b c

P2 x

y

Hình 2.3. Tìm vùng đệm

Sau đây là thuật toán đã được nghiên cứu và cài đặt để thực hiện buffering:

Vùng đệm của đoạn đường tạo bởi các điểm P1, P2, P3, P4 là đa giác tạo bởi các điểm P11, P21, ...., P22, P12, P11 cách đều đoạn đường một khoảng b và hai nửa đường trong tại hai đầu đường có bán kính b cho trước (thí dụ 500 m).

1. Tìm các điểm P11, P21, ... của đa giác. Giả sử ta phải tìm điểm P12 cách P1 một khoảng c cho trước như trên Hình 2.3.

Xét tam giác vuông tạo bởi các điểm P1, P , P12. Hai điểm P1(x1, y1) và P2(x2,y2) tạo thành đoạn thẳng và có góc  (Theta) được tính từ biểu thức sau:

tang  = (y2 - y1) / (x2 - x1).

Từ đó suy ra góc  (Anpha):  = 90 -  b = c / cos 

a = c / sin 

Vậy điểm P12(x12, y12) có toạ độ:

x12 = x1 + b y12 = y1 + a

2. Tìm điểm P22. Cần phải phân biệt hai trường hợp xảy ra ở đây.

P1

P2 P3

P12

P22 P32

P22' P22''

Hình 2.4. Trường hợp góc tù

a) Khi góc tạo bởi hai đoạn thẳng [P1, P2] và [P2, P3] nhỏ hơn 180

(Hình 2.4)

Toạ độ của điểm P22'(x22', y22') được tính như trên và có:

x22' = x2 + b y22' = y2 + a

Tính tương tự cho các điểm P22'' và P32. Hai đoạn thẳng tạo bởi P12, P22' và P22'' và P32 sẽ cắt nhau tại điểm P22. Toạ độ của giao điểm P22 được tính theo thuật toán đã trình bày trên. Vậy, các điểm P12, P22 thuộc đa giác bao quanh. Xét tương tự cho các điểm từ P3 trở đi.

b) Khi góc tạo bởi hai đoạn thẳng [P1, P2] và [P2, P3] lớn hơn 180

(Hình 2.4)

P1

P2 P3

P12

P22 P32

P22' P22''

M

N a b

x

y

Hình 2.5. Trường hợp góc bẹt

Các điểm P12, P22', P22'', P32 được tìm như trường hợp đã mô tả trên.

Để cho đơn giản cho cài đặt và tăng tốc độ thực hiện, trong thuật toán này điểm P22 được tính như sau:

Chọn M làm điểm giữa của đoạn thẳng nối P22' và P22''. Nối P2 với M và trên đường thẳng kéo dài này ta chọn điểm P22 sao cho khoảng cách P2, P22 bằng c cho trước. Vậy, các điểm P12, P22', P22, P22'', P32 đều thuộc đa giác bao quanh.

Các toạ độ được tính cụ thể như sau:

Toạ độ của điểm M:

xM = x22'' + (x22' - x22'')/2 y M = y22'' + (y22' - y22'')/2

Xét tam giác tạo bởi các điểm P2, P22, N. Gọi góc nghiêng của đường thẳng qua hai điểm P2 và M là . Đoạn thẳng P2, P22 có độ dài c cho trước.

Các cạnh còn lại được tính theo công thức:

b = c/cos 

a = c/sin 

Vậy, toạ độ của điểm P22 sẽ là:

x22 = x2 + b y22 = y2 - a

3. Vùng đệm của hai đầu của đoạn đường là hai nửa hình tròn như trong Hình 2.2 với bán kính bằng c và tâm là P1 và P4.

4. Tìm những đối tượng điểm là các trạm bán xăng dầu ở trong vùng đệm.

Công việc này được thực hiện theo hai bước.

a) Tìm các đối tượng điểm nằm trong đệm của hai đầu đoạn đường, có nghĩa ta tìm các điểm từ cơ sở dữ liệu sao cho toạ độ của chúng cách P1 hoặc P4 một khoảng c cho trước.

b) Tìm các đối tượng điểm nằm trong đa giác vừa được xác định trên đây.

Thuật toán xác định một điểm có nằm trong một đa giác hay không được mô tả trong Newsgroups “comp.graphics.algorithms” trên mạng Internet. Trong bài báo của mình, ông Anson Tsao có khẳng định: ” Đoạn mã chương trình trong quyển sách Algorithms của Sedgewick là không đúng”. Sau đó, ông ta đã giới thiệu thuật toán của Prof. Randolph Franklin. Trong hệ thống này, để xác định điểm có nằm trong đa giác hay không, có thể sử dụng thuật toán đang đề cập trên vào việc cài đặt bằng ngôn ngữ C như sau:

// Toạ độ của điểm: x,y

// Tổng số toạ độ của đa giác: npol // Các toạ độ của đa giác: xp[], yp[]

// Output: c = 1 Điểm đang xét nằm trong đa giác int pnpoly(int npol, float *xp, float *yp, float x, float y) {

int i, j, c = 0;

for (i = 0, j = npol - 1; i < npol; j = i++) {

if((((yp[i] <= y) && (y < yp[j])) ||

((yp[j] <= y) && (y < yp[i]))) &&

(x < (xp[j] - xp[i]) * (y - yp[i]) / (yp[j] - yp[i]) + xp[i])) c = !c;

} return c;

}

Một phần của tài liệu Hệ thống thông tin địa lý (gẻogaphic information sýtem – GIS) ra đời trên cơ sở phát triển của khoa học may tính và được ứng dụng rộng rãi trong nhiều nghành khoa học có liên quan đến xử lý dữ liệu không gian (Trang 32 - 38)

Tải bản đầy đủ (PDF)

(79 trang)