#pragma once

#include <cstdint>
#include <memory>
#include <string>
#include <vector>

#include <inputs/dn_pefs/dn_lrm_pefs.h>

#include <factorizations/dn_lrm_factorization/config.h>


namespace npeff {
namespace factorizations {
namespace dn_lrm_factorization {


// Additional configuration for the run context.
struct AdditionalRunContextConfig {
    std::string output_filepath;
    int64_t n_preprocess_cpu_threads = 1;
    bool non_finite_norms_to_zeros = false;
};


struct RunContext {
    using FloatMatrixPtr = std::unique_ptr<npeff::DenseMatrix<float>>;

    std::string output_filepath;

    FactorizationConfig config;
    std::vector<FloatMatrixPtr> partitions;

    // Performs the actual run.
    void run();
};


// Note that this function can modify its inputs.
RunContext create_run_context(
    npeff::inputs::DnLrmPefs& pefs,
    FactorizationConfig& partial_config,
    AdditionalRunContextConfig& additional_config
);


}  // dn_lrm_factorization
}  // factorizations
}  // npeff
