-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathHeader.cpp
55 lines (53 loc) · 1.49 KB
/
Header.cpp
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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
//
// Header.cpp
// cppransac
//
// Created by ललित सिंह on 09/11/2016.
// Copyright © 2016 ललित सिंह. All rights reserved.
//
#include "Header.hpp"
#include <math.h>
double sqr(double a){
return a*a;
}
double abs(double a){
if (a<0)
return -1* a;
else
return a;
}
double distance(mypoint2f a, mypoint2f b){
return sqrt( sqr(a.getx()- b.getx()) + sqr(a.gety()- b.gety()));
}
double determinant(double a11, double a12, double a21, double a22){
return a11 * a22 - a12 * a21;
}
internsectionPoint solveLinearEquation(LinearEqu a, LinearEqu b){
double den = determinant(a.getA(), a.getB(), b.getA(), b.getB());
internsectionPoint result;
if ( den == 0){
result.doesIntersect = true;
return result;
}
double x = determinant(a.getC(), a.getB(), b.getC(), b.getB());
double y = determinant(a.getA(), a.getC(), b.getA(), b.getC());
result.point = mypoint2f(x/den, y/den);
result.doesIntersect = false;
return result;
}
std::vector<mypoint2f> compliment(std::vector<mypoint2f> set, std::vector<mypoint2f> subset ){
std::vector<mypoint2f> complimentset;
for(int i = 0; i<set.size();i++){
bool check = false;
for (int j = 0 ; j< subset.size(); j++){
if (set[i]==subset[j]){
check = true;
break;
}
}
if (!check){
complimentset.push_back(set[i]);
}
}
return complimentset;
}