Steganography in LatexHow to add an invisible watermark to PDF documents?Security Printing in pdflatex documents

Mindfulness of Watching Youtube

How could a civilization detect tachyons?

Should one save up to purchase a house/condo or maximize their 401(k) first?

How do I give a darkroom course without negatives from the attendees?

My parents are Afghan

While drilling into kitchen wall, hit a wire - any advice?

Why did Ham the Chimp push levers?

Do these creatures from the Tomb of Annihilation campaign speak Common?

Every group the homology of some space?

Examples where existence is harder than evaluation

Steganography in Latex

Employee is self-centered and affects the team negatively

Crime rates in a post-scarcity economy

Names of the Six Tastes

What computer port is this?

History: Per Leviticus 19:27 would the apostles have had corner locks ala Hassidim today?

I'm attempting to understand my 401k match and how much I need to contribute to maximize the match

What will Doctor Strange protect now?

How would an instant or sorcery with an effect that targets work with Feather?

When an electron around an atom drops to a lower state, is 100% of the energy converted to a photon?

Is there an application which does HTTP PUT?

Is this strange Morse signal type common?

Can radiation block all wireless communications?

Does this website provide consistent translation into Wookiee?



Steganography in Latex


How to add an invisible watermark to PDF documents?Security Printing in pdflatex documents













7















I am a teacher. An ongoing problem is that students post assignments to websites like chegg.com to have other people write projects for them. I don't know if the students are providing JPGs or PDFs -- but what I see on the website is a text version of the assignment. See for example:
https://www.chegg.com/homework-help/questions-and-answers/part-2-confidence-intervals-recovery-great-recession-2007-2009-economic-situation-many-fam-q37153607



For my assignments, the assignment is written in LaTex. I'm wondering how I might embed a unique identifier in each student's assignment so that I can tell by looking at the assignment who posted it. Let's imagine that I'm teaching 500 students (9 bits), and it would be good to encode the semester and year (5 bits), plus a parity bit for good measure-- so let's just say I need to encode 16 bits.



Requirements:



  1. Cannot use font changes -- the font information is lost in the
    chegg posting.

  2. Cannot use watermarks or other imagery -- again, this information
    has been stripped from the posting.

  3. Cannot use spacing changes -- mainly because this runs counter to
    how LaTex is formatting the page, and I'm not sure that subtle
    spacing changes would survive to the posting. (in other words, no
    stegsnow)

  4. The optimal answer would embed the identifier multiple times so that
    even if only a portion of the assignment is posted, it is possible to
    identify the source.

What this means, I believe, is that I basically need something that is visible, but easily overlooked in the text itself. Ideas:



  1. Double a particular word that that a reader is likely to overlook --depending on which word is doubled, identity is know (such as my doubling the word "that" in the preceding text).

  2. Using extra punctuation marks that might be easily overlooked.. (see double periods at the end).

  3. Inserting occasoinal letter flips that look like sloppy spell checking but actually encode the identifier. (see spelling of occasional)

Anyone know of something that has already been implemented? Any suggestions about the easiest way to do this?



Here's a potential starting point for a solution. In the optimal implementation, the stenagbox could include "complicated" text such as begin/endenumerate, multiple paragraphs with formatting, etc.



documentclass[10pt]article

newcommandstenagbox[2]#2

begindocument

stenagbox16000When moving to a new area, it is important to
understand the climate that you will be living in. Does it rain
more or less than you are used to? Will it typically be hotter or
colder than the city that you are coming from? Just knowing where
a city is located on a map is not sufficient. In some areas,
nearby mountains may block the wind and make the climate hotter or
colder than expected. In other areas, the ocean may keep the
region cool in the summer time and warm in the winter. Using
statistics, the climate in two areas can be compared to determine
what to expect.

enddocument









share|improve this question



















  • 1





    You seem to have some ideas in mind. Can you clarify what kind of help with LaTeX you are looking for?

    – Davislor
    3 hours ago











  • @Davislor I would assume OP is wanting a way to TeX a file and get ideas 1-3 to occur at set points. But one question would be if OP is willing to post 500 different pdfs to the students.

    – Teepeemm
    3 hours ago











  • @Davislor I have high level knowledge of what might be done. I don't have the LaTex skill to do it and don't know if there are any existing implementations that might work (or be easilty modified to work).

    – Christopher Donham
    3 hours ago












  • @Teepeemm If I did this, students would not get a PDF of the assignment. They would get a physical copy only. Students would hand back the physical copy with their name on it when they handed in the assignment so that I had the correspondence of ID with student.

    – Christopher Donham
    3 hours ago











  • Well, a simple implementation might take a counter and decompose it into bits. Then you'd write the minor textual variants with if and else. Maybe variant"2it’s notit isn’t, for each bit of the counter, where “It’s not” represents a zero in bit 2, and “it isn’t” represents a one.

    – Davislor
    3 hours ago
















7















I am a teacher. An ongoing problem is that students post assignments to websites like chegg.com to have other people write projects for them. I don't know if the students are providing JPGs or PDFs -- but what I see on the website is a text version of the assignment. See for example:
https://www.chegg.com/homework-help/questions-and-answers/part-2-confidence-intervals-recovery-great-recession-2007-2009-economic-situation-many-fam-q37153607



For my assignments, the assignment is written in LaTex. I'm wondering how I might embed a unique identifier in each student's assignment so that I can tell by looking at the assignment who posted it. Let's imagine that I'm teaching 500 students (9 bits), and it would be good to encode the semester and year (5 bits), plus a parity bit for good measure-- so let's just say I need to encode 16 bits.



