This repository was archived by the owner on Mar 26, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathverts.hpp
More file actions
61 lines (53 loc) · 1.27 KB
/
verts.hpp
File metadata and controls
61 lines (53 loc) · 1.27 KB
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
56
57
58
59
60
61
#ifndef MY_HEADER_HPP
#define MY_HEADER_HPP
#include <stdio.h>
#include <iostream>
template<typename T, unsigned int N>
struct Vert {
public:
T &operator[](std::size_t idx) { return data[idx]; }
T data[N];
};
template<>
struct Vert<float, 3> {
public:
float &operator[](std::size_t idx) { return data[idx]; }
float data[3] = {0.0f, 0.0f, 0.0f};
};
template<>
struct Vert<float, 6> {
public:
float &operator[](std::size_t idx) { return data[idx]; }
float data[6] = {0.0f, 0.0f, 0.0f, 1.0f, 1.0f, 1.0f};
};
template<typename T, unsigned int N>
std::ostream &operator<< (std::ostream &os, const Vert<T,N> &m) {
for (int i = 0; i < N-1; ++i) {
os << m.data[i] << ' ';
}
os << m.data[N-1];
return os;
}
template<typename T, unsigned int N>
void maximum(std::vector<Vert<T,N>> list, Vert<T,N> &max) {
max = list[0];
for (int i = 0; i < N-1; ++i) {
for(int j = 0; j < list.size(); ++j) {
if(list[j][i] > max[i]) {
max[i] = list[j][i];
}
}
}
}
template<typename T, unsigned int N>
void minimum(std::vector<Vert<T,N>> list, Vert<T,N> &min) {
min = list[0];
for (int i = 0; i < N-1; ++i) {
for(int j = 0; j < list.size(); ++j) {
if(list[j][i] < min[i]) {
min[i] = list[j][i];
}
}
}
}
#endif