Program Listing for File QuadtreePolarEuclid.hpp

Return to documentation for file (include/networkit/generators/quadtree/QuadtreePolarEuclid.hpp)

/*
 * Quadtree.hpp
 *
 *  Created on: 21.05.2014
 *      Author: Moritz v. Looz
 */

#ifndef NETWORKIT_GENERATORS_QUADTREE_QUADTREE_POLAR_EUCLID_HPP_
#define NETWORKIT_GENERATORS_QUADTREE_QUADTREE_POLAR_EUCLID_HPP_

#include <cmath>
#include <memory>
#include <omp.h>
#include <vector>

#include <networkit/generators/quadtree/QuadNodePolarEuclid.hpp>

namespace NetworKit {

template <class T>
class QuadtreePolarEuclid final {
    friend class QuadTreePolarEuclidGTest;

public:
    QuadtreePolarEuclid() {
        root = QuadNodePolarEuclid<T>();
        this->maxRadius = 1;
    }

    QuadtreePolarEuclid(double maxR, bool theoreticalSplit = false, double alpha = 1,
                        count capacity = 1000, double balance = 0.5) {
        root = QuadNodePolarEuclid<T>(0, 0, 2 * PI, maxR, capacity, 0, theoreticalSplit, alpha,
                                      balance);
        this->maxRadius = maxR;
    }

    QuadtreePolarEuclid(const vector<double> &angles, const vector<double> &radii,
                        const vector<T> &content, bool theoreticalSplit = false,
                        count capacity = 1000, double balance = 0.5) {
        const count n = angles.size();
        assert(angles.size() == radii.size());
        assert(radii.size() == content.size());
        maxRadius = 0;
        for (double radius : radii) {
            if (radius > maxRadius)
                maxRadius = radius;
        }
        maxRadius = std::nextafter(maxRadius, std::numeric_limits<double>::max());
        root = QuadNodePolarEuclid<T>(0, 0, 2 * PI, maxRadius, capacity, theoreticalSplit, balance);
        for (index i = 0; i < n; i++) {
            assert(content[i] < n);
            root.addContent(content[i], angles[i], radii[i]);
        }
    }

    void addContent(T newcomer, double angle, double r) { root.addContent(newcomer, angle, r); }

    bool removeContent(T toRemove, double angle, double r) {
        return root.removeContent(toRemove, angle, r);
    }

    vector<T> getElements() const { return root.getElements(); }

    void extractCoordinates(vector<double> &anglesContainer, vector<double> &radiiContainer) const {
        root.getCoordinates(anglesContainer, radiiContainer);
    }

    void getElementsInEuclideanCircle(const Point2DWithIndex<double> circleCenter,
                                      const double radius, vector<T> &circleDenizens) const {
        root.getElementsInEuclideanCircle(circleCenter, radius, false, circleDenizens);
    }

    count getElementsProbabilistically(Point2DWithIndex<double> euQuery,
                                       std::function<double(double)> prob,
                                       vector<T> &circleDenizens) {
        return root.getElementsProbabilistically(euQuery, prob, false, circleDenizens);
    }

    count getElementsProbabilistically(Point2DWithIndex<double> euQuery,
                                       std::function<double(double)> prob, bool suppressLeft,
                                       vector<T> &circleDenizens) {
        return root.getElementsProbabilistically(euQuery, prob, suppressLeft, circleDenizens);
    }

    void recount() { root.recount(); }

    count size() const { return root.size(); }

    count height() const { return root.height(); }

    count countLeaves() const { return root.countLeaves(); }

    index indexSubtree(index nextID) { return root.indexSubtree(nextID); }

    index getCellID(double phi, double r) const { return root.getCellID(phi, r); }

    double getMaxRadius() const { return maxRadius; }

    void reindex() {
#pragma omp parallel
        {
#pragma omp single nowait
            { root.reindex(0); }
        }
    }

    void trim() { root.trim(); }

private:
    QuadNodePolarEuclid<T> root;
    double maxRadius;
};
} // namespace NetworKit

#endif // NETWORKIT_GENERATORS_QUADTREE_QUADTREE_POLAR_EUCLID_HPP_