Requirements:



  1. Cannot use font changes -- the font information is lost in the
    chegg posting.

  2. Cannot use watermarks or other imagery -- again, this information
    has been stripped from the posting.

  3. Cannot use spacing changes -- mainly because this runs counter to
    how LaTex is formatting the page, and I'm not sure that subtle
    spacing changes would survive to the posting. (in other words, no
    stegsnow)

  4. The optimal answer would embed the identifier multiple times so that
    even if only a portion of the assignment is posted, it is possible to
    identify the source.

What this means, I believe, is that I basically need something that is visible, but easily overlooked in the text itself. Ideas:



  1. Double a particular word that that a reader is likely to overlook --depending on which word is doubled, identity is know (such as my doubling the word "that" in the preceding text).

  2. Using extra punctuation marks that might be easily overlooked.. (see double periods at the end).

  3. Inserting occasoinal letter flips that look like sloppy spell checking but actually encode the identifier. (see spelling of occasional)

Anyone know of something that has already been implemented? Any suggestions about the easiest way to do this?



Here's a potential starting point for a solution. In the optimal implementation, the stenagbox could include "complicated" text such as begin/endenumerate, multiple paragraphs with formatting, etc.



documentclass[10pt]article

newcommandstenagbox[2]#2

begindocument

stenagbox16000When moving to a new area, it is important to
understand the climate that you will be living in. Does it rain
more or less than you are used to? Will it typically be hotter or
colder than the city that you are coming from? Just knowing where
a city is located on a map is not sufficient. In some areas,
nearby mountains may block the wind and make the climate hotter or
colder than expected. In other areas, the ocean may keep the
region cool in the summer time and warm in the winter. Using
statistics, the climate in two areas can be compared to determine
what to expect.

enddocument









share|improve this question



















  • 1





    You seem to have some ideas in mind. Can you clarify what kind of help with LaTeX you are looking for?

    – Davislor
    3 hours ago











  • @Davislor I would assume OP is wanting a way to TeX a file and get ideas 1-3 to occur at set points. But one question would be if OP is willing to post 500 different pdfs to the students.

    – Teepeemm
    3 hours ago











  • @Davislor I have high level knowledge of what might be done. I don't have the LaTex skill to do it and don't know if there are any existing implementations that might work (or be easilty modified to work).

    – Christopher Donham
    3 hours ago












  • @Teepeemm If I did this, students would not get a PDF of the assignment. They would get a physical copy only. Students would hand back the physical copy with their name on it when they handed in the assignment so that I had the correspondence of ID with student.

    – Christopher Donham
    3 hours ago











  • Well, a simple implementation might take a counter and decompose it into bits. Then you'd write the minor textual variants with if and else. Maybe variant"2it’s notit isn’t, for each bit of the counter, where “It’s not” represents a zero in bit 2, and “it isn’t” represents a one.

    – Davislor
    3 hours ago














7












7








7


2






I am a teacher. An ongoing problem is that students post assignments to websites like chegg.com to have other people write projects for them. I don't know if the students are providing JPGs or PDFs -- but what I see on the website is a text version of the assignment. See for example:
https://www.chegg.com/homework-help/questions-and-answers/part-2-confidence-intervals-recovery-great-recession-2007-2009-economic-situation-many-fam-q37153607



For my assignments, the assignment is written in LaTex. I'm wondering how I might embed a unique identifier in each student's assignment so that I can tell by looking at the assignment who posted it. Let's imagine that I'm teaching 500 students (9 bits), and it would be good to encode the semester and year (5 bits), plus a parity bit for good measure-- so let's just say I need to encode 16 bits.



Requirements:



  1. Cannot use font changes -- the font information is lost in the
    chegg posting.

  2. Cannot use watermarks or other imagery -- again, this information
    has been stripped from the posting.

  3. Cannot use spacing changes -- mainly because this runs counter to
    how LaTex is formatting the page, and I'm not sure that subtle
    spacing changes would survive to the posting. (in other words, no
    stegsnow)

  4. The optimal answer would embed the identifier multiple times so that
    even if only a portion of the assignment is posted, it is possible to
    identify the source.

What this means, I believe, is that I basically need something that is visible, but easily overlooked in the text itself. Ideas:



  1. Double a particular word that that a reader is likely to overlook --depending on which word is doubled, identity is know (such as my doubling the word "that" in the preceding text).

  2. Using extra punctuation marks that might be easily overlooked.. (see double periods at the end).

  3. Inserting occasoinal letter flips that look like sloppy spell checking but actually encode the identifier. (see spelling of occasional)

Anyone know of something that has already been implemented? Any suggestions about the easiest way to do this?



Here's a potential starting point for a solution. In the optimal implementation, the stenagbox could include "complicated" text such as begin/endenumerate, multiple paragraphs with formatting, etc.



documentclass[10pt]article

newcommandstenagbox[2]#2

begindocument

stenagbox16000When moving to a new area, it is important to
understand the climate that you will be living in. Does it rain
more or less than you are used to? Will it typically be hotter or
colder than the city that you are coming from? Just knowing where
a city is located on a map is not sufficient. In some areas,
nearby mountains may block the wind and make the climate hotter or
colder than expected. In other areas, the ocean may keep the
region cool in the summer time and warm in the winter. Using
statistics, the climate in two areas can be compared to determine
what to expect.

enddocument









share|improve this question
















I am a teacher. An ongoing problem is that students post assignments to websites like chegg.com to have other people write projects for them. I don't know if the students are providing JPGs or PDFs -- but what I see on the website is a text version of the assignment. See for example:
https://www.chegg.com/homework-help/questions-and-answers/part-2-confidence-intervals-recovery-great-recession-2007-2009-economic-situation-many-fam-q37153607



