#include <util/h5_util.h>

#include "./cl_bert_dn_lrm_pefs_loader.h"

namespace npeff {
namespace inputs {


DnLrmPefs load_cl_bert_dn_lrm_pefs(
    const std::string& filepath,
    const ClBertDnLrmPefLoadOptions options
) {
    DnLrmPefs ret;
    hid_t file = H5Fopen(filepath.c_str(), H5F_ACC_RDONLY, H5P_DEFAULT);

    ret.pefs = util::h5::read_dataset_to_3_tensor<float>(
        file, "data/pefs", options.n_examples, options.examples_offset);

    ret.pef_frobenius_norms = util::h5::read_dataset_to_matrix<float>(
        file, "data/pef_frobenius_norms", options.n_examples, options.examples_offset);

    H5Fclose(file);
    return ret;
}


}  // inputs
}  // npeff
