#ifndef INTERNAL_POINT_H
#define INTERNAL_POINT_H

#include <header.hpp>



struct Internal_point
{
    double vec[constants::Dim];
    int point_index;
    int color;

    Internal_point() {}

    Internal_point(std::vector<double> & arr, int indx, int color)
    {
        this->point_index = indx;
       // this->vec = arr;
        //std::copy(arr ,constants::Dim ,this->vec);
        for (int i = 0; i < constants::Dim; i++)
        {
        vec[i] = arr[i];
        }
        this->color = color;
       // std::cout << "Candiate point " << arr[0] << " , " << arr[1] << std::endl;
        //std::cout << "Added point: " << vec[0] << " , " << vec[1] << " : " << indx << " : color : " << color << std::endl;
    }

    double coord(int i) const
    {
        return vec[i];
    }
    double& coord(int i)
    {
        return vec[i];
    }
    bool operator==(const Internal_point& p)
    {
        return point_index == p.point_index;
    }

    bool operator!=(const Internal_point& p)
    {
        return !(*this == p);
    }
    int returnPointIndx() const
    {
        return this->point_index;

    }
    int returnColor() const
    {
        return this->color;
    }

    //    virtual ~Internal_point() {}




};

#endif // INTERNAL_POINT_H
