-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPointDataGenerator.h
32 lines (26 loc) · 1.04 KB
/
PointDataGenerator.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
//
// Created by rkindela on 27-05-18.
//
#ifndef PMTOOL_POINTDATAGENERATOR_H
#define PMTOOL_POINTDATAGENERATOR_H
#include "PointRepository.h"
#include "utils.h"
class PointDataGenerator {
protected:
std::vector<POINT*> generateOnHullPoints(int radius, int hullSize);
std::vector<POINT*> generateInsideHullPoints(int radius, int insideAmount);
int maximum;
int dimension;
public:
PointDataGenerator(int max = MAX_VALUE, int dim = 2):maximum(max), dimension(dim){};
int randomInt(int min, int max);
POINT* randomPoint(int min, int max);
void randomPointCloud(int pointCount);
void randomPointGrid(int pointCountDegree);
void randomPointCloudWithPercentInside(int pointCount, float percent);
void randomPointCloudWithPercentOnHull(int pointCount, float percent);
void randomPointCloudWithPercentOn3DHull(int pointCount, float percent);
vector<int>* getRandomPermutation(const vector<int>& pointCloud, int exceptionPoint);
inline int getMaximum() {return maximum;}
};
#endif //PMTOOL_POINTDATAGENERATOR_H