﻿#include <iostream>
#include "header.h"
#include "utilities.h"

#include "clupig.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);

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

    clupig vbc(sParam.n_points, sParam.n_features);
    vbc.set_params(sParam.n_proj, sParam.topK, sParam.topM, sParam.topP, 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();
    int rangeMinPts = 10;
    float alpha = 2.0;
//    dbscan.test_sDbscan(MATRIX_X, sParam.eps, fRangeEps, sParam.minPts);

    for (int i = 0; i < 5; ++i)
    {
        float new_minPts = sParam.minPts + i * rangeMinPts;

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

    // For big data
    int minPts = 50;

    vbc.ceos2_dnp_from_file(dataset, minPts);




}

