25'ten fazla konu seçemezsiniz Konular bir harf veya rakamla başlamalı, kısa çizgiler ('-') içerebilir ve en fazla 35 karakter uzunluğunda olabilir.
 
 
 

337 satır
13 KiB

  1. #include <stddef.h>
  2. #include <stdint.h>
  3. #include "params.h"
  4. #include "poly.h"
  5. #include "polyvec.h"
  6. /**************************************************************/
  7. /************ Vectors of polynomials of length L **************/
  8. /**************************************************************/
  9. /*************************************************
  10. * Name: PQCLEAN_DILITHIUM2_CLEAN_polyvecl_freeze
  11. *
  12. * Description: Reduce coefficients of polynomials in vector of length L
  13. * to standard representatives.
  14. *
  15. * Arguments: - polyvecl *v: pointer to input/output vector
  16. **************************************************/
  17. void PQCLEAN_DILITHIUM2_CLEAN_polyvecl_freeze(polyvecl *v) {
  18. for (size_t i = 0; i < L; ++i) {
  19. PQCLEAN_DILITHIUM2_CLEAN_poly_freeze(&v->vec[i]);
  20. }
  21. }
  22. /*************************************************
  23. * Name: PQCLEAN_DILITHIUM2_CLEAN_polyvecl_add
  24. *
  25. * Description: Add vectors of polynomials of length L.
  26. * No modular reduction is performed.
  27. *
  28. * Arguments: - polyvecl *w: pointer to output vector
  29. * - const polyvecl *u: pointer to first summand
  30. * - const polyvecl *v: pointer to second summand
  31. **************************************************/
  32. void PQCLEAN_DILITHIUM2_CLEAN_polyvecl_add(
  33. polyvecl *w, const polyvecl *u, const polyvecl *v) {
  34. for (size_t i = 0; i < L; ++i) {
  35. PQCLEAN_DILITHIUM2_CLEAN_poly_add(&w->vec[i], &u->vec[i], &v->vec[i]);
  36. }
  37. }
  38. /*************************************************
  39. * Name: PQCLEAN_DILITHIUM2_CLEAN_polyvecl_ntt
  40. *
  41. * Description: Forward NTT of all polynomials in vector of length L. Output
  42. * coefficients can be up to 16*Q larger than input coefficients.
  43. *
  44. * Arguments: - polyvecl *v: pointer to input/output vector
  45. **************************************************/
  46. void PQCLEAN_DILITHIUM2_CLEAN_polyvecl_ntt(polyvecl *v) {
  47. for (size_t i = 0; i < L; ++i) {
  48. PQCLEAN_DILITHIUM2_CLEAN_poly_ntt(&v->vec[i]);
  49. }
  50. }
  51. /*************************************************
  52. * Name: PQCLEAN_DILITHIUM2_CLEAN_polyvecl_pointwise_acc_invmontgomery
  53. *
  54. * Description: Pointwise multiply vectors of polynomials of length L, multiply
  55. * resulting vector by 2^{-32} and add (accumulate) polynomials
  56. * in it. Input/output vectors are in NTT domain representation.
  57. * Input coefficients are assumed to be less than 22*Q. Output
  58. * coeffcient are less than 2*L*Q.
  59. *
  60. * Arguments: - poly *w: output polynomial
  61. * - const polyvecl *u: pointer to first input vector
  62. * - const polyvecl *v: pointer to second input vector
  63. **************************************************/
  64. void PQCLEAN_DILITHIUM2_CLEAN_polyvecl_pointwise_acc_invmontgomery(
  65. poly *w, const polyvecl *u, const polyvecl *v) {
  66. poly t;
  67. PQCLEAN_DILITHIUM2_CLEAN_poly_pointwise_invmontgomery(w, &u->vec[0], &v->vec[0]);
  68. for (size_t i = 1; i < L; ++i) {
  69. PQCLEAN_DILITHIUM2_CLEAN_poly_pointwise_invmontgomery(&t, &u->vec[i], &v->vec[i]);
  70. PQCLEAN_DILITHIUM2_CLEAN_poly_add(w, w, &t);
  71. }
  72. }
  73. /*************************************************
  74. * Name: PQCLEAN_DILITHIUM2_CLEAN_polyvecl_chknorm
  75. *
  76. * Description: Check infinity norm of polynomials in vector of length L.
  77. * Assumes input coefficients to be standard representatives.
  78. *
  79. * Arguments: - const polyvecl *v: pointer to vector
  80. * - uint32_t B: norm bound
  81. *
  82. * Returns 0 if norm of all polynomials is strictly smaller than B and 1
  83. * otherwise.
  84. **************************************************/
  85. int PQCLEAN_DILITHIUM2_CLEAN_polyvecl_chknorm(const polyvecl *v, uint32_t B) {
  86. for (size_t i = 0; i < L; ++i) {
  87. if (PQCLEAN_DILITHIUM2_CLEAN_poly_chknorm(&v->vec[i], B)) {
  88. return 1;
  89. }
  90. }
  91. return 0;
  92. }
  93. /**************************************************************/
  94. /************ Vectors of polynomials of length K **************/
  95. /**************************************************************/
  96. /*************************************************
  97. * Name: PQCLEAN_DILITHIUM2_CLEAN_polyveck_reduce
  98. *
  99. * Description: Reduce coefficients of polynomials in vector of length K
  100. * to representatives in [0,2*Q[.
  101. *
  102. * Arguments: - polyveck *v: pointer to input/output vector
  103. **************************************************/
  104. void PQCLEAN_DILITHIUM2_CLEAN_polyveck_reduce(polyveck *v) {
  105. for (size_t i = 0; i < K; ++i) {
  106. PQCLEAN_DILITHIUM2_CLEAN_poly_reduce(&v->vec[i]);
  107. }
  108. }
  109. /*************************************************
  110. * Name: PQCLEAN_DILITHIUM2_CLEAN_polyveck_csubq
  111. *
  112. * Description: For all coefficients of polynomials in vector of length K
  113. * subtract Q if coefficient is bigger than Q.
  114. *
  115. * Arguments: - polyveck *v: pointer to input/output vector
  116. **************************************************/
  117. void PQCLEAN_DILITHIUM2_CLEAN_polyveck_csubq(polyveck *v) {
  118. for (size_t i = 0; i < K; ++i) {
  119. PQCLEAN_DILITHIUM2_CLEAN_poly_csubq(&v->vec[i]);
  120. }
  121. }
  122. /*************************************************
  123. * Name: PQCLEAN_DILITHIUM2_CLEAN_polyveck_freeze
  124. *
  125. * Description: Reduce coefficients of polynomials in vector of length K
  126. * to standard representatives.
  127. *
  128. * Arguments: - polyveck *v: pointer to input/output vector
  129. **************************************************/
  130. void PQCLEAN_DILITHIUM2_CLEAN_polyveck_freeze(polyveck *v) {
  131. for (size_t i = 0; i < K; ++i) {
  132. PQCLEAN_DILITHIUM2_CLEAN_poly_freeze(&v->vec[i]);
  133. }
  134. }
  135. /*************************************************
  136. * Name: PQCLEAN_DILITHIUM2_CLEAN_polyveck_add
  137. *
  138. * Description: Add vectors of polynomials of length K.
  139. * No modular reduction is performed.
  140. *
  141. * Arguments: - polyveck *w: pointer to output vector
  142. * - const polyveck *u: pointer to first summand
  143. * - const polyveck *v: pointer to second summand
  144. **************************************************/
  145. void PQCLEAN_DILITHIUM2_CLEAN_polyveck_add(
  146. polyveck *w, const polyveck *u, const polyveck *v) {
  147. for (size_t i = 0; i < K; ++i) {
  148. PQCLEAN_DILITHIUM2_CLEAN_poly_add(&w->vec[i], &u->vec[i], &v->vec[i]);
  149. }
  150. }
  151. /*************************************************
  152. * Name: PQCLEAN_DILITHIUM2_CLEAN_polyveck_sub
  153. *
  154. * Description: Subtract vectors of polynomials of length K.
  155. * Assumes coefficients of polynomials in second input vector
  156. * to be less than 2*Q. No modular reduction is performed.
  157. *
  158. * Arguments: - polyveck *w: pointer to output vector
  159. * - const polyveck *u: pointer to first input vector
  160. * - const polyveck *v: pointer to second input vector to be
  161. * subtracted from first input vector
  162. **************************************************/
  163. void PQCLEAN_DILITHIUM2_CLEAN_polyveck_sub(
  164. polyveck *w, const polyveck *u, const polyveck *v) {
  165. for (size_t i = 0; i < K; ++i) {
  166. PQCLEAN_DILITHIUM2_CLEAN_poly_sub(&w->vec[i], &u->vec[i], &v->vec[i]);
  167. }
  168. }
  169. /*************************************************
  170. * Name: PQCLEAN_DILITHIUM2_CLEAN_polyveck_shiftl
  171. *
  172. * Description: Multiply vector of polynomials of Length K by 2^D without modular
  173. * reduction. Assumes input coefficients to be less than 2^{32-D}.
  174. *
  175. * Arguments: - polyveck *v: pointer to input/output vector
  176. **************************************************/
  177. void PQCLEAN_DILITHIUM2_CLEAN_polyveck_shiftl(polyveck *v) {
  178. for (size_t i = 0; i < K; ++i) {
  179. PQCLEAN_DILITHIUM2_CLEAN_poly_shiftl(&v->vec[i]);
  180. }
  181. }
  182. /*************************************************
  183. * Name: PQCLEAN_DILITHIUM2_CLEAN_polyveck_ntt
  184. *
  185. * Description: Forward NTT of all polynomials in vector of length K. Output
  186. * coefficients can be up to 16*Q larger than input coefficients.
  187. *
  188. * Arguments: - polyveck *v: pointer to input/output vector
  189. **************************************************/
  190. void PQCLEAN_DILITHIUM2_CLEAN_polyveck_ntt(polyveck *v) {
  191. for (size_t i = 0; i < K; ++i) {
  192. PQCLEAN_DILITHIUM2_CLEAN_poly_ntt(&v->vec[i]);
  193. }
  194. }
  195. /*************************************************
  196. * Name: PQCLEAN_DILITHIUM2_CLEAN_polyveck_invntt_montgomery
  197. *
  198. * Description: Inverse NTT and multiplication by 2^{32} of polynomials
  199. * in vector of length K. Input coefficients need to be less
  200. * than 2*Q.
  201. *
  202. * Arguments: - polyveck *v: pointer to input/output vector
  203. **************************************************/
  204. void PQCLEAN_DILITHIUM2_CLEAN_polyveck_invntt_montgomery(polyveck *v) {
  205. for (size_t i = 0; i < K; ++i) {
  206. PQCLEAN_DILITHIUM2_CLEAN_poly_invntt_montgomery(&v->vec[i]);
  207. }
  208. }
  209. /*************************************************
  210. * Name: PQCLEAN_DILITHIUM2_CLEAN_polyveck_chknorm
  211. *
  212. * Description: Check infinity norm of polynomials in vector of length K.
  213. * Assumes input coefficients to be standard representatives.
  214. *
  215. * Arguments: - const polyveck *v: pointer to vector
  216. * - uint32_t B: norm bound
  217. *
  218. * Returns 0 if norm of all polynomials are strictly smaller than B and 1
  219. * otherwise.
  220. **************************************************/
  221. int PQCLEAN_DILITHIUM2_CLEAN_polyveck_chknorm(const polyveck *v, uint32_t B) {
  222. for (size_t i = 0; i < K; ++i) {
  223. if (PQCLEAN_DILITHIUM2_CLEAN_poly_chknorm(&v->vec[i], B)) {
  224. return 1;
  225. }
  226. }
  227. return 0;
  228. }
  229. /*************************************************
  230. * Name: PQCLEAN_DILITHIUM2_CLEAN_polyveck_power2round
  231. *
  232. * Description: For all coefficients a of polynomials in vector of length K,
  233. * compute a0, a1 such that a mod Q = a1*2^D + a0
  234. * with -2^{D-1} < a0 <= 2^{D-1}. Assumes coefficients to be
  235. * standard representatives.
  236. *
  237. * Arguments: - polyveck *v1: pointer to output vector of polynomials with
  238. * coefficients a1
  239. * - polyveck *v0: pointer to output vector of polynomials with
  240. * coefficients Q + a0
  241. * - const polyveck *v: pointer to input vector
  242. **************************************************/
  243. void PQCLEAN_DILITHIUM2_CLEAN_polyveck_power2round(
  244. polyveck *v1, polyveck *v0, const polyveck *v) {
  245. for (size_t i = 0; i < K; ++i) {
  246. PQCLEAN_DILITHIUM2_CLEAN_poly_power2round(&v1->vec[i], &v0->vec[i], &v->vec[i]);
  247. }
  248. }
  249. /*************************************************
  250. * Name: PQCLEAN_DILITHIUM2_CLEAN_polyveck_decompose
  251. *
  252. * Description: For all coefficients a of polynomials in vector of length K,
  253. * compute high and low bits a0, a1 such a mod Q = a1*ALPHA + a0
  254. * with -ALPHA/2 < a0 <= ALPHA/2 except a1 = (Q-1)/ALPHA where we
  255. * set a1 = 0 and -ALPHA/2 <= a0 = a mod Q - Q < 0.
  256. * Assumes coefficients to be standard representatives.
  257. *
  258. * Arguments: - polyveck *v1: pointer to output vector of polynomials with
  259. * coefficients a1
  260. * - polyveck *v0: pointer to output vector of polynomials with
  261. * coefficients Q + a0
  262. * - const polyveck *v: pointer to input vector
  263. **************************************************/
  264. void PQCLEAN_DILITHIUM2_CLEAN_polyveck_decompose(
  265. polyveck *v1, polyveck *v0, const polyveck *v) {
  266. for (size_t i = 0; i < K; ++i) {
  267. PQCLEAN_DILITHIUM2_CLEAN_poly_decompose(&v1->vec[i], &v0->vec[i], &v->vec[i]);
  268. }
  269. }
  270. /*************************************************
  271. * Name: PQCLEAN_DILITHIUM2_CLEAN_polyveck_make_hint
  272. *
  273. * Description: Compute hint vector.
  274. *
  275. * Arguments: - polyveck *h: pointer to output vector
  276. * - const polyveck *v0: pointer to low part of input vector
  277. * - const polyveck *v1: pointer to high part of input vector
  278. *
  279. * Returns number of 1 bits.
  280. **************************************************/
  281. uint32_t PQCLEAN_DILITHIUM2_CLEAN_polyveck_make_hint(
  282. polyveck *h,
  283. const polyveck *v0,
  284. const polyveck *v1) {
  285. uint32_t s = 0;
  286. for (size_t i = 0; i < K; ++i) {
  287. s += PQCLEAN_DILITHIUM2_CLEAN_poly_make_hint(
  288. &h->vec[i], &v0->vec[i], &v1->vec[i]);
  289. }
  290. return s;
  291. }
  292. /*************************************************
  293. * Name: PQCLEAN_DILITHIUM2_CLEAN_polyveck_use_hint
  294. *
  295. * Description: Use hint vector to correct the high bits of input vector.
  296. *
  297. * Arguments: - polyveck *w: pointer to output vector of polynomials with
  298. * corrected high bits
  299. * - const polyveck *v: pointer to input vector
  300. * - const polyveck *h: pointer to input hint vector
  301. **************************************************/
  302. void PQCLEAN_DILITHIUM2_CLEAN_polyveck_use_hint(
  303. polyveck *w, const polyveck *v, const polyveck *h) {
  304. for (size_t i = 0; i < K; ++i) {
  305. PQCLEAN_DILITHIUM2_CLEAN_poly_use_hint(
  306. &w->vec[i], &v->vec[i], &h->vec[i]);
  307. }
  308. }