Advertisement
Mohammed_AhmedAF

Untitled

May 9th, 2014
313
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 2.10 KB | None | 0 0
  1. #include <iostream>
  2. #include <algorithm>
  3. #include <vector>
  4. #include <math.h>
  5. #include <boost/dynamic_bitset.hpp>
  6.  
  7. using namespace std;
  8.  
  9. class lfsr {
  10. int y, xx, polyLoc, turnCount, n, end, p, q, d, f, e, m, c, l, g;
  11. boost::dynamic_bitset<> inpSeq;
  12. boost::dynamic_bitset<> operSeq;
  13. boost::dynamic_bitset<> bit;
  14. vector <int> xorArray;
  15. vector <int> keyReg;
  16. public:
  17. lfsr (int, int, int, int, int, int, int, int, int, int, int, int, int, int, int, boost::dynamic_bitset <>, boost::dynamic_bitset <>, boost::dynamic_bitset <>);
  18. void rsa (int, int, int, boost::dynamic_bitset<> = boost::dynamic_bitset<>(5));
  19. int key () {
  20. while(polyLoc>0)
  21. {
  22. xorArray.push_back(polyLoc%10);
  23. polyLoc/=10;
  24. }
  25. sort(xorArray.rbegin(), xorArray.rend());
  26. operSeq = inpSeq;
  27. keyReg.push_back(inpSeq[0]);
  28. int x = xorArray[0];
  29. do {
  30. for (unsigned int r = 1; r < xorArray.size(); r++)
  31. {
  32. bit[4] = operSeq[x];
  33. y = xorArray[r];
  34. bit[4] = bit[4] ^ operSeq[y];
  35. }
  36. operSeq >>= 1;
  37. operSeq[4] = bit[4];
  38. keyReg.push_back(operSeq[0]);
  39. turnCount ++;
  40. }
  41. while ((operSeq != inpSeq) && (turnCount < 1024));
  42. for ( unsigned int i = 0; i < keyReg.size(); i++)
  43. {
  44. if (keyReg[i]==1)
  45. {
  46. m = m + int(pow(2,i));
  47. }
  48. n = p*q;
  49. f = (p-1)*(q-1);
  50. for (int k = 0; end < 1; k++)
  51. {
  52. if ( (1+k*f)%d == 0)
  53. {
  54. end = 2;
  55. e = (1+(k*f))/d;
  56. }
  57. }
  58. g = int(pow(m,e));
  59. c = g%n;
  60. return (c);}
  61. };
  62.  
  63. lfsr::lfsr() //Constructor
  64. {
  65. y = 0;
  66. turnCount = 0;
  67. xx = 0;
  68. polyLoc = 320;
  69. n = 0;
  70. end = 0;
  71. p = 0;
  72. q = 0;
  73. d = 0;
  74. f = 0;
  75. e = 0;
  76. m = 0;
  77. c = 0;
  78. l = 0, g = 0;
  79. boost::dynamic_bitset<> inpSeq(5);
  80. boost::dynamic_bitset<> operSeq(5);
  81. boost::dynamic_bitset<> bit(5);
  82.  
  83. }
  84. void lfsr::rsa (int x, int y, int z, boost::dynamic_bitset <> initSeq)
  85. {
  86. p = x;
  87. q = y;
  88. d = z;
  89. inpSeq = initSeq;
  90. }
  91.  
  92. int main ()
  93. {
  94. lfsr public_key, private_key;
  95. public_key.rsa (29, 41, 74, 00111);
  96. private_key.rsa (43, 89, 73, 01011);
  97. cout << "Public key is: " << public_key.key() << endl;
  98. cout << "Private key is: " << private_key.key() << endl;
  99. cin.get();
  100. return 0;
  101. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement