CBC-Mode-Encryption.tex 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. \documentclass{article}
  2. \usepackage[pdftex,active,tightpage]{preview}
  3. \usepackage{tikz}
  4. \usetikzlibrary{calc}
  5. \begin{document}
  6. \begin{preview}
  7. % thanks to http://tex.stackexchange.com/a/75838/5645
  8. \tikzset{XOR/.style={fill=black!15,draw,minimum size=13pt,circle,append after command={
  9. [shorten >=\pgflinewidth, shorten <=\pgflinewidth,]
  10. (\tikzlastnode.north) edge (\tikzlastnode.south)
  11. (\tikzlastnode.east) edge (\tikzlastnode.west)
  12. }
  13. }
  14. }
  15. \tikzstyle{encrypt}=[draw,fill=black!15,rectangle,minimum size=20pt,inner sep=0pt]
  16. \begin{tikzpicture}
  17. \newcommand{\n}{3}
  18. \foreach \nr in {1, ..., \n}{
  19. \node (M\nr) at (0,{(\n-\nr)*2}) {$M_\nr$};
  20. \node (x\nr)[XOR] at (2,{(\n-\nr)*2}) {};
  21. \node (E\nr)[encrypt] at (4,{(\n-\nr)*2}) {$E$};
  22. \node (C\nr) at (6,{(\n-\nr)*2}) {$C_\nr$};
  23. \node (K\nr) at (4,{(\n-\nr)*2+1}) {$K$};
  24. \draw[->,very thick] (M\nr) -- (x\nr);
  25. \draw[->,very thick] (x\nr) -- (E\nr);
  26. \draw[->,very thick] (E\nr) -- (C\nr);
  27. \draw[->,very thick] (K\nr) -- (E\nr);
  28. }
  29. \foreach \nr in {2, ..., \n}{
  30. \pgfmathtruncatemacro{\tmp}{\nr-1}
  31. \draw[->,very thick] (E\tmp) -- (4, {(\n-\tmp)*2-0.5}) -- (2, {(\n-\nr)*2+1.5}) -- (x\nr);
  32. }
  33. \node (IV) at (2,{\n*2-1}) {$IV$};
  34. \draw[->, very thick] (IV) -- (x1);
  35. \node (Mx) at (0,-1) {$\vdots$};
  36. \node (xx) at (2,-1) {$\vdots$};
  37. \node (Ex) at (4,-1) {$\vdots$};
  38. \node (Cx) at (6,-1) {$\vdots$};
  39. \end{tikzpicture}
  40. \end{preview}
  41. \end{document}