Nghiên cứu hệ thống camera phát hiện và tự động bám theo đối tượng di chuyển

Phát hiện đối tuợng di chuyển và bám theo là một trong những ứng dụng quan trọng của hệ thống an ninh và hệ thống giám sát. Ngày nay việc giám sát bằng camera rất phổ biến nhưng việc cho hệ thống tự động phát hiện ra đối tượng và bám theo đối tượng là rất khó khăn vì: Xây hệ thống xử lý ảnh trên nền vi điều khiển khó thực hiện, việc lập trình và mở rộng các ứng dụng có nhiều hạn chế và không thừa hưỡng được những phần mềm hỗ trợ xử lý ảnh cũng như các thư viện có sẵn. Để giải quyết vấn đề trên, đề tài nghiên cứu vấn đề thu thập và xử lý ảnh trên hệ thống nhúng linux. Với cách làm này, hệ thống dễ dàng thu nhận được hình ảnh từ webcam dạng jpeg và xử lý ảnh nhờ các thư viện có sẵn hỗ trợ cho linux như libjpg, uvc lib, opencv

pdf5 trang | Chia sẻ: lvbuiluyen | Lượt xem: 2616 | Lượt tải: 2download
Bạn đang xem nội dung tài liệu Nghiên cứu hệ thống camera phát hiện và tự động bám theo đối tượng di chuyển, để tải tài liệu về máy bạn click vào nút DOWNLOAD ở trên
Tuyển tập Báo cáo Hội nghị Sinh viên Nghiên cứu Khoa học lần thứ 7 Đại học Đà Nẵng năm 2010 201 NGHIÊN CỨU HỆ THỐNG CAMERA PHÁT HIỆN VÀ TỰ ĐỘNG BÁM THEO ĐỐI TƯỢNG DI CHUYỂN RESEARCH A CAMERA SYSTEM FOR AUTOMATIC DETECT AND TRACKING OF MOVING OBJECTS SVTH: Phạm Quang Sơn, Lê Đoàn Trương Lớp 05DT1, 05DT3, Khoa Điện tử Viễn thông, Trường Đại học Bách Khoa GVHD: Ths. Nguyễn Duy Nhật Viễn Khoa Điện tử Viễn thông, Trường Đại học Bách Khoa TÓM TẮT Camera tự động phát hiện và bám theo đối tượng di chuyển có ứng dụng rộng rãi cho hệ thống giám sát và an ninh. Hệ thống được trình bày trong báo cáo này bao gồm một camera gắn trên một cơ cấu cơ khí có thể quay 360 độ được điều khiển bởi hệ thống nhúng. Hệ thống có nhiệm vụ phát hiện và bám đối tượng đang di chuyển, thông qua điều khiển động cơ DC sao cho ảnh của đối tượng thu được ở chính giữa tâm camera. Hình ảnh thu được sẽ truyền lên internet thông qua giao thức HTTP theo kiểu stream. Báo cáo cũng giới thiệu về phương pháp xử lí ảnh, tự động tìm kiếm và nhận dạng đối tượng di động. Các kết quả nghiên cứu được thực hiện bằng mô hình thực tế và kết quả đạt được như mong muốn. ABSTRACT Camera, which automatically detects and tracks motion objects, is used widely for the security and surveillance system. The System introduced in this paper consists of mechanical structure mounted Camera which can rotate 360 degree and be controlled by an embedded system. The target of system is to move camera when anything moves in the vision area of camera to the center of image. The received images will be transmitted over the Internet through HTTP protocol, this image is mjpeg type. This paper also introduces about Image Processing Method, Technique which automatically detect and track motion objects. All research results were obtained by using a practical model and we produced the excellent results as well as we expected. 1. Đặt vấn đề Phát hiện đối tuợng di chuyển và bám theo là một trong những ứng dụng quan trọng của hệ thống an ninh và hệ thống giám sát. Ngày nay việc giám sát bằng camera rất phổ biến nhưng việc cho hệ thống tự động phát hiện ra đối tượng và bám theo đối tượng là rất khó khăn vì: Xây hệ thống xử lý ảnh trên nền vi điều khiển khó thực hiện, việc lập trình và mở rộng các ứng dụng có nhiều hạn chế và không thừa hưỡng được những phần mềm hỗ trợ xử lý ảnh cũng như các thư viện có sẵn. Để giải quyết vấn đề trên, đề tài nghiên cứu vấn đề thu thập và xử lý ảnh trên hệ thống nhúng linux. Với cách làm này, hệ thống dễ dàng thu nhận được hình ảnh từ webcam dạng jpeg và xử lý ảnh nhờ các thư viện có sẵn hỗ trợ cho linux như libjpg, uvc lib, opencv… 2. Hệ thống nhúng Linux nhúng là hệ điều hành được cài đặt trên các thiết bị nhúng với cấu trúc điển hình như sau: Tuyển tập Báo cáo Hội nghị Sinh viên Nghiên cứu Khoa học lần thứ 7 Đại học Đà Nẵng năm 2010 202 Hình 1. Cấu trúc tổng quát của một hệ thống Linux Hình 2. Cấu trúc phần cứng hỗ trợ linux nhúng Hình 3. Chức năng phần cứng Thiết bị phần cứng được sử dụng trong đề tài này là KIT ARM9 với các tính năng sau: CPU AT91SAM9260 32 bit, 180Mhz là bộ xử lý thực hiện điều hành, xử lý tất cả mọi hoạt động của hệ thống. SDRAM là chip MT48LC16M16A2, 32M làm nhiệm vụ load kenel, làm bộ đệm, bộ nhớ tạm thời trong quá trình hoạt động. FLASH là chip K9F2G08UOM 256M làm nhiệm vụ lưu trữ boot loader, lưu trữ nhân của hệ điều hành. Console dùng UART0 để truy cập và thao tác trên hệ thống. Các thiết bị ngoại vi tùy theo ứng dụng mà kết nối như ethernet DM9161EA 10/100 duplex, usb host, usb device, sd card 4GB, uart, ADC Extension Connector. 3. Thuật toán xử lý ảnh 3.1. JPEG 3.1.1. Khái niệm: Chuẩn JPEG mô tả một họ kỹ thuật nén ảnh cho tone liên tục (mức xám hay màu) của ảnh. JPEG khai thác độ dư thừa sinh lý thị giác trong ảnh. JPEG được tiến nhất trí với giải pháp DCT thích nghi để cải thiện và tăng cường ảnh. 3.1.2. Mã hóa JPEG: Hình 4. Sơ đồ mã hóa JPEG Tuyển tập Báo cáo Hội nghị Sinh viên Nghiên cứu Khoa học lần thứ 7 Đại học Đà Nẵng năm 2010 203 3.1.3. Chuyển đổi Cosin rời rạc DCT (Discrete Cosine Transform) DCT thuận: otherwise orf jif vjuivu vuF i j 1 00 2 1 )( ),(. 16 ).12( cos. 16 ).12( cos 4 )()( , 7 0 7 0 (1) DCT ngược: otherwise orf vuF vjui vujif u v 1 00 2 1 )( ),(. 16 ).12( cos. 16 ).12( cos)()( 4 1 ),( 7 0 7 0 ~ (2) 3.2. Thuật toán phát hiện sự chuyển động và bám theo đối tượng 3.2.1. Thuật toán phát hiện sự chuyển động Có nhiều phương pháp tiếp cận để phát hiện chuyển động trong hình ảnh video liên tục. Có thể so sánh khung hình hiện tại với hình nền chúng ta chụp từ ban đầu khi bật camera hoặc từ khung hình trước. Đối với phương pháp thứ nhất thì đơn giản và giảm được việc xử lý. Tuy nhiên, cách tiếp cận có một bất lợi lớn - điều gì sẽ xảy ra, ví dụ nếu có một đối tượng đang di chuyển ở frame đầu tiên, nhưng sau đó nó đã biến mất. Phương pháp thứ hai thì xử lý phức tạp hơn, xử lý nhiều hơn nhưng lại thích nghi với mọi môi trường, kể cả môi trường ít thay đổi hoặc thay đổi nhiều. Nhược điểm là nếu đối tượng di chuyển một cách rất chậm thì hệ thống không phát hiện ra. Nhưng có thể giải quyết bằng cách tăng số khung hình trên giây. Trong đề tài này giới thiệu theo phương pháp thứ hai. Giả sử rằng chúng ta có một bản gốc 24 bpp RGB là hình ảnh hiện tại (img1) và khung hình trước đó (img2), một bản sao màu xám của nó (gray_img1) và (gray_img2). Trước hết, chúng ta hãy tìm những khu vực nơi hai khung hình khác nhau bằng cách trừ từng pixel Begin Thu khung hình hiện tại, và trước đó Chuyển thành ảnh xám So sánh từng pixel của 2 ảnh xám Giá trị > ngưỡng cho truớc Pixel ảnh đầu ra màu đen Pixel ảnh đầu ra màu trắng Số điểm trắng > mức báo động Không có sự di chuyển End Có sự di chuyển N N Y Y Hình 5. Lưu đồ thuật toán phát hiện sự chuyển động Tuyển tập Báo cáo Hội nghị Sinh viên Nghiên cứu Khoa học lần thứ 7 Đại học Đà Nẵng năm 2010 204 của 2 khung hình xám kia và so sánh với một ngưỡng cho trước. Tiếp đó, chúng ta sẽ nhận được một hình ảnh ở đầu ra (result) với các điểm ảnh màu trắng nơi mà những điểm ảnh của khung hiện tại khác với khung hình trước đó với một ngưỡng cho trước ở trên còn lại màu đen. Ta có thể đếm các điểm ảnh màu trắng và nếu số điểm ảnh của nó lớn hơn một mức độ báo động xác định trước chúng ta có thể báo hiệu về một sự kiện chuyển động. Lưu đồ thuật toán được thể hiện ở hình 5. 3.2.2. Thuật toán bám theo đối tượng Khi có sự di chuyển giữa 2 khung hình ta sẽ xác định được tọa độ lớn nhất và nhỏ nhất trên một hàng mà ở đó pixel của hai khung hình có giá trị khác nhau, sau đó ta sẽ tìm được giá trị trung bình của các tọa độ kia đó là tâm của đối tượng di chuyển. Nếu tâm này nằm ngoài điểm ảnh mà định nghĩa trước là điểm min và max thì điều khiển động cơ quay sang trái hoặc phải tùy vào là vượt điểm max hoặc min. Lưu đồ thuật toán được thể hiện ở hình 6. 4. Kết quả Kết quả thi công phần cứng hệ thống cũng như thuật toán xử lý ảnh được thể hiện bằng các hình ảnh dưới đây. 4.1. Thi công hệ thống Hình 7. Hình ảnh thật hệ thống 4.2. Kết quả thực hiện thuật toán xử lý ảnh Hình 8. Ảnh đầu vào 1 và Ảnh đầu vào 2 Hệ thống gồm webcam độ phân giải 5.0 Mpxl, tiêu cự f = 3.58mm, tín hiệu ra 30 hình/s. Quá trình xử lý điều khiển thực hiện bởi chip AT91SAM9260 tốc độ 180MHz. Phần mềm được viết bằng ngôn ngữ C chạy trên nền Linux. Begin Xác định tọa độ điểm khác biệt trên 1 hàng Xác định tâm Tâm > xmax Quay phải động cơ 1 bước Tâm < xmin Quay trái động cơ 1 bước End Y N Y N Hình 6. Lưu đồ thuật toán bám theo đối tượng Tuyển tập Báo cáo Hội nghị Sinh viên Nghiên cứu Khoa học lần thứ 7 Đại học Đà Nẵng năm 2010 205 Hình 9. Ảnh sau khi chuyển sang gray Hình 10. Ảnh đầu ra và tâm của sự thay đổi Kết luận Bài báo đã xây dựng được thuật toán xử lý ảnh và điều khiển bám theo đối tượng chính xác. Mô hình thực nghiệm cho kết quả tốt khẳng định tính đúng đắn của thuật toán. TÀI LIỆU THAM KHẢO [1] Ths. Nguyễn Duy Nhật Viễn (2006), “Giáo trình xử lý ảnh”, Ch. 3. Tr. 26-39. [2] Andrew Kirillov, Software Developer (4/2007), “Motion Detection Algorithms” [3]