Classic McEliece

Category 1

NistyPQC.McEliece.Category1.generate_keysFunction
generate_keys([; δ¹])

Return a tuple (; ek, dk) consisting of an encapsulation key and the corresponding decapsulation key. The length of ek will be 261120 bytes and the length of dk 6492 bytes.

For a deterministic result, a seed δ¹ of 32 bytes can be provided.

source
NistyPQC.McEliece.Category1.encapsulate_secretFunction
encapsulate_secret(ek[; rng])

Return a tuple (; K, c) consisting of a shared secret K and a ciphertext c from which K can be recomputed with the decapsulation key dk that corresponds to ek. The parameter ek must be a valid encapsulation key of 261120 bytes. The length of K will be 32 bytes and the length of c 96 bytes.

For a deterministic result, rng can be provided. This pseudorandom number generator must implement rand(rng, UInt8, ::Int).

source
NistyPQC.McEliece.Category1.decapsulate_secretFunction
decapsulate_secret(c, dk)

Return the secret key K in case of successful decapsulation. Otherwise implicitly reject, i.e. return a deterministic value K derived from c and dk. The parameter c must have 96 bytes and dk 6492 bytes. Both for successful and failed decapsulation, K will have a length of 32 bytes.

source

Category 1f

NistyPQC.McEliece.Category1f.generate_keysFunction
generate_keys([; δ¹])

Return a tuple (; ek, dk) consisting of an encapsulation key and the corresponding decapsulation key. The length of ek will be 261120 bytes and the length of dk 6492 bytes.

For a deterministic result, a seed δ¹ of 32 bytes can be provided.

source
NistyPQC.McEliece.Category1f.encapsulate_secretFunction
encapsulate_secret(ek[; rng])

Return a tuple (; K, c) consisting of a shared secret K and a ciphertext c from which K can be recomputed with the decapsulation key dk that corresponds to ek. The parameter ek must be a valid encapsulation key of 261120 bytes. The length of K will be 32 bytes and the length of c 96 bytes.

For a deterministic result, rng can be provided. This pseudorandom number generator must implement rand(rng, UInt8, ::Int).

source
NistyPQC.McEliece.Category1f.decapsulate_secretFunction
decapsulate_secret(c, dk)

Return the secret key K in case of successful decapsulation. Otherwise implicitly reject, i.e. return a deterministic value K derived from c and dk. The parameter c must have 96 bytes and dk 6492 bytes. Both for successful and failed decapsulation, K will have a length of 32 bytes.

source

Category 3

NistyPQC.McEliece.Category3.generate_keysFunction
generate_keys([; δ¹])

Return a tuple (; ek, dk) consisting of an encapsulation key and the corresponding decapsulation key. The length of ek will be 524160 bytes and the length of dk 13608 bytes.

For a deterministic result, a seed δ¹ of 32 bytes can be provided.

source
NistyPQC.McEliece.Category3.encapsulate_secretFunction
encapsulate_secret(ek[; rng])

Return a tuple (; K, c) consisting of a shared secret K and a ciphertext c from which K can be recomputed with the decapsulation key dk that corresponds to ek. The parameter ek must be a valid encapsulation key of 524160 bytes. The length of K will be 32 bytes and the length of c 156 bytes.

For a deterministic result, rng can be provided. This pseudorandom number generator must implement rand(rng, UInt8, ::Int).

source
NistyPQC.McEliece.Category3.decapsulate_secretFunction
decapsulate_secret(c, dk)

Return the secret key K in case of successful decapsulation. Otherwise implicitly reject, i.e. return a deterministic value K derived from c and dk. The parameter c must have 156 bytes and dk 13608 bytes. Both for successful and failed decapsulation, K will have a length of 32 bytes.

source

Category 3f

NistyPQC.McEliece.Category3f.generate_keysFunction
generate_keys([; δ¹])

Return a tuple (; ek, dk) consisting of an encapsulation key and the corresponding decapsulation key. The length of ek will be 524160 bytes and the length of dk 13608 bytes.

For a deterministic result, a seed δ¹ of 32 bytes can be provided.

source
NistyPQC.McEliece.Category3f.encapsulate_secretFunction
encapsulate_secret(ek[; rng])

