-
Notifications
You must be signed in to change notification settings - Fork 8
/
Util.hpp
80 lines (64 loc) · 1.95 KB
/
Util.hpp
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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
#ifndef UTIL_H
#define UTIL_H
#include <algorithm>
#include <list>
#include <set>
#include <string>
#include <vector>
#include <map>
namespace springLegacyAI {
class IAICallback;
}
namespace util {
std::string GetAbsFileName(IAICallback*, const std::string&, bool readonly = false);
void SanitizeFileNameInPlace(std::string&);
void StringToLowerInPlace(std::string&);
std::string StringToLower(std::string);
std::string StringStripSpaces(const std::string&);
/**
* Removes all white space chars in the supplied string.
* @param s to clean string
*/
void RemoveWhiteSpaceInPlace(std::string& s);
std::string IntToString(int i, const std::string& format = "%i");
void StringSplit(const std::string& src, char splitter, std::vector<std::string>& dest, bool empty = true);
bool StringContainsChar(const std::string& src, const char c);
float WeightedAverage(std::list<float>&, std::list<float>&);
float GaussDens(float, float mu = 0.0f, float sigma = 1.0f);
unsigned int CountOneBits(unsigned int n);
/**
* Determines if A is a binary subset of B
*
* @param unsigned, binary mask A
* @param unsigned, binary mask B
* @return bool, A \subseteq B
*/
bool IsBinarySubset(unsigned A, unsigned B);
template<class T>
std::set<T> IntersectSets(const std::set<T>& s1, const std::set<T>& s2) {
std::set<T> r;
typename std::set<T>::const_iterator sit;
for (sit = s1.begin(); sit != s1.end(); sit++) {
if (s2.find(*sit) != s2.end()) {
r.insert(*sit);
}
}
return r;
}
template<class T>
std::set<T> UnionSets(const std::set<T>& s1, const std::set<T>& s2) {
std::set<T> r;
r.insert(s1.begin(), s1.end());
r.insert(s2.begin(), s2.end());
return r;
}
template <class Key, class T>
void GetShuffledKeys(std::vector<Key> &out, std::map<Key, T> &in) {
typename std::map<Key, T>::iterator it;
for (it = in.begin(); it != in.end(); it++) {
out.push_back(it->first);
}
std::random_shuffle(out.begin(), out.end());
}
}
#endif