MỞ ĐẦU .1
Chương 1.GIẤU THÔNG TIN VÀ GIẤU TIN TRONG ÂM THANH.7
1.1. Giấu thông tin.7
1.1.1. Lịch sử giấu thông tin .7
1.1.2. Các thành phần của hệ giấu tin.7
1.1.3. Các yêu cầu của hệ giấu tin .8
1.1.4. Phân loại giấu tin .10
1.1.5. Tấn công hệ thống giấu tin .11
1.1.6. Các ứng dụng của giấu tin .12
1.2. Giấu tin trong âm thanh số .13
1.2.1. Ngưỡng nghe .14
1.2.2. Hiện tượng che khuất.14
1.2.3. Âm thanh và các đặc tính của âm thanh .16
1.2.4. Biểu diễn âm thanh số.17
1.2.5. Các định dạng âm thanh phổ biến .19
1.2.6. Một số chương trình giấu tin trên âm thanh .20
Tổng kết chương 1 .20
Chương 2.PHƯƠNG PHÁP GIẤU TIN TRONG ÂM THANH .22
2.1. Các kỹ thuật bổ trợ cho giấu tin .22
2.1.1. Các phép biến đổi từ miền thời gian sang miền tần số.22
2.1.2. Xáo trộn dữ liệu mật .24
2.1.3. Sinh chuỗi giả ngẫu nhiên.26
2.2. Đánh giá các phương pháp giấu tin trong âm thanh.27
2.2.1. Đánh giá bằng các độ đo.27
2.2.2. Đánh giá bằng các phần mềm phát hiện tin.27
2.2.3. Đánh giá bằng bảng đánh giá ODG (Object Difference Grade) .28
2.3. Phương pháp giấu tin trong âm thanh .28
2.3.1. Phương pháp điều chỉnh bit ít quan trọng nhất (LSB coding).28
2.3.2. Phương pháp chẵn lẻ (parity coding).29
2.3.3. Phương pháp mã hoá pha (phase coding).30
2.3.4. Phương pháp mã hoá tiếng vọng (echo coding) .33
2.3.5. Phương pháp trải phổ.35
2.3.6. Phương pháp điều chỉnh biên độ .37
2.3.7. Phương pháp lượng tử hoá (quantization) .38
120 trang |
Chia sẻ: honganh20 | Ngày: 15/03/2022 | Lượt xem: 307 | Lượt tải: 2
Bạn đang xem trước 20 trang tài liệu 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
, trong đó d là một hằng số có giá trị nhỏ.
𝑎𝑖
∗ = 𝑎𝑖 + 𝑑 và 𝑏𝑖
∗ = 𝑏𝑖 − 𝑑
Quá trình giải tin được thực hiện bắt đầu bằng cách trừ các giá trị các mẫu trên
hai tập A, B. Tiếp theo giá trị 𝐸[�̅�∗ − �̅�∗] được dùng để xác định các mẫu có tin giấu
Giấu bit 1 Giấu bit 0
Tín hiệu gốc
40
hay không. Giá trị �̅�∗ và �̅�∗ là giá trị trung bình của A và B sau khi được giấu tin. Quá
trình giải tin theo kỹ thuật Patchwork không cần dùng tin gốc.
Hình 2.14. So sánh giá trị trung bình của tín hiệu không có và có giấu tin.
Kỹ thuật này có hạn chế là quá trình giải tin có thể nhận tin sai. Ta có:
𝐸[�̅�∗ − �̅�∗] = 𝐸[(�̅� + 𝑑 ) − (�̅� − 𝑑)] = 𝐸[�̅� − �̅� ] + 2𝑑 (2.19)
Kỹ thuật này giả định 𝐸[�̅�∗ − �̅�∗] = 2𝑑 hay 𝐸[ �̅� − �̅� ] = 0 nhưng trong thực tế
𝐸[�̅� − �̅� ] không thoả giá trị bằng 0, điều này dẫn đến quá trình rút trích có thể
nhận giá trị sai.
Yeo và Kim trong [76] cải tiến kỹ thuật giấu dựa trên Patchwork gọi là MPA.
Kỹ thuật này hạn chế việc giải tin sai của thuật toán Patchwork.
Các bước của quá trình giấu tin như sau:
Bước 1) Chọn hai tập ngẫu nhiên A, B sau đó thực hiện các phép tính �̅� và �̅� rồi
tính giá trị S theo công thức (2.20) như sau:
𝑆 = √
∑ (𝑎𝑖− 𝑎)̅̅ ̅
2+ ∑ (𝑏𝑖− �̅�)
2𝑁
𝑖=1
𝑁
𝑖=1
𝑁∗(𝑁−1)
(2.20)
Bước 2) Hàm nhúng được thực hiện theo công thức (2.21):
{
𝑎𝑖
∗ = 𝑎𝑖 + 𝑠𝑖𝑔𝑛(�̅� − �̅�)√𝐶 ∗ 𝑆/2
𝑏𝑖
∗ = 𝑏𝑖 + 𝑠𝑖𝑔𝑛(�̅� − �̅�)√𝐶 ∗ 𝑆/2
(2.21)
Trong công thức trên C là một hằng số, sign là hàm làm cho giá trị lớn hơn sẽ lớn hơn
và giá trị nhỏ sẽ nhỏ hơn. Mục đích của việc này là làm cho giá trị trung bình khoảng
cách giữa hai giá trị mẫu luôn lớn hơn 𝑑 = √𝐶 ∗ 𝑆.
41
Hình 2.15. Giá trị trung bình của tín hiệu có và không có giấu tin theo MPA
Theo cách điều chỉnh của thuật toán MPA, giá trị phân bố giá trị trung bình
khoảng cách 2 mẫu sẽ như hình 2.15.
Thuật toán giải tin như sau:
Bước 1) Tính giá trị thống kê như công thức (2.20)
𝑇2 =
(�̅�− �̅�)2
𝑆2
(2.20)
Bước 2) So sánh giá trị 𝑇2 với ngưỡng 𝛽. Nếu 𝑇2 > 𝛽 thì xác nhận có tin giấu, ngược
lại thì không có.
2.3.10. Phương pháp dựa vào các đặc trưng nổi bật
Các đặc trưng nổi bật là các tín hiệu đặc biệt, gây được sự chú ý của người
nhúng và người rút trích, nhưng vẫn phải bảo đảm cho kẻ tấn công không phát hiện
ra. Chúng có thể là tự nhiên có được hay do chính ta tạo ra. Tuy nhiên, trong bất kỳ
cách nào thì chúng cũng phải bền vững đối với các tấn công. Và các đặc trưng này
thường được tạo và rút trích theo kinh nghiệm. Đặc biệt, các đặc trưng nổi bật này rất
tốt cho quá trình đồng bộ hoá để dò tìm ra thông tin giấu trong quá trình rút trích. Wu
và các cộng sự trong [72] đề xuất một kỹ thuật giấu dựa vào chính nội dung của tín
hiệu âm thanh. Trong [61] cũng trình bày thuật toán giấu dựa vào các đỉnh của dữ
liệu (peak) để giấu tin trong âm thanh định dạng mp3.
Các kỹ thuật giấu ở trên là cơ sở nền tảng để tiến hành giấu tin trong âm thanh.
Một số chi tiết liên quan đến các kỹ thuật giấu đã được trình bày trong nghiên cứu
của các tác giả khác ở [13, 19, 20, 34]. Các nghiên cứu trong [11, 21, 22, 23, 28] thực
42
hiện các cải tiến trên kỹ thuật giấu LSB để giấu tin. Một số nghiên cứu kết hợp giữa
mã hoá và giấu tin như [12] hoặc kết hợp nhiều kỹ thuật giấu với nhau như trong [35].
Mỗi một định dạng âm thanh khác nhau đòi hỏi các kỹ thuật giấu khác nhau.
Trong [77] trình bày kỹ thuật giấu có điều chỉnh tỉ lệ bit cho âm thanh chuẩn AAC,
[59] trình bày thuật toán giấu cho dữ liệu theo định dạng mp3 và [60] trình bày thuật
toán giấu cho định dạng PCM. Đối với ứng dụng dạng thời gian thực và cho các thiết
bị di động, hai thuật toán giấu được trình bày trong [27, 39].
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 nhằm mục đích thay đổi thứ tự các bit dữ liệu mật
trước khi giấu vào tín hiệu âm thanh, các kỹ thuật sinh số ngẫu nhiên, các tiêu chí
đánh giá các thuật toán giấu tin. Nội dung chính của chương trình bày về các phương
pháp giấu tin trong tệp âm thanh, là cơ sở nền tảng để triển khai các kỹ thuật giấu.
Mục này của chương cũng có những đánh giá các ưu nhược điểm của từng phương
pháp, đánh giá khả năng áp dụng của các phương pháp đó trong giấu tin mật hay thủy
vân, các giải pháp cải tiến từng phương pháp để nâng cao hiệu quả giấu về cả tỉ lệ dữ
liệu và tính bền vững cùng các nghiên cứu liên quan đến phương pháp giấu đó.
43
Chương 3. MỘT SỐ THUẬT TOÁN GIẤU TIN TRÊN
MIỀN THỜI GIAN
Những vấn đề cần phải quan tâm giải quyết trong bài toán giấu tin là ít làm
thay đổi dữ liệu chứa, phát hiện được có tấn công làm thay đổi tin giấu và tránh người
thám tin lấy được tin giấu. Chương này của luận án sẽ trình bày 5 thuật toán giấu tin,
giải quyết một phần những vấn đề trên. Nội dung chương dựa trên các bài báo, từ bài
số 1 đến bài số 4 và bài số 6, trong danh mục các công trình khoa học. Các thuật toán
trình bày trong chương này thực hiện giấu tin trên miền thời gian, bằng cách điều
chỉnh trực tiếp giá trị các mẫu dữ liệu. Đây là các thuật toán giấu không bền vững
nhưng có tỉ lệ dữ liệu lớn và thích hợp để giấu tin mật. Trong thử nghiệm đánh giá
các thuật toán ở chương 3 và chương 4, luận án sử dụng các tệp âm thanh mẫu tại địa
chỉ website [79, 88] làm dữ liệu chứa. Các tệp âm thanh được chọn là đại diện cho
các kiểu âm thanh khác nhau, đó là bài phát biểu, tiếng cười, đoạn thông báo ở nơi
công cộng hoặc bản hòa tấu. Khi triển khai trong thực tế, việc lựa chọn các tệp âm
thanh làm dữ liệu chứa cũng có ảnh hưởng đến tính mật của việc giấu tin. Thông
thường các tệp âm thanh được chọn phải là các tệp không phổ biến, mục đích là để
người thám tin không có dữ liệu âm thanh gốc để đối chiếu với tệp mang tin. Trong
thử nghiệm, kiểu tệp dữ liệu được chọn để giấu là tệp văn bản (dohoa.cpp), tệp ảnh
nhị phân (DuyTanlogo, có các kích thước khác nhau) và một tệp ảnh có kích thước
lớn (map.gif) để so sánh dung lượng giấu của các kỹ thuật với nhau.
3.1. Thuật toán giấu tin kết hợp mã sửa lỗi Hamming
Các phương pháp giấu tin trên dữ liệu số thực hiện giấu tin vào các “khe hở”
của dữ liệu chứa C. Khe hở của dữ liệu được hiểu là khoảng biến thiên giá trị của dữ
liệu có cùng ảnh hưởng đến hệ thống tri giác của con người. Sau khi giấu tin xong,
dữ liệu mang tin giấu C’ sẽ được truyền đi ra môi trường công cộng và bên nhận sẽ
giải tin để lấy lại tin giấu. Trong quá trình truyền, đối tượng C’ có thể chịu một số tấn
công [9, 57] làm cho nội dung C’ bị thay đổi thành C’’. Khi giải tin, người giải tin sẽ
giải được M’ từ C’’ thay vì có được M từ C’. Sẽ có trường hợp M’ khác với M trong
44
khi người giải tin không hề hay biết và vẫn dùng M’. Trong một số ứng dụng, việc
sai sót này trong một mức độ nào đó là có thể cho phép, nhưng đa số ứng dụng thì
việc sai khác giữa M và M’ là không thể chấp nhận và có thể gây ra hậu quả nghiêm
trọng, chẳng hạn như trong lĩnh vực ngân hàng, y tế, quân sự... đòi hỏi sự chính xác
tuyệt đối. Thuật toán giấu kết hợp với mã hoá Hamming nhằm giúp cho người nhận
tin hạn chế thấp nhất khả năng nhận tin sai, có thể biết được tin khi nhận M’ có bị sai
khác với bản tin gốc M được giấu hay không và đưa ra bản sửa lỗi M’’.
3.1.1. Mã Hamming
Mã Hamming là một mã trong họ các mã sửa lỗi ECC (Error Correction Code)
được công bố năm 1950. Nguyên lý của mã Hamming bắt nguồn từ việc khai triển và
mở rộng quan điểm chẵn lẻ. Với mỗi nhóm 4 bit dữ liệu, mã Hamming thêm 3 bit
kiểm tra. Hình 3.1 là minh hoạ mã Hamming (7,4) trong đó có 4 bit dữ liệu được
truyền đi d1, d2, d3, d4 và 3 bit chẵn lẻ kiểm tra p1, p2, p3.
Hình 3.1. Minh hoạ mã Hamming với 4 bit dữ liệu và 3 bit kiểm tra chẵn lẻ
Mã Hamming sử dụng hai ma trận, gọi là ma trận sinh G và ma trận kiểm tra
H. Đối với mã Hamming (7,4) ma trận G và H sẽ như sau :
Hình 3.2. Ma trận sinh và ma trận kiểm tra của mã Hamming (7, 4)
45
Chuỗi bit thông tin u sẽ được mã hóa bằng cách nhân với ma trận sinh G, kết
quả được từ mã v. Từ mã v được tính theo công thức :
v = G ∗ u (3.1)
Nếu nhân v với H sẽ được 0. Đây là công thức để kiểm tra lỗi :
H ∗ v = 0 (3.2)
Ví dụ ta cần gửi đi chuỗi bit thông tin là u = 1011. Chuỗi u này sẽ được mã hóa thành
từ mã là v = 0110011 và truyền đi.
Bên nhận sẽ nhận được chuỗi bit r. Để kiểm tra r nhận được có sai hay không,
ta tiến hành nhân r với H, nếu kết quả khác 0 thì r bị sai.
Ta có thể viết r = v + e trong đó e là vector lỗi. Nếu e chỉ gồm có một bit lỗi
thì mã Hamming có thể sửa được. Nếu e gồm 2 lỗi thì mã Hamming chỉ phát hiện
được lỗi chứ không sửa được [67].
Mã Hamming (7,4) có thể mở rộng sang (8,4) bằng cách thêm một dòng bit
chẵn lẻ ở dòng đầu tiên của ma trận G và thêm bit chẵn lẻ vào dòng cuối cùng của ma
trận H.
Vận dụng tính chất có thể phát hiện được 2 lỗi trên 7 bit nhận được của mã
Hamming, thuật toán đề xuất dưới đây kết hợp phương pháp giấu với phương pháp
mã hóa chuỗi bit sử dụng mã Hamming. Việc dùng mã Hamming nhằm mục đích
kiểm soát quá trình tin giấu gửi đi (trong đối tượng chứa) có bị thay đổi hay không.
3.1.2. Quá trình giấu tin
Quá trình giấu tin gồm 2 bước là mã hoá và giấu. Mục đích của bước 1 là thêm
các bit kiểm tra tin giấu có bị thay đổi không. Bước 2 sẽ thực hiện giấu chuỗi bit đã
mã hoá vào tệp âm thanh theo một thuật toán đã định trước.
Thuật toán giấu tin kết hợp mã xác thực như sau:
Đầu vào: - Tệp âm thanh gốc C;
- Chuỗi bit M cần giấu có độ dài L (L là bội số của 8).
Đầu ra: - Tệp âm thanh chứa tin giấu C’.
Các bước giấu tin như sau:
Bước 1) Mã hóa
46
Chuỗi bit M được chia thành các đoạn có độ dài 4 bit. Mỗi đoạn bit thông tin
này sẽ được mã hoá dùng mã Hamming sẽ thành từ mã có độ dài 7 bit. Ghép các
chuỗi bit kết quả lại để được chuỗi bit M’. Độ dài chuỗi M’ sẽ bằng (L/4)*7.
Bước 2) Giấu tin
- Đọc tệp chứa C, trích phần header và phần dữ liệu.
- Kiểm tra tệp chứa có đủ để giấu chuỗi bit M’ không. Nếu không đủ thì
dừng và báo không giấu được. Ngược lại sẽ ghi header của C vào C’ sau
đó thực hiện giấu từng bit của chuỗi M’ vào phần dữ liệu của C để ghi ra
C’ như sau :
+ Trích tuần tự 3 mẫu dữ liệu của C và tính tổng. Nếu bit đang xét của
M’ là 1 mà tổng lẻ thì đã thỏa điều kiện giấu, không cần điều chỉnh, ngược
lại điều chỉnh mẫu số 2 của 3 mẫu đang xét để cho tổng là số lẻ. Nếu bit
đang xét của M’ là 0 mà tổng chẵn thì đã thỏa điều kiện giấu, không cần
điều chỉnh, ngược lại điều chỉnh mẫu 1 hoặc mẫu thứ 3 trong 3 mẫu đang
xét để cho tổng là số chẵn.
+ Ghi 3 mẫu đang xét ra tệp C’.
- Lặp lại hai bước con trên bước trên cho đến khi toàn bộ các bit của chuỗi
M’ đã được giấu.
- Ghi các mẫu còn lại từ C vào C’ và kết thúc.
3.1.3. Quá trình giải tin và xác thực tin giấu
Thuật toán giải tin và xác thực tin giấu như sau:
Đầu vào: - Tệp âm thanh chứa tin giấu C’;
- Độ dài chuỗi bit cần lấy.
Đầu ra: - Chuỗi bit M cần lấy, hoặc kết luận không lấy tin.
Các bước thực hiện giải tin như sau:
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 đã được biết trước, ta tiến hành
trích chuỗi bit từ dữ liệu C’’, kết quả ta thu được M’.
Bước 2) Xác thực
47
Chia M’ thành các đoạn có độ dài 7, tiến hành nhân từng đoạn này với H.
Trường hợp 1: Nếu như toàn bộ kết quả nhân các đoạn của M’ với H đều cho
kết quả 0 thì kết luận là không có tấn công trên C’ và thực hiện trích các bit dữ liệu
của M’ để nhận lại tin giấu M.
Trường hợp 2: Nếu như trong quá trình nhân các đoạn của M’ với H có đoạn
cho kết quả khác 0 thì kết luận là có tấn công hoặc do nhiễu và ghi nhận cách sửa lỗi.
Trong trường hợp này cũng rút trích dữ liệu từ M’ sau khi thực hiện sửa lỗi và tạo lại
tin giấu. Nếu như trong mỗi đoạn 7 bit có 2 bit lỗi thì hệ thống sẽ không tự sửa lỗi
được. Trường hợp này yêu cầu gửi lại hoặc không sử dụng thông tin rút trích trong
dữ liệu mang tin ra.
3.1.4. Kết quả thử nghiệm và đánh giá
Để đánh giá kỹ thuật đề xuất, chúng tôi thực hiện giấu giấu các tệp dữ liệu vào
tệp âm thanh gốc vào kiểm tra giá trị SNR. Kết quả thử nghiệm được thể hiện trong
bảng 3.1 và cho thấy tỉ lệ này đáp ứng yêu cầu về chất lượng của tệp âm thanh mang
tin so với tệp âm thanh gốc.
Bảng 3.1. Giá trị SNR khi thực hiện giấu kết hợp mã Hamming
Tên tệp chứa
Dạng tệp âm
thanh
Giá trị SNR
dohoa.cpp
(430 byte)
DuyTanlogo.bmp
(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 Thông báo 70.99 64.98 55.50
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 sự khác nhau khi nghe tệp âm thanh gốc và tệp mang tin. Kỹ thuật đề xuất cũng
cho phép rút trích đúng tin mật từ tệp mang tin. Hình 3.3 là đoạn gồm 100 mẫu tệp
âm thanh gốc speech-in.wav và tệp mang tin khi giấu tệp map.gif.
48
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 trên tệp mang tin, giá trị một số mẫu dữ liệu âm thanh sẽ thay
đổi. Nếu như không biết trước hoặc không có kỹ thuật nào kiểm soát, người nhận tin
có thể nhận tin sai. Mục đích chính của phương pháp giấu tin kết hợp với mã
Hamming là kiểm tra xem thông tin khi nhận có phải đúng là tin bên gửi đã gửi hay
không. Nếu như chúng ta chỉ sử dụng mã hoá thì chỉ có tác dụng làm cho người thám
tin không biết thông tin ta giấu là gì chứ không giúp ta kiểm tra được trong quá trình
truyền thông tin trên đường truyền công cộng, dữ liệu mang tin có bị thay đổi, làm
sai hay không. Thuật toán giấu vừa trình bày là một cách giúp chúng ta kiểm tra lại
thông tin rút trích trong dữ liệu mang tin trước khi quyết định sử dụng nó.
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
Để thử nghiệm khả năng phát hiện thay đổi trên tệp mang tin, làm sai khác tin
nhận được khi giải tin, luận án thực hiện điều chỉnh ngẫu nhiên một số mẫu trên tệp
mang tin. Tệp được chọn giấu là tệp map.gif và tệp âm thanh speech-in.wav được
49
chọn làm dữ liệu chứa. Sau khi giấu tin xong, tệp âm thanh mang tin sẽ được điều
chỉnh ngẫu nhiên một số mẫu. Kết quả thử nghiệm thể hiện trong bảng 3.2.
Tính an toàn của lược đồ giấu này phụ thuộc vào việc giữ mật kỹ thuật. Có thể
nâng cao tính an toàn cho kỹ thuật giấu bằng cách mã hóa (che thông tin) chuỗi thông
tin mật trước, sau đó dùng mã Hamming mã hóa để phục vụ cho việc kiểm tra lỗi rồi
mới thực hiện giấu.
Do phải thêm 3 bit kiểm tra (hoặc 4 bit nếu sử dụng mã Hamming mở rộng)
vào 4 bit dữ liệu nên tỉ lệ dữ liệu xấp xỉ bằng ½ so với phương pháp giấu không sử
dụng mã kiểm tra. Ngoài ra thuật toán điều chỉnh dựa vào tính chẵn lẻ của 3 mẫu kề
nhau để giấu nên tỉ lệ dữ liệu giấu xấp xỉ 1/6 số mẫu của dữ liệu chứa.
Chuỗi tin mật trước khi giấu cần được mã hóa bằng cách nhân với ma trận sinh
G và khi trích tin ta cần nhân với ma trận H để kiểm tra nên tốc độ giấu có chậm hơn
so với phương pháp dùng trực tiếp.
Kỹ thuật giấu này phù hợp với các ứng dụng gửi tin mật.
3.2. Thuật toán giấu điều chỉnh giá trị nhóm bit
Mục này của luận án trình bày một kỹ thuật giấu tin trong âm thanh dựa vào
việc điều chỉnh LSB. Việc giấu tin được thực hiện bằng cách chọn các mẫu và vị trí
bit trên mỗi mẫu dữ liệu để giấu tin. Kỹ thuật này cũng đề xuất cách điều chỉnh bit để
làm giảm độ sai khác giữa mẫu dữ liệu gốc và mẫu dữ liệu mang tin giấu. Kỹ thuật
giấu dùng chuỗi số ngẫu nhiên được sinh từ khoá bí mật.
Quá trình giấu tin gồm 2 giai đoạn. Giai đoạn 1 sẽ dùng khoá mật K để sinh ra
chuỗi ngẫu nhiên gồm L số, trong đó L là chiều dài chuỗi bit mật. Giai đoạn 2 sẽ giấu
lần lượt từng bit của chuỗi tin mật vào trong tệp âm thanh dựa vào chuỗi ngẫu nhiên
đã sinh. Việc giấu tin dựa vào chuỗi ngẫu nhiên nhằm mục đích tăng cường tính mật
cho tin giấu.
3.2.1. Sinh chuỗi xác định mẫu dữ liệu và vị trí trên mẫu
Phương pháp đề xuất dưới đây sẽ dùng chuỗi giả ngẫu nhiên để xác định vị trí
các mẫu dữ liệu chọn và vị trí bit sẽ dùng để giấu tin. Bộ sinh số ngẫu nhiên được
50
chọn là bộ sinh số đồng dư cải tiến đã được trình bày ở mục 2.1.3. Khoá K gồm ba
số (x, y, N) sẽ được dùng như số mồi và hệ số trong công thức sinh chuỗi ngẫu nhiên
SR gồm L số. Sau đó dựa vào chuỗi SR này, ta sẽ tính ra chuỗi S và chuỗi V, trong
đó S[i] cho biết mẫu nào được chọn để giấu và V[i] cho biết vị trí bit trên mẫu được
chọn lần thứ i để giấu bit mật thứ i. Công thức (3.3) dùng để sinh dãy SR như sau:
𝑆𝑅[𝑖] = (𝑥 ∗ 𝑆𝑅[𝑖 − 1] + 2 ∗ 𝑦)𝑚𝑜𝑑 𝑁 (3.3)
3.2.2. Điều chỉnh độ lệch bit
Đối với phương pháp chèn vào các bit ít quan trọng, ta có thể sử dụng các bit
ở vị trí từ 1 đến 3 của mẫu dữ liệu gốc để chứa tin giấu. Trong trường hợp thay đổi
bit ở vị trí 3, độ lệch giá trị giữa mẫu dữ liệu gốc và mẫu dữ liệu sau khi điều chỉnh
để giấu tin là 4 như hình 3.4. Tương tự nếu điều chỉnh bit ở vị trí thứ 2 thì giữa dữ
liệu gốc và dữ liệu mang tin sẽ sai khác nhau 2 đơn vị.
Hình 3.4. Độ sai khác khi điều chỉnh bit thứ 3 của mẫu dữ liệu
Nếu bit tin mật được giấu vào vị trí bit 3 sẽ an toàn hơn (trước một số tấn công)
so với giấu ở vị trí bit 1. Mặc dù 3 vị trí bit giấu là ít ảnh hưởng đến hệ thống tri giác
của con người nhưng nếu giấu quá nhiều vị trí bit 3 sẽ làm cho người nghe dễ phát
hiện ra hoặc nghi ngờ do ảnh hưởng đến tính “trong suốt” của dữ liệu chứa. Nguyên
nhân là do giấu trên bit thứ 3 sẽ gây ra sự sai khác giữa tín hiệu âm thanh gốc và tín
hiệu âm thanh chứa tin giấu nhiều hơn so với giấu trên bit 1. Để giảm độ lệch khi
chèn vào bit cao ta tiến hành như sau:
Nếu đổi bit ở vị trí 3 từ 0 thành 1, ta sẽ đổi các bit ở vị trí 2 và ở vị trí 1 thành
0 và nếu đổi bit ở vị trí 3 từ 1 thành 0 ta sẽ đổi các bit ở vị trí 2 và ở vị trí 1 thành 1.
1 1 0 1 1 0 1 1
1 1 0 1 1 1 1 1
219
223
1 1 0 1 1 1 0 0
1 1 0 1 1 0 0 0
220
giá trị tương ứng chuỗi bit
216
51
Tương tự, nếu đổi bit ở vị trí 2 từ 0 thành 1, ta sẽ đổi bit ở vị trí 1 thành 0 và
nếu đổi bit ở vị trí 2 từ 1 thành 0 ta sẽ đổi bit ở vị trí 1 thành 1.
Thủ tục điều chỉnh bit thứ i chứa giá trị k (k =0 hoặc k=1) như sau:
PROC DIEUCHINH(i,k)
SET(i,k);
if(i>1) SET(1,1-k); if(i>2) SET(2,1-k);
END PROC
Hình 3.5. Độ sai khác khi sử dụng kỹ thuật điều chỉnh các bit thấp hơn
Nếu tiến hành điều chỉnh theo phương pháp đề xuất thì chênh lệch giá trị giữa
mẫu dữ liệu âm thanh gốc và mẫu âm thanh mang tin chỉ là 1, thấp hơn so với trường
hợp giữ nguyên như hình 3.4. Trong [78] đề xuất một thuật toán điều chỉnh các mẫu
bit nhằm làm giảm sai khác giá trị mẫu trước và sau khi giấu theo hướng tiếp cận gen.
So với thuật toán đề xuất thì thuật toán trong [78] cho phép giấu các bit ở mức cao
hơn và giải quyết được yêu cầu chống phá mã.
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 có độ dài L, 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.
Bước 1) Chuẩn bị
Dựa vào khoá (x, y, N) sinh ra chuỗi ngẫu nhiên SR theo công thức (3.3), từ
đó tính mảng S[] cho biết mẫu dữ liệu được chọn để giấu tin và mảng V[] cho biết vị
trí bit sẽ được giấu trong mỗi mẫu.
1 1 0 1 1 0 1 1
1 1 0 1 1 1 0 0
219
220
1 1 0 1 1 1 0 0
1 1 0 1 1 0 1 1
220
219
52
Bước 2) Giấu tin: Giấu lần lượt từng bit mật Mi cho đến khi giấu xong.
- Đọc tệp dữ liệu âm thanh, dựa vào mảng S[] để chọn mẫu cần giấu.
- Dựa vào mảng V[] để biết vị trị bit giấu.
- 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 đã được điều chỉnh ra tệp âm thanh A’.
3.2.3.1. Sinh mảng S[]
Mỗi một phần tử trong mảng S[] được dùng trong thuật toán có giá trị trong
khoảng [1..4]. Giá trị S[i] = p có nghĩa là mẫu được chọn để giấu bit Mi sẽ cách mẫu
được chọn để giấu bit Mi-1 p mẫu, vì vậy S[i] luôn lớn hơn 0 để tránh trường hợp hai
bit được giấu trên cùng một mẫu dữ liệu. Công thức xác định S[i] dựa vào chuỗi ngẫu
nhiên SR như sau:
S[i] = (SR[i] mod 9) mod 4 + 1 (3.4)
Ví dụ, ta cần giấu hai byte dữ liệu và dùng khoá K gồm 3 số là (7, 9137, 10000).
Chuỗi số ngẫu nhiên gồm 16 số sẽ được sinh như sau:
SR={ 7, 18323, 46535, 44019, 26407, 3123, 40135, 99219, 12807, 7923
73735, 34419, 59207, 32723, 47335, 49619}
Khi đó giá trị của mảng S sẽ là:
S= { 4, 1, 2, 1, 2, 1, 1, 4, 1, 4, 4, 4, 2, 1, 1, 3}
Mảng S[i] cho biết mẫu kế tiếp sẽ được chọn giấu tin, so với mẫu đã chọn để
giấu bit thứ i-1, do đó vị trí các mẫu được chọn để giấu 16 bit dữ liệu là {4, 5, 7, 8,
10,11, 12, 16, 17, 21, 25, 29, 31, 32, 33, 36 }.
3.2.3.2. Sinh mảng V[]
Trên mỗi mẫu dữ liệu được xác định dựa vào mảng S[i] ta sẽ chọn ra vị trí bit
cần điều chỉnh để giấu bit tin mật. Vị trí bit được chọn là một vị trí ngẫu nhiên nằm
trong phạm vi từ 1 đến 3 chứ không cố định. Giá trị của V[i] cũng dựa vào giá trị của
chuỗi ngẫu nhiên SR[] và được xác định như công thức (3.5).
V[i] = (SR[i]mod 3) + 1 (3.5)
53
Ví dụ với chuỗi SR như trên và cần giấu 2 byte dữ liệu thì kết quả mảng V sẽ
như sau:
V={2, 3, 3, 1, 2, 1, 2, 1, 1, 1, 2, 1, 3, 3, 2, 3}
Để giấu được chuỗi bit độ dài L vào trong tệp âm thanh A thì tệp A được chọn
phải có ít nhất 4*L mẫu, do đó kích thước tệp làm đối tượng chứa cần được kiểm tra
trước khi giấu tin.
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 âm thanh A’ chứa tin giấu, khoá K gồm ba số (x, y, N), độ dài L của
chuỗi bit cần lấy.
Đầu ra: - Chuỗi bit M được giấu.
Bước 1) Chuẩn bị
Dựa vào khoá (x, y, N) sinh ra mảng S[] cho biết mẫu dữ liệu có chứa tin và
mảng V[] cho biết vị trí bit chứa tin.
Bước 2) Giải tin
Đọc tệp dữ liệu âm thanh A’, dựa vào mảng S[] để chọn mẫu có chứa bit thông
tin giấu, dựa vào mảng V[] để lấy bit thứ i của mẫu tin giấu.
Thực hiện liên tục cho đến khi L bit đã được lấy.
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
Phương pháp LSB nguyên thuỷ sẽ chọn 1 vị trí bit cố định và các mẫu dữ liệu
tuần tự để giấu tin. So với kỹ thuật LSB nguyên thuỷ, phương pháp này cần phải tốn
thời gian cho việc sinh chuỗi giả ngẫu nhiên, chuỗi S[] và chuỗi V[]. Bên cạnh đó ta
phải tốn chi phí thời gian cho việc điều chỉnh bit để giảm độ chênh lệch giá trị trước
và sau khi giấu. Ngoài ra trong quá trình giải tin chúng ta cũng tốn chi phí cho sinh
chuỗi giả ngẫu nhiên để biết vị trí mẫu và bit chứa tin giấu. Như vậy, so với thuật
toán điều chỉnh LSB nguyên thủy, thời gian để giấu tin và giải tin của thuật toán đề
xuất lâu hơn.
54
3.2.5.2. Tỉ lệ dữ liệu giấu
Phương pháp LSB nguyên thuỷ thực hiện giấu bit tin trên 1 mẫu dữ liệu.
Phương pháp cải tiến này dùng mảng độ lệch để xác định mẫu giấu. Trường hợp xấu
nhất, các mẫu này đều có độ lệch 4 nên cần ít nhất là 4*L mẫu để có thể giấu chuỗi
bit độ dài L. Vì vậy so với phương pháp LSB nguyên thuỷ này có tỉ lệ dữ liệu giấu
thấp hơn, chỉ bằng ¼.
3.2.5.3. Độ mật của kỹ thuật
Giả định rằng nếu biết độ dài của chuỗi bit giấu là L, người thám tin phải chọn
ra L mẫu dữ liệu trong 4*L mẫu. Trong số
)!3!.(
)!4(
4 LL
L
C
L
L
cách chọn chỉ có 1 cách
chọn là đúng. Sau khi chọn xong được L mẫu chắc chắn chứa tin giấu, người thám
tin phải dò 1 trong 3L chuỗi bit để xác định chuỗi tin giấu. Đối với phương pháp LSB
dùng cho giấu tin mật, với độ dài L lớn, thì khả năng tìm này gần như không thể.
Trong trường hợp những người thám tin có được tệp âm thanh gốc A và tệp
chứa tin giấu A’ thì người thám tin cũng không thể dùng phương pháp trừ các mẫu
để lấy được chuỗi tin giấu như phương pháp LSB nguyên thuỷ, vì trong phương pháp
cải tiến chúng ta có thể thay đổi nhiều hơn 1 bit chỉ để giấu 1 bit tin. Việc điều chỉnh
nhiều bit không tạo thành qui luật để người thám tin phát hiện được bit mật trong mẫu
dữ liệu. Ví dụ với ba bit cuối của mẫu dữ liệu là “100” thì ta có thể trích bit 1 nếu như
vị trí giấu ở bit 3 hoặc cũng có thể là trích bit 0 nếu như giấu ở vị trí 1.
Bên cạnh đó, việc chọn bộ sinh số ngẫu nhiên với các tham số khác nhau cũng
gây khó khăn cho những người thám tin khi họ muốn lấy tin giấu.
Bù lại chi phí thời gian cho quá trình giấu tin và giải tin, chúng ta có được một
kỹ thuật an toàn hơn so với cách dùng LSB nguyên thuỷ.
Với việc chọn ngẫu nhiên các mẫu và các bit dữ liệu để giấu tin sẽ làm cho
người thám tin khó rút trích thông tin. Kỹ thuật điều chỉnh bit sẽ làm giảm độ sai khác
giữa tệp chứa thông tin và tệp gốc.
55
Các thử nghiệm cho thấy không thể phân biệt được sự khác nhau khi nghe tệp
âm thanh
Các file đính kèm theo tài liệu này:
- luan_an_mot_so_ky_thuat_giau_tin_trong_am_thanh_so.pdf