For my assignments, the assignment is written in LaTex. I'm wondering how I might embed a unique identifier in each student's assignment so that I can tell by looking at the assignment who posted it. Let's imagine that I'm teaching 500 students (9 bits), and it would be good to encode the semester and year (5 bits), plus a parity bit for good measure-- so let's just say I need to encode 16 bits.



Requirements:



  1. Cannot use font changes -- the font information is lost in the
    chegg posting.

  2. Cannot use watermarks or other imagery -- again, this information
    has been stripped from the posting.

  3. Cannot use spacing changes -- mainly because this runs counter to
    how LaTex is formatting the page, and I'm not sure that subtle
    spacing changes would survive to the posting. (in other words, no
    stegsnow)

  4. The optimal answer would embed the identifier multiple times so that
    even if only a portion of the assignment is posted, it is possible to
    identify the source.

What this means, I believe, is that I basically need something that is visible, but easily overlooked in the text itself. Ideas:



  1. Double a particular word that that a reader is likely to overlook --depending on which word is doubled, identity is know (such as my doubling the word "that" in the preceding text).

  2. Using extra punctuation marks that might be easily overlooked.. (see double periods at the end).

  3. Inserting occasoinal letter flips that look like sloppy spell checking but actually encode the identifier. (see spelling of occasional)

Anyone know of something that has already been implemented? Any suggestions about the easiest way to do this?



Here's a potential starting point for a solution. In the optimal implementation, the stenagbox could include "complicated" text such as begin/endenumerate, multiple paragraphs with formatting, etc.



documentclass[10pt]article

newcommandstenagbox[2]#2

begindocument

stenagbox16000When moving to a new area, it is important to
understand the climate that you will be living in. Does it rain
more or less than you are used to? Will it typically be hotter or
colder than the city that you are coming from? Just knowing where
a city is located on a map is not sufficient. In some areas,
nearby mountains may block the wind and make the climate hotter or
colder than expected. In other areas, the ocean may keep the
region cool in the summer time and warm in the winter. Using
statistics, the climate in two areas can be compared to determine
what to expect.

enddocument






steganography






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited 2 hours ago







Christopher Donham

















asked 4 hours ago









Christopher DonhamChristopher Donham

382111




382111







  • 1





    You seem to have some ideas in mind. Can you clarify what kind of help with LaTeX you are looking for?

    – Davislor
    3 hours ago











  • @Davislor I would assume OP is wanting a way to TeX a file and get ideas 1-3 to occur at set points. But one question would be if OP is willing to post 500 different pdfs to the students.

    – Teepeemm
    3 hours ago











  • @Davislor I have high level knowledge of what might be done. I don't have the LaTex skill to do it and don't know if there are any existing implementations that might work (or be easilty modified to work).

    – Christopher Donham
    3 hours ago












  • @Teepeemm If I did this, students would not get a PDF of the assignment. They would get a physical copy only. Students would hand back the physical copy with their name on it when they handed in the assignment so that I had the correspondence of ID with student.

    – Christopher Donham
    3 hours ago











  • Well, a simple implementation might take a counter and decompose it into bits. Then you'd write the minor textual variants with if and else. Maybe variant"2it’s notit isn’t, for each bit of the counter, where “It’s not” represents a zero in bit 2, and “it isn’t” represents a one.

    – Davislor
    3 hours ago













  • 1





    You seem to have some ideas in mind. Can you clarify what kind of help with LaTeX you are looking for?

    – Davislor
    3 hours ago











  • @Davislor I would assume OP is wanting a way to TeX a file and get ideas 1-3 to occur at set points. But one question would be if OP is willing to post 500 different pdfs to the students.

    – Teepeemm
    3 hours ago











  • @Davislor I have high level knowledge of what might be done. I don't have the LaTex skill to do it and don't know if there are any existing implementations that might work (or be easilty modified to work).

    – Christopher Donham
    3 hours ago












  • @Teepeemm If I did this, students would not get a PDF of the assignment. They would get a physical copy only. Students would hand back the physical copy with their name on it when they handed in the assignment so that I had the correspondence of ID with student.

    – Christopher Donham
    3 hours ago











  • Well, a simple implementation might take a counter and decompose it into bits. Then you'd write the minor textual variants with if and else. Maybe variant"2it’s notit isn’t, for each bit of the counter, where “It’s not” represents a zero in bit 2, and “it isn’t” represents a one.

    – Davislor
    3 hours ago








1




1





You seem to have some ideas in mind. Can you clarify what kind of help with LaTeX you are looking for?

– Davislor
3 hours ago





You seem to have some ideas in mind. Can you clarify what kind of help with LaTeX you are looking for?

– Davislor
3 hours ago













@Davislor I would assume OP is wanting a way to TeX a file and get ideas 1-3 to occur at set points. But one question would be if OP is willing to post 500 different pdfs to the students.

– Teepeemm
3 hours ago





@Davislor I would assume OP is wanting a way to TeX a file and get ideas 1-3 to occur at set points. But one question would be if OP is willing to post 500 different pdfs to the students.

– Teepeemm
3 hours ago













@Davislor I have high level knowledge of what might be done. I don't have the LaTex skill to do it and don't know if there are any existing implementations that might work (or be easilty modified to work).

– Christopher Donham
3 hours ago






@Davislor I have high level knowledge of what might be done. I don't have the LaTex skill to do it and don't know if there are any existing implementations that might work (or be easilty modified to work).

– Christopher Donham
3 hours ago