Return a tuple (; K, c) consisting of a shared secret K and a ciphertext c from which K can be recomputed with the decapsulation key dk that corresponds to ek. The parameter ek must be a valid encapsulation key of 524160 bytes. The length of K will be 32 bytes and the length of c 156 bytes.

For a deterministic result, rng can be provided. This pseudorandom number generator must implement rand(rng, UInt8, ::Int).

source
NistyPQC.McEliece.Category3f.decapsulate_secretFunction
decapsulate_secret(c, dk)

Return the secret key K in case of successful decapsulation. Otherwise implicitly reject, i.e. return a deterministic value K derived from c and dk. The parameter c must have 156 bytes and dk 13608 bytes. Both for successful and failed decapsulation, K will have a length of 32 bytes.

source

Category 5A

NistyPQC.McEliece.Category5A.generate_keysFunction
generate_keys([; δ¹])

Return a tuple (; ek, dk) consisting of an encapsulation key and the corresponding decapsulation key. The length of ek will be 1044992 bytes and the length of dk 13932 bytes.

For a deterministic result, a seed δ¹ of 32 bytes can be provided.

source
NistyPQC.McEliece.Category5A.encapsulate_secretFunction
encapsulate_secret(ek[; rng])

Return a tuple (; K, c) consisting of a shared secret K and a ciphertext c from which K can be recomputed with the decapsulation key dk that corresponds to ek. The parameter ek must be a valid encapsulation key of 1044992 bytes. The length of K will be 32 bytes and the length of c 208 bytes.

For a deterministic result, rng can be provided. This pseudorandom number generator must implement rand(rng, UInt8, ::Int).

source
NistyPQC.McEliece.Category5A.decapsulate_secretFunction
decapsulate_secret(c, dk)

Return the secret key K in case of successful decapsulation. Otherwise implicitly reject, i.e. return a deterministic value K derived from c and dk. The parameter c must have 208 bytes and dk 13932 bytes. Both for successful and failed decapsulation, K will have a length of 32 bytes.

source

Category 5Af

NistyPQC.McEliece.Category5Af.generate_keysFunction
generate_keys([; δ¹])

Return a tuple (; ek, dk) consisting of an encapsulation key and the corresponding decapsulation key. The length of ek will be 1044992 bytes and the length of dk 13932 bytes.

For a deterministic result, a seed δ¹ of 32 bytes can be provided.

source
NistyPQC.McEliece.Category5Af.encapsulate_secretFunction
encapsulate_secret(ek[; rng])

Return a tuple (; K, c) consisting of a shared secret K and a ciphertext c from which K can be recomputed with the decapsulation key dk that corresponds to ek. The parameter ek must be a valid encapsulation key of 1044992 bytes. The length of K will be 32 bytes and the length of c 208 bytes.

For a deterministic result, rng can be provided. This pseudorandom number generator must implement rand(rng, UInt8, ::Int).

source
NistyPQC.McEliece.Category5Af.decapsulate_secretFunction
decapsulate_secret(c, dk)

Return the secret key K in case of successful decapsulation. Otherwise implicitly reject, i.e. return a deterministic value K derived from c and dk. The parameter c must have 208 bytes and dk 13932 bytes. Both for successful and failed decapsulation, K will have a length of 32 bytes.

source

Category 5B

NistyPQC.McEliece.Category5B.generate_keysFunction
generate_keys([; δ¹])

Return a tuple (; ek, dk) consisting of an encapsulation key and the corresponding decapsulation key. The length of ek will be 1047319 bytes and the length of dk 13948 bytes.

For a deterministic result, a seed δ¹ of 32 bytes can be provided.

source
NistyPQC.McEliece.Category5B.encapsulate_secretFunction
encapsulate_secret(ek[; rng])

Return a tuple (; K, c) consisting of a shared secret K and a ciphertext c from which K can be recomputed with the decapsulation key dk that corresponds to ek. The parameter ek must be a valid encapsulation key of 1047319 bytes. The length of K will be 32 bytes and the length of c 194 bytes.

For a deterministic result, rng can be provided. This pseudorandom number generator must implement rand(rng, UInt8, ::Int).

