/* CAO Compiler
Copyright (C) 2014 Cryptography and Information Security Group, HASLab - INESC TEC and Universidade do Minho
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see . */
#ifndef CAO_MATRIX_H
#define CAO_MATRIX_H
#include "CAO_globals.h"
#include "CAO_globalOp.h"
#ifdef __cplusplus
#include
#include
NTL_CLIENT
typedef struct CAO_matrix_s {
int rows;
int cols;
char type;
CAO_REF *value;
} CAO_matrix_s;
extern "C" {
#endif
CAO_RES CAO_matrix_decl(CAO_matrix *, CAO_rint, CAO_rint, const char *, void **);
CAO_RES _CAO_matrix_decl(CAO_matrix *, CAO_rint, CAO_rint, const char *, void **, int *);
CAO_RES CAO_matrix_dispose(CAO_matrix);
CAO_RES CAO_matrix_const_init(CAO_matrix, void *);
CAO_RES CAO_matrix_init(CAO_matrix, void **);
CAO_RES _CAO_matrix_init(CAO_matrix, void **, int *);
CAO_RES CAO_matrix_assign(CAO_matrix, CAO_matrix);
CAO_RES CAO_matrix_clone(CAO_matrix *, CAO_matrix);
CAO_REF CAO_matrix_ref(CAO_matrix, CAO_rint, CAO_rint);
CAO_REF _CAO_matrix_ref(CAO_matrix, CAO_rint, CAO_rint, char *);
CAO_RES CAO_matrix_dump(CAO_matrix);
#define CAO_matrix_equal(a,b,c) a = _CAO_matrix_equal(b,c)
CAO_bool _CAO_matrix_equal(CAO_matrix, CAO_matrix);
CAO_RES CAO_matrix_select(CAO_REF, CAO_matrix, CAO_rint, CAO_rint);
CAO_RES CAO_matrix_range_select(CAO_matrix, CAO_matrix, CAO_rint, CAO_rint, CAO_rint, CAO_rint);
CAO_RES CAO_matrix_range_set(CAO_matrix, CAO_matrix, CAO_rint, CAO_rint, CAO_rint, CAO_rint);
CAO_RES CAO_matrix_row_range_select(CAO_matrix r, CAO_matrix m, CAO_rint c, CAO_rint ri, CAO_rint rj);
CAO_RES CAO_matrix_col_range_select (CAO_matrix r, CAO_matrix m, CAO_rint row, CAO_rint ci, CAO_rint cj);
CAO_RES CAO_matrix_row_range_set (CAO_matrix r, CAO_matrix m, CAO_rint c, CAO_rint ri, CAO_rint rj);
CAO_RES CAO_matrix_col_range_set (CAO_matrix r, CAO_matrix m, CAO_rint row, CAO_rint ci, CAO_rint cj);
CAO_RES CAO_matrix_addTo (CAO_matrix r, CAO_matrix m8);
CAO_RES CAO_matrix_add (CAO_matrix r, CAO_matrix a, CAO_matrix b);
CAO_RES CAO_matrix_subTo (CAO_matrix r, CAO_matrix m);
CAO_RES CAO_matrix_sub (CAO_matrix r, CAO_matrix a, CAO_matrix b);
CAO_RES CAO_matrix_sym (CAO_matrix r, CAO_matrix m);
CAO_RES CAO_matrix_mul (CAO_matrix r, CAO_matrix a, CAO_matrix b);
CAO_RES CAO_matrix_assign_zero (CAO_matrix);
CAO_RES CAO_matrix_assign_one (CAO_matrix);
CAO_RES CAO_matrix_pow (CAO_matrix r, CAO_matrix m, CAO_int n);
CAO_RES CAO_matrix_cast_matrix (CAO_matrix, CAO_matrix);
#ifdef __cplusplus
}
#endif
#endif