#pragma once

#include <vector>

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

namespace npeff {
namespace preprocessing {


// Partitions the dense LRM-PEFs by contiguous chunks of examples. There will be
// n_partitions in total. Each partition should have the same number of
// examples. If n_partitions does not evenly divide the number of examples,
// then the last partition will have extra examples.
// 
// NOTE: The returned partitions will just be views on the memory associated to the
// arrays backing the pefs and norms. Hence the memory associated to the input `pefs`
// must NOT be released as long as we are to use the data pointers associated to the
// pefs and norms of the partitions.
std::vector<std::unique_ptr<inputs::DnLrmPefsPartition>>
construct_dn_lrm_pefs_datawise_partitions(const inputs::DnLrmPefs& pefs, int64_t n_partitions);


}  // preprocessing
}  // npeff
