Đồ án Tìm hiểu bài toán nhận dạng biển số xe - Phạm Thị Thanh Thủy

pdf 61 trang huongle 3640
Bạn đang xem 20 trang mẫu của tài liệu "Đồ án Tìm hiểu bài toán nhận dạng biển số xe - Phạm Thị Thanh Thủy", để tải tài liệu gốc về máy bạn click vào nút DOWNLOAD ở trên

Tài liệu đính kèm:

  • pdfdo_an_tim_hieu_bai_toan_nhan_dang_bien_so_xe_pham_thi_thanh.pdf

Nội dung text: Đồ án Tìm hiểu bài toán nhận dạng biển số xe - Phạm Thị Thanh Thủy

  1. BỘ GIÁO DỤC VÀ ĐÀO TẠO TRƯỜNG ĐẠI HỌC DÂN LẬP HẢI PHÒNG o0o ĐỒ ÁN TỐT NGHIỆP NGÀNH CÔNG NGHỆ THÔNG TIN HẢI PHÒNG 2009 9
  2. BỘ GIÁO DỤC VÀ ĐÀO TẠO TRƯỜNG ĐẠI HỌC DÂN LẬP HẢI PHÒNG o0o TÌM HIỂU BÀI TOÁN NHẬN DẠNG BIỂN SỐ XE ĐỒ ÁN TỐT NGHIỆP ĐẠI HỌC HỆ CHÍNH QUY Ngành: Công nghệ thông tin 10
  3. BỘ GIÁO DỤC VÀ ĐÀO TẠO TRƯỜNG ĐẠI HỌC DÂN LẬP HẢI PHÒNG o0o TÌM HIỂU BÀI TOÁN NH ẬN DẠNG BIỂN SỐ XE ĐỒ ÁN TỐT NGHIỆP HỆ CHÍNH QUY Ngành: Công nghệ thông tin Sinh viên thực hiện: Phạm Thị Thanh Thuỷ Giáo viên hướng dẫn: PGS.TS. ĐỖ NĂNG TOÀN Mã số sinh viên: 0901 25 MỤC LỤC PHẦN GIỚI THIỆU 20 H¶i Phßng11 - 2009
  4. BỘ GIÁO DỤC VÀ ĐÀO TẠO CỘNG HOÀ XÃ HỘI CHỦ NGHĨA VIỆT NAM TRƢỜNG ĐẠI HỌC DÂN LẬP HẢI PHÒNG Độc lập - Tự do - Hạnh phúc o0o NHIỆM VỤ THIẾT KẾ TỐT NGHIỆP Sinh viên: Phạm Thị Thanh Thuỷ. Mã số: 090125. Lớp: CT902. Ngành: Công nghệ thông tin. Tên đề tài: TÌM HIỂU BÀI TOÁN NHẬN DẠNG BIỂN SỐ XE 12
  5. NHIỆM VỤ ĐỀ TÀI 1. Nội dung và các yêu cầu cần giải quyết trong nhiệm vụ đề tài tốt nghiệp a. Nội dung: . Tìm hiểu về biển số xe và hệ thống nhận dạng biển số xe . Phát biểu bài toán và hướng giải quyết . Nghiên cứu một số thuật toán ứng dụng trong việc nhận dạng biển số xe b. Các yêu cầu cần giải quyết: . Tìm hiểu khái quát về xử lý ảnh và bài toán nhận dạng biển số xe . Tìm hiểu thông tin về biển số xe và phân loại biển số xe của Việt Nam . Tìm hiểu các công đoạn chính của bài toán nhận dạng biển số xe gồm 2 khâu chính: Phát hiện biển số xe Nhận dạng biển số xe . Cài đặt thử nghiệm 2 . Địa điểm thực tập: VIỆN CNTT-VIỆN KH&CN Việt Nam Đc: Số 8 HOÀNG QUỐC VIỆT-HÀ NỘI 13
  6. CÁN BỘ HƢỚNG DẪN ĐỀ TÀI TỐT NGHIỆP Người hướng dẫn thứ nhất: Họ và tên: ĐỖ NĂNG TOÀN Học hàm,học vị: PGS.TS Cơ quan công tác:VIỆN CNTT-VIỆN KH&CN Việt Nam Nội dung hướng dẫn: Người hướng dẫn thứ hai: Họ và tên: ĐỖ NĂNG TOÀN Học hàm,học vị: PGS.TS Cơ quan công tác:VIỆN CNTT-VIỆN KH&CN Việt Nam Nội dung hướng dẫn: Đề tài tốt nghiệp được giao ngày 06 tháng 04 năm 2009 Yêu cầu phải được hoàn thành trước ngày 11 tháng 07 năm 2009 Đã nhận nhiệm vụ: Đ.T.T.N Đã nhận nhiệm vụ: Đ.T.T.N Sinh viên Cán bộ hƣớng dẫn Đ.T.T.N Hải Phòng, ngày tháng năm 2009 HiÖu tr•ëng GS.TS.NGƯT Trần Hữu Nghị 14
  7. PhÇn nhËn xÐt tãm t¾t cña c¸n bé h•íng dÉn 1. Tinh thÇn th¸i ®é cña sinh viªn trong qu¸ tr×nh lµm ®Ò tµi tèt nghiÖp: 2. §¸nh gi¸ chÊt l•îng cña ®å ¸n (so víi néi dung yªu cÇu ®· ®Ò ra trong nhiÖm vô §.T.T.N trªn c¸c mÆt lý luËn, thùc tiÔn, tÝnh to¸n sè liÖu ): 3. Cho ®iÓm cña c¸n bé h•íng dÉn: (§iÓm ghi b»ng sè vµ ch÷) H¶i Phßng, ngµy th¸ng n¨m 2009 C¸n bé h•íng dÉn chÝnh (Ký, ghi râ hä tªn) 15
  8. PhÇn nhËn xÐt ®¸nh gi¸ cña c¸n bé chÊm ph¶n biÖn ®Ò tµi tèt nghiÖp 1. Đánh giá chất lượng đề tài tốt nghiệp (về các mặt như cơ sở lí luận,thuyết minh chương trình, giá trị thực tế ) 2. Cho điểm của cán bộ phản biện ( §iÓm ghi b»ng sè vµ ch÷ ) Ngµy th¸ng n¨m 2009 C¸n bé chÊm ph¶n biÖn ( Ký, ghi râ hä tªn ) 16
  9. LỜI CẢM ƠN Em xin chân thành cảm ơn PGS.TS ĐỖ NĂNG TOÀN - VIỆN CNTT - VIỆN KH&CN Việt Nam, người đã trực tiếp hướng dẫn tận tình và tạo mọi điều kiện thuận lợi cho em để em hoàn thành khoá luận của mình. Em cũng xin chân thành cảm ơn tất cả các anh chị trong Viện CNTT - Viện KH&CN Việt Nam đã nhiệt tình chỉ dạy và cung cấp những kiến thức quý báu để em có thể hoàn thành tốt báo cáo tốt nghiệp này. Vì thời gian có hạn, kinh nghiệm bản thân còn ít. Cho nên trong đề tài của em không tránh khỏi những thiếu sót, em rất mong được sự góp ý quý báu của tất cả các thầy cô giáo cũng như các bạn để đề tài của em được hoàn thiện hơn. Em xin chân thành cảm ơn! Hải Phòng, ngày 4 tháng 07 năm 2009. Sinh viên Phạm Thị Thanh Thuỷ 17
  10. Mục lục Phần giới thiệu Chƣơng 1: TỔNG QUAN VỀ BÀI TOÁN NHẬN DẠNG BIẾN SỐ XE . 21 1.1. Khái quát về xử lý ảnh: 21 1.2. Khái niệm về nhận dạng biển số xe: 21 1.2.1 Khái niệm & ứng dụng: 21 1.2.2 Phân loại biển số xe: 24 1.3. Một số hướng giải quyết bài toán nhận dạng biển số xe: 27 1.3.1. Hướng tiếp cận phát triển vùng: 27 1.3.2. Hướng tiếp cận dò biên và biến đổi Hough: 27 1.4 Hướng giải quyết: 28 Chƣơng 2: PHÁT HIỆN VÙNG CHỨA BIỂN SỐ XE 31 2.1 Một số khái niệm cơ bản: 31 2.1.1 Tổng quan về ảnh 31 2.1.2 Phương pháp tách dò ngưỡng tự động 32 2.2 Biên và các phương pháp phát hiện biên. 33 2.2.1 Phương pháp gradient 33 2.2.2. Kỹ thuật Laplace: 35 2.3 Phát hiện vùng chứa biển số xe 37 2.3.1. Nhị phân hóa ảnh 37 2.3.2 Tách biên: 38 2.3.3 Biến đổi HOUGH 39 2.3.4 Trích chọn đoạn thẳng và tính giao điểm 42 2.3. Xác định chính xác vùng chứa biển số xe 43 2.3.1. Bước ban đầu: 44 2.4.2 Tiêu chí tỷ lệ chiều dài/rộng. 45 2.4.3 Tiêu chí số ký tự trong vùng biển số xe 46 Chƣơng 3: BÀI TOÁN NHẬN DẠNG KÝ TỰ 47 3.1 Tổng quan về nhận dạng 47 18
  11. 3.1.1 Không gian biểu diễn đối tượng, không gian diễn dịch 47 3.1.2 Mô hình và bản chất của quá trình nhận dạng 48 3.1.2.1 Mô hình 48 3.1.2.2 Bản chất của quá trình nhận dạng 50 3.2 Mô hình mạng nơron nhân tạo 51 3.2.1 Mô hình nơron nhân tạo 51 3.2.2 Mạng Nơron 52 3.2.2.1 Phân loại các mạng noron 53 3.2.2.2 Hai chức năng của mạng noron 54 3.2.3 Mạng Kohonen 56 3.2.3.1 Cấu trúc mạng 56 3.2.3.3 Sử dụng mạng 59 3.2.4 Mạng nơron nhiều lớp lan truyền ngược sai số 61 3.2.4.1 Kiến trúc mạng 61 3.2.4.2 Huấn luyện mạng 61 3.2.4.3 Sử dụng mạng 63 3.3 Sử dụng mạng nơron lan truyền ngược hướng cho nhận dạng ký tự 63 3.3.1 Nhận dạng bằng mạng nơron lan truyền ngược hướng (kn chung) . 63 3.3.2 Cài đặt mạng lan truyền ngược hướng cho nhận dạng ký tự 64 3.3.3 Nhận dạng các ký tự sử dụng mạng lan truyền ngược hướng 66 Kết luận 67 PHẦN KẾT LUẬN 68 TÀI LIỆU THAM KHẢO 69 19
  12. PHẦN GIỚI THIỆU Ngày nay trên thế giới bên cạnh việc tăng trưởng kinh tế là sự phát triển của các ngành khoa học kỹ thuật nói chung, mà trong đó ngành công nghiệp sản xuất các phương tiện giao thông lại là một trong những ngành có tốc độ phát triển cực nhanh. Sự phát triển ấy, được thể hiện rõ ràng nhất thông qua hình ảnh các phương tiện giao thông trên thế giới ngày một tăng cao và đa dạng. Tuy nhiên,điều đó lại gây ra một áp lực đối với những người và cơ quan các cấp quản lý,làm cho công tác quản lý và giám sát sẽ khó khăn hơn, Và đây cũng là một trong những vấn nạn ở Việt Nam. Công tác quản lý phương tiện giao thông nói chung và quản lý ôtô, xe máy là vô cùng phức tạp cũng như công tác phát hiện, xử phạt các hành vi vi phạm giao thông, chống trộm, sẽ tốn nhiều thời gian và công sức hơn Để làm giảm lượng nhân lực trong việc công tác quản lý, kiểm soát phương tiện giao thông, trên thế giới đã nhanh chóng xây dựng hệ thống giám sát tự động đối với các phương tiện giao thông. Và các hệ thống giám sát đều lấy biển số xe là mục tiêu giám sát. Hệ thống này đã được sử dụng rộng rãi tuy nhiên ở Việt Nam đây vẫn là một lĩnh vực mới mẻ. Do đó em chọn làm đề tài “Tìm hiểu hệ thống nhận dạng biển số xe” với mục đích để tìm hiểu nhằm trợ giúp cho công tác giám sát, quản lý các phương tiện giao thông một cách hiệu quả, dễ dàng và nhanh chóng hơn Em tin ở Việt Nam mình trong tương lai gần hệ thống này sẽ được sử dụng rộng rãi. Bố cục trình bày trong báo cáo của em gồm 3 phần: Chƣơng 1: Tổng quan về bài toán nhận dạng biển số xe Chƣơng 2: Phát hiện vùng chứa biển số xe Chƣơng 3: Nhận dạng ký tự 20
  13. Chƣơng 1: TỔNG QUAN VỀ BÀI TOÁN NHẬN DẠNG BIẾN SỐ XE 1.1. Khái quát về xử lý ảnh: Xử lý ảnh là một trong những mảng quan trọng nhất trong kỹ thuật thị giác máy tính, là tiền đề cho nhiều nghiên cứu thuộc lĩnh vực này. Hai nhiệm vụ cơ bản của quá trình xử lý ảnh là nâng cao chất lượng thông tin hình ảnh và xử lý số liệu cung cấp cho các quá trình khác trong đó có việc ứng dụng thị giác vào điều khiển. Quá trình bắt đầu từ việc thu nhận ảnh nguồn (từ các thiết bị thu nhận ảnh dạng số hoặc tương tự) gửi đến máy tính. Dữ liệu ảnh được lưu trữ ở định dạng phù hợp với quá trình xử lý. Người lập trình sẽ tác động các thuật toán tương ứng lên dữ liệu ảnh nhằm thay đổi cấu trúc ảnh phù hơp với các ứng dụng khác nhau. - Chuyển ảnh màu thành ảnh xám - Lược đồ xám của ảnh (Histogram) - Các bộ lọc không gian + Lọc tuyến tính + Lọc phi tuyến - Tách biên đối tượng 1.2. Khái niệm về nhận dạng biển số xe: 1.2.1 Khái niệm & ứng dụng: a) Khái niệm: , , *) ứng dụng nhận dạng biển số xe: Ứng dụng nhận dạng biển số xe là ứng dụng có khả năng phân tích hình ảnh và xác định biển số xe từ các hình ảnh chụp được từ các thiết bị thu hình. 21
  14. Nguồn hình ảnh cho ứng dụng có rất nhiều. Và phát triển, hình ảnh được trực tiếp thu nhận từ camera. Trong báo cáo tốt nghiệp của em chỉ dừng lại ở mức xác định được biển số xe (xác định các chữ) từ các bức ảnh. Có nhiều cách thức khác nhau để phân loại các ứng dụng nhận dạng biển số xe. Một trong những cách đơn giản là phân loại ứng dụng nhận dạng biển số xe thông qua mục đích sử dụng. Có thể chia ứng dụng nhận dạng biển số xe thành hai loại sau: 1 Đầu vào: Ảnh thu trực tiếp từ các thiết bị ghi nhận ảnh kỹ thuật số. Ảnh được ghi nhận thường chỉ giới hạn trong vùng có biển số xe. Nguyên lý hoạt động: Các phương tiện giao thông phải chạy với một tốc độ đủ chậm để máy ghi nhận hình ảnh co thể thu được ảnh vùng biển số xe. Ứng dụng: Những ứng dụng nhận dạng biển số xe loại này thường được dung tại cac trạm kiểm soát, các trạm thu phí, các bãi gửi xe tự động, các trạm gác cổng. 2 Đầu vào: Ảnh đầu vào thu được từ các thiết bị ghi hình tự động, không phụ thuộc vào góc độ, các đối tượng xung quanh, ảnh không cần bắt buộc chỉ chụp vùng chứa biển số xe, mà có thể ảnh tổng hợp như chứa them các đối tượng như người, cây, đường phố , miễn là vùng biển số xe phải đủ rõ để có thể thực hiện nhận dạng được các ký tự trong vùng đó. Nguyên lý hoạt động: Do đặc tính không giới hạn vùng nhìn mà ảnh đầu vào có thể thu được từ một thiết bị ghi hình (camara, máy ảnh ). Và do đó, công việc đầu tiên là dò tìm trong ảnh, để xác định đúng vùng nào là biển số xe. Sau đó, thực hiện tách vùng và nhận dạng. Cuối cùng tùy thuộc vào mục đích sử dụng mà kết quả nhận dạng được truyền đi hay lưu trữ để phục vụ nhu cầu của người dùng cuối. Ứng dụng: Vì không phụ thuộc vào hình ảnh thu được nên có thể dùng ứng dụng tại nhiều nơi như tại những nơi điều tiết giao thông, tại các vị trí nhạy 22
  15. cảm của giao thông như ngã ba, ngã tư đường giao nhau. Kiểm soát, phát hiện những hành vi vi phạm an toàn giao thông. : - - - – - - Trong quá trình tìm hiểu, xây dựng ứng dụng của mình. Ứng dụng mà em hướng tới trong quá trình xây dựng là ứng dụng loại 2. Vì vậy, trong toàn bộ báo cáo này, chỉ nêu cách thức giải quyết là làm sao nhận dạng (lọc ra) được các ký tự số và chữ. b) Ứng dụng của hệ thống nhận dạng biển số xe: Hệ thống nhận dạng biển số xe được xây dựng nhằm mục đích giám sát, kiểm soát các phương tiện. Dưới đây chúng ta đề cập đến một số ứng dụng phổ biến đối với hệ thống nhận dạng biển số xe: +) . +) . +) . Ngo thô ) 23
  16. 1.2.2 Phân loại biển số xe: Trước tiên là quy định biển số của 64 tỉnh thành (Biển trắng chữ đen): 11 - Cao Bằng 43 - Đà Nẵng 77 - Bình Định 12 - Lạng Sơn 47 - Đắc Lắc 78 - Phú Yên 14 - Quảng Ninh 48 - Đắc Nông 79 - Khánh Hòa 15,16 - Hải Phòng 49 - Lâm Đồng 80 - Các đơn vị kinh tế 17 - Thái Bình 50 đến 59 - TP. Hồ Chí thuộc TW (hàng không) 18 - Nam Định Minh 81 - Gia Lai 19 - Phú Thọ 60 - Đồng Nai 82 - KonTum 20 - Thái Nguyên 61 - Bình Dương 83 - Sóc Trăng 21 - Yên Bái 62 - Long An 84 - Trà Vinh 22 - Tuyên Quang 63 - Tiền Giang 85 - Ninh Thuận 23 - Hà Giang 64 - Vĩnh Long 86 - Bình Thuận 24 - Lào Cai 65 - Cần Thơ 88 - Vĩnh Phúc 25 - Lai Châu 66 - Đồng Tháp 89 - Hưng Yên 26 - Sơn La 67 - An Giang 90 - Hà Nam 27 - Điện Biên 68 - Kiên Giang 92 - Quảng Nam 28 - Hòa Bình 69 - Cà Mau 93 - Bình Phước 29,30,31,32 - Hà Nội 70 - Tây Ninh 94 - Bạc Liêu 33 - Hà Tây 71 - Bến Tre 95 - Hậu Giang 34 - Hải Dương 72 - Bà Rịa - Vũng Tàu 97 - Bắc Cạn 35 - Ninh Bình 73 - Quảng Bình 98 - Bắc Giang 36 - Thanh Hóa 74 - Quảng Trị 99 - Bắc Ninh 37 - Nghệ An 75 - Huế 38 - Hà Tĩnh 76 - Quảng Ngãi *) Những quy định về màu sắc và chữ số đặc biệt: 1. Màu xanh chữ trắng là biển xe của các cơ quan hành chính sự nghiệp: - Trực thuộc chính phủ thì là biển xanh 80 24
  17. - Các tỉnh thành thì theo số tương ứng 2. Màu đỏ chữ trắng là biển xe trong quân đội: AT: Binh đoàn 12 AD: Quân Đoàn 4 , Binh đoàn cửu long BB: bộ binh BC: Binh chủng Công Binh BH: Binh chủng hoá học BS: Binh đoàn Trường Sơn BT: Binh chủng thông tin liên lạc BP: Bộ tư lệnh biên phòng HB: Học viện lục quân HH: Học viện quân y KA: Quân khu 1 KB: Quân khu 2 KC: Quân khu 3 KD: Quân khu 4 KV: Quân khu 5 KP: Quân khu 7 KK: Quân khu 9 PP: Các quân y viện QH: Quân chủng hải quân QK, QP: Quân chủng phòng không không quân TC: Tổng cục chính trị TH: Tổng cục hậu cần TK: Tổng cục công nghiệp quốc phòng TT:Tổng cục kỹ thuật TM: Bộ tổng tham mưu VT: Viettel 3. Màu trắng 2 chữ, 5 số là biển dành cho người nước ngoài: - NG là xe ngoại giao 25
  18. - NN là xe của các tổ chức, cá nhân nước ngoài: Trong đó 3 số ở giữa là mã quốc gia, 2 số tiếp theo là số thứ tự. * Xe số 80 NG xxx-yy là biển cấp cho các đại sứ quán, thêm gạch đỏ ở giữa và 2 số cuối là 01 là biển xe của tổng lãnh sự 4. Những xe mang biển 80 gồm có : - Các Ban của Trung ương Đảng - Văn phòng Chủ tịch nước - Văn phòng Quốc hội - Văn phòng Chính phủ - Bộ Công an - Xe phục vụ các đồng chí uỷ viên Trung ương Đảng công tác tại Hà Nội và các thành viên Chính phủ - Bộ ngoại giao - Viện kiểm soát nhân dân tối cao - Toà án nhân dân tối cao - Đài truyền hình Việt Nam - Đài tiếng nói Việt Nam - Thông tấn xã Việt Nam - Báo nhân dân - Thanh tra Nhà nước - Học viện Chính trị quốc gia - Ban quản lý Lăng, Bảo tàng, khu Di tích lịch sử Hồ Chí Minh; - Trung tâm lưu trữ quốc gia - Uỷ ban Dân số kế hoạch hoá gia đình - Tổng công ty Dầu khí Việt Nam - Các đại sứ quán, tổ chức quốc tế và nhân viên người nước ngoài - Uỷ ban Chứng khoán Nhà nước - Cục Hàng không dân dụng Việt Nam - Kiểm toán nhà nước 26
  19. 5. Các biển A : Xe của Công An - Cảnh Sát tương ứng với các tỉnh ví dụ: 31A = xe của Công An - Cảnh Sát thành phố Hà Nội 1.3. Một số hƣớng giải quyết bài toán nhận dạng biển số xe: Có rất nhiều phương pháp tiếp cận. Trong đó có hai cách tiếp cận phổ biến dưới đây: 1.3.1. Hƣớng tiếp cận phát triển vùng: Nhóm tác giả Nigel Whyte and Adrien Kiernan được đại diện cho cách tiếp cận này Ý tưởng của phương pháp này: đó là biển số xe thường chứa một màu đồng nhất, chẳng hạn màu trắng, và có diện tích tương đối nhất định. Vì vậy có thể dùng phương pháp phát triển vùng, hoặc sử dụng khung chữ nhật di chuyển trong để tìm ra vùng có tính chất thỏa mãn biển số xe và tiến hành nhận dạng. Ưu điểm: rất đơn giản, và xử lý rất nhanh đối với những ảnh chỉ chứa vùng biển số xe. Nhược điểm: khi ảnh có thêm nhiều đối tượng không phải là vùng biển số xe, chẳng hạn là ảnh chụp tổng quát gồm cả cảnh vật bên ngoài thì cách tiếp cận này trở nên không hiệu quả. Vì vậy phương pháp này rất hiệu quả đối với hệ thống trạm thu phí, trạm gác cổng, gửi xe tự động 1.3.2. Hƣớng tiếp cận dò biên và biến đổi Hough: Nhóm tác giả Michael Lidenbaum, Rosen Alexander, Vichik Sergey, Sandler Roman được đại diện cho cách tiếp cận này. Ý tưởng của cách tiếp cận này là: Biển số xe được bao boc bởi đường viền. Do đó, có thể dùng phương pháp phát hiện biên, sau đó dùng phép biến đổi Hough để trích những đoạn thẳng dọc, ngang tồn tại trong ảnh. Giao điểm của những đoạn thẳng này chính là vùng bao chứa biển số xe. Và cuối cùng là tiến hành nhận dạng các ký tự ở trên mỗi vùng con. Ưu điểm: độ chính xác cao. Và các hệ thống nhận dạng đa phần đều phát triển theo hướng tiếp cận này. 27
  20. Nhược điểm: Độ phức tạp tính toán khá cao. Khi ảnh có thêm nhiêu đối tượng khác thì khối lượng tính toán tăng lên rất nhiều. Do mục đích là phải xác định được vùng con nào chứa biển số xe. Ngoài hai cách tiếp cận trên, còn có nhiều cách tiếp cận khác để xác định chính xác vùng nào chứa biển số xe và bước cuối cùng là tiến hành nhận dạng ký tự. Mỗi cách tiếp cận có một ưu và nhược điểm. Đa số các ứng dụng đều sử dụng cách tiếp cận biến đổi Hough.Trong báo cáo đề tài của em,em xin trình bày cách tiếp cận Hough. 1.4 Hƣớng giải quyết: Ở phần 1.3 chúng ta đã tìm hiểu 2 hướng giải quyết cho việc xác đinh vùng chứa biển số xe. Mỗi cách giải quyết có những ưu điểm và hạn chế riêng của nó. *) Một số đặc điểm về biển số xe ở Việt Nam: Tiêu chuẩn về kích thước: Ở mỗi nước thường có tiêu chuẩn về kích thước nhất định. Đối với nước ta, biển số xe qui định khá đồng đều cho mỗi loại xe, tỷ lệ chiều dài, rộng cho mỗi loại xe là như nhau. Đối với loại xe có một hàng ký tự thì tỉ lệ dài/ rộng là: 3.5 W / H 4.5 . Đối với loại xe có hai hàng ký tự thì tỷ lệ đó là: 0.8 W / H 1.4 . Từ các đặc tính này, ta có thể xác định được các vùng con thỏa mãn các tiêu chí về ngưỡng tỷ lệ dài/rộng. Và chỉ những vùng con thỏa mãn thì khả năng chứa biển số xe là cao 28
  21. Số lượng ký tự trong biển số xe. Mỗi ký tự thường có tỷ lệ kích thước về chiều rộng, chiều cao tương ứng với chiều dài và rộng của biển số xe. Ví dụ, chiều cao của mỗi ký tự luôn nhỏ hơn 85% chiều cao của biển số xe và luôn lớn hơn 33% chiều cao của biến xe. Còn chiều rộng của ký tự không lớn hơn 20% chiều dài của biển số xe. Mỗi ký tự của biển số xe được xem như là một vùng liên thông con. Do đó, chúng ta có thể đếm vùng liên thông con thỏa mãn tính chất đó là ký tự. Chú ý số ký tự trên biển số xe là từ 6 đến 10 ký tự. Ở nước ta chỉ có số ký tự trên mỗi biển số xe nằm trong khoảng 6 đến 8 ký tự. Vậy ta có thể dùng ngưỡng [6.8] để nhận dạng vùng biển số xe. Từ những nhận xét trên, chúng ta có thể đưa ra giải pháp cho bài toán nhận dạng: sử dụng phương pháp phát hiện biên và biến đổi Hough. Sau đó, sử dụng hai tính chất trên biển số xe để xác định chính xác vùng con chứa biển số xe. Khi đã xác định chính xác vùng con chứa biển số xe thì tiến hành nhận dạng các ký tự. Để giải quyết bài toán nhận dạng biển số xe, trong báo cáo em xin trình bày 3 bước như sau: Bước 1: Ảnh vào ảnh mức xám I(x,y) thực hiện theo phương pháp dò biên và biến đổi Hough để tìm ra các vùng con có khả năng chứa biển số xe. Gọi tập con này là Ic. Bước 2: Xác định chính xác vùng con nào chứa biển số xe bằng hai thao tác được miêu tả ở trên đó là tiêu chí tỷ lệ chiều dài với chiểu rộng và số ký tự trong biển số xe. Kết quả của bước 2 là cho ra một tập ảnh con chứa biển số ' xe. Gọi tập con này là I c . Bước 3: Giải quyết bài toán nhận dạng ký tự cho tập . Bằng cách áp dụng phương pháp và kỹ thuật nhận dạng ký tự Qua ba bước như trên ta có thể nhận dạng được biển số xe . Trong bước 3: nhận dạng ký tự em sử dụng phương pháp mạng noron truyền ngược cho việc nhận dạng ký tự. 29
  22. Trong phần tiếp theo đó là chi tiết từng bước xử lý bài toán nhận dạng biển số xe, và một số khái niệm cơ bản quen thuộc mà có liên quan đến nhận dạng biển số xe. 30
  23. Chƣơng 2: PHÁT HIỆN VÙNG CHỨA BIỂN SỐ XE 2.1 Một số khái niệm cơ bản: 2.1.1 Tổng quan về ảnh a. Ảnh và điểm ảnh: Ảnh là mảng số thực hai chiều I m,n , có kích thước (MxN), trong đó mỗi giá trị I m,n (tại một điểm ảnh), biểu thị mức xám của ảnh tại vị trí m,n tương ứng Một ảnh là ảnh nhị phân nếu giá trị bằng 0 hoặc 1. b. Mức xám: Mức xám là kết quả sự mã hóa tương ứng một cường độ sang của mỗi điểm ảnh với một giá trị số- kết quả của quá trình lượng hóa. Cách mã hóa kinh điển thường dùng 16, 32, 64. Mã hóa 256 mức là phổ dụng nhất do lý do kỹ thuật. Vì 28= 256, nên với 256 mức, mỗi pixel được mã hóa 8bit. c. Đối tượng ảnh: Trong phần này ta chỉ xét với ảnh nhị phân, vì mọi ảnh nhị phân đều có thể đưa về ảnh nhị phân bằng các kỹ thuật phân ngưỡng. Ta ký hiệu E là tập các điểm vùng (điểm đen) và E là tập các điểm nền (điểm trắng). Hai điểm Is và Ie nằm trong E (hoặc ) được gọi là 4 liên thông (8 liên thông) nếu tồn tại một dãy các điểm gọi là đường đi: i0 , j0 = Is và in , jn = Ie i1, j1 . in , jn mà ik , jk E với mọi k= 0,1 ,n ik , jk là 4 láng giếng (8 láng giếng) của ik 1 , jk 1 với mọi k= 1, 2, ,n d. 4- Láng giềng và 8- láng giềng: Nếu là một điểm ảnh, thì 4 láng giềng của nó là các điểm ở ngay bên trên, dưới, phải, và trái. Ta ký hiệu N 4 là tập 4 láng giềng của điểm . N 4 m 1,n , m 1,n , m,n 1 , m,n 1 31
  24. Tương tự ta có tập 8- láng giềng N 8 N 8 N4 m 1,n 1 , m 1,n 1 , m 1,n 1 , m 1,n 1 e. Chu tuyến của ảnh: Định nghĩa chu tuyến: Chu tuyến của một đối tượng ảnh I m,n là dãy các điểm của đối tượng: ' ’ p0 p1 pn . Sao cho pi 1 , pi 1 là 8 láng giềng của pi , p I và p là 4 láng giềng của pi, và p0 pn . Khi đó ta gọi n là độ dài hay chu vi của chu tuyến. Chu tuyến đối ngầu: Hai chu tuyến C= và C’= được gọi là hai chu tuyến đối ngẫu của nhau nếu và chỉ nếu: i j sao cho Pi và Qj là 8 láng giềng của nhau Các điểm Pi là ảnh thì Qj là nền và ngược lại. Chu tuyến trong: Chu tuyến C được gọi là chu tuyến trong nếu và chỉ nếu: Chu tuyến đối ngẫu C’ của nó là chu tuyến của các điểm nến. Độ dài của chu tuyến C’ nhỏ hơn độ dài của chu tuyến C Chu tuyến ngoài: Chu tuyến C được gọi là chu tuyến ngoài nếu và chỉ nếu: Chu tuyến đối ngẫu C’ của C là chu tuyến các điểm nền Độ dài của chu tuyến C’ lớn hơn độ dài của chu tuyến C Từ định nghĩa, ta thấy chu tuyến ngoài của một đối tượng là một đa giác có độ dày bằng một bao quanh đối tượng. 2.1.2 Phƣơng pháp tách dò ngƣỡng tự động h g : là tổng số mức xám g Gọi: t g h i i g Trong đó: P – Số điểm ảnh được xét= m*n G – Số mức xám được xét 32
  25. g ih i g m g i 0 iP i Gọi t g là giá trị trung bình cấp xám g i 0 t g f g m g m G 1 2 1 P t g argmax f g với 0 g G -1 Vậy suy ra là ngưỡng của ảnh 2.2 Biên và các phƣơng pháp phát hiện biên. *) Khái niệm về biên: Biên là một vấn đề chủ yếu trong phân tích ảnh vì các kỹ thuật phân đoạn ảnh chủ yếu dựa vào biên. Một điểm ảnh có thể coi là điểm biên nếu có sự thay đổi đột ngột và mức xám hay biên là điểm có cấp xám có giá trị khác hẳn các điểm xung quanh. Tập hợp các điểm biên tạo thành biên hay đường bao của ảnh *) Các phương pháp phát hiện biên: *) Phương pháp tiếp cận theo kiểu cổ điển Đây là phương pháp dựa vào sự biến thiên về giá trị độ sang của điểm ảnh. Kỹ thuật chủ yếu dùng phát hiện biên ở đây là kỹ thuật đạo hàm. Nếu lấy đạo hàm bậc nhất của ảnh ta có phương pháp Gradient, nếu lấy đạo hàm bậc hai ta co kỹ thuật Laplace. Hai phương pháp trên được gọi là phương pháp dò biên cục bộ. 2.2.1 Phƣơng pháp gradient Dựa vào cực đại hóa của đạo hàm. Theo định nghĩa, gradient là một vecto có các thành phần biểu thị tốc độ thay đổi giá trị của điểm ảnh theo 2 hướng x và y. Các thành phần của Gradient được tính bởi: f (x, y) f (x dx, y) f (x, y) fx x dx f (x, y) f (x, y dy) f (x, y) fx y dy Đổi sang tọa độ cực x rcos y rsin Suy ra: 33
  26. f f f cos sin r x y f f f ( r sin ) cos r x y Với dx là khoảng cách giữa các điểm theo hướng x (khoảng cách tính bằng số điểm) và tương tự với dy. Trên thực tế người ta hay dùng với dx= dy= 1 Với một ảnh liên tục f(x, y), các đạo hàm riêng của nó cho phép xác định vị trí cục bộ theo hướng của biên. Thực vậy, gradient của một ảnh liên tục, được biểu diễn bởi một hàm f(x,y), dọc theo r với góc , được định nghĩa bởi: df f dx f dy = fxcos + fysin dr x dr y dr Chú ý: khi ta nói lấy đạo hàm của ảnh nhưng thực ra chỉ là mô phỏng và xấp xỉ đạo hàm bằng các kỹ thuật nhân chập (phép cuộn). Do ảnh số là tín hiệu rời rạc nên đạo hàm không tồn tại Kỹ thuật Gradient sử dụng một cặp mặt nạ H1 và H2 trực giao (theo 2 hướng vuông góc). Nếu định nghĩa g1, g2 là gradient tương ứng theo 2 hướng x và y, thì biên độ của gradient, ký hiệu là g tại điểm (m,n) được tính theo công thức: 2 2 A0= g(m,n)= g1 (m,n) g 2 (m,n) (1) 1 (m,n) tan (g 2 (m,n) / g1 (m,n)) (2) Chú ý: để giảm tính toán, công thức (1) được tính gần đúng bởi: A0 g1 (m,n) g 2 (m,n) Các toán tử đạo hàm được áp dụng là khá nhiều, ở đây, ta chỉ xét một số toán tử tiêu biểu: toán tử Robert, Solbel *)Kỹ thuật Robert Với mỗi điểm ảnh I(x,y) của I, đạo hàm theo x, theo y được ký hiệu tương ứng bởi gx, gy được tính: g I(x 1, y) I(x, y) x g y I(x, y 1) I(x, y) Điều này tương đương với việc chập ảnh với 2 mặt nạ H1 và H2: 34
  27. 0 1 1 0 H H 1 1 0 2 0 1 Quá trình tính toán được thực hiện qua các bước sau: Bước 1: Tính I x I H x và I y I H y 2 2 Bước 2: Tính I x I y 2 2 Từ ma trận I x I y chọn ra các điểm cao thứ 2, hoặc thứ 3 chiếm đa số *)Kỹ thuật PreWitt: Kỹ thuật này sử dụng hai mặt nạ H1 và H2: 1 0 1 1 2 1 H1 2 0 2 H 2 0 0 0 1 0 1 1 2 1 Quá trình tính toán được thực hiện qua 2 bước: Bước 1: Tính I H x và I H y Bước 2: Tính I H x + I H y *)Kỹ thuật Sobel: Tương tự như kỹ thuật PreWitt, kỹ thuật Sobel sử dụng 2 ma trận mặt nạ nhân chập là: 1 0 1 1 1 1 H1 1 0 1 H 2 0 0 0 1 0 1 1 1 1 2.2.2. Kỹ thuật Laplace: Các phương pháp đánh giá Gradient ở trên làm việc khá tốt khi mà độ sang thay đổi rõ nét. Khi mức xám (giá trị tại một điểm của ảnh ) thay đổi chậm, miền chuyển tiếp trải rộng, thì ta có phương pháp Laplace (đạo hàm bậc hai) có hiệu quả hơn. Toán tử Laplace được định nghĩa như sau: 2 f 2 f 2 f dx2 dy2 Vậy suy ra ta có: 35
  28. 2 f f f x 1, y f x, y f x 1, y f x, y f x, y f x 1, y x 2 x x x f x 1, y 2 f x, y f x, y 1 Tương tự ta có: 2 f f x, y 1 2 f x, y f x, y 1 y 2 Toán tử Laplace dùng nhiều kiểu mặt nạ khác nhau để xấp xỉ rời rạc đạo hàm bậc 2. Dưới đây là 3 kiểu mặt nạ hay dùng: 0 1 0 1 1 1 1 2 1 H1 1 4 1 H 2 1 8 1 H 2 2 5 2 0 1 0 1 1 1 1 2 1 Quá trình tính toán được thực hiện qua các bước sau: Bước 1: H I Bước 2: H I x, y Bước 3: Tách ngưỡng Ý nghĩa hình học: H I x, y 4I x 1, y 1 I(x 1, y) I x, y 1 I x 2, y 1 I x 1, y 2 = I(x+1, y+1)- I(x+1, y) + I(x+1, y+1)- I(x, y+1) + I(x+1, y+1)- I(x+2, y+1) + I(x+1, y+1) – I(x+1, y+2) I x 1, y I x, y 1 I x 1, y 1 I x 1, y 1 y x y x 2 I x 1, y 1 2 I x 1, y 1 2 I x 2 y 2 36
  29. 2.3 Phát hiện vùng chứa biển số xe Sơ đồ các bước được mô tả trong hình dưới Ảnh đầu vào Nhị phân hóa Tách biên Biến đổi Hough Thu được vùng con Ic Hình 2.1: Sơ đồ giải quyết Ảnh đầu vào: là một ảnh có 256 mức xám, được nhị phân hóa thành ảnh nhị phân. Mục đích của giai đoạn nhị phân hóa ảnh là nhằm làm nổi bật vùng biển số xe. Khi ta tách biên, vùng bao của biển số xe sẽ hiện lên rõ ràng. Sau đó dùng phương pháp phát hiện biên để có được biên dọc vào ngang của ảnh. Kết quả của công đoạn này, ảnh thu được là ảnh nhị phân chỉ chứa các cạnh dọc và ngang. Thực hiện biến đổi Hough cho các đoạn biên vừa lấy được và xác định các đoạn thẳng đi qua tập các điểm biên của mỗi biên, kết quả sẽ là các đoạn thẳng ngang và dọc. Giao của những đoạn thẳng này sẽ cho ra vùng con Ic 2.3.1. Nhị phân hóa ảnh Ảnh ban đầu được sử dụng là ảnh 256 mức xám. Việc sử dụng ảnh 256 mữc xám không làm giảm đi tính đa năng của ứng dụng. Trên thực tế, ảnh 256 mức xám vẫn được sử dụng nhiều, và nhiều thiết bị ghi hình cũng có khả năng tự chuyển ảnh màu thành ảnh 256 mức xám. Tuy nhiên, nếu để ảnh 256 mức xám thì việc phát hiện biên không hiệu quả, vì sự thay đổi liên tục của các mức xám làm cho việc xác định biên không phải dễ dàng, và việc tìm ra các vùng liên tục của biên khá hạn chế. Vì vậy, chúng ta thực hiện chuyển ảnh về dạng nhị phân để thực hiện việc lấy biên nhanh hơn. 37
  30. void Binarize// Nhị phân hóa ảnh { // Ảnh đầu vào: ảnh 256 mức xám // Đầu ra là ảnh nhị phân P: là tổng số điểm ảnh được xét (m,n) g(j,j) tương ứng là mức xám của điểm ảnh I(i,j) : là ngưỡng của ảnh được xác định theo phương pháp ở trên. for(int i= 0; i< m; i++) for(int j= 0; j< n; j++) if(g(i, j)<= ) { Ic(I, j)= 0 }else Ic(I, j)= 1 } Vậy ta thu được ảnh nhị phân Ic, ảnh nhị phân thu được vẫn đảm bảo tách biệt giữa vùng chứa biển số xe với vùng xung quanh. Đồng thời loại bỏ những vùng đồng nhất và ít biến thiên. 2.3.2 Tách biên: Vì biển số xe có viền bao quanh, nên chúng ta cần làm nổi bật đường biên (boundary). Các đường biên có thể được xem là các cạnh dọc và ngang. Mục đích của giai đoạn này là tách ra các cạnh dọc và ngang để tìm ra vùng con chứa biển số xe nhờ tính giao điểm của các cạnh dọc và ngang. Ở đây, ảnh đầu vào là ảnh nhị phân, nên thích hợp với phương pháp đạo hàm bậc nhất. Dùng hai ma trận Sobel theo hai hưỡng x(dọc) và y(ngang) để tách các cạnh của ảnh 1 0 1 1 2 1 H1 2 0 2 H 2 0 0 0 1 0 1 1 2 1 38
  31. Void BoundaryDetach() {// Tách biên của ảnh // Ảnh đầu vào: ảnh 256 mức xám // Đầu ra là I’(i, j) P: là tổng số điểm ảnh được xét (m,n) g(j,j) tương ứng là mức xám của điểm ảnh I(i,j) : là ngưỡng của ảnh được xác định theo phương pháp ở trên. // Trước hết tính hai ma trận ảnh theo trục dọc x và ngang y Ix = H1* I, Iy = H2* I for(int i= 0; i< m; i++) for(int j= 0; j< n; j++) I’(I,j)= Ix(I, j)+ Iy(I, j); } Kết quả thu được , một ảnh cạnh dọc Ix và một cạnh ngang Iy. Có thể xem ảnh ở dưới với phương pháp Sobel. 2.3.3 Biến đổi HOUGH Biến đổi Hough là phương pháp dùng để xác định đường thẳng (đường tròn elip) gần đúng đi qua một tập hợp điểm. Với (x,y) là một điểm y mx c c mx y Như vậy nếu có N điểm nằm trên 1 đường thẳng mx c y c y x m i i i i i 1, N i 1, N Thay vì tìm N điểm trên đường thẳng, người ta xét tất cả các điểm, xem điểm nào có nhiều đường thẳng đi qua nhất 39
  32. Hình 2.2 Trục tọa độ đề các đi qua 2 điểm C= y2-x2m C= y1-x1m Hình 2.3. Trục tọa độ đề các Thực chất biến đổi Hough là biến điểm thành đường thẳng a m c 0 m,c xi , yi m,c tm c yi xi m thi a m c Sau đó đếm trên ma trận Hạn chế: hệ số 0 m 1 m 1 thì lưu a c m m 1 thì lưu a m c 40
  33. Biến đổi Hough theo tọa độ cực (x,y) r Hình 2.4: Hệ tọa độ cực Các điểm trên đường thẳng có tọa độ cực t/m r x.cos y.sin với M 2 N 2 0 360 và r với M và N là chiều cao và chiều rộng của ảnh 2 Lấy tại tâm ảnh r, a r 0 r, x, y neu r x cos y sin thi a r x1,y1 x2,y2 Biến dổi Hough pi , i Hình 2.5. Đƣờng thẳng Hough trong tọa độ cực Biến đổi Hough ánh xạ N điểm này thành N đường sin trong tọa độ cực mà các đường này đều đi qua điểm ( ri , i ). Giao điểm ( ri , i ) của N đường sin sẽ xác định một đường thẳng trong hệ tọa độ các. Như vậy, những đường thẳng đi 41
  34. qua điểm xi , yi sẽ cho duy nhất một cặp ( ri , i ) và có bao nhiêu đường qua sẽ có bấy nhiêu cặp giá trị ( ri , i ). Mục đích là tìm ra cặp r, sao cho số đường hình sin đi qua nhiều nhất, và cặp đó chính là cặp tham số cho đường thẳng 2.3.4 Trích chọn đoạn thẳng và tính giao điểm Sau khi xây dựng các đường thẳng Hough, chúng ta thu được hai tập đường thẳng: tập đường thẳng dọc và tập đường ngang các ảnh nhị phân cạnh dọc và ngang. Tiếp theo, chúng ta xác định giao điểm của các đường này này để tạo thành các vùng con là các tứ giác có khả năng chứa biển số xe. Tuy nhiên, lượng vùng con có được là rất nhiều. Do vậy, chúng ta thay vì tính giao điểm của các đường thẳng, mà chúng ta sẽ thực hiện việc tính giao điểm của các đoạn thẳng. Các đoạn thẳng chính là các đoạn đi qua tập hợp điểm được xác định thông qua đường thẳng Hough. Việc xác định các đoạn thẳng này là đơn giản thông qua hai đầu mút của đoạn thẳng. Một cách đơn giản, ta có thể xem đầu mút trên (hoặc bên trái) là điểm trong tập hợp điểm nằm trên đường thẳng Hough có tổng tọa độ theo trục x và y là nhỏ nhất. Điểm đầu mút dưới (hoặc bên phải) là điểm nằm trong tập hợp điểm nằm trên đường thẳng Hough có tổng tọa độ theo x và y là lớn nhất. Để đảm bảo rằng các đường thẳng dọc, ngang (từ ảnh cạnh dọc, ngang) có thể cắt nhau như trong thực tế, chúng ta cần mở rộng các đoạn thẳng về hai hướng mỗi đoạn 5 điểm. Như vậy đoạn thẳng mà chúng ta sử dụng so với đoạn thẳng thực tế sx dài hơn nhiều hơn khoảng 10 điểm. Kết quả của phép biến đổi Hough va trích chọn đoạn thẳng được mô tả trong hình dưới Việc tính giao điểm của các đoạn thẳng là khá đơn giản. Chúng ta chỉ cần tính giao điểm của các đường thẳng Hough và kiểm tra xem giao điểm đó cao nằm trên đoạn thẳng được trích chọ ra hay không. Giao điểm của các đoạn thẳng sẽ là các vùng con Ic có khả năng chứa biển số xe. Kết quả của phần trên cho chúng ta một tập các vùng con Ic là các tứ giác. Đến đây, chúng ta có thể khẳng định bài toán trên chính là thực hiện theo phương pháp biến đổi Hough. Tuy vậy, điểm khác biệt (cũng là điểm tiến bộ) 42
  35. của phương pháp trình bày trong tiểu luận này là: phương pháp biến đổi Hough chỉ dừng lại ở bươc này, và sau đó thực hiện tiến hành nhận dạng các ký tự trong các vùng con ngay. Việc nhận dạng có thể có nhiều phương pháp khác nhau, nhưng với mỗi vùng con đang còn một lượng khá lớn. Vậy trong bài tiểu luận này em không chỉ dừng lại trong việc tìm ra các vùng con Ic, mà tìm tiếp những vùng con có xác suất chứa biển số xe, loại đi những vùng mà khả năng tồn tại của biển số xe là rất ít. Vậy có, tập các vùng con Ic được thu hẹp, làm cho không gian bài toán nhận dạng thu hẹp lại. Vì vậy, cách giải quyết này trở nên nhanh hơn, hiệu quả hơn cách tiếp cận biến đổi Hough, không phụ thuộc nhiều vào không gian ảnh đầu vào. 2.3. Xác định chính xác vùng chứa biển số xe Kết quả của bài toán trên đưa ra tập các vùng con Ic có khả năng chứa biển số xe. Các vùng con này là các tứ giác. Tuy nhiên, số lượng các vùn con Ic là khác nhiều, chưa thể đảm bảo chính xác vùng nào chứa biển số xe để thực hiện việc cuối cùng là nhận dạng ảnh. Vì vậy, phải loại bỏ đi những vùng con trong Ic không có khả năng chứa biến số xe. Sơ đồ thực hiện bài toán này: Vùng con Ic Bước ban đầu Tiêu chí về chiều rộng và cao Tiêu chí số ký tự Vùng con Ib Hình 2.6: Sơ đồ thực hiện bài toán này 43
  36. 2.3.1. Bƣớc ban đầu: Ta biết: Biển số xe trên thực tế có hình dạng là hình chữ nhật. Vì vậy, khi chụp ảnh của biển số xe sẽ có dạng tựa hình bình hành. Trường hợp tối ưu là ảnh hình chữ nhật. Do đó, trong quá trình xét duyệt các vùng con Ic, nếu hình nào không có hình dạng tựa hình bình hành thì có thể loại bỏ ngay mà không cần tính đến. Ta có thể xem hình tứ giác tựa hình bình hành có những đặc điểm sau: Các góc không có nhỏ. Có thể lấy ngưỡng là 450 Hai góc đối không chênh lệch quá lớn. Lấy ngưỡng 300 Biến số xe phải có một diện tích nào đó, và đủ lớn để có thể nhận diện ra ký tự tồn tại trên đó. Vì vậy, những vùng con có diện tích nhỏ hơn một ngưỡng nào đó, thì loại bỏ ngay và chú ý kích thước chiều dài và rộng của vùng con I . ci Vậy thì chu vi của vùng con nhỏ hơn ngưỡng nào đó thì có thể loại bỏ ngay Void Filter { // Đầu vào là tập vùng con Ic ' // Đầu ra: tập vùng con I c // là ngưỡng về chu vi // Perimeter( ) là chu vi của mỗi vùng con Ic // N là số vùng con For(int i=0; i ) // Caclulate goc A,B,C,D của mỗi vùng con If( A && B && C && D thỏa mãn ngưỡng) Copy( I ' , ) ci } } Sau khi loại bỏ đi những vùng con theo hai tiêu chí trên, chúng ta thu được tập con . Vì thực tế biển số xe có hình chữ nhật, nên ta có thể dùng phép tịnh tiến, phép quay, phép tỷ lệ để đưa các vùng con thành các hình chữ nhật. 44
  37. Lý do để đưa các hình tứ giác thành hình chữ nhật vì biển số xe có dạng hình chữ nhật, các ký tự nằm trong vùng biển số xe vuông góc với cạnh dài của hình chữ nhật. Khi thu được ảnh, có nhiều nguyên nhân làm cho ảnh biển số xe bị nghiêng. Kéo theo đó, các ký tự cũng bị nghiêng theo, làm cho việc nhận dạng trở nên không chính xác. Việc nắn tứ giác trở lại thành hình chữ nhật và cũng nắn các ký tự trở nên thành đứng. Và khi trở thành hình dạng chữ nhật, thì biển số xe mới thể hiện rõ tính tỷ lện chiều dài/rộng. Và ta có các tiêu chí dưới đây. 2.4.2 Tiêu chí tỷ lệ chiều dài/rộng. Với mỗi quốc gia, thì biển số xe có kích thước nhất định. Và thể hiện thông qua tỷ lệ giữa các cạnh. Ví dụ với biển số xe ở nước ta: với biển số có một hàng thì tỷ lệ nằm trong khoảng 3.5 W H 4.5 và với biển số xe có hai hàng thì tỷ lệ là 0.8 W H 1.4. Và kết quả của tiêu chí tỷ lệ chiều dài/rộng là thu được ' một tập con của I c chứa biển số xe. Vậy ta có giải thuật Void RatioWH { // Đầu vào là tập con '' // Đầu ra là tập con I c của // Gọi edge_ratio= tỷ lệ chiều dài/rộng // là ngưỡng chiều dài/rộng [0.8,4.5] For(int i=0;i< N;i++) { Int m= edge_ratio( I ' ) ci If(m [0.8,4.5] ) Copy( I '' , ) ci } } Kết quả: tập các vùng con có khả năng chứa biển số xe. Với số vùng con nhỏ hơn hẳn số vùng con ma ta thu được ban đầu trong biển đổi Hough. 45
  38. 2.4.3 Tiêu chí số ký tự trong vùng biển số xe Với mỗi nước thì số ký tự trong biển là khác nhau. Ở nước ta, số ký tự trong biển số xe thường là 6,7,8 tương ứng đối với các xe quân đội, xe máy cũ và xe ô tô, đối với xe máy bây giờ. Mỗi ký tự có các đặc trưng sau: 0.33 Height 0.85 Width 0.22 Từ đó ta có ngưỡng sử dụng là [6,8] Void Character { // Đầu vào tập vùng con I '' ci // Đầu ra tập vùng con I ''' ci // N là tổng số vùng con của For(int i= 0; i< N; i++) { Với mỗi vùng con - Tìm vùng liên thông của mỗi - Lưu các thông số về chiều rộng, cao của mỗi vùng liên thông If(thỏa mãn ngưỡng ) thì tiến hành nhận dạng } } Kết quả nếu tìm được biển số xe đầu tiên thỏa mãn, chúng ta có thể dừng thuật toán ngay và chuyển sang bước 3 là nhận dạng ký tự. Nếu tìm tất cả các biển số xe tồn tại trong ảnh, thì bắt buộc phải duyệt qua toàn bộ vùng ảnh. 46
  39. Chƣơng 3: BÀI TOÁN NHẬN DẠNG KÝ TỰ 3.1 Tổng quan về nhận dạng Nhận dạng là quá trình phân loại các đối tượng được biểu diễn theo một mô hình nào đó và gán cho chúng vào một lớp (gán cho đối tượng một tên gọi) dựa theo những quy luật và các mẫu chuẩn. Quá trình nhận dạng dựa vào những mẫu học biết trước gọi là nhận dạng có thày hay học có thày (supervised learning); trong trường hợp ngược lại gọi là học không có thày (non supervised learning). Chúng ta sẽ lần lượt giới thiệu các khái niệm này. 3.1.1 Không gian biểu diễn đối tƣợng, không gian diễn dịch *)Không gian biểu diễn đối tượng Các đối tượng khi quan sát hay thu thập được, thường được biểu diễn bởi tập các đặc trưng hay đặc tính. Người ta thường phân các đặc trưng theo các loại như: đặc trưng tô pô, đặc trưng hình học và đặc trưng chức năng. Việc biểu diễn ảnh theo đặc trưng nào là phụ thuộc vào ứng dụng tiếp theo. Ở đây ta đưa ra một cách hình thức việc biểu diễn các đối tượng. Giả sử đối tượng X (ảnh, chữ viết, dấu vân tay, v ,v) được biểu diễn bởi n thành phần (n đặc trưng): X = {x1, x2, , xn}; mỗi xi biểu diễn một đặc tính. Không gian biểu diễn đối tượng thường gọi tắt là không gian đối tượng X được định nghĩa: X = {X1, X2, , Xm} trong đó mỗi Xi biểu diễn một đối tượng. Không gian này có thể là vô hạn. Để tiện xem xét chúng ta chỉ xét tập X là hữu hạn. *)Không gian diễn dịch Không gian diễn dịch là tập các tên gọi của đối tượng. Kết thúc quá trình nhận dạng ta xác định được tên gọi cho các đối tượng trong tập không gian đối tượng hay nói là đã nhận dạng được đối tượng Một cách hình thức gọi là tập tên đối tượng: = {w1, w2, ,wk} với wi, i = 1, 2, , k là tên các đối tượng 47
  40. Quá trình nhận dạng đối tượng f là một ánh xạ f: X > với f là tập các quy luật để xác định một phần tử trong X ứng với một phần tử trong . Nếu tập các quy luật và tập tên các đối tượng là biết trước như trong nhận dạng chữ viết (có 26 lớp từ A đến Z), người ta gọi là nhận dạng có thày. Trường hợp thứ hai là nhận dạng không có thày. Đương nhiên trong trường hợp này việc nhận dạng có khó khăn hơn. 3.1.2 Mô hình và bản chất của quá trình nhận dạng 3.1.2.1 Mô hình Việc chọn lựa một quá trình nhận dạng có liên quan mật thiết đến kiểu mô tả mà người ta sử dụng để đặc tả đối tượng. Trong nhận dạng, người ta phân chia làm 2 họ lớn: - Họ mô tả theo tham số - Họ mô tả theo cấu trúc. Cách mô tả được lựa chọn sẽ xác định mô hình của đối tượng. Như vậy, chúng ta sẽ có 2 loại mô hình: mô hình theo tham số và mô hình cấu trúc. Mô hình tham số: sử dụng một véctơ để đặc tả đối tượng. Mỗi phần tử của véctơ mô tả một đặc tính của đối tượng. Thí dụ như trong các đặc trưng chức năng, người ta sử dụng các hàm cơ sở trực giao để biểu diễn. Và như vậy ảnh sẽ được biểu diễn bởi một chuỗi các hàm trực giao. Giả sử C là đường bao của ảnh và C(i,j) là điểm thứ i trên đường bao, i = 1, 2, , N (đường bao gồm N điểm). Giả sử tiếp : 1 N x0 = xi N i 1 1 N y0 = yi N i 1 là toạ độ tâm điểm. Như vậy, moment trung tâm bậc p, q của đường bao là: p q pq = (xi-x0) (yi-y0) (7.1) 48
  41. Véctơ tham số trong trường hợp này chính là các moment ij với i=1, 2, ,p và j=1, 2, ,q. Còn trong số các đặc trưng hình học, người ta hay sử dụng chu tuyến , đường bao, diện tích và tỉ lệ T = 4 S/p2, với S là diện tích, p là chu tuyến. Việc lựa chọn phương pháp biểu diễn sẽ làm đơn giản cách xây dựng. Tuy nhiên, việc lựa chọn đặc trưng nào là hoàn toàn phụ thuộc vào ứng dụng. Thí dụ , trong nhận dạng chữ (sẽ trình bày sau), các tham số là các dấu hiệu: - số điểm chạc ba, chạc tư, - số điểm chu trình, - số điểm ngoặt, - số điểm kết thúc, chẳng hạn với chữ t có 4 điểm kết thúc, 1 điểm chạc tư, Mô hình cấu trúc:Cách tiếp cận của mô hình này dựa vào việc mô tả đối tượng nhờ một số khái niệm biểu thị các đối tượng cơ sở trong ngôn ngữ tự nhiên. Để mô tả đối tượng, người ta dùng một số dạng nguyên thuỷ như đoạn thẳng, cung, v, ,v. Chẳng hạn một hình chữ nhật được định nghĩa gồm 4 đoạn thẳng vuông góc với nhau từng đôi một. Trong mô hình này người ta sử dụng một bộ kí hiệu kết thúc Vt, một bộ kí hiệu không kết thúc gọi là Vn. Ngoài ra có dùng một tập các luật sản xuất để mô tả cách xây dựng các đối tượng phù hợp dựa trên các đối tượng đơn giản hơn hoặc đối tượng nguyên thuỷ (tập Vt). Trong cách tiếp cận này, ta chấp nhận một khẳng đinh là: cấu trúc một dạng là kết quả của việc áp dụng luật sản xuất theo theo những nguyên tắc xác định bắt đầu từ một dạng gốc ban đầu. Một cách hình thức, ta có thể coi mô hình này tương đương một văn phạm G = (Vt, Vn, P, S) với: - Vt là bộ ký hiệu kết thúc, - Vn là bộ ký hiệu không kết thúc, - P là luật sản xuất, 49
  42. - S là dạng (ký hiệu bắt đầu). 3.1.2.2 Bản chất của quá trình nhận dạng Quá trình nhận dạng gồm 3 giai đoạn chính: - Lựa chọn mô hình biểu diễn đối tượng. - Lựa chọn luật ra quyết định (phương pháp nhận dạng) và suy diễn quá trình học. - Học nhận dạng. Khi mô hình biểu diễn đối tượng đã được xác định, có thể là định lượng (mô hình tham số) hay định tính (mô hình cấu trúc), quá trình nhận dạng chuyển sang giai đoạn học. Học là giai đoạn rất quan trọng. Thao tác học nhằm cải thiện, điều chỉnh việc phân hoạch tập đối tượng thành các lớp. Việc nhận dạng chính là tìm ra quy luật và các thuật toán để có thể gán đối tượng vào một lớp hay nói một cách khác gán cho đối tượng một tên. *)Học có thày (supervised learning) Kỹ thuật phân loại nhờ kiến thức biết trước gọi là học có thày. Đặc điểm cơ bản của kỹ thuật này là người ta có một thư viện các mẫu chuẩn. Mẫu cần nhận dạng sẽ được đem sánh với mẫu chuẩn để xem nó thuộc loại nào. Thí dụ như trong một ảnh viễn thám, người ta muốn phân biệt một cánh đồng lúa, một cánh rừng hay một vùng đất hoang mà đã có các miêu tả về các đối tượng đó. Vấn đề chủ yếu là thiết kế một hệ thống để có thể đối sánh đối tượng trong ảnh với mẫu chuẩn và quyết định gán cho chúng vào một lớp. Việc đối sánh nhờ vào các thủ tục ra quyết định dựa trên một công cụ gọi là hàm phân lớp hay hàm ra quyết định. Hàm này sẽ được đề cập trong phần sau. *)Học không có thày(unsupervised learning) Kỹ thuật học này phải tự định ra các lớp khác nhau và xác định các tham số đặc trưng cho từng lớp. Học không có thày đương nhiên là khó khăn hơn. Một mặt, do số lớp không được biết trước, mặt khác những đặc trưng của các lớp cũng không biết trước. Kỹ thuật này nhằm tiến hành mọi cách gộp nhóm có thể và chọn lựa cách tốt nhất. Bắt đầu từ tập dữ liệu, nhiều thủ tục xử lý khác nhau nhằm phân lớp và nâng cấp dần để đạt được một phương án phân loại. 50
  43. Nhìn chung, dù là mô hình nào và kỹ thuật nhận dạng ra sao, một hệ thống nhận dạng có thể tóm tắt theo sơ đồ sau: Trích chọn đặc Phân lớp ra Đánh tính biểu diễn quyết định giá đối t ƣợng Quá trình ti ền xử lý Khối nhận dạng Hình 3.1: Sơ đồ tổng quát một hệ nhận dạng. 3.2 Mô hình mạng nơron nhân tạo Mạng nơron nhân tạo (Artificial Neural Network) bao gồm các nút (đơn vị xử lý) được nối với nhau bởi các liên kết nơron. Mỗi liên kết kèm theo một trọng số nào đó, đặc trưng cho đặc tính kích hoạt giữa các nơron. Có thể xem trọng số là phương tiện để lưu giữa thông tin dài hạn trong mạng và nhiệm vụ của quá trình huấn luyện (học) mạng là cập nhật các trọng số khi có them các thông tin về các mẫu học, hay nói cách khác, các trọng số được điều chỉnh sao cho đúng. Trong mạng, một số nơron được nối với môi trường bên ngoài như các đầu ra, đầu vào 3.2.1 Mô hình nơron nhân tạo Hình 3.2: Mô hình nơron nhân tạo 51
  44. Mỗi nơron được nối với các nơron khác và nhận được các tín hiệu sj từ chúng với các trọng số wj. Tổng các thông tin vòa có trọng số là: Net= w j s j Người ta gọi đây là thành phần tuyến tính của nơron. Hàm kích hoạt g (còn gọi là hàm chuyển). Đóng vai trò biến đổi từ Net sang tín hiệu đầu ra out. Out= g(Net) Đây là thành phần phi tuyến của nơron. Có 3 dạng hàm kích hoạt thường được dùng trong thực tế *)Hàm dạng bước: 1 x 0 1 x step x step x 0 x 0 0 x *)Hàm dấu: 1 x 0 1 x step x step x 1 x 0 1 x 1 *)Hàm sigmoid: Sigmoid(x) 1 e x Ở đây ngưỡng đóng vai trò làm tăng tính thích nghi và khả năng tính toán của mạng nơron. Sử dụng ký pháp véctơ, S s1 , , sn véctơ tín hiệu vào, W w1 , , wn vecto trọng số, ta có out g Net Net SW Trường hợp xét ngưỡng , ta dùng biểu diễn vecto mới S s1 , , sn , , ' W w1, , wn , 1 3.2.2 Mạng Nơron Mạng nơron là hệ thống bao gồm nhiều phần tử xử lý đơn giản (nơron) hoạt động song song. Tính năng của hệ thống này tùy thuộc vào cấu trúc của hệ, các trọng số liên kết nơron và quá trình toán tại các nơron đơn lẻ. Mạng nơron có thể học từ dữ liệu mẫu và tổng quát hóa dựa trên các dựa trên các dữ liệu mẫu 52
  45. học. Trong mạng nơron, các nơron đón nhận tín hiệu vào gọi là nơron vào và các nơron đưa thông tin ra gọi là nơron ra. 3.2.2.1 Phân loại các mạng noron Theo kiểu liên kết nơron: ta có mạng nơron truyền thẳng (feel- forward Neural Network) và mạng nơron qui hồi (recurrent Neural Network). Trong mạng nơron truyền thẳng, các liên kết nơron đi theo một hướng nhất định, không tạo thành đồ thị không có chu trình với các đỉnh là các nơron, các cung là các liên kết giữa chúng. Ngược lại, các mạng qui hồi cho phép các liên kết nơron tạo thành chu trình. Vì các thông tin ra của các nơron được truyền lại cho các nơron đã góp phần kích hoạt chúng, nên mạng hồi quy còn có khả năng lưu giữ trạng tháitrong của nó dưới dạng các ngưỡng kích hoạt ngoài các trọng số liên kết nơron. Theo số lớp: các nơron có thể tổ chức lại thành các lớp sao cho mỗi nơron của lớp này cỉ được nối với các nơron ở lớp tiếp theo, không cho phép các liên kết giữa các nơron trong cùng một lớp, hoặc từ nơron lớp dưới lên nơron lớp trên. Ở đây cũng không cho phép các liên kết nhảy qua một lớp Hình 3.3: Mạng nơron truyền thẳng và nhiều lớp Hình 3.4: Mạng nơ ron hồi qui 53
  46. 3.2.2.2 Hai chức năng của mạng noron Mạng nơron nhƣ một công cụ tính toán: Giả sử mạng nơron Neural network có m nơron vào và n nơron ra, khi đó với mỗi vecto các tín hiệu vào X=(x1, ,xn), sau quá trình tính toán tại các nơron ẩn, ta nhận được kết quả ra Y=(y1, ,yn). Theo nghĩa nào đó mạng nơron làm việc với tư cách một bảng tra, mà không cần biết dạng phụ thuộc hàm tường minh giữa Y và X. khi đó ta viết: Y tinh X , NN Cần lưu các nơron trên cùng một lớp có thể tính toán đồng thời, do vậy độ phức tạp tính toán nói chung sẽ phụ thuộc vào số lớp mạng. Các thông số cấu trúc mạng nơron bao gồm: + Số tín hiệu vào, số tín hiệu ra + Số lớp nơron + Số nơron trên mỗi lớp ẩn + Số lượng liên kết của mỗi nơron (liên kết đầy đủ, liên kết bộ phận và liên kết ngẫu nhiên) + Các trọng số liên kết nơron. Mạng nơron nhƣ một hệ thống thích nghi có khả năng học: Để chỉnh các trọng số liên kết cũng như cấu truc của mình sao cho phù hợp với các mẫu học (samples). Người ta phân biệt ba loại kỹ thuật học: (a) Học có quan sát (supervised learning) (b) Học không quan sát (unsupervised learning) (c) Học tăng cường. Trong học giám sát, mạng được cung cấp một tập mẫu học {(Xs,Ys)} theo nghĩa Xs là các tín hiệu vào, thì kết quả ra đúng của hệ phải là Ys. Ở mỗi lần học, vecto tín hiệu vào Xs được đưa vào mạng, sau đó so sánh sự sai khác giữa các kết quả ra đúng Ys với kết quả tính toán outs. Sai số này sẽ được dùng để hiệu chỉnh lại các trọng số liên kết trong mạng. Quá trình cứ tiếp tục cho đến khi thỏa mãn một tiêu chuẩn nào đó. Có hai cách sử dụng tập mẫu học: hoặc dùng 54
  47. các mẫu lần lượt, hết mẫu này đến mẫu khác, hoặc sử dụng đồng thời tất cả các mẫu một lúc. Các mạng với cơ chế học không giám sát được gọi là các mạng tự tổ chức. Các kỹ thuật học trong mạng nơron có thể nhằm vào hiệu chỉnh các trọng số liên kết (gọi là học tham số) hoặc điều chỉnh, sửa đổi cấu trúc của mạng bao gồm số lớp, số nơron, kiểu và trọng số các liên kết (gọi là học cấu trúc). *)Học tham số: Giả sử có k nơron trong mạng và mỗi nơron có đúng một liên kết vào với các nơron khác. Khi đó, ma trận trọng số liên kết W sẽ có kích thước kx1. Các thủ tục học tham số nhằm mục đích tìm kiếm ma trận W sao cho Ys Tinh X s ,W đối với mọi mẫu học S X s ,Ys (1) Xs Mạng nơron N Ys Hiệu chỉnh W Sai số Hình 3.5: Học tham số có giám sát *)Học cấu trúc: Với học tham số ta giả định rằng mạng có một cấu trúc cố định. việc học cấu trúc của mạng truyền thẳng gắn với yêu cầu tìm ra số lớp của mạng L và số nơron trên mỗi lớp nj. Tuy nhiên, với các mạng hồi quy còn phải xác định thêm các tham số ngưỡng của các nơron trong mạng. Một cách tổng quát phải xác định bộ tham số P L,n1 , , nk , 1 , , k ở đây k n j sao cho Ys Tinh X s , P đối với mọi mẫu học s X s ,Ys (2). Về thực chất, việc điều chỉnh các vecto tham sô W trong (1) hay P trong (2) đều qui về bài toán tìm kiếm tối ưu trong không gian tham số. Do vậy, có thể áp dụng các cơ chế tìm kiếm kinh điểm theo gradient. 55
  48. 3.2.3 Mạng Kohonen Cách xử lý thông tin trong các mạng ở trên thường chỉ quan tâm tới giá trị và dấu của các thông tin đầu vào, mà chưa quan tâm khai thác các mối liên hệ có tính chất cấu trúc trong lân cận của các vùng dữ liệu mẫu hay toàn thể không gian mẫu. Chẳng hạn, với 2 thành phần: 1 tam giác, 1 hình chữ nhật, ta có thể tạo thành hình ngôi nhà khi chúng được phân bố kề giáp với nhau theo một trật tự nhất định. Teuvo Kohonen (1989) đã đề xuất một ý tưởng rất đáng chú ý về ánh xạ các đặc trưng topo tự tổ chức (theo nghĩa không cần có mẫu học) nhằm bảo toàn trật tự sắp xếp các mẫu trong không gian biểu diễn nhiều chiều sang một không gian mới các mảng nơron (một hoặc hai chiều). Trong mạng Kohonen, các vectơ tín hiệu vào gần nhau sẽ được ánh xạ sang các nơ ron trong mạng lân cận nhau. 3.2.3.1 Cấu trúc mạng Mạng Kohonen rất gần gũi với kiểu cấu trúc mạng nơ ron sinh học cả về cấu tạo lẫn cơ chế học. Mạng Kohonen thuộc vào nhóm mạng một lớp các nơ ron được phân bố trong mặt phẳng hai chiều theo kiểu lưới vuông, hay lưới lục giác dưới Phân bố này phải thoả mãn yêu cầu ; Mỗi nơ ron có cùng số nơ ron trong từng lớp láng giềng. ý tưởng cơ bản của Kohonen là các đầu vào tương tự nhau sẽ kích hoạt các nơ ron gần nhau về khoảng không gian. Mối quan hệ tương tự (theo khoảng cách) có thể tổng quát hoá cho một lớp tương đối rộng các quan hệ tương tự giữa các tín hiệu đầu vào. 56
  49. for i:=-k to k do for j:=-k to k do begin xi:=mod(x+i+p-1,p) + 1; yi:=mod(y+j+q-1,q) + 1; if (i=k) or (j=k) then nơ ron (xi, yi) thuộc vào lớp láng giềng thứ k else nơ ron (xi, yi) thuộc vào lớp láng giềng thứ r r<k; r được xác định bởi max(xi,yi) end; Trường hợp lớp nơ ron Kohonen là một dãy, cách cuộn tròn mảng nơ ron tạo thành một đường tròn. Tất cả các nơ ron ở lớp kích hoạt có liên kết đầy đủ với lớp vào. Điểm quan trọng nhất trong mạng Kohonen là với một vectơ tín hiệu vào, nó chỉ cho phép các phản hồi mang tính chất địa phương nghĩa là đầu ra của mỗi nơ ron 57
  50. không được nối với tất cả các nơ ron khác mà chỉ với một số nơ ron lân cận. Sự phản hồi mang tính địa phương của những điều chỉnh (nếu có) tạo ra hiệu ứng là các nơ ron gần nhau về vị trí sẽ có hành vi tương tự khi có những tín hiệu giống nhau được đưa vào. 3.2.3.2 Huấn luyện mạng Quá trình học được sử dụng trong mạng Kohonen dựa trên kỹ thuật cạnh tranh, không cần có tập mẫu học. Khác với trường hợp học có giám sát, các tín hiệu đầu ra có thể không biết được một cách chính xác. Tại mỗi thời điểm chỉ có một nơ ron duy nhất C trong lớp kích hoạt được lựa chọn sau khi đã đưa vào mạng các tín hiệu Xs. Nơron này được chọn theo một trong hai nguyên tắc sau: Nguyên tắc 1 Nơ ron c có tín hiệu ra cực đại outc max(outj) = max ( (xsi wji) (9) j=1 i=1 Nguyên tắc 2 Vectơ trọng số của nơ ron c gần với tín hiệu vào nhất errc min(errj) = min ( (xsi - wji)2 (10) j i=1 Sau khi xác định được nơ ron c, các trọng số wci được hiệu chỉnh nhằm làm cho đầu ra của nó lớn hơn hoặc gần hơn giá trị trọng số mong muốn. Do vậy, nếu tín hiệu vào xsi với trọng số wci tạo kết qủa ra quá lớn thì phải giảm trọng số và ngược lại. Các trọng số của các nơ ron láng giềng j cũng phải được hiệu chỉnh giảm, tuỳ thuộc vào khoảng cách tính từ c. Ta đưa vào hàm tỷ lệ a(.) = a(dcj), ở đây dcj là khoảng cách topo giữa nơ ron trung tâm c và nơ ron j đang xét. Trên thực tế hàm a(.) có thể là hằng số, hàm tỷ lệ nghịch hoặc hàm có điểm uốn. Để đảm bảo yêu cầu, do có nhiều mẫu tham gia quá trình huấn luyên, ta đưa vào hệ số (t): f = (t) . a(dcj), tmax - t (t) = (amax - amin) ___ + amin (11) tmax - 1 58
  51. ở đây t là số đối tượng mẫu đã dùng để luyện mạng tmax là số mẫu tối đa amax, amin tương ứng là giá trị cực đại, cực tiểu của hàm a(.) Tuỳ thuộc vào nơ ron trung tâm c được lựa chọn theo nguyên tắc 1 hoặc nguyên tắc 2 ta có cách hiệu chỉnh các trọng số wji tương ứng: wji = wji + (t) a(dcj )(1 - xi wji ) (12) hoặc wji = wji + (t) a(dcj) (xi - wji ) (13) n 2 Sau đó, chuẩn hoá các trọng số sao cho:wji = 1 i=1 Theo kinh nghiệm, cần phải tạo ra phân bố ngẫu nhiên các trọng số trong khoảng -0.1 đến 0.1 hoặc -1/m đến 1/m, ở đây m là số trọng số của mạng và chuẩn hoá dữ liệu vào, ra bằng -1 hoặc 1. Tuy nhiên cũng phải chú ý một điều là việc lựa chọn tiêu chuẩn chuẩn hoá, định cỡ dữ liệu phụ thuộc rất nhiều vào bản chất bài toán. 3.2.3.3 Sử dụng mạng Giả sử đã huấn luyện mạng để nhận được ma trận trọng số W. Khi đưa vào mạng một vector X, toàn bộ ma trận W lại được cập nhật theo các công thức (12) hoặc (13) tuỳ thuộc vào sử dụng nguyên tắc 1 hay nguyên tắc 2. Như vậy, mạng Kohonen cho chúng ta biết được sự phân bố và quan hệ tương đối về mặt "địa lý" giữa các mẫu trong không gian biểu diễn. 3.2.3.4 Thử nghiệm mạng Ánh xạ từ không gian 3 chiều sang không gian 2 chiều. Bài toán đặt ra là tạo ánh xạ từ một mặt cầu đơn vị 3 chiều với 2000 điểm phân bố ngẫu nhiên trong 8 múi cầu sang mặt phẳng các nơ ron được phân bố trong lưới kích thước 15x15. Mạng Kohonen được thiết kế có 3 đầu vào, tương ứng với 3 toạ độ và 225 nơron, phân bố thành lưới vuông 15x15. Mỗi nơ ron vào được nối đầy đủ với các nơ ron ra, do vậy tổng cộng có 675 trọng số. Ban đầu nơ ron trung tâm có 7 lớp láng giềng để đảm bảo rằng tất cả các vùng láng giềng kề giáp nhau. Giả sử, hiệu chỉnh cực đại tại nơ ron trung tâm a(0) = 0.3 (xem công thức(11)) và tại lớp 59
  52. thứ 7 giá trị này chỉ là 0,5 % giá trị tại nơ ron trung tâm, do vậy bằng 0,3x0,005 = 0,0015. Giá trị có thể xem là rất nhỏ, do đó n(t) = hằng số. Trong quá trình luyện mạng, cứ 400 điểm mẫu được đưa vào để luyện mạng sẽ có một lớp láng giềng ở vòng ngoài bị co lại. Các nơ ron láng giềng càng xa sẽ càng ít bị hiệu chỉnh hơn. Trong thí nghiệm này ta sử dụng nguyên tắc 2 và công thức hiệu chỉnh (13), các giá trị trọng số ban đầu được lấy ngẫu nhiên trong khoảng [-0,1 - 0,1]. Kết quả huấn luyện mạng với 2000 mẫu được cho trong hình 3.7. Dễ ràng thấy rằng tất cả các quan hệ topo giữa các vùng trên mặt cầu được bảo toàn sau khi ánh xạ (hình 3.8). Điểm thú vị là trên mạng có những vùng trống, nhằm tách rời điểm hội tụ của các vùng 1,2,3,4 ở cực bắc khỏi các vùng 5,6,7,8 ở bán cầu nam. Một số lưu ý về mạng Kohonen 60
  53. Mạng không chỉ quan tâm đến nội dung tín hiệu vào mà còn xem xét cấu trúc topo của các mẫu. Mạng có thể biến đổi từ không gian nhiều chiều sang không gian ít chiều hơn Cơ chế học không có giám sát Các quan hệ topo được bảo toàn khi ánh xạ. 3.2.4 Mạng nơron nhiều lớp lan truyền ngƣợc sai số 3.2.4.1 Kiến trúc mạng Lớp vào Lớp ẩn Lớp ra Hình 3.9: Mạng Nơron 2 lớp Các nơron lớp thứ t được nối đầy đủ với các nơron lớp thứ t+1. Trong nhiều ứng dụng thực tế, để đơn giản, người ta thường sử dụng mạng có một lớp ẩn, số nơron trong lớp ẩn được xác định dựa trên kinh nghiệm, hoặc dựa trên các kỹ thuật tìm kiếm khác. 3.2.4.2 Huấn luyện mạng Quá trình huấn luyện mạng được trình bày ở đây là quá trình học có giám sát với tập mẫu X s ,Ys . Quá trìnhhọc có thể tóm tắt như dưới: Mỗi khi một mẫu X s x1 , , xn vào mạng, ta thực hiện các công việc sau: Lan truyền mẫu X s qua mạng để có outs Tinh X s , NN , Tính sai số Errs của mạng dựa trên sai lệch outs Ys , 61
  54. W Hiệu chỉnh các trọng số liên kết nơron dẫn tới lớp ra ij từ nơron j tại lớp ẩn cuối cùng tới nơron i tại lớp ra: wij wij a j i (1) Với: là hệ số học. a j là đầu ra của nơron j, i là sai số mà nơron I ở lớp ra phải chụi trách nhiệm, được xác định theo ' công thức: i erri g Neti (2) với erri là sai số thành phần thứ I trong err , Neti là tổng thông tin vào có ' trọng số của nơron thứ i Neti wij .a j và g . là đạo hàm của hàm kích hoạt g được dùng trong các nơron. Hiệu chỉnh các trọng số liên kết nơron Wik dẫn tới tất cả lớp ẩn từ nơron thứ k sang nơron j (các lớp ẩn được xét từ dưới lên): Tính tổng sai số tại nơron j phải chụi trách nhiệm ' j g Net j w i (3) Hiệu chỉnh trọng số w jk w jk ak j (4) (Trường hợp xét liên kết từ nơron vào thứ k sang nơron j trên lớp ẩn thứ nhất, ta có ak ik ) chính là tín hiệu vào). Chú ý: a) Trường hợp xét hàm kích hoạt tại các nơron 1 g x 1 e x Ta có hệ thức g ' x g x 1 g x b) Từ các công thức (1) và (4) ta có thể viết lại: wij wij wij với wij a j i và w jk w jk w jk với w jk ak j Trong thực tế, thường hiệu chỉnh wij theo nguyên tắc có chú ý đến thao tác trước đó. Do vậy: moi cu wij a j i wij , ở đây là hệ số quán tính. 62
  55. Quá trình huấn luyện mạng cần chú ý tới các yếu tố sau: i. Các trọng số ban đầu wij được gán các giá trị ngẫu nhiên, nhỏ, ii. Lựa chọn các hệ số học và hệ số quán tính sao cho 1, với không lớn hơn quá nhiều, Các tín hiệu vào, ra nên được định cỡ chỉ nằm trong khoảng 0,1 . Các nghiên cứu thực nghiệm chỉ ra rằng nên ở trong khoảng 0.2,0.8 3.2.4.3 Sử dụng mạng Giả sử đã huấn luyện mạng như hình ở trên với tập mẫu X s ,Ys để được ma trận trọng số W. Quá trình lan truyền trong mạng một vecto tín hiệu vào X x1, x2, x3 được cho bởi: out g w64a4 w65a5 g w64 g w41 x1 w42 x2 w43 x3 w65 g w51 x1 w52 x2 w53 x3 F X ,W Khả năng tính toán của mạng nhiều lớp Với một lớp ẩn, mạng có thể tính toán xấp xỉ một hàm liên tục bất kỳ đối với các biến tương ứng là các tín hiệu vào. Với 2 lớp ẩn, mạng có thể tính toán xấp xỉ một hàm bất kỹ. Tuy vậy, số nơron trong các lớp ẩn có thể tăng theo hàm mũ đối với số đầu vào và cho đến nay vẫn chưa có các hàm có thể xấp xỉ nhờ các mạng nhiêu lớp 3.3 Sử dụng mạng nơron lan truyền ngƣợc hƣớng cho nhận dạng ký tự 3.3.1 Nhận dạng bằng mạng nơron lan truyền ngƣợc hƣớng (kn chung) Mạng nơron nói chung và mạng lan truyền ngược hướng nói riêng là sự mô phỏng sinh học bằng máy tính bộ não người. Nó có khả năng học từ kinh nghiệm hay từ một tập mẫu. Quá trình học của mạng lan truyền ngược hướng là quá trình học có giám sát với một mẫu X s ,Ys cho trước, ở đây Xs là vecto vào (ma trận điểm ảnh của một ký tự) và Ys là giá trị ASCII của ký tự đó. Thực chất việc học của mạng là biến đổi và ánh xạ topo vác ký tự xuống mặt phẳng hai chiều tương ứng với cá nơron. Sau khi huấn luyện, mạng lan truyền ngược hướng hoạt động như một bảng tra với đầu vào là các vecto điểm ảnh của các 63
  56. ký tự. Một trong những ưu điểm chính của mạng là không đòi hỏi các quá trình tiền xử lý như làm mảnh, làm trơn đường biên hay khử nhiễu. Quá trình học của mạng lan truyền ngược hướng là quá trình học có giám sát. Do đó nó cần có một tập mẫu chuẩn { Xs, Ys}. Trong quá trình học vectơ vectơ vào Xs đi vào mạng Kohonen, ở đây diễn ra quá trình học cạnh tranh . Vectơ lời giải Ys đi vào lớp ra theo hướng ngược lại làm thay đổi giá trị các trọng số của các nơ ron trên lớp ra. Giả thiết chúng ta có mạng lan truyền ngược hướng gồm N nơ ron trên lớp Kohonen và M nơ ron trên lớp ra. Wji là trọng số thứ i của nơ ron thứ j trên lớp Kohonen. Cji là trọng số của nơ ron thứ i trên lớp ra nối với nơ ron thứ j trên lớp Kohonen. Quá trình học của mạng lan truyền ngược hướng bao gồm các bước sau đây: - Một đối tương gồm cặp vectơ (Xs, Ys) được lấy ra từ tập mẫu. - Vectơ Xs đi vào lớp Kohonen. - Nơ ron trung tâm được chon theo phương trình - Tất cả các trọng số của nơ ron trên lớp Kohonen được điều chỉnh theo phương trình . - Các trọng số của nơ ron trên lớp ra được điều chỉnh theo phương trình: Cji(new) = Cji(old) + (t).a(dc - dj).(yi - Cji(old)) - Quá trình lặp lại đối với đối tượng tiếp theo. Mỗi lần tất cả các đối tượng mẫu đã đi qua mạng được gọi là một lượt. Thông thường cần phải thực hiện từ vài trăm đến hàng nghìn lượt để mạng ổn định. Khi chọn được các hằng số đặc trưng của quá trình học amax, amin thích hợp, quá trình học của mạng luôn hội tụ. 3.3.2 Cài đặt mạng lan truyền ngƣợc hƣớng cho nhận dạng ký tự Một mạng tổng quát cho việc nhận dạng ký tự được cài đặt trên ngôn ngữ C như một lớp (Class) có tên gọi là Netcount. Các tham số của mạng là các biến thành viên còn các chức năng của mạng được thiết kế cho các hàm thành viên. Mạng chỉ có một nơ ron trên lớp ra và có kiếu là ký tự. 64
  57. Class Netcount {protected: int dai, rong, N; float amax, amin, *W[1600]; char C[1600]; public; Netcount(int, int); Void hoc(char*, long T); Char doan (char*); }; Các trọng số Wji được cấp phát động cho bảng các con trỏ W. Khoảng cách giữa nơ ron có toạ độ kj, lj với nơ ron trung tâm kc, lc được tính theo công thức: D = max[min(|kj-kc|, |kj-kc+dai|, |kj-kc-dai|), min(|lj-lc|, |lj-lc+rong|,|lj-lc- rong|)] Hàm phụ thuộc topo a(dc - dj) được dùng trong chương trình là hàm tam giác: a d cj 0 Dci Dmax Dmax D Dci Dmax Dmax Trong đó: Dmax là khoảng cách từ lân cận xa nhất có thể có của mạng: Dmax = max(dai/2, rong/2) + 1; Nhìn chung để cài đặt mạng nơ ron cho nhận dạng ký tự cần: Tổ chức số liệu Tập mẫu được tổ chức trong một tệp số liệu. Các cặp (Xs, Ys) được viết lần lượt theo từng dòng. Một điều đặt ra là phải số thực hoá các vectơ vào khoảng [0, 1] vì các trọng số của mạng là các số thực. Các nghiên cứu cho thấy việc số thực hoá làm cho mạng có khả năng đoán nhận các ký tự từ các ảnh số sai lệch lớn hơn. Hơn nữa, với việc tổ chức số thực hoá, chúng ta có thể làm giảm kích thước của vectơ vào và có khả năng làm việc đối với các ký tự có kích 65
  58. thước ảnh khác nhau. Thực tế chỉ ra các phương pháp số thực hoá khác nhau sẽ ảnh hưởng đến khả năng cực đại mà mạng có thể đoán nhận từ các ảnh sai lệch. Cấu trúc và các tham số học Mục đích của việc xây dựng mạng là xác định số lượng nơ ron trên lớp Kohonen. Với số lượng nơ ron trên lớp Kohonen càng lớn, khả năng đoán nhận các ký tự từ các ảnh có tỷ lệ sai lớn hơn. Tuy nhiên, khi tăng số lượng các nơ ron, khả năng nhận biết sẽ tiến sát tới khả năng cực đại mà mạng có thể đoán nhận với các ảnh sai (phụ thuộc vào phương pháp số thực hoá). Chúng ta cũng dễ nhận thấy thời gian học và thời gian đoán nhận, cũng như bộ nhớ của máy tính tăng tỷ lệ , có thể hàm mũ với số lượng nơ ron trên lớp Kohonen. Thực tế, việc xây dựng mạng là công việc thử nghiệm, dần dần tăng kích thước mạng cho đến khi đạt được các chỉ tiêu mong muốn. Các giá trị trọng số ban đầu thực sự không quan trọng với quá trình học nhưng chúng phải được gán bằng các số ngẫu nhiên từ 0 đến 1. Các tham số học amax, amin ảnh hưởng không nhiều đến quá trình học nếu chúng thoả mãn các điều kiện sau: amax [0.3, 1]; amin [0, 0.1]. Với giá trị amax = 0.5 và amin = 0.01 có thể là giá trị tốt cho quá trình học. 3.3.3 Nhận dạng các ký tự sử dụng mạng lan truyền ngƣợc hƣớng Một tập mẫu 37 ký tự từ A Z, 0 9 và ký tự '<' được tách ra từ tệp ảnh quét bởi scanner có kích thước 32 x 32 điểm ảnh. Ba thử nghiệm được tiến hành là: - Không số thực hoá - Lọc các điểm ảnh bằng mặt nạ 3 x 3 - Phân mảnh ảnh thành 64 mảnh. Mỗi vùng có giá trị thực bằng tổng điểm số điểm ảnh đen ( giá trị 1) chia cho 16 Bảng 1 thống kê khả năng nhận đúng ký tự từ các ảnh có tỷ lệ sai cực đại của mạng 20 x 20 nơ ron sau 3000 lượt học. 66
  59. Bảng 2 thống kê sự phụ thuộc của khả năng nhận dạng các ảnh sai vào kích thước với việc số thực hoá là phân 64 mảnh. Bảng 1 Không số thực hoá Mặt nạ 3 x Phân 64 3 mảnh 3% 15% 19% Bảng 2 10 x 10 20 x 20 30 x 30 40 x 40 3% 19% 24% 25% Với việc phân bố của các ký hiệu ở hình bên ta dễ nhận thấy mạng đã phát hiện một cách khách quan các đặc trưng topo của các ký tự thường được dùng trong các phương pháp nhận dạng cấu trúc truyền thống. Các ký tự có cấu trúc topo tương đối giống nhau được sắp xếp đặt gần nhau, như các ký tự có điểm kết thúc như nhau {'Z', '2'}, {'5', 'S'}; các ký tự có một chu trình {'O', '0', 'Q', 'R', '9', 'D'}; Các ký tự có hai chu trình {'B', '8'}. Một đặc điểm rất quan trọng là mạng đã phát hiện ra các ký tự có "tiềm năng" giống nhau như các ký tự {'H', 'E', 'W'} rất dễ trở thành có hai chu trình khi ảnh bị sai lớn. Ký tự 'A' khi bị mất góc cuối bên trái có thể trở thành số '4'; Ký tự 'U' rất dễ trở thành có chu trình. Ngoài ra mạng đã phát hiện các ký tự có một hay nhiều phần giống nhau khó có khả năng mô tả trong các chương trình nhận dạng truyền thống như mật độ các điểm đen như {'M', 'X', 'A'}, hay nét cong của đường biên ký tự 'G' và 'O'. Kết luận Từ ví dụ nhận dạng 37 ký tự cho thấy việc nhận dạng ký tự bằng mạng lan truyền ngược hướng có hiệu quả, đơn giản và nhanh hơn các phương pháp truyền thống. Nó có khả năng nhận dạng được các ký tự từ các ảnh có chất lượng tồi với số điểm ảnh sai 25%. Lợi thế chính của mạng loại này xuất phát từ khả năng học các đặc trưng topo của các mẫu. Tuy nhiên với một tập mẫu khá lớn, việc sử dụng tài nguyên của máy tính sẽ rất lớn. 67
  60. PHẦN KẾT LUẬN Sự phát triển của công nghệ thông tin đã có tác động đến nhiều mặt của đời sống xã hội trong đó phải kể đến lĩnh vực giám sát tự động. Trong giám sát tự động, việc giám sát đối với các phương tiện giao thông là một vấn đề nổi trội. Nhiều chính phủ, thành phố trên thế giới đã xây dựng hệ thống giám sát tự động đối với các phương tiện giao thông cảu mình. Và các hệ thống giám sát đều lấy biển số xe là mục tiêu giám sát. Ở nước ta, các hệ thống giám sát tự động nói chung và các hệ thống nhận dạng biển số xe nói riêng chưa được chú ý tới và nó cũng là một lĩnh vực tương đối mới mẻ. Đa phần các công tác quản lý, xử lý đối với các phương tiện giao thông đều cần nhân lực là con người. Báo cáo nhằm mục đích tìm hiểu bài toán giám sát, quản lý các phương tiện giao thông một cách tự động thông qua việc “Phát hiện và nhận dạng chữ, số trong biển số xe”. Khoá luận đã trình bày một cách hệ thống về bài toán nhận dạng biển số xe và các hướng giải quyết trên cơ sở các bài toán cơ bản: Phát hiện vùng chứa biển số xe và bài toán nhận dạng chữ và số trong vùng được phát hiện. Với mục đích để tìm hiểu do thời gian có hạn nên em không hoàn thành được sản phẩm ứng dụng của mình. Em hy vọng rằng ở Việt nam không xa, thì các hệ thống này được sử dụng nhiều. Để hỗ trợ một phần công tác giám sát, quản lý các phương tiện giao thông một cách hiệu quả hơn. 68
  61. TÀI LIỆU THAM KHẢO [1] Nhập môn xử lý ảnh số. Ths. Lương Mạnh Bá, Pts. Nguyễn Thanh Thủy. Nxb KHKT 2003. [2] Một thuật toán phát hiện vùng và ứng dụng của nó trong quá trình vecto hóa tự động.PGS.TS Đỗ Năng Toàn.Tạp chí Tin học và Điều khiển, Tập 16 số 1 năm 2000 [3] Machine Vision: Theory, Algorithms and Practicalities. E.Davies. Academic Press 1990 [4] A robust and fast skew detection algolrithm for generic document. B.Yu and A.Jain. Pattern Reconigtion 1996 [5] Khoá luận của anh Đào Đình Dũng trường ĐHQGHN khoá 2005 Và 1 số tạp chí tin học khác 69