#include "poly.h" void PQCLEAN_NTRUHPS40961229_CLEAN_poly_S3_tobytes(unsigned char msg[NTRU_PACK_TRINARY_BYTES], const poly *a) { int i; unsigned char c; int j; for (i = 0; i < NTRU_PACK_DEG / 5; i++) { c = a->coeffs[5 * i + 4] & 255; c = (3 * c + a->coeffs[5 * i + 3]) & 255; c = (3 * c + a->coeffs[5 * i + 2]) & 255; c = (3 * c + a->coeffs[5 * i + 1]) & 255; c = (3 * c + a->coeffs[5 * i + 0]) & 255; msg[i] = c; } i = NTRU_PACK_DEG / 5; c = 0; for (j = NTRU_PACK_DEG - (5 * i) - 1; j >= 0; j--) { c = (3 * c + a->coeffs[5 * i + j]) & 255; } msg[i] = c; } void PQCLEAN_NTRUHPS40961229_CLEAN_poly_S3_frombytes(poly *r, const unsigned char msg[NTRU_PACK_TRINARY_BYTES]) { int i; unsigned char c; int j; for (i = 0; i < NTRU_PACK_DEG / 5; i++) { c = msg[i]; r->coeffs[5 * i + 0] = c; r->coeffs[5 * i + 1] = c * 171 >> 9; // this is division by 3 r->coeffs[5 * i + 2] = c * 57 >> 9; // division by 3^2 r->coeffs[5 * i + 3] = c * 19 >> 9; // division by 3^3 r->coeffs[5 * i + 4] = c * 203 >> 14; // etc. } i = NTRU_PACK_DEG / 5; c = msg[i]; for (j = 0; (5 * i + j) < NTRU_PACK_DEG; j++) { r->coeffs[5 * i + j] = c; c = c * 171 >> 9; } r->coeffs[NTRU_N - 1] = 0; PQCLEAN_NTRUHPS40961229_CLEAN_poly_mod_3_Phi_n(r); }