forked from iss4e/Robust_Sizing
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcommon.h
58 lines (39 loc) · 1.32 KB
/
common.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
51
52
53
54
55
56
57
58
// common.h
#ifndef COMMON_H
#define COMMON_H
#include <vector>
using namespace std;
// INPUTS
extern double B_inv; // cost per cell
extern double PV_inv; // cost per unit (kW) of PV
extern double epsilon;
extern double confidence;
extern int metric;
extern int days_in_chunk;
extern vector<double> load;
extern vector<double> solar;
// define the upper and lower values to test for battery cells and pv,
// as well as the step size of the search
extern double cells_min;
extern double cells_max;
extern double cells_step; // search in step of x cells
extern double pv_min;
extern double pv_max;
extern double pv_step; // search in steps of x kW
// CONSTANTS
// defines the number of samples, set via command line input
int static number_of_chunks = 100;
double static T_u = 1.0; // this is the time unit, representing the number of hours in each time slot of the load and solar traces
double static kWh_in_one_cell = 0.011284;
double static num_cells_steps = 400; // search in total of n steps for cells
double static num_pv_steps = 350; // search in total of n steps for pv
struct SimulationResult {
double B;
double C;
double cost;
SimulationResult(double B_val, double C_val, double cost_val) :
B(B_val), C(C_val), cost(cost_val) {}
};
vector<double> read_data_from_file(string);
int process_input(char**, bool);
#endif