Moved alternative board to a new "modifications" section
This commit is contained in:
parent
00f89c47c7
commit
8e4e169a39
114
README.md
114
README.md
|
@ -63,62 +63,6 @@ To run (hand-run) the encryption/decryption, you will also need some kind of a
|
||||||
marker (e.g. a small shiny stone, bolt nut or similar kind of well-shaped
|
marker (e.g. a small shiny stone, bolt nut or similar kind of well-shaped
|
||||||
trash).
|
trash).
|
||||||
|
|
||||||
#### Alternative playing-card-compatible board
|
|
||||||
|
|
||||||
The following board can be used so that characters and offsets can be easily
|
|
||||||
mapped to playing cards, similar to the Solitaire cipher [2]. Using playing
|
|
||||||
cards could be more innocuous and easily explainable to the secret police than
|
|
||||||
a set of peculiar numbered tiles.
|
|
||||||
|
|
||||||
```
|
|
||||||
0 a b c d e f
|
|
||||||
g h i j k l m
|
|
||||||
n o p q r s t
|
|
||||||
u v w x y z _
|
|
||||||
. , - + * / :
|
|
||||||
? ! ' ( ) 1 2
|
|
||||||
3 4 5 6 7 8 9
|
|
||||||
```
|
|
||||||
|
|
||||||
With this layout, the following mapping to playing cards is used:
|
|
||||||
|
|
||||||
| **Character** | Card | Index | **Character** | Card | Index | **Character** | Card | Index | **Character** | Card | Index |
|
|
||||||
|-----------|------|-------|-----------|------|-------|-----------|------|-------|-----------|------|--------|
|
|
||||||
| a | A♦ | 1 | n | A♣ | 14 | _ | A♥ | 27 | 1 | A♠ | 40 |
|
|
||||||
| b | 2♦ | 2 | o | 2♣ | 15 | . | 2♥ | 28 | 2 | 2♠ | 41 |
|
|
||||||
| c | 3♦ | 3 | p | 3♣ | 16 | , | 3♥ | 29 | 3 | 3♠ | 42 |
|
|
||||||
| ... | ... | ... | ... | ... | ... | ... | ... | ... | ... | ... | ... |
|
|
||||||
| j | 10♦ | 10 | w | 10♣ | 23 | ! | 10♥ | 39 | 7 | 7♠ | 46 |
|
|
||||||
| k | J♦ | 11 | x | J♣ | 24 | ' | J♥ | 39 | 8 | 8♠ | 47 |
|
|
||||||
| l | Q♦ | 12 | y | Q♣ | 25 | ( | Q♥ | 39 | 9 | 9♠ | 48 |
|
|
||||||
| m | K♦ | 13 | z | K♣ | 26 | ) | K♥ | 39 | 0 | 10♠ | 49 (0) |
|
|
||||||
|
|
||||||
The (x, y) offset can be calculated by first determining the index: take the
|
|
||||||
number of the suit (0-3), multiply by 13, and add the card number (using 1 for
|
|
||||||
the Ace, 11-13 for face cards). Then, determine the offset from the index
|
|
||||||
using the usual modular arithmetic: `x = index % 7` and `y = index / 7`.
|
|
||||||
|
|
||||||
Alphanumeric characters can be easily mapped to cards, with letters mapping to
|
|
||||||
Diamonds or Clubs and numbers mapping to Spades (note that Spades face cards
|
|
||||||
are ommitted). All of the special characters are mapped to the Hearts, though
|
|
||||||
coming up with a mnemonic for the mapping of each special character to each
|
|
||||||
Heart is left as an exercise for the reader.
|
|
||||||
|
|
||||||
For LC4, the following board could be used:
|
|
||||||
|
|
||||||
```
|
|
||||||
# a b c d e
|
|
||||||
f g h i j k
|
|
||||||
l m n o p q
|
|
||||||
r s t u v w
|
|
||||||
x y z _ 2 3
|
|
||||||
4 5 6 7 8 9
|
|
||||||
```
|
|
||||||
|
|
||||||
The "Hearts" suit would be ommitted from the card mapping table, and the index
|
|
||||||
of each of the Spades would be decreased by 13 to compensate. `#` and `_`
|
|
||||||
would map to 10♠ and A♠, respectively.
|
|
||||||
|
|
||||||
## How-To
|
## How-To
|
||||||
|
|
||||||
You may as well see the paper [1], there are also pictures. This is somewhat more concentrated:
|
You may as well see the paper [1], there are also pictures. This is somewhat more concentrated:
|
||||||
|
@ -198,6 +142,8 @@ stays the same.
|
||||||
|
|
||||||
Grab a bag full of tiles and randomly draw them one by one. Key is the 49-item permutation of them.
|
Grab a bag full of tiles and randomly draw them one by one. Key is the 49-item permutation of them.
|
||||||
|
|
||||||
|
## Modifications
|
||||||
|
|
||||||
### Key expansion from a password
|
### Key expansion from a password
|
||||||
|
|
||||||
Remembering 49-position random permutation that includes weird characters is
|
Remembering 49-position random permutation that includes weird characters is
|
||||||
|
@ -252,6 +198,62 @@ This works because the cipher output is message-dependent: Having a wrong bit
|
||||||
somewhere in the middle causes avalanche effect and erases any meaning from the
|
somewhere in the middle causes avalanche effect and erases any meaning from the
|
||||||
text after several characters.
|
text after several characters.
|
||||||
|
|
||||||
|
### Alternative playing-card-compatible board
|
||||||
|
|
||||||
|
The following board can be used so that characters and offsets can be easily
|
||||||
|
mapped to playing cards, similar to the Solitaire cipher [2]. Using playing
|
||||||
|
cards could be more innocuous and easily explainable to the secret police than
|
||||||
|
a set of peculiar numbered tiles.
|
||||||
|
|
||||||
|
```
|
||||||
|
0 a b c d e f
|
||||||
|
g h i j k l m
|
||||||
|
n o p q r s t
|
||||||
|
u v w x y z _
|
||||||
|
. , - + * / :
|
||||||
|
? ! ' ( ) 1 2
|
||||||
|
3 4 5 6 7 8 9
|
||||||
|
```
|
||||||
|
|
||||||
|
With this layout, the following mapping to playing cards is used:
|
||||||
|
|
||||||
|
| **Character** | Card | Index | **Character** | Card | Index | **Character** | Card | Index | **Character** | Card | Index |
|
||||||
|
|-----------|------|-------|-----------|------|-------|-----------|------|-------|-----------|------|--------|
|
||||||
|
| a | A♦ | 1 | n | A♣ | 14 | _ | A♥ | 27 | 1 | A♠ | 40 |
|
||||||
|
| b | 2♦ | 2 | o | 2♣ | 15 | . | 2♥ | 28 | 2 | 2♠ | 41 |
|
||||||
|
| c | 3♦ | 3 | p | 3♣ | 16 | , | 3♥ | 29 | 3 | 3♠ | 42 |
|
||||||
|
| ... | ... | ... | ... | ... | ... | ... | ... | ... | ... | ... | ... |
|
||||||
|
| j | 10♦ | 10 | w | 10♣ | 23 | ! | 10♥ | 39 | 7 | 7♠ | 46 |
|
||||||
|
| k | J♦ | 11 | x | J♣ | 24 | ' | J♥ | 39 | 8 | 8♠ | 47 |
|
||||||
|
| l | Q♦ | 12 | y | Q♣ | 25 | ( | Q♥ | 39 | 9 | 9♠ | 48 |
|
||||||
|
| m | K♦ | 13 | z | K♣ | 26 | ) | K♥ | 39 | 0 | 10♠ | 49 (0) |
|
||||||
|
|
||||||
|
The (x, y) offset can be calculated by first determining the index: take the
|
||||||
|
number of the suit (0-3), multiply by 13, and add the card number (using 1 for
|
||||||
|
the Ace, 11-13 for face cards). Then, determine the offset from the index
|
||||||
|
using the usual modular arithmetic: `x = index % 7` and `y = index / 7`.
|
||||||
|
|
||||||
|
Alphanumeric characters can be easily mapped to cards, with letters mapping to
|
||||||
|
Diamonds or Clubs and numbers mapping to Spades (note that Spades face cards
|
||||||
|
are ommitted). All of the special characters are mapped to the Hearts, though
|
||||||
|
coming up with a mnemonic for the mapping of each special character to each
|
||||||
|
Heart is left as an exercise for the reader.
|
||||||
|
|
||||||
|
For LC4, the following board could be used:
|
||||||
|
|
||||||
|
```
|
||||||
|
# a b c d e
|
||||||
|
f g h i j k
|
||||||
|
l m n o p q
|
||||||
|
r s t u v w
|
||||||
|
x y z _ 2 3
|
||||||
|
4 5 6 7 8 9
|
||||||
|
```
|
||||||
|
|
||||||
|
The "Hearts" suit would be ommitted from the card mapping table, and the index
|
||||||
|
of each of the Spades would be decreased by 13 to compensate. `#` and `_`
|
||||||
|
would map to 10♠ and A♠, respectively.
|
||||||
|
|
||||||
## References
|
## References
|
||||||
|
|
||||||
[1] *Kaminsky, Alan. "ElsieFour: A Low-Tech Authenticated Encryption Algorithm For Human-to-Human Communication." IACR Cryptology ePrint Archive 2017 (2017): 339.*
|
[1] *Kaminsky, Alan. "ElsieFour: A Low-Tech Authenticated Encryption Algorithm For Human-to-Human Communication." IACR Cryptology ePrint Archive 2017 (2017): 339.*
|
||||||
|
|
Loading…
Reference in a new issue