@Teepeemm If I did this, students would not get a PDF of the assignment. They would get a physical copy only. Students would hand back the physical copy with their name on it when they handed in the assignment so that I had the correspondence of ID with student.

– Christopher Donham
3 hours ago





@Teepeemm If I did this, students would not get a PDF of the assignment. They would get a physical copy only. Students would hand back the physical copy with their name on it when they handed in the assignment so that I had the correspondence of ID with student.

– Christopher Donham
3 hours ago













Well, a simple implementation might take a counter and decompose it into bits. Then you'd write the minor textual variants with if and else. Maybe variant"2it’s notit isn’t, for each bit of the counter, where “It’s not” represents a zero in bit 2, and “it isn’t” represents a one.

– Davislor
3 hours ago






Well, a simple implementation might take a counter and decompose it into bits. Then you'd write the minor textual variants with if and else. Maybe variant"2it’s notit isn’t, for each bit of the counter, where “It’s not” represents a zero in bit 2, and “it isn’t” represents a one.

– Davislor
3 hours ago











2 Answers
2






active

oldest

votes


















5














I create a bitstream[<total tests>]<test number> (default 256 total tests) that writes a token register of the binary bits comprising the test number. I demonstrate how it works in the MWE (you don't need that in your test preparation, it was only for demonstration)



Then, to encode your test versions, one uses dobit<output A><output B> to place slight differences into the output stream (i.e., the printed test). Each time it is invoked, it sucks the high-order bit from the bits token register and uses it to decide output A versus B.



In the MWE, I created an 8-test matrix, requiring 3 bits (2^3=8), and so 3 dobit choices are encountered to create 8 unique versions of the test. The versions have a comma included or not, spell "versions" correctly or not, and repeat the word "the" or not.



Whereas I just do a bigskip to separate the test versions, presumably, one would use a clearpage so that individual tests would appear on separate pieces of paper.



documentclassarticle
usepackagepgffor
newcounterbitreg
newcounterbitval
newtoksbits
newcommandaddtotoks[2]#1expandafterthe#1#2
newcommandbitstream[2][256]%
setcounterbitreg#2%
setcounterbitvalthenumexpr#1/2relax%
bits%
bitstreamaux%

newcommandbitstreamaux%
addtocounterbitreg-thebitval%
ifnumthebitreg>-1relaxaddtotoksbits1else
addtotoksbits0addtocounterbitregthebitvalfi
ifnumthebitval=1relaxelse%
setcounterbitvalthenumexprthebitval/2relax%
expandafterbitstreamaux%
fi

newcommanddobit[2]%
expandaftercheckbitthebitsrelax
ifnumthisbit=1relax#2else#1fi

defcheckbit#1#2relaxgdefthisbit#1bits#2
begindocument
bitstream255 thebits

bitstream128 thebits

bitstream53 thebits

bitstream[8]5 thebits

foreachx in0,...,7bitstream[8]x
Test x:
This is a testdobit, of % COMMA IN OR NOT
multiple versdobitiooins. The test %VERSIONS MISSPELLED OR NOT
is for all dobitthe thethe marbles.bigskippar% THE REPEATED OR NOT.

enddocument


enter image description here






share|improve this answer

























  • +1 for using punctuation which is good in principle as less noticeable between two students comparing questions, the danger is that in OCR it may be corrected to point at the wrong student, it is less obvious but also less robust in terms of accuracy.

    – KJO
    1 hour ago






  • 1





    @KJO I chose some punctuation examples, because it was mentioned by the OP. The dobit function allows any subtle difference to be introduced, at the testmaker's discretion.

    – Steven B. Segletes
    1 hour ago











  • Interesting. Instead of having the code search through for the spot to modify, this is having me specify where each bit is encoded. I had not thought of doing it this way. Cool. This is the most complete of the two answers and I can see how to make it work for my situation. Thanks!

    – Christopher Donham
    1 hour ago











  • @ChristopherDonham A perhaps more subtle way that would be easy to check is to modify the punctuation that comes after the question number. For example, Q1. Q2: Q3), etc.

    – erik
    43 mins ago



















0














To get your 16 bits with the example you could tabulate a word/phrase per bit I got bored/tired around 12 bits (but more are possible) perhaps set it as a class assignment and see how many come back with an answer like this ?



The tex for if [1] then else [2] should be trivial perhaps from a csv table decoding is just reading / decoding the reversed order



When moving to a new

1 = area/region

, it is important to understand the climate that you will be

2 = living in/moving to

. Does it

rain/snow

more or less than you are used to? Will it typically be

3= hotter or colder / colder or hotter

than the

4/5 = city/area/town/region

that you are coming from? Just knowing where

6= a city / an area

is located on a map is not sufficient. In some

7= cities/areas,

nearby mountains may block the wind and make the climate

8= colder or hotter / hotter or colder

than expected. In other

9= regions/areas,

the ocean may keep the region

10 [cool in the summer time] and [warm in the winter]

. Using statistics, the climate in

11= two/multiple

areas can be compared to determine what to

12= expect/predict.



To simplify the input each choice would be say



When moving to a new input1, it is important to input2 the climate that you will be input3 etc etc.






share|improve this answer

























  • Thank you very much for your thoughts. If I understand correctly, what you describe above can be implemented with the solution posted by the other poster. It would be "When moving to a new dobitarearegion ..." Thanks for your help.

    – Christopher Donham
    1 hour ago











Your Answer








StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "85"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);

else
createEditor();

);

function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);



);













draft saved

draft discarded


















StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2ftex.stackexchange.com%2fquestions%2f489697%2fsteganography-in-latex%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown

























2 Answers
2






active

oldest

votes








2 Answers
2






