#pragma once

#include <vector>

#include <containers/dense_matrix.h>
#include <inputs/dn_pefs/dn_lrm_pefs.h>

namespace npeff {
namespace preprocessing {


// Partitions the matrix by contiguous chunks of columns. There will be
// n_partitions in total. Each partition should have the same number of
// columns. If n_partitions does not evenly divide the number of columns,
// then the last partition will have extra columns.
// 
// Each partition matrix will have shape [n_classes * n_examples, partition_size].
// 
// The pefs.pefs 3-tensor will have its array's memory released when calling this function.
// The pointer to the 3-tensor itself will still be valid though (ignoring its data of course).
std::vector<std::unique_ptr<DenseMatrix<float>>>
construct_dn_pefs_partition_matrices(inputs::DnLrmPefs& pefs, int64_t n_partitions);


}  // preprocessing
}  // npeff
