A Novel steganographic method for JPEG images by Vasiliy Sachnev - Introduction JPEG compression Steganography - Block based steganography method (F5) - Improved matrix encoding - Experimental results - Conclusion
JPEG compression
Introduction JPEG steganography:
Matrix Encoding (F5) Matrix encoding allows to hide n bits of data to stream of 2 n -1 coefficients (S) by modifying one coefficient. ME schemes: (m, 2 m -1), examples (2, 3) (3, 7) (4, 15) 1) Get stream of non-zero DCT coefficients: 1, -1, 2, 3, 1, -1, -3, 1, 8, 3, -1, -1, -1, 2, 1, 1, 1, 2, 3, 1, 12,…, N 2) Compute stream of corresponding informative bits b: 1, -1, 2, 3, 1, -1, -3, 1, 8, 3, -1, -1, -1, 2, 1, 1, 1, 2, 3, 1, 12, … 1, 0, 0, 1, 1, 0, 0, 1, 0, 1, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 0, … 3) Define the matrix encoding scheme (n, 2 n -1) such as, where C is the size of hidden message.
Matrix encoding(F5) Assume that the ME scheme is(3,7). Hidden message (M) is (0 0 1). Stream of DCT coefficients (D) and stream of informative bits (S) are (3, -1, 2, 1, 1, -1, -3) and (1, 0, 0, 1, 1, 0, 0) respectively. For embedding message M to S one coefficient from D has to be modified. Compute necessary position (P={p 1, p 2, p 3 }) : S = {a 1, a 2, a 3, a 4,a 5,a 6,a 7 } 1) Compute syndrome O = {o 1, o 2, o 3 } o 1 = xor(a 4,a 5,a 6,a 7 ) o 2 = xor(a 2,a 3,a 6,a 7 ) o 3 = xor(a 1,a 3,a 5,a 7 ) 2) Position (P) in binary representation is computed as: P = xor(O,M)
Matrix Encoding (F5), example Hiding message M (0 0 1) to (3, -1, 2, 1, 1, -1, -3) or (1, 0, 0, 1, 1, 0, 0) 1)Get syndrome : o 1 = xor(a 4,a 5,a 6,a 7 )=xor(1,1,0,0) = 0 o 2 = xor(a 2,a 3,a 6,a 7 )=xor(0,0,0,0) = 0 o 3 = xor(a 1,a 3,a 5,a 7 )=xor(1,0,1,0) = 0 2)Get position: P = xor(M,O) = {xor(0,0), xor(0,0), xor(1,0)} = {0, 0, 1}. P 10 = 1 3)Get stream of modified coefficients and informative bits (2(4), -1, 2, 1, 1, -1, -3) and (0, 0, 0, 1, 1, 0, 0) 4)Verification (get syndrome): (0, 0, 0, 1, 1, 0, 0) m 1 = xor(a 4,a 5,a 6,a 7 )=xor(1,1,0,0) = 0 m 2 = xor(a 2,a 3,a 6,a 7 )=xor(0,0,0,0) = 0 m 3 = xor(a 1,a 3,a 5,a 7 )=xor(0,0,1,0) = 1
Modified matrix encoding Each 1 flip solution P can be replaced to floor(n/2) 2 flips solutions P 1, P 2, such that P = xor(P 1, P 2 ). Example: P = 5 10 = P 1 P flips solution is also possible: P = xor(P 1, P 2, P 3 )
Overlapped matrix encoding Original ME: Overlapped ME: I
Overlapped matrix encoding Assume that A and B are the positions to flip for block 1 and 2. (a 1, a 2 ), (b 1,b 2 ), (a 11,a 12,a 13 ) or (b 11,b 12,b 13 ) are the numbers such that A = xor(a 1,a 2 ) = xor (a 11,a 12,a 13 ), and B = xor(b 1,b 2 ) = xor (b 11,b 12,b 13 ) B’ is a position for block 2, if A, (a 1 or a 2 ), or (a 11 or a 12 or a 13 ) belong to I. B’ = xor(b’ 1,b’ 2 ) = xor (b’ 11,b’ 12,b’ 13 ) 1 flip solution: A = B, (A,B) ϵ I 2 flips solution: (A,B), (a 1,a 2 = B) or (b’ 1 = A, b’ 2 ) 3 flips solution: (a 1,a 2,B), (a 1,a 2 = b’ 1,b’ 2 ), (A, b 1, b 2 ) or (a 11,a 12 = b’ 1,a 13 = b’ 2 ), (a 1 = b’ 11,a 2 = b’ 12,b’ 13 ) 4 flips solution: (a 1,a 2,b 1,b 2 ), (a 11,a 12,a 13 = b’ 1,b’ 2 ), (a 11,a 12 = b’ 11,a 13 = b’ 12, b’ 13 ), (a 1,a 2 = b’ 11,b’ 12,b’ 13 )
Example: Assume that A = 4 and B = 2: Possible solutions: (2, 6) 2 = 010, 6 = 110, xor(010,110) = 100 = 4. Coefficient 6 has index 2 for block 2. (B = 2) (4,9,11), A = 4, 9 th and 11 th coefficients have the indexes 5 and 7 correspondingly. Thus, 5 = 101, 7 = 111, xor(101,111) = 010 =2.
Insert - Remove (IR) approach The stream of non-rounded AC coefficients: 1.45,0.21, 0.35, 1.02, -0.01, -0.28, -5.12, 9.87, -0.45, 0.02, 1.89, -0.85, 4.01, -8.74, -6.04, 1.55, 3.11, , 5.04 Hidden data: m 1 =101, m 2 =100 Assume that the candidates for inserting are the AC coefficients belonging to the (0.25, 0.5) and (-0.5, -0.25). 0.35, -0.28, are the candidates for inserting (c I ). 1.45, 1.02, are the candidates for removing (c R ). The stream of non-rounded AC coefficients for hiding data. 1.45, 1.02, -5.12, 9.87, 1.89, -0.85, 4.01, -6.04, 1.55, 3.11, Rounded: 1, 1, -5, 10, 2, -1, 4, -6, 2, 3, -10 Block 1: 1, 1, -5, 10, 2, -1, 4 Block 2: 2, -1, 4, -6, 2, 3, -10 Intersected area I : 2, -1, 4
Distortion impact Distortion impact due to modification: D = E 2 ∙ Q 2 Distortion impact due to insertion or removing: D IR = |0.5-|C|| 2 ∙ Q 2 Total distortion impact:
IR approach (without IR) AC: Q : D : D IR : AC: Q : D : D IR : Hidden data: m 1 =101, m 2 =100 Block 1: 1, 1, -5, 10, 2, -1, 4 Block 2: 2, -1, 4, -6, 2, 3, -10 Among one, two, and three flips solutions define A = (1,4), B = (6) Distortion for original approach is 100.2
IR approach (Insertion and removing) Insert 0.35 (i.e > 1), then Block 1: 1, 1,1, -5, 10, 2, -1 Block 2: 10, 2, -1, 4, -6, 2, 3 Among one, two, and three flips solutions define A = (1 7), B = (6) Distortion after inserting is = 22.7 Remove 1.45 (i.e > 0), then Block 1: 1, -5, 10, 2, -1, 4, -6 Block 2: -1, 4, -6, 2, 3, -10, 5 Among one, two, and three flips solutions define A = (2 4 6), B = (7) Distortion for original approach is = 210.9
Experimental results The stego images have been tested by using 274 – features steganalysis method proposed by Pevny and Fridrich
Conclusion The proposed oimproved matrix encoding: - achieves higher capacity. -can improve any block based steganographic method -decrease detectability of steganalysis - can be improved further.