source
NistyPQC.McEliece.Category5B.decapsulate_secretFunction
decapsulate_secret(c, dk)

Return the secret key K in case of successful decapsulation. Otherwise implicitly reject, i.e. return a deterministic value K derived from c and dk. The parameter c must have 194 bytes and dk 13948 bytes. Both for successful and failed decapsulation, K will have a length of 32 bytes.

source

Category 5Bf

NistyPQC.McEliece.Category5Bf.generate_keysFunction
generate_keys([; δ¹])

Return a tuple (; ek, dk) consisting of an encapsulation key and the corresponding decapsulation key. The length of ek will be 1047319 bytes and the length of dk 13948 bytes.

For a deterministic result, a seed δ¹ of 32 bytes can be provided.

source
NistyPQC.McEliece.Category5Bf.encapsulate_secretFunction
encapsulate_secret(ek[; rng])

Return a tuple (; K, c) consisting of a shared secret K and a ciphertext c from which K can be recomputed with the decapsulation key dk that corresponds to ek. The parameter ek must be a valid encapsulation key of 1047319 bytes. The length of K will be 32 bytes and the length of c 194 bytes.

For a deterministic result, rng can be provided. This pseudorandom number generator must implement rand(rng, UInt8, ::Int).

source
NistyPQC.McEliece.Category5Bf.decapsulate_secretFunction
decapsulate_secret(c, dk)

Return the secret key K in case of successful decapsulation. Otherwise implicitly reject, i.e. return a deterministic value K derived from c and dk. The parameter c must have 194 bytes and dk 13948 bytes. Both for successful and failed decapsulation, K will have a length of 32 bytes.

source

Category 5C

NistyPQC.McEliece.Category5C.generate_keysFunction
generate_keys([; δ¹])

Return a tuple (; ek, dk) consisting of an encapsulation key and the corresponding decapsulation key. The length of ek will be 1357824 bytes and the length of dk 14120 bytes.

For a deterministic result, a seed δ¹ of 32 bytes can be provided.

source
NistyPQC.McEliece.Category5C.encapsulate_secretFunction
encapsulate_secret(ek[; rng])

Return a tuple (; K, c) consisting of a shared secret K and a ciphertext c from which K can be recomputed with the decapsulation key dk that corresponds to ek. The parameter ek must be a valid encapsulation key of 1357824 bytes. The length of K will be 32 bytes and the length of c 208 bytes.

For a deterministic result, rng can be provided. This pseudorandom number generator must implement rand(rng, UInt8, ::Int).

source
NistyPQC.McEliece.Category5C.decapsulate_secretFunction
decapsulate_secret(c, dk)

Return the secret key K in case of successful decapsulation. Otherwise implicitly reject, i.e. return a deterministic value K derived from c and dk. The parameter c must have 208 bytes and dk 14120 bytes. Both for successful and failed decapsulation, K will have a length of 32 bytes.

source

Category 5Cf

NistyPQC.McEliece.Category5Cf.generate_keysFunction
generate_keys([; δ¹])

Return a tuple (; ek, dk) consisting of an encapsulation key and the corresponding decapsulation key. The length of ek will be 1357824 bytes and the length of dk 14120 bytes.

For a deterministic result, a seed δ¹ of 32 bytes can be provided.

source
NistyPQC.McEliece.Category5Cf.encapsulate_secretFunction
encapsulate_secret(ek[; rng])

Return a tuple (; K, c) consisting of a shared secret K and a ciphertext c from which K can be recomputed with the decapsulation key dk that corresponds to ek. The parameter ek must be a valid encapsulation key of 1357824 bytes. The length of K will be 32 bytes and the length of c 208 bytes.

For a deterministic result, rng can be provided. This pseudorandom number generator must implement rand(rng, UInt8, ::Int).

source
NistyPQC.McEliece.Category5Cf.decapsulate_secretFunction
decapsulate_secret(c, dk)

Return the secret key K in case of successful decapsulation. Otherwise implicitly reject, i.e. return a deterministic value K derived from c and dk. The parameter c must have 208 bytes and dk 14120 bytes. Both for successful and failed decapsulation, K will have a length of 32 bytes.

source