Ý tưởng chính của thuật toán được đề xuất là: Xác định tất cả các
điểm nằm trên biên không theo hướng tìm kiếm và sử dụng các ma trận lọc, thông qua việc so sánh độ chênh lệch về mức xám của nó so với mức xám chung của các điểm ảnh lân cận (mức xám nền). Trước hết giá trị xám trung bình của các điểm ảnh nằm trong phạm vi của ma trận 3×3 hoặc 5×5 có tâm là điểm ảnh đang xét sẽ được tính toán. Nếu như độ chênh lệch mức xám giữa điểm đang xét với giá trị xám trung bình thỏa mãn lớn hơn một
x 0
và ghi nhận lại, còn các điểm không thỏa mãn điều kiện trên sẽ được coi là
điểm nền.
a) Ma trận điểm ảnh trước khi lọc b) Ma trận điểm ảnh sau khi lọc
Hình 3.4. Ma trận điểm ảnh trước và sau lọc
Thuật toán có thểđược mô tả như sau: for (i=0; i< biHeight; i++)
for (j=0; j< biWidth; j++) {
tt_GrayScale=0;
for (ii=i-1; ii<=i+1; ii++) for (jj=j-1; jj<=j+1; jj++) tt_GrayScale+=GetPoint(pOrgImg,ii,jj); if (tt_GrayScale>9*GetPoint(pOrgImg,i,j)+δ1) SetPoint(pBdImg,i,j,BLACK); } Trong đó:
• biWidth, biHeight: là chiều rộng và chiều cao của ảnh tính theo
đơn vị Pixel.
• pOrgImg, pBdImg: lần lượt là các con trỏ trỏ đến các vùng dữ liệu của ảnh gốc và ảnh biên.
• tt_GrayScale: là tổng giá trị độ xám của các điểm ảnh thuộc ma trận 3×3 có tâm là điểm ảnh đang xét.
• δ1: là độ chênh lệch mức xám của điểm ảnh đang xét so với giá trị
xám trung bình của ma trận.
• SetPoint() và GetPoint(): là các hàm đọc, ghi giá trịđiểm ảnh.
Chúng ta có thể so sánh được hiệu quả của thuật toán phát hiện biên này so với các thuật toán phát hiện biên truyền thống thông qua các hình minh họa dưới đâỵ Hình 3.5a là ảnh gốc, Hình 3.5b là ảnh biên qua lọc
Ả
1
Sobel Hx, Hình 3.5c là ảnh biên qua lọc Sobel Hy, Hình 3.5d là ảnh biên qua lọc Kirsh, Hình 3.5e là ảnh biên qua lọc Laplacẹ Hình 3.6 là các ảnh biên thu được khi sử dụng thuật toán phát hiện biên đề xuất dựa vào trung bình cục bộ với giá trị δ1 khác nhaụ Hình 3.6a là ảnh biên thu được với
δ1= 25, Hình 3.6b là ảnh biên thu được với δ1= 250.
a) Ảnh gốc b) Ảnh qua lọc Sobel Hx c) Ảnh qua lọc Sobel Hy
d) Ảnh qua lọc Kirsh e) Ảnh qua lọc Laplace
Hình 3.5. Các ảnh biên theo các thuật toán phát hiện biên truyền thống
a) Ảnh biên thu được với δ1= 25 b) Ảnh biên thu được với δ1= 250
Hình 3.6. Các ảnh biên kết quả thu được theo thuật toán đề xuất
*Nhận xét:
Chúng ta có nhận xét là ảnh gốc sử dụng trong chương trình có mầu nền khá tối và có rất nhiều nhiễụ Các bộ lọc sử dụng trong minh họa trên
đều mắc phải vấn đề nàỵ Thuật toán dò biên sử dụng trong chương trình tuy đã hạn chế được nhiều nhiễu so với việc sử dụng các bộ lọc và làm nổi rõ các đường biên nhưng vẫn không loại bỏđược hầu hết các nhiễụ Khi áp dụng thuật toán trên chúng ta vẫn có thể làm giảm bớt nhiễu đi nhiều hơn
Thuật toán có độ phức tạp tỷ lệ với kích thước ảnh và kích thước cửa sổ. Với độ phức tạp của thuật toán là O(n2) nên nó thực hiện việc tìm biên khá nhanh, ảnh biên thu được chỉ gồm các điểm ảnh và điểm biên nên dễ
xử lý, bản thân thuật toán này cũng ít chịu ảnh hưởng của nhiễu hơn là kỹ
thuật Sobel mặc dù nó có khả năng phát hiện khá tốt các vùng biên nhiễụ Nhưng cũng giống các phương pháp phát hiện biên trực tiếp khác là nó cho kết quả đường biên có độ dày không đềụ