Tóm tắt Luận án Một số kỹ thuật giấu tin trong âm thanh số

Thuật toán giấu chuỗi bit W vào tệp C, kết quả ghi ra tệp S.

Bước 1) Sinh ra chuỗi R dựa vào khoá theo công thức (3.9), (3.10).

Bước 2) Chia dữ liệu trên tệp C thành các đoạn Ci có kích thước bằng

nhau. Nếu số frame < độ dài chuỗi bit (L) cần giấu thì dừng.

Bước 3) Gán giá trị các đoạn Si bằng Ci

Dựa vào giá trị của Ri và giá trị bit cần giấu Wi, dùng công thức (3.11)

để thêm tiếng vọng vào cho các đoạn Si.

pdf23 trang | Chia sẻ: honganh20 | Lượt xem: 417 | Lượt tải: 0download
Bạn đang xem trước 20 trang tài liệu Tóm tắt Luận án Một số kỹ thuật giấu tin trong âm thanh số, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
g tin. Hiện nay giấu tin nói chung và giấu tin trong âm thanh vẫn còn nhiều vấn đề mở cần nghiên cứu. 2. Mục tiêu của luận án Trong luận án này chúng tôi đặt ra mục tiêu chính sau đây: • Nghiên cứu và đề xuất một số thuật toán giấu tin trong âm thanh thực hiện trên miền thời gian, có thể áp dụng để giấu tin mật. • Nghiên cứu và đề xuất một số thuật toán giấu tin trong âm thanh trên miền tần số, bền vững trước một số tấn công cơ bản. 3. Đóng góp của luận án • Đề xuất sử dụng mã hỗ trợ xác thực trong quá trình giấu tin. Mục đích của việc mã hoá là tránh trường hợp nhận tin sai nếu tệp chứa tin giấu bị tấn công làm thay đổi nội dung tin giấu. Kết quả được đăng tải trong Tạp chí Khoa học Tự nhiên và Công nghệ, Tạp chí Khoa học Đại học quốc gia Hà Nội năm 2009. 2 • Đề xuất cách chọn mẫu dữ liệu và bit điều chỉnh để giấu tin dựa vào chuỗi ngẫu nhiên được sinh ra từ khoá. Trong kỹ thuật này cũng đề xuất cách điều chỉnh các bit để sự sai khác giữa các mẫu trên tệp gốc và tệp mang tin giấu là ít nhất. Kết quả được đăng tải trong Tạp chí Khoa học Tự nhiên và Công nghệ, Tạp chí Khoa học Đại học quốc gia Hà Nội năm 2013. • Áp dụng và cải tiến các phương pháp giấu tin cho dữ liệu âm thanh. Kết quả được đăng tải trong kỷ yếu Hội nghị IEEE SoCPaR năm 2013 và Hội nghị IEEE ATC năm 2014 tại Hà Nội. • Cải tiến kỹ thuật giấu tin sử dụng tiếng vọng của một tác giả trước đó. Kết quả nghiên cứu được trình bày và đăng tải trong Kỷ yếu Hội nghị Quốc tế ICIEIS năm 2013 tại Malaysia. • Đề xuất kỹ thuật giấu tin bằng cách điều chỉnh các hệ số trên miền tần số của tín hiệu âm thanh. Kết quả nghiên cứu được trình bày tại Hội nghị Quốc tế IEEE DICTAP năm 2014 tại Thái Lan. • Đề xuất kỹ thuật giấu tin bằng cách điều chỉnh các hệ số của thành phần chi tiết của phép biến đổi wavelet. Kết quả đăng trên tạp chí Khoa học Công nghệ, Đại học Đà Nẵng. Nội dung của luận án dựa trên các bài báo đã công bố. 4. Bố cục của luận án Bố cục của luận án bao gồm phần mở đầu, bốn chương nội dung và phần kết luận. Chương 1 trình bày tổng quan về giấu thông tin. Chương 2 trình bày về các phương pháp giấu tin trong âm thanh. Nội dung chính của luận án được trình bày trong hai chương cuối. Chương 3 trình bày về các phương pháp giấu tin trên miền thời gian và chương 4 trình bày về các phương pháp giấu trên miền tần số. 3 Chương 1 GIẤU THÔNG TIN VÀ GIẤU TIN TRONG ÂM THANH 1.1. Giấu thông tin 1.1.1. Lịch sử giấu thông tin Từ giấu thông tin (steganography) bắt nguồn từ Hi Lạp và được sử dụng cho tới ngày nay, có nghĩa là tài liệu được phủ (covered writing). Công nghệ thông tin đã tạo ra những môi trường giấu tin mới, ta có thể giấu tin trong các tệp văn bản, hình ảnh, âm thanh, video Ý tưởng về che giấu thông tin đã có từ rất lâu nhưng chủ yếu dùng trong lĩnh vực an ninh và quân sự. Ngày nay, giấu tin còn được dùng để bảo vệ bản quyền các tài liệu số, kiểm soát sao chép. 1.1.2. Các thành phần của hệ giấu tin Một hệ giấu tin gồm có các thành như hình 1.1. Hình 1.1. Sơ đồ của hệ giấu tin 1.1.3. Các yêu cầu của hệ giấu tin 1.1.4. Phân loại giấu tin Ta có thể phân loại các kỹ thuật giấu tin theo kiểu tài liệu dùng làm dữ liệu chứa, theo miền xử lý hay theo mục đích giấu tin. 1.1.5. Tấn công hệ thống giấu tin Tấn công một hệ giấu tin bao gồm các phương pháp để phát hiện, phá huỷ, trích rút hay sửa đổi tin giấu trong dữ liệu mang tin. Khoá Dữ liệu chủ Quá trình Giấu tin Quá trình Giải tin Khoá Dữ liệu chủ Dữ liệu mang tin Môi trường mạng Thông điệp mật Thông điệp mật 4 1.1.6. Các ứng dụng của giấu tin 1.1.1.1. Liên lạc bí mật 1.1.1.2. Bảo vệ bản quyền (copyright protection) 1.1.1.3. Nhận thực hay phát hiện xuyên tạc thông tin 1.1.1.4. Ghi dấu vân tay (fingerprinting) 1.1.1.5. Gán nhãn (labeling) 1.1.1.6. Điều khiển sao chép (copy control) 1.2. Giấu tin trong âm thanh số Giấu tin trong âm thanh dựa vào ngưỡng nghe của con người và hiện tượng che khuất (masking) âm thanh để giấu tin. 1.2.1. Ngưỡng nghe Phạm vi nghe của người trong khoảng từ 20Hz đến 20 kHz. 1.2.2. Hiện tượng che khuất Hiện tượng che khuất tín hiệu âm thanh xảy ra khi một âm thanh này ảnh hưởng đến sự cảm nhận âm thanh khác. 1.2.3. Âm thanh và các đặc tính của âm thanh Ba đặc trưng sinh lý của âm thanh là âm lượng, độ cao và âm sắc. Đơn vị đo âm thanh là decibel (dB). 1.2.4. Biểu diễn âm thanh số Số byte dùng để lưu 1 giây âm thanh nb thức (1.2): 𝑆ố 𝑏𝑦𝑡𝑒 ≈ (𝑡ầ𝑛 𝑠ố 𝑙ấ𝑦 𝑚ẫ𝑢 ∗ 𝑠ố 𝑘ê𝑛ℎ ∗ 𝑠ố 𝑏𝑖𝑡 𝑏𝑖ể𝑢 𝑑𝑖ễ𝑛 1 𝑚ẫ𝑢)/8 (1.2) 1.2.5. Các định dạng âm thanh phổ biến 1.2.6. Một số chương trình giấu tin trên âm thanh Tổng kết chương 1 Chương 1 trình bày các khái niệm liên quan đến giấu tin, phân loại và các ứng dụng. Ngoài ra, hiện tượng che khuất tín hiệu, cách lấy mẫu và biểu diễn âm thanh số, định dạng tệp âm thanh và một số phần mềm giấu trên âm thanh hiện có cũng được trình bày. 5 Chương 2 CÁC PHƯƠNG PHÁP GIẤU TIN TRONG ÂM THANH 2.1. Các kỹ thuật bổ trợ cho giấu tin 2.1.1. Các phép biến đổi từ miền thời gian sang miền tần số 2.1.1.1. Phép biến đổi Fourier rời rạc 2.1.1.2. Phép biến đổi wavelet (DWT) 2.1.2. Xáo trộn dữ liệu mật Giả sử có chuỗi M gồm n phần tử, là thông điệp mật cần giấu. Thay vì giấu tuần tự từng phần tử, ta thực hiện xáo trộn chuỗi M, nhằm gây khó cho người thám tin khi tấn công rút trích tin. 2.1.2.1. Xáo trộn dữ liệu theo chuỗi hoán vị 2.1.2.2. Xáo trộn dữ liệu bằng phép biến đổi Arnold 2.1.3. Sinh chuỗi giả ngẫu nhiên Các chuỗi ngẫu nhiên có thể dùng để xác định ví trí mẫu được chọn để giấu hoặc vị trí bit giấu. 2.1.3.1. Bộ sinh đồng dư (congruential generator) 2.1.3.2. Bộ sinh Fibonacci 2.2. Đánh giá các phương pháp giấu tin trong âm thanh 2.2.1. Đánh giá bằng các độ đo 2.2.1.1. Độ đo SNR Giá trị của SNR chỉ số lượng thay đổi trên dữ liệu chứa do chèn âm dữ liệu mật vào, tính theo thang độ decibel. 𝑆𝑅𝑁 = 10 𝑙𝑜𝑔10 ∑ 𝑥(𝑖)2𝑁𝑖=0 ∑ [𝑥(𝑖)−𝑦(𝑖)]2𝑁𝑖=0 (2.5) 2.2.1.2. Độ đo NCC (Normalized Cross Correlation) NCC dùng để đo độ tương quan giữa giữa âm thanh gốc và âm thanh chứa tin, hoặc chuỗi bit được giấu và chuỗi bit nhận được. 6 𝑁𝐶𝐶 = 1 𝑛 ∗ ∑ [𝑥(𝑖)∗ 𝑦(𝑖)] [𝑥(𝑖)]2 𝑛 𝑖=1 (2.6) 2.2.2. Đánh giá bằng các phần mềm phát hiện tin 2.2.3. Đánh giá bằng bảng đánh giá ODG (Object Difference Grade) 2.3. Một số phương pháp giấu tin trong âm thanh 2.3.1. Phương pháp điều chỉnh bit ít quan trọng nhất (LSB coding) Ý tưởng chính của kỹ thuật này là thay thế các bit ít quan trọng của mẫu dữ liệu gốc bằng các bit của tin giấu. Hình 2.4. Điều chỉnh bit thấp nhất của mẫu để giấu bit 1 2.3.2. Phương pháp chẵn lẻ (parity coding) Phương pháp chẵn lẻ tương tự như phương pháp mã hoá LSB nhưng thay vì dùng một mẫu dữ liệu sẽ một nhóm các mẫu. 2.3.3. Phương pháp mã hoá pha (phase coding) Hình 2.6. Sự dịch chuyển pha của tín hiệu Phương pháp mã hoá pha giấu tin bằng cách thay thế pha của đoạn âm thanh ban đầu bằng một pha tham chiếu thể hiện dữ liệu. 2.3.4. Phương pháp mã hoá tiếng vọng (echo coding) Phương pháp mã hoá tiếng vọng giấu tin vào âm thanh bằng cách điều chỉnh độ trễ thêm tiếng vọng vào tín hiệu gốc. 0 1 0 1 1 1 1 0 Giá trị mẫu sau khi điều chỉnh để giấu bit 1: 0 1 0 1 1 1 1 1 Giá trị mẫu dữ liệu gốc 7 𝑋(𝑛) = 𝑆(𝑛) + 𝛼. 𝑆(𝑛 − 𝑑) (2.8) Trong đó S(n) là tín hiệu gốc, X(n) là tín hiệu được thêm tiếng vọng, α là hệ số tỉ lệ, d là độ trễ. 2.3.5. Phương pháp trải phổ 2.3.6. Phương pháp điều chỉnh biên độ 2.3.7. Phương pháp lượng tử hoá (quantization) 2.3.8. Phương pháp điều chế tỉ lệ thời gian 2.3.9. Phương pháp giấu dựa vào Patchwork 2.3.10. Phương pháp dựa vào các đặc trưng nổi bật Tổng kết chương 2 Chương 2 của luận án đã trình bày về các kỹ thuật bổ trợ cho giấu tin trong âm thanh, các kỹ thuật xáo trộn dữ liệu, sinh số ngẫu nhiên và các tiêu chí đánh giá các thuật toán giấu. Nội dung chính của chương là trình bày về các phương pháp giấu tin trong tệp âm thanh. Chương 3 MỘT SỐ THUẬT TOÁN GIẤU TIN TRÊN MIỀN THỜI GIAN 3.1. Thuật toán giấu tin kết hợp mã sửa lỗi Hamming Kỹ thuật giấu kết hợp với kỹ thuật mã hoá Hamming nhằm giúp cho người nhận tin hạn chế khả năng nhận tin sai. 3.1.1. Mã Hamming Mã Hamming sử dụng ma trận sinh G và ma trận kiểm tra H. Với mỗi nhóm 4 bit dữ liệu, mã Hamming (7, 4) thêm 3 bit kiểm tra. Mã Hamming (7, 4) có thể phát hiện và sửa lỗi 1 bit, phát hiện lỗi 2 bit trong chuỗi 7 bit nhận được. 8 Hình 2.1. Ma trận sinh và ma trận kiểm tra của mã Hamming (7, 4) 3.1.2. Quá trình giấu tin Bước 1) Chuỗi bit M được chia thành các đoạn dài 4 bit và mã hóa thành từ mã có độ dài 7 bit. Độ dài chuỗi M’ sẽ bằng (L/4)*7. Bước 2) Giấu tin: Đọc tệp âm thanh gốc và giấu lần lượt từng bit của chuỗi M’, theo qui tắc chẵn lẻ của nhóm gồm 3 mẫu. Nếu tổng 3 bit cuối của nhóm khác tính chẵn lẻ với bit giấu thì cần điều chỉnh 1 mẫu. 3.1.3. Quá trình giải tin và xác thực tin giấu Bước 1) Trích thông tin: Dựa vào khóa k, kỹ thuật giấu và số bit đã giấu, ta trích chuỗi bit từ tệp C’’, kết quả ta thu được M’. Bước 2) Xác thực: Chia M’ thành các đoạn có độ dài 7, nhân với ma trận H. Nếu kết quả nhân các đoạn bằng 0, ta trích các bit dữ liệu của M’ để nhận M. Trường hợp kết quả khác 0 thì kết luận là có tấn công. 3.1.4. Kết quả thử nghiệm và đánh giá Kết quả thử nghiệm cho thấy chất lượng tệp mang tin tốt, không phân biệt được khi nghe tệp âm thanh gốc và tệp mang tin Bảng 3.1. Giá trị SNR khi thực hiện giấu kết hợp mã Hamming Tên file chứa Dạng tệp âm thanh Tệp tin được giấu và giá trị SNR tương ứng dohoa.cpp (430 byte) DuyTanlogo.b mp (1694 byte) map.gif (14845 byte) jarre-in.wav Độc tấu 77.56 71.57 62.16 gazebo-in.wav Hòa tấu 78.04 72.19 62.77 brahms-in.wav Hòa tấu 76.33 70.47 60.70 speech-in.wav Bài nói 70.99 64.98 55.50 9 Hình 3.3. Dữ liệu âm thanh gốc và dữ liệu có chứa tin mật Khi có tấn công, giá trị một số mẫu dữ liệu âm thanh sẽ thay đổi. Bảng 3.2 thể hiện kết quả khi thay đổi ngẫu nhiên một số mẫu trên tệp mang tin và khả năng phát hiện thay đổi của kỹ thuật đề xuất. Bảng 3.2. Phát hiện thay đổi tin mật trên tệp mang tin Số mẫu điều chỉnh Phát hiện thay đổi Số bit sai phát hiện khi giải tin Số bit có thể sửa 5 Có 1 1 10 Có 3 2 40 Có 24 20 100 Có 38 14 500 Có 172 75 3.2. Thuật toán giấu điều chỉnh giá trị nhóm bit 3.2.1. Sinh chuỗi xác định mẫu dữ liệu và vị trí trên mẫu Dùng khoá K sinh chuỗi SR, tính chuỗi S và V, trong đó S[i] cho biết mẫu được chọn và V[i] cho biết vị trí bit trên mẫu để giấu. 3.2.2. Điều chỉnh độ lệch bit PROC DIEUCHINH(i,k) SET(i,k); if(i>1) SET(1,1-k); if(i>2) SET(2,1-k); END PROC 3.2.3. Thuật toán giấu tin theo phương pháp điều chỉnh giá trị nhóm bit Đầu vào: -Tệp âm thanh A, chuỗi bit M, khoá K gồm ba số (x, y, N). Đầu ra: - Tệp âm thanh A’ có chứa chuỗi bit mật M. 10 Bước 1) Sinh chuỗi SR, từ đó tính mảng S[] và mảng V[]. Bước 2) Giấu lần lượt từng bit Mi theo nguyên tắc nếu bit thứ Vi của mẫu chọn thứ i khác với Mi thì thực hiện DIEUCHINH(Vi, Mi). Bước 3) Ghi các mẫu đã điều chỉnh ra tệp âm thanh A’. 3.2.4. Quá trình giải tin theo phương pháp điều chỉnh giá trị nhóm bit Đầu vào: - Tệp A’ chứa tin giấu, khoá K(x, y, N), độ dài L. Đầu ra: - Chuỗi bit M được giấu. Bước 1) Chuẩn bị: dựa vào khoá sinh ra mảng S[] và mảng V[]. Bước 2) Giải tin: đọc tệp âm thanh A’, dựa vào mảng S[] và mảng V[], thực hiện lấy L bit từ các mẫu trên tệp A’. 3.2.5. Đánh giá phương pháp giấu tin 3.2.5.1. Chi phí thời gian giấu tin và giải tin 3.2.5.2. Tỉ lệ dữ liệu giấu 3.2.5.3. Độ mật của kỹ thuật Việc điều chỉnh các bit để giấu không tạo thành qui luật. Bảng 3.3. Giá trị SNR khi giấu theo phương pháp điều chỉnh nhóm bit Tên file chứa Giá trị SNR dohoa.cpp (430 byte) DuyTanlogo.bmp (1694 byte) map.gif (14845 byte) jarre-in.wav 71.52 65.46 56.14 gazebo-in.wav 72.03 66.23 56.77 brahms-in.wav 70.37 64.54 54.69 speech-in.wav 64.80 58.91 49.49 3.3. Thuật toán điều chỉnh 2 mẫu trong đoạn chứa 25 mẫu 3.3.1. Xáo trộn dữ liệu Chuỗi mật cần giấu được xáo trộn bằng biến đổi Arnold. 3.3.2. Thuật toán giấu 4 bit trong khối 25 mẫu dữ liệu Thuật toán thực hiện giấu 4 bit mật vào khối F, kết quả là F’. 11 Bước 1) Xây dựng ma trận A từ khối F, A[i][j] = LSB(F[i][j]) Bước 2) Lấy 4 dòng đầu của A, mỗi dòng thực hiện phép XOR tất cả các phần tử trong dòng, ta có r1r2r3r4. Bước 3) Lấy 4 cột đầu tiên của A, mỗi cột thực hiện XOR tất cả các phần tử của mỗi cột để được c1c2c3c4. Bước 4) Thực hiện XOR kết quả trong bước 2 và bước 3 để có s1s2s3s4. Bước 5) So sánh kết quả của Bước 4) với 4 bit cần giấu b1b2b3b4. Nếu giống nhau thỏa điều kiện giấu, ngược lại, cần xét các trường hợp sau: • Nếu khác nhau 1 bit bi tại vị trí i thì A[i][5] được điều chỉnh lật. • Nếu khác nhau trên 2 bit bi và bj tại vị trí i và j thì A[i][j] được lật. • Nếu có khác nhau trên 3 bit bi, bj và bk tại 3 vị trí i, j, k thì A[i][j] được lật và A[k][5] được lật. • Nếu có khác nhau trên cả 4 bit bi, bj, bk và bm tại 4 vị trí i, j, k, m thì thực hiện lật A[i][j] và A[k][m]. Bước 6) Đặt các bit LSB của khối F[i][j] giống A[i][j] ta được F’. 3.3.3. Thuật toán giấu tin Bước 1) Xáo trộn chuỗi thông điệp mật M ta được M’. Bước 2) Chia và chuyển dữ liệu âm thanh thành các khối Fi. Bước 3) Thực hiện bước sau cho đến khi toàn bộ thông điệp M’ được giấu vào trong các khối: Lấy 4 bit của M’ giấu vào mỗi khối Fi, theo thuật toán mục 3.3.2. Bước 4) Chuyển các khối Fi sang lại dạng vector và ghi ra tệp F’. 3.3.4. Thuật toán giải tin Bước 1) Chia tệp âm thanh thành các khối F kích thước 5*5. Bước 2) Lấy 4 bit trong mỗi khối giấu theo cách tính s1s2s3s4 và lấy đủ số bit được giấu ra. Bước 3) Thực hiện phép biến đổi ngược để lấy lại thông điệp mật M. 12 h e l l o w o r l d 1 2 3 4 5 6 7 8 1 2 3 4 5 6 7 8 Hoán vị thứ 1000 Hoán vị thứ 1000 1 3 5 4 7 8 2 6 1 3 5 4 7 8 2 6 h l o l w o e r d l 3.3.5. Kết quả thử nghiệm và đánh giá Hình 3.19 là biểu diễn đoạn gồm 50 mẫu của tệp âm thanh gốc và tệp mang tin sau khi giấu 1 byte dữ liệu. Kết quả thử nghiệm cũng cho thấy kỹ thuật đề xuất đáp ứng tiêu chí SNR khi giấu tin. Hình 3.19. Tín hiệu âm thanh trước và sau khi giấu tin Bảng 3.4. Giá trị SNR khi giấu tin theo kỹ thuật MCPT Tên file chứa Giá trị SNR dohoa.cpp (430 byte) DuyTanlogo.bmp (1694 byte) map.gif (14845 byte) jarre-in.wav 82.57 76.04 66.63 gazebo-in.wav 82.57 76.65 67.21 brahms-in.wav 80.51 74.66 65.19 speech-in.wav 75.37 69.42 59.95 3.4. Thuật toán chỉnh 1 bit để giấu 8 bit dữ liệu 3.4.1. Xáo trộn dữ liệu bằng phương pháp hoán vị Hình 3.5. Chuỗi tin gốc và chuỗi sau khi hoán vị 3.4.2. Tính tổng XOR của đoạn Thuật toán tính tổng XOR của đoạn S gồm 256 mẫu. 13 Bước 1) Từ mảng S ta xác định mảng Q, trong đó Q[i] = S[i]%2. Bước 2) h=0; Bước 3) Lặp i từ 0 đến 255: Nếu (Q[i]!=0) thì h = XOR(h,i); Bước 4) Trả về h; 3.4.3. Thuật toán giấu một byte vào trong khối S gồm 256 mẫu Bước 1) Tính XOR_sum của đoạn S: h=XOR_sum(S); Bước 2) Tìm vị trí của mẫu để giấu tin: pos= XOR (h, p); Bước 3) Nếu giá trị pos > 0 thì Q[pos] = 1 - Q[pos]; Nếu Q[pos] = 0 thì S[pos] += 1, ngược lại S[pos] = S[pos] - 1. 3.4.4. Thuật toán giấu tin Đầu vào: - Tệp âm thanh F, khoá (k, d), và thông điệp cần giấu M. Đầu ra: - Tệp âm thanh F’ chứa tin mật. Bước 1) Chia thông điệp mật M thành các đoạn có cùng độ dài d. Dựa vào giá trị k, xáo trộn M và ta có được M’. Bước 2) Chia tệp F thành các đoạn Si có độ dài bằng 256. Bước 3) Lấy lần lượt từng byte của M’ giấu vào trong đoạn Si theo thuật toán ở mục 3.4.3 cho đến khi toàn bộ thông điệp được giấu. Bước 4) Ghi các đoạn Si ra tệp F’. 3.4.5. Thuật toán giải tin Bước 1) Lấy h=   ddq */ đoạn (256 mẫu) từ tệp chứa tin mật. Bước 2) Lặp h lần để lấy h byte từ các đoạn, mỗi byte trong mỗi đoạn, byte thứ i được gán cho M’[i], với M’[i] =XOR_sum(Si). Bước 3: Đối với mỗi đoạn gồm d byte của M’, dùng phép biến đổi khôi phục lại chuỗi tin M như thuật toán đã trình bày ở mục 3.4.1. 3.4.6. Kết quả thử nghiệm và đánh giá Bảng 3.5 thể hiện độ đo SNR khi sử dụng kỹ thuật giấu để giấu các tệp dữ liệu vào các tệp âm thanh khác nhau. 14 Bảng 3.5. Giá trị SNR khi giấu theo thuật toán điều chỉnh một bit Tên file chứa Giá trị SNR dohoa.cpp (430 byte) DuyTanlogo.bmp (1694 byte) map.gif (14845 byte) jarre-in.wav 85.99 80.05 Không giấu được gazebo-in.wav 86.58 80.64 Không giấu được brahms-in.wav 84.61 78.62 Không giấu được speech-in.wav 79.32 32.62 Không giấu được 3.5. Phương pháp điều chỉnh tiếng vọng Kỹ thuật này cải tiến kỹ thuật được đề xuất bởi J. A. R. Chavez và các đồng sự. 3.5.1. Sơ đồ giấu của Rios Chavez 3.5.2. Kỹ thuật điều chỉnh tiếng vọng Bằng cách dựa vào các giá trị được sinh từ khoá và điều chỉnh công thức thêm tiếng vọng vào dữ liệu gốc, kỹ thuật đề xuất sẽ hạn chế khả năng người thám tin dò tìm được tin. 3.5.2.1. Thêm tiếng vọng dựa vào số ngẫu nhiên Để giấu chuỗi bit M ta cần sinh chuỗi R ngẫu nhiên, trong đó Ri chỉ nhận giá trị 0 hoặc 1. Dựa vào giá trị Ri này ta sẽ giữ nguyên đoạn hoặc thêm tiếng vọng vào đoạn. Để thêm tiếng vọng vào trong đoạn, ta sử dụng công thức (3.11). Si′(n) = [ 1.1 ∗ Si(n) nếu Si(n) = Si(n − d) 0.99 ∗ Si(n) + 0.1 ∗ Si(n − d) nếu Si(n) Si(n − d) (3.11) Công thức điều chỉnh này tránh được trường hợp rút trích tin sai do có xử lý cho đoạn có giá trị trùng nhau. 1: copy để giấu bit 1, thêm tiếng vọng để giấu bit 0 0: copy để giấu bit 0, thêm tiếng vọng để giấu bit 1 Nếu Ri = 15 3.5.2.2. Thuật toán giấu Thuật toán giấu chuỗi bit W vào tệp C, kết quả ghi ra tệp S. Bước 1) Sinh ra chuỗi R dựa vào khoá theo công thức (3.9), (3.10). Bước 2) Chia dữ liệu trên tệp C thành các đoạn Ci có kích thước bằng nhau. Nếu số frame < độ dài chuỗi bit (L) cần giấu thì dừng. Bước 3) Gán giá trị các đoạn Si bằng Ci Dựa vào giá trị của Ri và giá trị bit cần giấu Wi, dùng công thức (3.11) để thêm tiếng vọng vào cho các đoạn Si. Bước 4) Ghi các đoạn Si và chép các mẫu còn lại từ C ra tệp S. 3.5.2.3. Thuật toán giải tin Thuật toán trích chuỗi bit từ tệp gốc C và tệp mang tin S. Bước 1) Sinh ra chuỗi R dựa vào khoá theo công thức (3.9), (3.10). Bước 2) Chia dữ liệu tệp chứa tin giấu S và tệp gốc C thành các đoạn Si, Ci có kích thước bằng nhau. Bước 3) So sánh cepstrum của đoạn Ci với Si và dựa vào giá trị của Ri để trích bit 0 hoặc bit 1. Lặp lại bước 3 cho các đoạn dữ liệu Ci, Si cho đến khi lấy đủ L bit. 3.5.3. Kết quả thử nghiệm và đánh giá Hình 3.31. Phổ biên độ một đoạn của âm thanh trước và sau khi giấu Trong thử nghiệm, cặp số (7, 9137) được chọn làm số mồi cho bộ sinh số ngẫu nhiên. Chuỗi dữ liệu giấu có độ dài gồm 3440 bit được 16 lấy từ tệp dohoa.cpp. Tệp chứa được lấy mẫu ở tần số 44100, số bit lượng tử là 16, gồm 1422720 mẫu. Kích thước mỗi đoạn được chọn là 1000 và giá trị d1 được chọn bằng 441. Bảng 3.6. Giá trị SNR khi thêm tiếng vọng để giấu tin Tên file chứa Giá trị SNR dohoa.cpp (430 byte) DuyTanlogo.bmp (1694 byte) map.gif (14845 byte) S.wav 30.54 27.17 Không giấu được speech-in.wav 29.12 23.75 Không giấu được Tổng kết chương 3 Chương 3 trình bày năm thuật toán giấu tin trong âm thanh được thực hiện trên miền thời gian. Chương 4 MỘT SỐ THUẬT TOÁN GIẤU TIN TRÊN MIỀN BIẾN ĐỔI 4.1 Thuật toán điều chỉnh các hệ số trên miền biến đổi Fourier 4.1.1. Điều chỉnh giá trị trong miền tần số Trong kỹ thuật này, mỗi đoạn dữ liệu âm thanh Y sẽ được chuyển sang miền tần số dùng phép biến đổi Fourier. FFT(Y)FY  (4.1) Hình 4.1. Biểu diễn số phức trong hệ toạ độ cực Số phức z = x + i ∗ y có thể biểu diễn lại trong hệ toạ độ cực bằng công thức sau : 17 )sin(cos  irz  (4.2) Trị tuyệt đối (magnitude) của số phức được xác định như sau : 22)( yxzabsr  (4.3) Một số mẫu trong dãy FY sẽ được lựa chọn và điều chỉnh để giấu tin. Nếu ta thay đổi độ lớn (magnitude) r của một số phức z thành r’ thì giá trị x, y cũng thay đổi theo. Giá trị x’ và y’ được xác định theo công thức (4.5) và giá trị mới của z được xác định theo công thức (4.6).   sin'' cos'' ry rx   (4.5)  sin'*cos'' rirz  (4.6) 4.1.2. Thuật toán điều chỉnh mẫu để giấu một bit Thuật toán điều chỉnh số phức z để giấu bit mật b, dựa vào số d. Phương pháp: Dieuchinh(z, b, d) Bước 1) Tính biên độ (amplitude) và pha của z: amp = abs(z); phase= angle(z); Bước 2) Điều chỉnh giá trị số phức z để giấu bit b: Nếu b=1 { nếu mod (amp, d) < d/2 thì amp = amp + d/2; } Ngược lại nếu mod (amp, d)> =d/2 thì amp = amp + d/2; Bước 3) Tạo số phức mới z’ và trả về: return (r’=complex(amp*cos(phase),amp*sin(phase))); 4.1.3. Thuật toán giấu Đầu vào: - Vector Y, chuỗi bit M có độ dài q, giá trị d, k, fw. Đầu ra: - Vector Y’ mang tin. Bước 1) Chia Y thành các đoạn có kích thước bằng nhau, chứa fw (frame width) mẫu trên mỗi đoạn. Thực hiện phép biến đổi FFT trên mỗi đoạn để chuyển từ miền thời gian sang miền tần số. FYk = FFT (Yk). 18 Bước 3) Đối với mỗi đoạn FYk, tính biên độ và kiểm tra xem đoạn có thoả điều kiện để giấu không. Điều kiện đoạn được chọn để giấu tin là trong đoạn có số mẫu có biên độ là đỉnh (peak) lớn hơn hoặc bằng 8 và biên độ phải lớn hơn giá trị k (ngưỡng chọn). Nếu thoã mãn điều kiện giấu thì giấu lần lượt 8 bit tin mật vào trong đoạn 8 phần tử đầu tiên là đỉnh của đoạn, dùng kỹ thuật điều chỉnh ở mục 4.1.2 Bước 4) Thực hiện IFFT trên mỗi đoạn FY để chuyển FY từ miền tần số về lại miền thời gian lưu vào Y’ Bước 5) Trả về Y’. Bảng 4.1. Giá trị các mẫu trước và sau khi giấu các bit Giá trị trước khi điều chỉnh Bit giấu Giá trị sau khi điều chỉnh 7.774503 0 7.874503 11.513642 1 11.513642 6.869382 0 6.869382 7.337803 1 7.337803 6.913936 0 7.013936 6.913936 1 6.913936 7.337803 0 7.437803 6.869382 1 6.969382 4.1.4. Thuật toán lấy 1 bit mật từ 1 mẫu Thuật toán sẽ trích số nhị phân Mi từ số phức z. Phương thức: Getbit (z) Bước 1) Tính biên độ (amplitude) của z: amp = abs(z); Bước 2) Lấy bit Mi : nếu mod(amp,d)>d/2 thì Mi =1, ngược lại Mi =0 Bước 3) return Mi 4.1.5. Thuật toán giải tin Đầu vào: - Vector Y’ mang tin, độ dài chuỗi bit q, số d, k, fw. Đầu ra: - Chuỗi bit mật M. 19 Bước 1) Chia Y’ thành các đoạn có cùng số kích thước fw. Bước 2) Thực hiện FFT trên các đoạn Y’i để chuyển sang miền tần số: FY’i = FFT (Y’i). Tính biên độ cho đoạn và gán số bit đã nhận được h=0; Bước 3) Đối với mỗi đoạn FY’i, kiểm tra đoạn có chứa tin hay không dựa vào việc đếm số đỉnh lớn hơn ngưỡng chọn k. Nếu đoạn có chứa tin thì chọn 8 đỉnh đầu tiên trong đoạn để rút trích tin. M[h] = Getbit( FYk(i), d ); h=h+1; Nếu h>1 thì sang Bước 4; Xét các đoạn FY’i kế tiếp. Bước 4) return M. 4.1.6. Kết quả thử nghiệm và đánh giá Thực nghiệm thực hiện thêm nhiễu trắng vào dữ liệu mang tin. Nếu tỉ lệ gây nhiễu lớn hơn 90 thì không ảnh hưởng đến tin giấu. Bảng 4.2. Tỉ lệ bit sai khi tấn công thêm nhiễu trắng Tỉ lệ gây nhiễu Số bit nhận sai Tỉ lệ nhận sai 35 310 0.302734375 40 189 0.184570313 50 46 0.044921875 70 40 0.039062500 80 1 0.000976563 >=90 0 0 Hình 4.5. Ảnh thu được khi giải tin tương ứng với các tỉ lệ gây nhiễu hệ số nhiễu 35 hệ số nhiễu 40 hệ số nhiễu 50 hệ số nhiễu 70 hệ số nhiễu >=90 hệ số nhiễu 80 20 Bảng 4.3. Giá trị SNR khi điều chỉnh biên độ để giấu tin Tên file chứa Giá trị SNR dohoa.cpp (430 byte) DuyTanlogo.bmp (190 byte) map.gif (14845 byte) S.wav 80.41 76.73 Không giấu được speech-in.wav 76.35 72.27 Không giấu được 4.2 Thuật toán điều chỉnh hệ số biến đổi wavelet Phép biến đổi wavelet phân tích tín hiệu thành hai thành phần là A (Approximation) và D (Detail), trong đó thành phần D không quan trọng. Thay đổi trên D ít ảnh hưởng đến tín hiệu âm thanh gốc. 4.2.1. Thuật toán giấu 1 bit Thuật toán giấu bit b vào dãy D gồm fw phần tử, dựa vào số thực d. Bước 1) Tính giá trị trung bình của nửa đoạn trước và nửa đoạn sau của D. h2 = (∑ D[i] fw fw 2 +1 )/( fw 2 ) , h1 = (∑ D[i])/(fw/2) fw 2 1 (4.7) Bước 2) Tính giá trị lệch giá trị trung bình giữa hai đoạn, theo modulo d: k = abs(h1 − h2) mod d Bước 3) Điều chỉnh giá trị để giấu bit b : Nếu b=1 và k> d/2

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

  • pdftom_tat_luan_an_mot_so_ky_thuat_giau_tin_trong_am_thanh_so.pdf
Tài liệu liên quan