active

oldest

votes









active

oldest

votes






active

oldest

votes









5














I create a bitstream[<total tests>]<test number> (default 256 total tests) that writes a token register of the binary bits comprising the test number. I demonstrate how it works in the MWE (you don't need that in your test preparation, it was only for demonstration)



Then, to encode your test versions, one uses dobit<output A><output B> to place slight differences into the output stream (i.e., the printed test). Each time it is invoked, it sucks the high-order bit from the bits token register and uses it to decide output A versus B.



In the MWE, I created an 8-test matrix, requiring 3 bits (2^3=8), and so 3 dobit choices are encountered to create 8 unique versions of the test. The versions have a comma included or not, spell "versions" correctly or not, and repeat the word "the" or not.



Whereas I just do a bigskip to separate the test versions, presumably, one would use a clearpage so that individual tests would appear on separate pieces of paper.



documentclassarticle
usepackagepgffor
newcounterbitreg
newcounterbitval
newtoksbits
newcommandaddtotoks[2]#1expandafterthe#1#2
newcommandbitstream[2][256]%
setcounterbitreg#2%
setcounterbitvalthenumexpr#1/2relax%
bits%
bitstreamaux%

newcommandbitstreamaux%
addtocounterbitreg-thebitval%
ifnumthebitreg>-1relaxaddtotoksbits1else
addtotoksbits0addtocounterbitregthebitvalfi
ifnumthebitval=1relaxelse%
setcounterbitvalthenumexprthebitval/2relax%
expandafterbitstreamaux%
fi

newcommanddobit[2]%
expandaftercheckbitthebitsrelax
ifnumthisbit=1relax#2else#1fi

defcheckbit#1#2relaxgdefthisbit#1bits#2
begindocument
bitstream255 thebits

bitstream128 thebits

bitstream53 thebits

bitstream[8]5 thebits

foreachx in0,...,7bitstream[8]x
Test x:
This is a testdobit, of % COMMA IN OR NOT
multiple versdobitiooins. The test %VERSIONS MISSPELLED OR NOT
is for all dobitthe thethe marbles.bigskippar% THE REPEATED OR NOT.

enddocument


enter image description here






share|improve this answer

























  • +1 for using punctuation which is good in principle as less noticeable between two students comparing questions, the danger is that in OCR it may be corrected to point at the wrong student, it is less obvious but also less robust in terms of accuracy.

    – KJO
    1 hour ago






  • 1





    @KJO I chose some punctuation examples, because it was mentioned by the OP. The dobit function allows any subtle difference to be introduced, at the testmaker's discretion.

    – Steven B. Segletes
    1 hour ago











  • Interesting. Instead of having the code search through for the spot to modify, this is having me specify where each bit is encoded. I had not thought of doing it this way. Cool. This is the most complete of the two answers and I can see how to make it work for my situation. Thanks!

    – Christopher Donham
    1 hour ago











  • @ChristopherDonham A perhaps more subtle way that would be easy to check is to modify the punctuation that comes after the question number. For example, Q1. Q2: Q3), etc.

    – erik
    43 mins ago
















5














I create a bitstream[<total tests>]<test number> (default 256 total tests) that writes a token register of the binary bits comprising the test number. I demonstrate how it works in the MWE (you don't need that in your test preparation, it was only for demonstration)



Then, to encode your test versions, one uses dobit<output A><output B> to place slight differences into the output stream (i.e., the printed test). Each time it is invoked, it sucks the high-order bit from the bits token register and uses it to decide output A versus B.



In the MWE, I created an 8-test matrix, requiring 3 bits (2^3=8), and so 3 dobit choices are encountered to create 8 unique versions of the test. The versions have a comma included or not, spell "versions" correctly or not, and repeat the word "the" or not.



Whereas I just do a bigskip to separate the test versions, presumably, one would use a clearpage so that individual tests would appear on separate pieces of paper.



documentclassarticle
usepackagepgffor
newcounterbitreg
newcounterbitval
newtoksbits
newcommandaddtotoks[2]#1expandafterthe#1#2
newcommandbitstream[2][256]%
setcounterbitreg#2%
setcounterbitvalthenumexpr#1/2relax%
bits%
bitstreamaux%

newcommandbitstreamaux%
addtocounterbitreg-thebitval%
ifnumthebitreg>-1relaxaddtotoksbits1else
addtotoksbits0addtocounterbitregthebitvalfi
ifnumthebitval=1relaxelse%
setcounterbitvalthenumexprthebitval/2relax%
expandafterbitstreamaux%
fi

newcommanddobit[2]%
expandaftercheckbitthebitsrelax
ifnumthisbit=1relax#2else#1fi

defcheckbit#1#2relaxgdefthisbit#1bits#2
begindocument
bitstream255 thebits

bitstream128 thebits

bitstream53 thebits

bitstream[8]5 thebits

foreachx in0,...,7bitstream[8]x
Test x:
This is a testdobit, of % COMMA IN OR NOT
multiple versdobitiooins. The test %VERSIONS MISSPELLED OR NOT
is for all dobitthe thethe marbles.bigskippar% THE REPEATED OR NOT.

enddocument


enter image description here






share|improve this answer

























  • +1 for using punctuation which is good in principle as less noticeable between two students comparing questions, the danger is that in OCR it may be corrected to point at the wrong student, it is less obvious but also less robust in terms of accuracy.

    – KJO
    1 hour ago






  • 1





    @KJO I chose some punctuation examples, because it was mentioned by the OP. The dobit function allows any subtle difference to be introduced, at the testmaker's discretion.

    – Steven B. Segletes
    1 hour ago











  • Interesting. Instead of having the code search through for the spot to modify, this is having me specify where each bit is encoded. I had not thought of doing it this way. Cool. This is the most complete of the two answers and I can see how to make it work for my situation. Thanks!

    – Christopher Donham
    1 hour ago











  • @ChristopherDonham A perhaps more subtle way that would be easy to check is to modify the punctuation that comes after the question number. For example, Q1. Q2: Q3), etc.

    – erik
    43 mins ago














5












5








5







I create a bitstream[<total tests>]<test number> (default 256 total tests) that writes a token register of the binary bits comprising the test number. I demonstrate how it works in the MWE (you don't need that in your test preparation, it was only for demonstration)



Then, to encode your test versions, one uses dobit<output A><output B> to place slight differences into the output stream (i.e., the printed test). Each time it is invoked, it sucks the high-order bit from the bits token register and uses it to decide output A versus B.



In the MWE, I created an 8-test matrix, requiring 3 bits (2^3=8), and so 3 dobit choices are encountered to create 8 unique versions of the test. The versions have a comma included or not, spell "versions" correctly or not, and repeat the word "the" or not.



Whereas I just do a bigskip to separate the test versions, presumably, one would use a clearpage so that individual tests would appear on separate pieces of paper.



documentclassarticle
usepackagepgffor
newcounterbitreg
newcounterbitval
newtoksbits
newcommandaddtotoks[2]#1expandafterthe#1#2
newcommandbitstream[2][256]%
setcounterbitreg#2%
setcounterbitvalthenumexpr#1/2relax%
bits%
bitstreamaux%

newcommandbitstreamaux%
addtocounterbitreg-thebitval%
ifnumthebitreg>-1relaxaddtotoksbits1else
addtotoksbits0addtocounterbitregthebitvalfi
ifnumthebitval=1relaxelse%
setcounterbitvalthenumexprthebitval/2relax%
expandafterbitstreamaux%
fi

newcommanddobit[2]%
expandaftercheckbitthebitsrelax
ifnumthisbit=1relax#2else#1fi

defcheckbit#1#2relaxgdefthisbit#1bits#2
begindocument
bitstream255 thebits

bitstream128 thebits

bitstream53 thebits

bitstream[8]5 thebits

foreachx in0,...,7bitstream[8]x
Test x:
This is a testdobit, of % COMMA IN OR NOT
multiple versdobitiooins. The test %VERSIONS MISSPELLED OR NOT
is for all dobitthe thethe marbles.bigskippar% THE REPEATED OR NOT.

enddocument


enter image description here






share|improve this answer















I create a bitstream[<total tests>]<test number> (default 256 total tests) that writes a token register of the binary bits comprising the test number. I demonstrate how it works in the MWE (you don't need that in your test preparation, it was only for demonstration)



Then, to encode your test versions, one uses dobit<output A><output B> to place slight differences into the output stream (i.e., the printed test). Each time it is invoked, it sucks the high-order bit from the bits token register and uses it to decide output A versus B.



In the MWE, I created an 8-test matrix, requiring 3 bits (2^3=8), and so 3 dobit choices are encountered to create 8 unique versions of the test. The versions have a comma included or not, spell "versions" correctly or not, and repeat the word "the" or not.



Whereas I just do a bigskip to separate the test versions, presumably, one would use a clearpage so that individual tests would appear on separate pieces of paper.



documentclassarticle
usepackagepgffor
newcounterbitreg
newcounterbitval
newtoksbits
newcommandaddtotoks[2]#1expandafterthe#1#2
newcommandbitstream[2][256]%
setcounterbitreg#2%
setcounterbitvalthenumexpr#1/2relax%
bits%
bitstreamaux%

newcommandbitstreamaux%
addtocounterbitreg-thebitval%
ifnumthebitreg>-1relaxaddtotoksbits1else
addtotoksbits0addtocounterbitregthebitvalfi
ifnumthebitval=1relaxelse%
setcounterbitvalthenumexprthebitval/2relax%
expandafterbitstreamaux%
fi

newcommanddobit[2]%
expandaftercheckbitthebitsrelax
ifnumthisbit=1relax#2else#1fi

defcheckbit#1#2relaxgdefthisbit#1bits#2
begindocument
bitstream255 thebits

bitstream128 thebits

bitstream53 thebits

bitstream[8]5 thebits

foreachx in0,...,7bitstream[8]x
Test x:
This is a testdobit, of % COMMA IN OR NOT
multiple versdobitiooins. The test %VERSIONS MISSPELLED OR NOT
is for all dobitthe thethe marbles.bigskippar% THE REPEATED OR NOT.

enddocument


enter image description here







share|improve this answer














share|improve this answer



share|improve this answer








edited 1 hour ago

























answered 1 hour ago









Steven B. SegletesSteven B. Segletes

164k9209424




164k9209424












  • +1 for using punctuation which is good in principle as less noticeable between two students comparing questions, the danger is that in OCR it may be corrected to point at the wrong student, it is less obvious but also less robust in terms of accuracy.

    – KJO
    1 hour ago






  • 1





    @KJO I chose some punctuation examples, because it was mentioned by the OP. The dobit function allows any subtle difference to be introduced, at the testmaker's discretion.

    – Steven B. Segletes
    1 hour ago











  • Interesting. Instead of having the code search through for the spot to modify, this is having me specify where each bit is encoded. I had not thought of doing it this way. Cool. This is the most complete of the two answers and I can see how to make it work for my situation. Thanks!

    – Christopher Donham
    1 hour ago











  • @ChristopherDonham A perhaps more subtle way that would be easy to check is to modify the punctuation that comes after the question number. For example, Q1. Q2: Q3), etc.

    – erik
    43 mins ago


















  • +1 for using punctuation which is good in principle as less noticeable between two students comparing questions, the danger is that in OCR it may be corrected to point at the wrong student, it is less obvious but also less robust in terms of accuracy.

    – KJO
    1 hour ago






  • 1





    @KJO I chose some punctuation examples, because it was mentioned by the OP. The dobit function allows any subtle difference to be introduced, at the testmaker's discretion.

    – Steven B. Segletes
    1 hour ago











  • Interesting. Instead of having the code search through for the spot to modify, this is having me specify where each bit is encoded. I had not thought of doing it this way. Cool. This is the most complete of the two answers and I can see how to make it work for my situation. Thanks!

    – Christopher Donham
    1 hour ago











  • @ChristopherDonham A perhaps more subtle way that would be easy to check is to modify the punctuation that comes after the question number. For example, Q1. Q2: Q3), etc.

    – erik
    43 mins ago

















