﻿#include <iostream>
#include "Header.h"
#include "Utilities.h"

#include "FalconnLite.h"

#include <time.h> // for time(0) to generate different random number
#include <stdlib.h>
#include <sys/time.h> // for gettimeofday
#include <stdio.h>
#include <unistd.h>

#include <omp.h>

int main(int nargs, char** args)
{
    srand(time(NULL)); // should only be called once for random generator

//    cout << "RAM before loading data" << endl;
//    getRAM();

    /************************************************************************/
//	int iType = loadInput(nargs, args);

    FalconnLiteParam sParam;
    readParam(nargs, args, sParam);

//    FalconnLite falconn(sParam.n_points, sParam.n_features);
//    falconn.set_params(sParam.n_proj, sParam.iProbe, sParam.bucketLimit, sParam.qProbe, sParam.distance, sParam.ker_n_features,
//                     sParam.ker_sigma, sParam.ker_intervalSampling, sParam.verbose, sParam.n_threads, sParam.seed, sParam.output);

    // Read data
    string dataset = "";
    for (int i = 1; i < nargs; i++) {
        if (strcmp(args[i], "--dataset") == 0) {
            dataset = args[i + 1]; // convert char* to string
            break;
        }
    }
    if (dataset == "") {
        cerr << "Error: Data file does not exist !" << endl;
        exit(1);
    }

    RowMajorMatrixXf MATRIX_X;
    loadtxtData(dataset, sParam.distance, sParam.n_points, sParam.n_features, MATRIX_X);

    // Saving memory
//    loadtxtData(dataset, sParam.distance, sParam.n_points, sParam.n_features, dbscan.matrix_X);

    chrono::steady_clock::time_point begin, end;
    begin = chrono::steady_clock::now();


    // falconn.clear();

    begin = chrono::steady_clock::now();
    // falconn.fit_sVDC(MATRIX_X, new_minPts); // need to reset baseEps
    end = chrono::steady_clock::now();
    cout << "Method Wall Clock = " << chrono::duration_cast<chrono::milliseconds>(end - begin).count() << "[ms]" << endl;






}

