ebooksgratis.com

See also ebooksgratis.com: no banners, no cookies, totally FREE.

CLASSICISTRANIERI HOME PAGE - YOUTUBE CHANNEL
Privacy Policy Cookie Policy Terms and Conditions
McEliece cryptosystem - Wikipedia, the free encyclopedia

McEliece cryptosystem

From Wikipedia, the free encyclopedia

In cryptography, the McEliece cryptosystem is an asymmetric key algorithm developed in 1978 by Robert McEliece. The algorithm has never gained much acceptance in the cryptographic community.

The algorithm uses Goppa codes, which are a type of error-correcting code (see coding theory). The algorithm disguises a Goppa code made from the plaintext as a general linear code. Goppa codes are easy to decode, but distinguishing them from a general linear code is hard. This is McEliece's hard problem.

The private and public keys are large matrices, which is one of the main disadvantages of the algorithm. The public key is very large: 219 bits long.

Attempts have been made to cryptanalyze McEliece, but none have been successful. However, the algorithm is rarely used in practice because of the massive keys. One exceptional case that uses McEliece for encryption is the Freenet-like application Entropy (anonymous data store).

Contents

[edit] Scheme definition

McEliece consists of three algorithms: a probabilistic key generation algorithm which produces a public and a private key, a probabilistic encryption algorithm, and a deterministic decryption algorithm.

All users in a McEliece deployment share a set of common security parameters: n,t,k. Recommended values for these parameters are n = 1024,t = 38,k = 644 (source: Handbook of Applied Cryptography).

[edit] Key generation

  1. Users select a binary (n,k)-linear code C capable of correcting t errors. This code must possess an efficient decoding algorithm.
  2. Alice generates a k \times n generator matrix G for the code C.
  3. Select a random k \times k binary non-singular matrix S.
  4. Select a random n \times n permutation matrix P.
  5. Compute the k \times n matrix {\hat G} = SGP.
  6. Alice’s public key is ({\hat G}, t); her private key is (S,G,P).

[edit] Message encryption

Suppose Bob wishes to send a message m to Alice whose public key is ({\hat G}, t):

  1. Encode the message as a binary string of length k.
  2. Compute the vector c^{\prime} = m{\hat G}.
  3. Generate a random n-bit vector z containing at most t ones.
  4. Compute the ciphertext as c = c^{\prime} + z. '+' is XOR operator

[edit] Message decryption

  1. Compute the inverse of P, P − 1.
  2. Compute {\hat c} = cP^{-1}.
  3. Use the decoding algorithm for the code C to decode {\hat c} to {\hat m}.
  4. Compute m = {\hat m}S^{-1}.

[edit] References

  • Alfred J. Menezes, Scott A. Vanstone, A. J. Menezes and Paul C. van Oorschot, Handbook of Applied Cryptography.

[edit] External links

The "Handbook of Applied Cryptography" chapter that deals with the McEliece cryptosystem. (PDF); Postscript version.

Languages


aa - ab - af - ak - als - am - an - ang - ar - arc - as - ast - av - ay - az - ba - bar - bat_smg - bcl - be - be_x_old - bg - bh - bi - bm - bn - bo - bpy - br - bs - bug - bxr - ca - cbk_zam - cdo - ce - ceb - ch - cho - chr - chy - co - cr - crh - cs - csb - cu - cv - cy - da - de - diq - dsb - dv - dz - ee - el - eml - en - eo - es - et - eu - ext - fa - ff - fi - fiu_vro - fj - fo - fr - frp - fur - fy - ga - gan - gd - gl - glk - gn - got - gu - gv - ha - hak - haw - he - hi - hif - ho - hr - hsb - ht - hu - hy - hz - ia - id - ie - ig - ii - ik - ilo - io - is - it - iu - ja - jbo - jv - ka - kaa - kab - kg - ki - kj - kk - kl - km - kn - ko - kr - ks - ksh - ku - kv - kw - ky - la - lad - lb - lbe - lg - li - lij - lmo - ln - lo - lt - lv - map_bms - mdf - mg - mh - mi - mk - ml - mn - mo - mr - mt - mus - my - myv - mzn - na - nah - nap - nds - nds_nl - ne - new - ng - nl - nn - no - nov - nrm - nv - ny - oc - om - or - os - pa - pag - pam - pap - pdc - pi - pih - pl - pms - ps - pt - qu - quality - rm - rmy - rn - ro - roa_rup - roa_tara - ru - rw - sa - sah - sc - scn - sco - sd - se - sg - sh - si - simple - sk - sl - sm - sn - so - sr - srn - ss - st - stq - su - sv - sw - szl - ta - te - tet - tg - th - ti - tk - tl - tlh - tn - to - tpi - tr - ts - tt - tum - tw - ty - udm - ug - uk - ur - uz - ve - vec - vi - vls - vo - wa - war - wo - wuu - xal - xh - yi - yo - za - zea - zh - zh_classical - zh_min_nan - zh_yue - zu -