+1 for using punctuation which is good in principle as less noticeable between two students comparing questions, the danger is that in OCR it may be corrected to point at the wrong student, it is less obvious but also less robust in terms of accuracy.

– KJO
1 hour ago





+1 for using punctuation which is good in principle as less noticeable between two students comparing questions, the danger is that in OCR it may be corrected to point at the wrong student, it is less obvious but also less robust in terms of accuracy.

– KJO
1 hour ago




1




1





@KJO I chose some punctuation examples, because it was mentioned by the OP. The dobit function allows any subtle difference to be introduced, at the testmaker's discretion.

– Steven B. Segletes
1 hour ago





@KJO I chose some punctuation examples, because it was mentioned by the OP. The dobit function allows any subtle difference to be introduced, at the testmaker's discretion.

– Steven B. Segletes
1 hour ago













Interesting. Instead of having the code search through for the spot to modify, this is having me specify where each bit is encoded. I had not thought of doing it this way. Cool. This is the most complete of the two answers and I can see how to make it work for my situation. Thanks!

– Christopher Donham
1 hour ago





Interesting. Instead of having the code search through for the spot to modify, this is having me specify where each bit is encoded. I had not thought of doing it this way. Cool. This is the most complete of the two answers and I can see how to make it work for my situation. Thanks!

– Christopher Donham
1 hour ago













@ChristopherDonham A perhaps more subtle way that would be easy to check is to modify the punctuation that comes after the question number. For example, Q1. Q2: Q3), etc.

– erik
43 mins ago






@ChristopherDonham A perhaps more subtle way that would be easy to check is to modify the punctuation that comes after the question number. For example, Q1. Q2: Q3), etc.

– erik
43 mins ago












0














To get your 16 bits with the example you could tabulate a word/phrase per bit I got bored/tired around 12 bits (but more are possible) perhaps set it as a class assignment and see how many come back with an answer like this ?



The tex for if [1] then else [2] should be trivial perhaps from a csv table decoding is just reading / decoding the reversed order



When moving to a new

1 = area/region

, it is important to understand the climate that you will be

2 = living in/moving to

. Does it

rain/snow

more or less than you are used to? Will it typically be

3= hotter or colder / colder or hotter

than the

4/5 = city/area/town/region

that you are coming from? Just knowing where

6= a city / an area

is located on a map is not sufficient. In some

7= cities/areas,

nearby mountains may block the wind and make the climate

8= colder or hotter / hotter or colder

than expected. In other

9= regions/areas,

the ocean may keep the region

10 [cool in the summer time] and [warm in the winter]

. Using statistics, the climate in

11= two/multiple

areas can be compared to determine what to

12= expect/predict.



To simplify the input each choice would be say



When moving to a new input1, it is important to input2 the climate that you will be input3 etc etc.






share|improve this answer

























  • Thank you very much for your thoughts. If I understand correctly, what you describe above can be implemented with the solution posted by the other poster. It would be "When moving to a new dobitarearegion ..." Thanks for your help.

    – Christopher Donham
    1 hour ago















0














To get your 16 bits with the example you could tabulate a word/phrase per bit I got bored/tired around 12 bits (but more are possible) perhaps set it as a class assignment and see how many come back with an answer like this ?



The tex for if [1] then else [2] should be trivial perhaps from a csv table decoding is just reading / decoding the reversed order



When moving to a new

1 = area/region

, it is important to understand the climate that you will be

2 = living in/moving to

. Does it

rain/snow

more or less than you are used to? Will it typically be

3= hotter or colder / colder or hotter

than the

4/5 = city/area/town/region

that you are coming from? Just knowing where

6= a city / an area

is located on a map is not sufficient. In some

7= cities/areas,

nearby mountains may block the wind and make the climate

8= colder or hotter / hotter or colder

than expected. In other

9= regions/areas,

the ocean may keep the region

10 [cool in the summer time] and [warm in the winter]

. Using statistics, the climate in

11= two/multiple

areas can be compared to determine what to

12= expect/predict.



To simplify the input each choice would be say



When moving to a new input1, it is important to input2 the climate that you will be input3 etc etc.






share|improve this answer

























  • Thank you very much for your thoughts. If I understand correctly, what you describe above can be implemented with the solution posted by the other poster. It would be "When moving to a new dobitarearegion ..." Thanks for your help.

    – Christopher Donham
    1 hour ago













0












0








0







To get your 16 bits with the example you could tabulate a word/phrase per bit I got bored/tired around 12 bits (but more are possible) perhaps set it as a class assignment and see how many come back with an answer like this ?



The tex for if [1] then else [2] should be trivial perhaps from a csv table decoding is just reading / decoding the reversed order



