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
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:
- Cannot use font changes -- the font information is lost in the
chegg posting. - Cannot use watermarks or other imagery -- again, this information
has been stripped from the posting. - 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) - 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:
- 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).
- Using extra punctuation marks that might be easily overlooked.. (see double periods at the end).
- 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
|
show 15 more comments
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:
- Cannot use font changes -- the font information is lost in the
chegg posting. - Cannot use watermarks or other imagery -- again, this information
has been stripped from the posting. - 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) - 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:
- 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).
- Using extra punctuation marks that might be easily overlooked.. (see double periods at the end).
- 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
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 withif
andelse
. Maybevariant"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
|
show 15 more comments
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:
- Cannot use font changes -- the font information is lost in the
chegg posting. - Cannot use watermarks or other imagery -- again, this information
has been stripped from the posting. - 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) - 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:
- 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).
- Using extra punctuation marks that might be easily overlooked.. (see double periods at the end).
- 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
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:
- Cannot use font changes -- the font information is lost in the
chegg posting. - Cannot use watermarks or other imagery -- again, this information
has been stripped from the posting. - 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) - 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:
- 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).
- Using extra punctuation marks that might be easily overlooked.. (see double periods at the end).
- 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
steganography
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 withif
andelse
. Maybevariant"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
|
show 15 more comments
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 withif
andelse
. Maybevariant"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
|
show 15 more comments
2 Answers
2
active
oldest
votes
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
+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. Thedobit
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
add a comment |
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.
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
add a comment |
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
);
);
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
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
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
+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. Thedobit
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
add a comment |
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
+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. Thedobit
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
add a comment |
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
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
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. Thedobit
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
add a comment |
+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. Thedobit
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
add a comment |
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.
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
add a comment |
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.
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
add a comment |
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.
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.
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
add a comment |
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
add a comment |
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.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
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
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
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
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
andelse
. Maybevariant"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