#include "gr_vec.h"
#include "gr_mat.h"
int
gr_mat_concat_horizontal(gr_mat_t res, const gr_mat_t mat1, const gr_mat_t mat2, gr_ctx_t ctx)
{
int status = GR_SUCCESS;
slong i;
slong r1 = mat1->r;
slong c1 = mat1->c;
slong c2 = mat2->c;
slong sz = ctx->sizeof_elem;
if (mat1->r != mat2->r || res->r != mat1->r || res->c != mat1->c + mat2->c)
return GR_DOMAIN;
for (i = 0; i < r1; i++)
{
if (c1 > 0)
status |= _gr_vec_set(GR_MAT_ENTRY(res, i, 0, sz), GR_MAT_ENTRY(mat1, i, 0, sz), c1, ctx);
if (c2 > 0)
status |= _gr_vec_set(GR_MAT_ENTRY(res, i, c1, sz), GR_MAT_ENTRY(mat2, i, 0, sz), c2, ctx);
}
return status;
}