When moving to a new

1 = area/region

, it is important to understand the climate that you will be

2 = living in/moving to

. Does it

rain/snow

more or less than you are used to? Will it typically be

3= hotter or colder / colder or hotter

than the

4/5 = city/area/town/region

that you are coming from? Just knowing where

6= a city / an area

is located on a map is not sufficient. In some

7= cities/areas,

nearby mountains may block the wind and make the climate

8= colder or hotter / hotter or colder

than expected. In other

9= regions/areas,

the ocean may keep the region

10 [cool in the summer time] and [warm in the winter]

. Using statistics, the climate in

11= two/multiple

areas can be compared to determine what to

12= expect/predict.



To simplify the input each choice would be say



When moving to a new input1, it is important to input2 the climate that you will be input3 etc etc.






share|improve this answer















To get your 16 bits with the example you could tabulate a word/phrase per bit I got bored/tired around 12 bits (but more are possible) perhaps set it as a class assignment and see how many come back with an answer like this ?



The tex for if [1] then else [2] should be trivial perhaps from a csv table decoding is just reading / decoding the reversed order



When moving to a new

1 = area/region

, it is important to understand the climate that you will be

2 = living in/moving to

. Does it

rain/snow

more or less than you are used to? Will it typically be

3= hotter or colder / colder or hotter

than the

4/5 = city/area/town/region

that you are coming from? Just knowing where

6= a city / an area

is located on a map is not sufficient. In some

7= cities/areas,

nearby mountains may block the wind and make the climate

8= colder or hotter / hotter or colder

than expected. In other

9= regions/areas,

the ocean may keep the region

10 [cool in the summer time] and [warm in the winter]

. Using statistics, the climate in

11= two/multiple

areas can be compared to determine what to

12= expect/predict.



To simplify the input each choice would be say



When moving to a new input1, it is important to input2 the climate that you will be input3 etc etc.







share|improve this answer














share|improve this answer



share|improve this answer








edited 1 hour ago

























answered 1 hour ago









KJOKJO

4,4611424




4,4611424












  • Thank you very much for your thoughts. If I understand correctly, what you describe above can be implemented with the solution posted by the other poster. It would be "When moving to a new dobitarearegion ..." Thanks for your help.

    – Christopher Donham
    1 hour ago

















  • Thank you very much for your thoughts. If I understand correctly, what you describe above can be implemented with the solution posted by the other poster. It would be "When moving to a new dobitarearegion ..." Thanks for your help.

    – Christopher Donham
    1 hour ago
















Thank you very much for your thoughts. If I understand correctly, what you describe above can be implemented with the solution posted by the other poster. It would be "When moving to a new dobitarearegion ..." Thanks for your help.

– Christopher Donham
1 hour ago





Thank you very much for your thoughts. If I understand correctly, what you describe above can be implemented with the solution posted by the other poster. It would be "When moving to a new dobitarearegion ..." Thanks for your help.

– Christopher Donham
1 hour ago

















draft saved

draft discarded
















































Thanks for contributing an answer to TeX - LaTeX Stack Exchange!


  • Please be sure to answer the question. Provide details and share your research!

But avoid


  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.

To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2ftex.stackexchange.com%2fquestions%2f489697%2fsteganography-in-latex%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

Log på Navigationsmenu

Creating second map without labels using QGIS?How to lock map labels for inset map in Print Composer?How to Force the Showing of Labels of a Vector File in QGISQGIS Valmiera, Labels only show for part of polygonsRemoving duplicate point labels in QGISLabeling every feature using QGIS?Show labels for point features outside map canvasAbbreviate Road Labels in QGIS only when requiredExporting map from composer in QGIS - text labels have moved in output?How to make sure labels in qgis turn up in layout map?Writing label expression with ArcMap and If then Statement?

Nuuk Indholdsfortegnelse Etyomologi | Historie | Geografi | Transport og infrastruktur | Politik og administration | Uddannelsesinstitutioner | Kultur | Venskabsbyer | Noter | Eksterne henvisninger | Se også | Navigationsmenuwww.sermersooq.gl64°10′N 51°45′V / 64.167°N 51.750°V / 64.167; -51.75064°10′N 51°45′V / 64.167°N 51.750°V / 64.167; -51.750DMI - KlimanormalerSalmonsen, s. 850Grønlands Naturinstitut undersøger rensdyr i Akia og Maniitsoq foråret 2008Grønlands NaturinstitutNy vej til Qinngorput indviet i dagAntallet af biler i Nuuk må begrænsesNy taxacentral mødt med demonstrationKøreplan. Rute 1, 2 og 3SnescootersporNuukNord er for storSkoler i Kommuneqarfik SermersooqAtuarfik Samuel KleinschmidtKangillinguit AtuarfiatNuussuup AtuarfiaNuuk Internationale FriskoleIlinniarfissuaq, Grønlands SeminariumLedelseÅrsberetning for 2008Kunst og arkitekturÅrsberetning for 2008Julie om naturenNuuk KunstmuseumSilamiutGrønlands Nationalmuseum og ArkivStatistisk ÅrbogGrønlands LandsbibliotekStore koncerter på stribeVandhund nummer 1.000.000Kommuneqarfik Sermersooq – MalikForsidenVenskabsbyerLyngby-Taarbæk i GrønlandArctic Business NetworkWinter Cities 2008 i NuukDagligt opdaterede satellitbilleder fra NuukområdetKommuneqarfik Sermersooqs hjemmesideTurist i NuukGrønlands Statistiks databankGrønlands Hjemmestyres valgresultaterrrWorldCat124325457671310-5