#ifndef BIPARTIE_GRAPH_H
#define BIPARTIE_GRAPH_H


class Bipartie_Graph
{
public:

    virtual ~Bipartie_Graph() {}

    Bipartie_Graph(std::vector<std::vector<double>> & distMatrixx):distMatrix(distMatrixx)
    {


    }
    double distance(int i, int j) const
    {
        return distMatrix[i][j];
//        double maxx = 0;
//
//        for (int k = 0 ; k < constants::Dim; k++)
//        {
//            maxx = std::max(maxx,std::abs(u[i].coord(k)-v[j].coord(k)));
//
//        }
//        return maxx;

    }
//    Internal_point getVPoint(int indxV) const
//    {
//        return v[indxV];
//    }
//    Internal_point getUPoint(int indxU) const
//    {
//        return u[indxU];

    inline int size() const
    {
        return distMatrix[0].size();
        //  return static_cast<int> (u.size() + v.size());
    }

    inline std::vector<double> sorted_distances() const
    {

        std::vector<double> distances;
        distances.push_back(0.);  // for empty diagrams
        for (int i = 0; i < distMatrix.size(); i++)
        {
            //distances.push_back(distance(u_point_index, corresponding_point_in_v(u_point_index)));
            for (int j = 0; j < distMatrix[0].size();j++)
                {
                distances.push_back(distance(i,j));
                }
        }
//#ifdef GUDHI_USE_TBB
//       tbb::parallel_sort(distances.begin(), distances.end());
//#else
        std::sort(distances.begin(), distances.end());
//#endif
        return distances;
    }

protected:

private:
std::vector<std::vector<double>> distMatrix;
};

#endif // BIPARTIE_GRAPH_H
