-
Notifications
You must be signed in to change notification settings - Fork 1
/
Market.h
50 lines (50 loc) · 1.69 KB
/
Market.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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
#ifndef MARKET_H
#define MARKET_H
#include <string>
#include <random>
#include <ctime>
#include <algorithm>
#include <cstdlib>
#include <cmath>
#include <algorithm>
class Market {
private:
//Member variables listing different market dynmaics
double price;
double volatility;
std::mt19937 gen;
std::normal_distribution<> d;
double overallTrend;
public:
//Gets current price
Market() : price(100), volatility(0.02), gen(std::random_device{}()), d(0, 1), overallTrend(0) {}
//Gets current price
double getPrice() {
double drift = 0.0001 + overallTrend;
price *= std::exp((drift - 0.5 * volatility * volatility) + volatility * d(gen));
return price;
}
//Sets market volatility
void setVolatility(double vol) { volatility = vol; }
//Gets market volatility
double getVolatility() const { return volatility; }
//Adjusts volatility according to market events
void adjustVolatility(const std::string& marketEvent) {
if (marketEvent.find("uncertainty") != std::string::npos) {
volatility *= 1.2;
} else if (marketEvent.find("bull market") != std::string::npos) {
volatility *= 0.9;
}
volatility = std::min(std::max(volatility, 0.01), 0.05);
}
//Adjusts overall trend according to market events
void adjustOverallTrend(const std::string& marketEvent) {
if (marketEvent.find("bull market") != std::string::npos) {
overallTrend += 0.0002;
} else if (marketEvent.find("market downturn") != std::string::npos) {
overallTrend -= 0.0002;
}
overallTrend = std::min(std::max(overallTrend, -0.001), 0.001);
}
};
#endif //MARKET_H