Practical Linguistic Steganography using Contextual Synonym Substitution and Vertex Colour Coding
←
→
Page content transcription
If your browser does not render page correctly, please read the page content below
Practical Linguistic Steganography using Contextual Synonym Substitution and Vertex Colour Coding Ching-Yun Chang Stephen Clark University of Cambridge University of Cambridge Computer Laboratory Computer Laboratory Ching-Yun.Chang@cl.cam.ac.uk Stephen.Clark@cl.cam.ac.uk Abstract tersection of Computational Linguistics and Com- puter Security—is concerned with making changes Linguistic Steganography is concerned with to a cover text in order to embed information, in such hiding information in natural language text. a way that the changes do not result in ungrammati- One of the major transformations used in Lin- cal or unnatural text. guistic Steganography is synonym substitu- tion. However, few existing studies have stud- A related area is natural language watermarking, ied the practical application of this approach. in which changes are made to a text in order to iden- In this paper we propose two improvements tify it, for example for copyright purposes. An inter- to the use of synonym substitution for encod- esting watermarking application is “traitor tracing”, ing hidden bits of information. First, we use in which documents are changed in order to embed the Web 1T Google n-gram corpus for check- individual watermarks. These marks can then be ing the applicability of a synonym in context, used to later identify particular documents, for ex- and we evaluate this method using data from the SemEval lexical substitution task. Second, ample if a set of documents—identical except for we address the problem that arises from words the changes used to embed the watermarks— have with more than one sense, which creates a po- been sent to a group of individuals, and one of the tential ambiguity in terms of which bits are documents has been leaked to a newspaper. encoded by a particular word. We develop a In terms of security, a linguistic stegosystem novel method in which words are the vertices should impose minimum embedding distortion to in a graph, synonyms are linked by edges, and the cover text so that the resulting stegotext in which the bits assigned to a word are determined by a message is camouflaged is inconspicuous, result- a vertex colouring algorithm. This method ensures that each word encodes a unique se- ing in high imperceptibility. In addition, since quence of bits, without cutting out large num- steganography aims at covert communication, a lin- ber of synonyms, and thus maintaining a rea- guistic stegosystem should allow sufficient embed- sonable embedding capacity. ding capacity, known as the payload. There is a fun- damental tradeoff between imperceptibility and pay- load, since any attempt to embed more information 1 Introduction via changes to the cover text increases the chance Steganography is concerned with hiding informa- of introducing anomalies into the text and therefore tion in a cover medium, in order to facilitate covert raising the suspicion of an observer. communication, such that the presence of the infor- A linguistic transformation is required to em- mation is imperceptible to a user (human or com- bed information. Transformations studied in pre- puter). Much of the existing research in steganog- vious work include lexical substitution (Chapman raphy has used images as cover media; however, and Davida, 1997; Bolshakov, 2004; Taskiran et al., given the ubiquitous nature of electronic text, inter- 2006; Topkara et al., 2006b), phrase paraphrasing est is growing in using natural language as the cover (Chang and Clark, 2010), sentence structure manip- medium. Linguistic Steganography—lying at the in- ulations (Atallah et al., 2001a; Atallah et al., 2001b;
Liu et al., 2005; Meral et al., 2007; Murphy, 2001; Murphy and Vogel, 2007; Topkara et al., 2006a) and semantic transformations (Atallah et al., 2002; Vy- bornova and Macq, 2007). Many of these transfor- mations require some sophisticated NLP tools; for example, in order to perform semantic transforma- tions on text, word sense disambiguation, seman- tic role parsing and anaphora resolution tools may be required. However, the current state-of-the-art in language technology is arguably not good enough Figure 1: An example of the basic algorithm for secure linguistic steganography based on sophis- pension bridges are typically ranked by the length ticated semantic transformations, and the level of ro- of their main span”, and doing so would likely raise bustness required to perform practical experiments the suspicion of an observer due to the resulting has only just become available. Hence many exist- anomaly in the text. ing linguistic stegosystems are proof-of-concept im- Our solution to this problem is to perform a con- plementations with little practical evaluation of the textual check which utilises the Web 1T n-gram imperceptibility or payload. Google n-gram corpus.1 We evaluate the method 1.1 Synonym substitution using the data from the English Lexical Substitu- tion task for SemEval-2007.2 The resulting preci- Synonym substitution is a relatively straightforward sion of our lexical substitution system can be seen linguistic steganography method. It substitutes se- as an indirect measure of the imperceptibility of the lected words with the same part of speech (PoS) syn- stegosystem, whereas the recall can be seen as an onyms, and does not involve operating on the sen- indirect measure of the payload. tence structure so the modification can be guaran- The paper is organised so that the contextual teed to be grammatical. Another advantage of this check is described first, and this is evaluated inde- method is that many languages are profuse in syn- pendently of the steganographic application. Then onyms, and so there is a rich source of information the vertex colouring method is presented, and finally carriers compared with other text transformations. we show how the contextual check can be integrated There are two practical difficulties associated with with the vertex colouring coding method to give a hiding bits using synonym subsitution. The first is complete stegsosystem. For readers unfamiliar with that words can have more than one sense. In terms of linguistic steganogaphy, Section 2 has some exam- WordNet (Fellbaum, 1998), which is the electronic ples of how bits can be hidden using textual trans- dictionary we use, words can appear in more than formations. Also, Chang and Clark (2010) is a re- one synset. This is a problem because a word may be cent NLP paper which describes the general linguis- assigned different bit strings in the different synsets, tic steganography framework. and the receiver does not know which of the senses to use, and hence does not know which hidden bit 2 Related Work string to recover. Our solution to this problem is a novel vertex colouring method which ensures that In the original work on linguistic steganography in words are always assigned the same bit string, even the late 1990s, Winstein proposed an information when they appear in different synsets. hiding algorithm using a block coding method to en- The second problem is that many synonyms are code synonyms, so that the selection of a word from only applicable in certain contexts. For example, the a synset directly associates with part of the secret words in the WordNet synset {bridge, span} share bitstring (Bergmair, 2007). Figure 1 illustrates the the meaning of “a structure that allows people or ve- embedding procedure of this approach. In this ex- hicles to cross an obstacle such as a river or canal ample, the bitstring to be embedded is 010, which or railway etc.”. However, bridge and span cannot 1 www.ldc.upenn.edu/Catalog/docs/LDC2006T13/readme.txt 2 be substutited for each other in the sentence “sus- http://www.dianamccarthy.co.uk/task10index.html
the same codeword. The disadvantage is that many synonyms need to be discarded in order to achieve this property. Winstein calculates that only 30% of WordNet can be used in such a system. Another stegosystem based on synonym substi- tution was proposed by Bolshakov (2004). In or- der to ensure both sender and receiver use the same synsets, Bolshakov applied transitive closure to overlapping synsets to avoid the decoding ambi- Figure 2: An example of applying the basic algorithm to guity. Applying transitive closure leads to a merger overlapping synsets of all the overlapping synsets into one set which is then seen as the synset of a target word. Consider can be divided into two codewords, 0 and 10, and the the overlapping synsets in Figure 2 as an example. information carriers in the cover text are the words After applying transitive closure, the resulting set finished and project. According to the encoding dic- is {‘authorship’, ‘composition’, ‘paper’, ‘penning’, tionary, complete represents 0, and task represents ‘report’, ‘theme’, ‘writing’}. 10; hence these words are chosen and replace the Bolshakov (2004) also uses a method to deter- original words in the cover text (with suitable suffix- mine whether a substitution is applicable in context, ation). The stego sentence “He completed the task” using a collocation-based test. Finally, the colloca- is then sent to the receiver. In order to recover the tionally verified synonyms are encoded by using the message, the receiver only needs a copy of the en- block coding method. This is similar to our use of coding dictionary, and the decoding algorithm sim- the Google n-gram data to check for contextual ap- ply reverses the process used to encode the hidden plicability. bits. Note that the receiver does not need the origi- The disadvantage of Bolshakov’s system is that nal cover text to recover the information. all words in a synonym transitive closure chain need This algorithm requires synonym sets to be dis- to be considered, which can lead to very large sets joint; i.e. no word may appear in more than one syn- of synonyms, and many which are not synonymous onym set, since overlapping synsets may cause am- with the original target word. In contrast, our pro- biguities during the decoding stage. Figure 2 shows posed method operates on the original synonym sets what happens when the basic algorithm is applied to without extending them unnecessarily. two overlapping synonym sets. As can be seen from the example, composition is represented by two dif- 3 Proposed Method and Experiments ferent codewords and thus the secret bitstring can- not be reliably recovered, since the receiver does not 3.1 Resources know the original cover word or the sense of the We use WordNet (Fellbaum, 1998) to provide sets word. In order to solve this problem, we propose of synonyms (synsets) for nouns, verbs, adjectives a novel coding method based on vertex colouring, and adverbs. Since the purpose of using WordNet is described in Section 4. to find possible substitutes for a target word, those In addition to the basic algorithm, Winstein pro- synsets containing only one entry are not useful and posed the T-Lex system using synonym substitution are ignored by our stegosystem. In addition, our as the text transformation. In order to solve the stegosystem only takes single word substitution into problem of words appearing in more than one syn- consideration in order to avoid the confusion of find- onym set, Winstein defines interchangeable words ing information-carrying words during the decoding as words that belong to the same synsets, and only phase. For example, if the cover word ‘complete’ is uses these words for substitution. Any words that are replaced by ‘all over’, the receiver would not know not interchangeable are discarded and not available whether the secret message is embedded in the word for carrying information. The advantage in this ap- ‘over’ or the phrase ‘all over’. Table 1 shows the proach is that interchangeable words always receive statistics of synsets used in our stegosystem.
noun verb adj adv f2 =525,856 high pole 3,544 # of synsets 16,079 4,529 6,655 964 pole . 522,312 # of entries 30,933 6,495 14,151 2,025 f3 =554 very high pole 84 average set size 2.56 2.79 2.72 2.51 high pole . 470 max set size 25 16 21 8 f4 =72 a very high pole 72 very high pole . 0 Table 1: Statistics of synsets used in our stegosystem f5 =0 not a very high pole 0 a very high pole . 0 For the contextual check we use the Google Web Count(‘pole’)=log(f2 )+log(f3 )+log(f4 )+log(f5 )=23 1T 5-gram Corpus (Brants and Franz, 2006) which Score(‘pole’)=Count(‘pole’)/max=0.44>0.37 contains counts for n-grams from unigrams through to five-grams obtained from over 1 trillion word to- Figure 3: An example of using the proposed synonym kens of English Web text. The corpus has been used checking method for many tasks such as spelling correction (Islam and ing the substitution score for the synonym ‘pole’ Inkpen, 2009; Carlson et al., 2008) and multi-word given the cover sentence “This is not a very high expression classification (Kummerfeld and Curran, bar.” First of all, various contextual n-grams are ex- 2008). Moreover, for the SemEval-2007 English tracted from the sentence and the Web n-gram cor- Lexical Substitution Task, which is similar to our pus is consulted to obtain their frequency counts. substitution task, six out of ten participating teams Count(‘pole’) is then calculated using the n-gram utilised the Web 1T corpus. frequencies. Suppose the threshold is 0.37, and the max score is 52. Since Count(‘pole’) is greater 3.2 Synonym Checking Method than zero and the substitution score Score(‘pole’) In order to measure the degree of acceptability in a is 0.44, the word ‘pole’ is determined as acceptable substitution, the proposed filter calculates a substi- for this context (even though it may not be, depend- tution score for a synonym by using the observed ing on the meaning of ‘bar’ in this case). frequency counts in the Web n-gram corpus. The method first extracts contextual n-grams around the 3.3 Evaluation Data synonym and queries the n-gram frequency counts In order to evaluate the proposed synonym check- from the corpus. For each n, the total count fn is cal- ing method, we need some data to test whether our culated by summing up individual n-gram frequen- method can pick out acceptable substitutions. The cies, for every contextual n-gram containing the tar- English Lexical Substitution task for SemEval-2007 get word. We define a count function Count(w) = has created human-annotated data for developing P5 n=2 log(fn ) where log(0) is defined as zero. If systems that can automatically find feasible substi- Count(w) = 0, we assume the word w is unrelated tutes given a target word in context. This data com- to the context and therefore is eliminated from con- prises 2010 sentences selected from the English In- sideration. We then find the maximum Count(w) ternet Corpus3 , and consists of 201 words: nouns, called max from the remaining words. The main verbs, adjectives and adverbs each with ten sen- purpose of having max is to score each word rela- tences containing that word. The five annotators tive to the most likely synonym in the group, so even were asked to provide up to three substitutes for a in less frequent contexts which lead to smaller fre- target word in the context of a sentence, and were quency counts, the score of each synonym can still permitted to consult a dictionary or thesaurus of indicate the degree of feasibility. The substitution their choosing. score is defined as Score(w) = Count(w) ÷ max. We use the sentences in this gold standard as the The hypothesis is that a word with a high score is cover text in our experiments so that the substi- more suitable for the context, and we apply a thresh- tutes provided by the annotators can be the positive old so that synonyms having a score lower than the data for evaluating the proposed synonym check- threshold are discarded. 3 Figure 3 demonstrates an example of calculat- http://corpus.leeds.ac.uk/internet.html
noun verb adj adv # of target words 59 54 57 35 # of sentences 570 527 558 349 # of positives 2,343 2,371 2,708 1,269 # of negatives 1,914 1,715 1,868 884 Table 2: Statistics of experimental data ing methods. Since we only take into considera- tion the single word substitutions for the reason de- scribed earlier, multi-word substitutes are removed from the positive data. Moreover, we use Word- Figure 4: An example of automatic negative data Net as the source of providing candidate substitutes in our stegosystem, so if a human-provided sub- noun verb adj adv stitute does not appear in any synsets of its target # of true negatives 234 201 228 98 word in WordNet, there is no chance for our sys- # of false negatives 9 20 28 16 tem to replace the target word with the substitute and therefore, the substitute can be eliminated. Table 2 Table 3: Annotation results for negative data presents the statistics of the positive data for our ex- periments. ‘residuum’, ‘rest’} is selected for negative data col- Apart from positive data, we also need some neg- lection since it contains one of the positives while ative data to test whether our method has the ability the other synsets do not. We assume the selected to filter out bad substitutions. Since the annotators synset represents the meaning of the original word, were allowed to refer to a dictionary or thesaurus, and those synonyms in the synset which are not an- we assume that annotators used WordNet as one of notated as positives must have a certain degree of the reference resources while generating candidates. mismatch to the context. Therefore, from this exam- Hence we assume that, if a word in the correct synset ple, ‘balance’, ‘residue’, ‘residuum’ and ‘rest’ are for a target word is not in the set produced by the hu- extracted as negatives to test whether our synonym man annotators, then it is inappropriate for that con- checking method can pick out bad substitutions from text and a suitable negative example. This method is a set of words sharing similar or the same meaning. appropriate because our steganography system has In order to examine whether the automatically to distinguish between good and bad synonyms from collected instances are true negatives and hence WordNet, given a particular context. form a useful test set, a sample of automatically gen- For the above reasons, we extract the negative erated negatives was selected for human evaluation. data for our experiments by first matching positive For each PoS one sentence of each different target substitutes of a target word to all the synsets that word is selected, which results in roughly 13% of contain the target word in WordNet. The synset the collected negative data, and every negative sub- that includes the most positive substitutes is used stitute of the selected sentences was judged by the to represent the meaning of the target word. If second author. As can be seen from the annota- there is more than one synset containing the high- tion results shown in Table 3, most of the instances est number of positives, all the synsets are taken are true negatives, and only a few cases are incor- into consideration. We then randomly select up to rectly chosen as false negatives. Since the main pur- six single-word synonyms other than positive substi- pose of the data set is to test whether the proposed tutes from the chosen synset(s) as negative instances synonym checking method can guard against inap- of the target word. Figure 4 shows an example of propriate synonym substitutions and be integrated automatically collected negative data from WordNet in the stegosystem, it is reasonable to have a few given a target word and its positive substitutes. The false negatives in our experimental data. Also, it synset {‘remainder’, ‘balance’, ‘residual’, ‘residue’, is more harmless to rule out a permissible substitu-
PoS Acc% P% R% F% Threshold noun 70.2 70.0 80.2 74.7 0.58 verb 68.1 69.7 79.5 74.3 0.56 adj 72.5 72.7 85.7 78.7 0.48 adv 73.7 76.4 80.1 78.2 0.54 Table 4: Performance of the synonym checking method tion than including an inappropriate replacement for a stegosystem in terms of the security. Table 2 gives the statistics of the automatically collected negative data for our experiments. Note that, although we use the data from the lex- ical substitution task, our task is different: the pos- sible substitutions for a target word need to be fixed in advance for linguistic steganography (in order for the receiver to be able to recover the hidden bits), whereas for the lexical substitution task participants were asked to discover possible replacements. 3.4 Results The performance of the proposed checking method is evaluated in terms of accuracy, precision, recall and balanced F-measure. Accuracy represents the percentage of correct judgements over all accept- able and unacceptable substitutions. Precision is the percentage of substitutions judged acceptable by the method which are determined to be suitable syn- onyms by the human judges. Recall is the percent- age of substitutions determined to be feasible by the human annotators which are also judged acceptable Figure 5: System performance under various thresholds by the method. The interpretation of the measures for a stegosystem is that a higher precision value im- plies a better security level since good substitutions various thresholds on the system performance. Fig- are less likely to be seen as suspicious by the ob- ure 5 shows the precision and recall values with re- server; whereas a larger recall value means a greater spect to different thresholds for each PoS. From the payload capacity since words are being substituted graphs we can clearly see the trade-off between pre- where possible and therefore embedding as much in- cision and recall. Although a higher precision can formation as possible. be achieved by using a higher threshold value, for In order to derive sensible threshold values for example noun’s substitutions almost reach 90% pre- each PoS, 5-fold cross-validation was implemented cision with threshold equal to 0.9, the large drop in to conduct the experiments. For each fold, 80% of recall means many applicable synonyms are being the data is used to find the threshold value which eliminated. In other words, the trade-off between maximises the accuracy, and that threshold is then precision and recall implies the trade-off between applied to the remaining 20% to get the final result. imperceptibility and payload capacity for linguistic Table 4 gives the results for the synonym checking steganography. Therefore, the practical threshold method and the average threshold values over the 5 setting would depend on how steganography users folds. In addition, we are interested in the effect of want to trade off imperceptibility for payload.
Figure 6: An example of coloured synonym graph 4 Proposed Stegosystem 4.1 The Vertex Coloring Coding Method In this section, we propose a novel coding method based on vertex colouring by which each synonym is assigned a unique codeword so the usage of overlap- ping synsets is not problematic for data embedding and extracting. A vertex colouring is a labelling of the graph’s vertices with colours subject to the con- dition that no two adjacent vertices share the same colour. The smallest number of colours required to colour a graph G is called its chromatic num- ber χ(G), and a graph G having chromatic number χ(G) = k is called a k-chromatic graph. The main idea of the proposed coding method is to represent Figure 7: Examples of 2,3,4-chromatic synonym graphs overlapping synsets as an undirected k-chromatic graph called a synonym graph which has a vertex vertex is assigned a single-bit codeword either ‘0’ for each word and an edge for every pair of words or ‘1’ as shown in Figure 7(a). When χ(G) = 3, that share the same meaning. A synonym is then the overlapping set’s size is either 2 or 3, which can- encoded by a codeword that represents the colour not exhaust the 2-bit coding space although code- assigned by the vertex colouring of the synonym words ‘00’, ‘01’ and ‘10’ are initially assigned to graph. Figure 6 shows the use of four different each vertex. Therefore, only the most significant colours, represented by ‘00’, ‘01’, ‘10’ and ‘11’, to bits are used to represent the synonyms, which we colour the 4-chromatic synonym graph of the two call codeword reduction. After the codeword reduc- overlapping synsets in Figure 2. Now, the over- tion, if a vertex has the same codeword, say ‘0’, as lapped word ‘composition’ receives a unique code- all of its neighbors, the vertex’s codeword must be word no matter which synset is considered, which changed to ‘1’ so that the vertex would be able to ac- means the replacement of ‘paper’ to ‘composition’ commodate either secret bit ‘0’ or ‘1’, which we call in Figure 2 will not cause an ambiguity since the re- codeword correction. Figure 7(b) shows an example ceiver can apply the same coding method to derive of the process of codeword reduction and codeword identical codewords used by the sender. correction for χ(G) = 3. For the case of χ(G) = 4, 99.6% of synsets in WordNet have size less than codeword reduction is applied to those vertices that 8, which means most of the synsets cannot exhaust themselves or their neighboring vertices have no ac- more than a 2-bit coding space (i.e. we can only cess to all the codewords ‘00’, ‘01’, ‘10’ and ‘11’. encode at most 2 bits using a typical synset). There- For example, vertices a, b, c, e and f in Figure 7(c) fore, we restrict the chromatic number of a synonym meet the requirement of needing codeword reduc- graph G to 1 < χ(G) ≤ 4, which implies the max- tion. The codeword correction process is then fur- imum size of a synset is 4. When χ(G) = 2, each ther applied to vertex f to rectify its accessibility.
Figure 8 describes a greedy algorithm for con- INPUT: a synonym list w1 , w2 ,. . . , wn and an structing a coded synonym graph using at most empty graph G 4 colours, given n synonyms w1 , w2 ,. . . , wn in OUTPUT: a coded synonym graph G using at the overlapping synsets. Let us define a function most four colours E(wi , wj ) which returns an edge between wi and wj if wi and wj are in the same synset; otherwise FOR every synonym wi in the input list returns false. Another function C(wi ) returns the initialize four colours as available for wi colour of the synonym wi . The procedure loops FOR every wj in graph G through all the input synonyms. For each iteration, IF E(wi , wj ) THEN the procedure first finds available colours for the tar- set C(wj ) as unavailable get synonym wi . If there is no colour available, END IF namely all the four colours have already been given END FOR to wi ’s neighbors, wi is randomly assigned one of IF there is a colour available THEN the four colours; otherwise, wi is assigned one of assign one of the available colours the available colours. After adding wi to the graph to wi G, the procedure checks whether adding an edge of ELSE wi to graph G would violate the vertex colouring. assign one of the four colours to wi After constructing the coloured graph, codeword re- END IF duction and codeword correction as previously de- ADD wi to graph G scribed are applied to revise improper codewords. FOR every wj in graph G IF E(wi , wj ) and C(wi ) is not 4.2 Proposed Lexical Stegosystem equal to C(wj ) THEN Figure 9 illustrates the framework of our lexical ADD edge E(wi , wj ) to G stegosystem. Note that we have preprocessed Word- END IF Net by excluding multi-word synonyms and single- END FOR entry synsets. A possible information carrier is first END FOR found in the cover sentence. We define a possi- codeword reduction ble information carrier as a word in the cover sen- codeword correction tence that belongs to at least one synset in Word- OUTPUT graph G Net. The synsets containing the target word, and all Figure 8: Constructing a coloured synonym graph other synsets which can be reached via the synonym relation, are then extracted from WordNet (i.e. we build the connected component of WordNet which same graph. It is important to note, however, that contains the target word according to the synonym the sender only considers the synonyms of the target relation). Words in these sets are then examined word as potential substitutes; the connected compo- by the Google n-gram contextual checking method nent is only used to consistently assign the codes. to eliminate inappropriate substitutions. If there is For the decoding process, the receiver does not more than one word left and if words which pass the need the original text for extracting secret data. An filter all belong to the same synset, the block cod- information carrier can be found in the stegotext by ing method is used to encode the words; otherwise referring to WordNet in which related synonyms are the vertex colouring coding is applied. Finally, ac- extracted. Those words in the related sets undergo cording to the secret bitstring, the system selects the the synonym checking method and then are encoded synonym that shares an edge with the target word by either block coding or vertex colouring coding and has as its codeword the longest potential match scheme depending on whether the remaining words with the secret bitstring. are in the same synset. Finally, the secret bitstring is We use the connected component of WordNet implicit in the codeword of the information carrier containing the target word as a simple method to en- and therefore can be extracted. sure that both sender and receiver colour-code the We demonstrate how to embed secret bit 1 in the
cover sentence: It is a shame that we could not reach the next stage original synsets retained synsets {commiseration.28 , {commiseration, pity.97 , ruth.13 , pathos.31 } pity, pathos} {pity.97 , shame1 } {pity, shame} {compassion.49 , pity.97 } {compassion, pity} {condolence.27 , {commiseration} commiseration.28 } {pathos, poignancy} {pathos.31 , poignancy.31 } {shame, disgrace} {shame1 , disgrace.84 , {compassion} ignominy.24 } {poignancy} {compassion.49 , compassionateness0 } {poignance.12 , poignancy.31 } Table 5: Synsets of ‘shame’ before and after applying the synonym checking method Figure 9: Framework of the proposed lexical stegosystem sentence “it is a shame that we could not reach the next stage.” A possible information carrier ‘shame’ is first found in the sentence. Table 5 lists the re- lated synsets extracted from WordNet. The score of each word calculated by the synonym checking method using the Web 1T Corpus is given as a sub- script. Assume the threshold score is 0.27. The out- put of the synonym checking method is shown at the right side of Table 5. Since the remaining words do Figure 10: Synonym graph of ‘shame’ not belong to the same synset, the vertex colouring coding method is then used to encode the words. coding which improves the data embedding capacity Figure 10(a) is the original synset graph in which compared to existing systems. The vertex colouring each vertex is assigned one of the four colours; Fig- coding method represents synonym substitution as a ure 10(b) is the graph after applying codeword re- synonym graph so the relations between words can duction. Although both ‘disgrace’ and ‘pity’ are en- be clearly observed. In addition, an automatic sys- coded by ‘1’, ‘pity’ is chosen to replace the cover tem for checking synonym acceptability in context is word since it has a higher score. Finally, the stego- integrated in our stegosystem to ensure information text is generated, “it is a pity that we could not reach security. For future work, we would like to explore the next stage.” more linguistic transformations that can meet the re- As a rough guide to the potential payload with quirements of linguistic steganography — retaining this approach, we estimate that, with a threshold of the meaning, grammaticality and style of the origi- 0.5 for the contextual check, the payload would be nal text. In addition, it is crucial to have a full eval- slightly higher than 1 bit per newspaper sentence. uation of the linguistic stegosystem in terms of im- perceptibility and payload capacity so we can know 5 Conclusions how much data can be embedded before the cover text reaches its maximum distortion which is toler- One of the contributions of this paper is to develop a ated by a human judge. novel lexical stegosystem based on vertex colouring
References pages 1241–1249, Morristown, USA. Association for Computational Linguistics. Mikhail J. Atallah, Craig J. McDonough, Victor Raskin, Jonathan K Kummerfeld and James R Curran. 2008. and Sergei Nirenburg. 2001a. Natural language pro- Classification of verb particle constructions with the cessing for information assurance and security: an Google Web 1T Corpus. In Proceedings of the Aus- overview and implementations. In Proceedings of the tralasian Language Technology Association Workshop 2000 workshop on New security paradigms, pages 51– 2008, pages 55–63, Hobart, Australia, December. 65, Ballycotton, County Cork, Ireland. Yuling Liu, Xingming Sun, and Yong Wu. 2005. A nat- Mikhail J. Atallah, Victor Raskin, Michael C. Crogan, ural language watermarking based on Chinese syntax. Christian Hempelmann, Florian Kerschbaum, Dina In Advances in Natural Computation, volume 3612, Mohamed, and Sanket Naik. 2001b. Natural lan- pages 958–961, Changsha, China. guage watermarking: design, analysis, and a proof- Diana McCarthy and Roberto Navigli. 2007. Semeval- of-concept implementation. In Proceedings of the 4th 2007 task 10: English lexical substitution task. In Pro- International Information Hiding Workshop, volume ceedings of the 4th International Workshop on Seman- 2137, pages 185–199, Pittsburgh, Pennsylvania. tic Evaluations, pages 48–53, Prague, Czech Republic. Mikhail J. Atallah, Victor Raskin, Christian F. Hempel- Hasan M. Meral, Emre Sevinc, Ersin Unkar, Bulent mann, Mercan Karahan, Umut Topkara, Katrina E. Sankur, A. Sumru Ozsoy, and Tunga Gungor. 2007. Triezenberg, and Radu Sion. 2002. Natural language Syntactic tools for text watermarking. In Proceed- watermarking and tamperproofing. In Proceedings of ings of the SPIE Conference on Security, Steganogra- the 5th International Information Hiding Workshop, phy, and Watermarking of Multimedia Contents, vol- pages 196–212, Noordwijkerhout, The Netherlands. ume 6505, San Jose, CA. Richard Bergmair. 2007. A comprehensive bibliogra- Brian Murphy and Carl Vogel. 2007. The syntax of con- phy of linguistic steganography. In Proceedings of the cealment: reliable methods for plain text information SPIE Conference on Security, Steganography, and Wa- hiding. In Proceedings of the SPIE Conference on Se- termarking of Multimedia Contents, volume 6505. curity, Steganography, and Watermarking of Multime- Igor A. Bolshakov. 2004. A method of linguistic dia Contents, volume 6505, San Jose, CA. steganography based on collocationally-verified syn- Brian Murphy. 2001. Syntactic information hiding in onym. In Information Hiding: 6th International Work- plain text. Master’s thesis, Trinity College Dublin. shop, volume 3200, pages 180–191, Toronto, Canada. Cuneyt M. Taskiran, Mercan Topkara, and Edward J. Thorsten Brants and Alex Franz. 2006. Web 1T 5- Delp. 2006. Attacks on linguistic steganography sys- gram corpus version 1.1. Technical report, Google Re- tems using text analysis. In Proceedings of the SPIE search. Conference on Security, Steganography, and Water- Andrew Carlson, Tom M. Mitchell, and Ian Fette. 2008. marking of Multimedia Contents, volume 6072, pages Data analysis project: Leveraging massive textual cor- 97–105, San Jose, CA. pora using n-gram statistics. Technical report, School Mercan Topkara, Umut Topkara, and Mikhail J. Atallah. of Computer Science, Carnegie Mellon University. 2006a. Words are not enough: sentence level natural Ching-Yun Chang and Stephen Clark. 2010. Linguis- language watermarking. In Proceedings of the ACM tic steganography using automatically generated para- Workshop on Content Protection and Security, pages phrases. In Human Language Technologies: The 2010 37–46, Santa Barbara, CA. Annual Conference of the North American Chapter of Umut Topkara, Mercan Topkara, and Mikhail J. Atal- the Association for Computational Linguistics, pages lah. 2006b. The hiding virtues of ambiguity: quan- 591–599, Los Angeles, California, June. Association tifiably resilient watermarking of natural language text for Computational Linguistics. through synonym substitutions. In Proceedings of the Mark Chapman and George I. Davida. 1997. Hiding the 8th Workshop on Multimedia and Security, pages 164– hidden: A software system for concealing ciphertext 174, Geneva, Switzerland. as innocuous text. In Proceedings of the First Interna- M. Olga Vybornova and Benoit Macq. 2007. A tional Conference on Information and Communication method of text watermarking using presuppositions. Security, volume 1334, pages 335–345, Beijing. In Proceedings of the SPIE Conference on Secu- Christiane Fellbaum. 1998. WordNet: An electronic lex- rity, Steganography, and Watermarking of Multimedia ical database. MIT Press, first edition. Contents, volume 6505, San Jose, CA. Aminul Islam and Diana Inkpen. 2009. Real-word spelling correction using Google Web IT 3-grams. In EMNLP ’09: Proceedings of the 2009 Conference on Empirical Methods in Natural Language Processing,
You can also read