#pragma once
// A collections of partitions of the W matrix on the host, split across
// the examples dimension.

#include <memory>
#include <vector>

#include <containers/dense_matrix.h>


namespace npeff {
namespace outputs {


class WPartitions {
    using DenseMatrixPtr = std::unique_ptr<npeff::DenseMatrix<float>>;
    
    // These are column-major and each has the shape [n_partition_examples, npeff_rank].
    std::vector<DenseMatrixPtr> partitions;

public:
    WPartitions(std::vector<DenseMatrixPtr> partitions) :
        partitions(std::move(partitions))
    {}

    // Will clear the memories associated to the partition matrices.
    DenseMatrixPtr get_full_row_major_W();

private:
    int64_t compute_n_examples_total() const;
    int64_t compute_rank() const;
        
};


}  // outputs
}  // npeff
