//
// Created by Иван Ильин on 08.03.2021.
//

#ifndef ENGINE_SIMPLEX_H
#define ENGINE_SIMPLEX_H

#include "../utils/Point4D.h"

struct Simplex {
private:
    std::array<Point4D, 4> m_points{};
    unsigned m_size = 0;

public:
    Simplex() = default;

    Simplex& operator=(std::initializer_list<Point4D> list) {
        for (auto v = list.begin(); v != list.end(); v++) {
            m_points[std::distance(list.begin(), v)] = *v;
        }
        m_size = list.size();
        return *this;
    }

    void push_front(const Point4D& point) {
        m_points = { point, m_points[0], m_points[1], m_points[2] };
        m_size = std::min(m_size + 1, 4u);
    }

    Point4D& operator[](unsigned i) { return m_points[i]; }
    [[nodiscard]] unsigned size() const { return m_size; }

    [[nodiscard]] auto begin() const { return m_points.begin(); }
    [[nodiscard]] auto end()   const { return m_points.end() - (4 - m_size); }
};

#endif //INC_3DZAVR_SIMPLEX_H