#ifndef _INTERNAL_H_
#define _INTERNAL_H_

#include <stdint.h>
#include <stddef.h>

// Internal data structures used in enclave
struct Vector {
    size_t size;
    float* data;
};

struct VectorList {
    size_t count;
    Vector* vectors;
};

struct VectorListList {
    size_t count;
    VectorList* vectors_list;
};

struct Indices {
    size_t size;
    uint32_t* data;
};

struct IndicesList {
    size_t count;
    Indices* indices;
};


// Function declarations
void house_holder_cal_col(float* input, size_t batch_size, size_t seq_length, size_t hidden_size, const VectorList& vector_list);
void permutate_col(float* input, size_t batch_size, size_t seq_length, size_t hidden_size, const Indices& indices);

#endif /* !_INTERNAL_H_ */