#ifndef UTILS_H
#define UTILS_H

#include <immintrin.h>
#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>
#include <stdint.h>
#include <errno.h>

#define min(i, j) ((i) < (j) ? (i) : (j))

bool aligned(float *arr);

float * align_padding(float *x, int num, int dim, bool row_padding);

void free_array(float *arr);

float * malloc_align(int n);


typedef struct {
    int n_samples_chunk;
    int num;
    int n_chunks;
} OMP_CHUNK;

void init_chunk_par(OMP_CHUNK *C, int num, int CHUNK_SIZE);

int seg_arr(int *count, int n, int m, int *start_arr, int *end_arr, double *sum_arr);

void print_arr(float *a, int num, int dim, int pi, int pj);

void print_arr_int(int *a, int num, int dim, int pi, int pj);
void print_arr_double(double *a, int num, int dim, int pi, int pj);

void array_add_m256(float *a, float *b, float *c, int n);
#endif