Bug fix: deserializing the tunernumber ...
[satune.git] / src / Tuner / multituner.h
1 #ifndef MULTITUNER_H
2 #define MULTITUNER_H
3 #include "classlist.h"
4 #include "structs.h"
5
6 #define AUTOTUNERFACTOR 0.3
7
8 class Problem {
9 public:
10         Problem(const char *problem);
11         char *getProblem() {return problem;}
12         ~Problem();
13         CMEMALLOC;
14 private:
15         int problemnumber;
16         int result;
17         char *problem;
18         long long besttime;
19         friend class MultiTuner;
20 };
21
22 class TunerRecord {
23 public:
24         TunerRecord(SearchTuner *_tuner) : tuner(_tuner), tunernumber(-1) {}
25         TunerRecord(SearchTuner *_tuner, int _tunernumber) : tuner(_tuner), tunernumber(_tunernumber) {}
26         SearchTuner *getTuner() {return tuner;}
27         TunerRecord *changeTuner(SearchTuner *_newtuner);
28         void updateTuner(SearchTuner *_newtuner) {tuner = _newtuner;}
29         long long getTime(Problem *problem);
30         void setTime(Problem *problem, long long time);
31 private:
32         SearchTuner *tuner;
33         Vector<Problem *> problems;
34         Hashtable<Problem *, long long, uint64_t> timetaken;
35         int tunernumber;
36         friend class MultiTuner;
37         friend void clearVector(Vector<TunerRecord *> *tunerV);
38 };
39
40 class MultiTuner {
41 public:
42         MultiTuner(uint budget, uint rounds, uint timeout);
43         ~MultiTuner();
44         void addProblem(const char *filename);
45         void addTuner(SearchTuner *tuner);
46         void readData(uint numRuns);
47         void updateTimeout(Problem *problem, long long metric);
48         void tuneK();
49         void tuneComp();
50         void printData();
51         void findBestThreeTuners();
52         CMEMALLOC;
53 protected:
54         long long evaluate(Problem *problem, TunerRecord *tuner);
55         double evaluateAll(TunerRecord *tuner);
56         SearchTuner *mutateTuner(SearchTuner *oldTuner, uint k);
57         void mapProblemsToTuners(Vector<TunerRecord *> *tunerV);
58         void improveTuners(Vector<TunerRecord *> *tunerV);
59         TunerRecord *tune(TunerRecord *tuner);
60         Vector<TunerRecord *> allTuners;
61         Vector<Problem *> problems;
62         Vector<TunerRecord *> tuners;
63         uint budget;
64         uint rounds;
65         uint timeout;
66         int execnum;
67 };
68
69 inline long long min(long long num1, long long num2, long long num3) {
70         return num1 < num2 && num1 < num3 ? num1 :
71                                  num2 < num3 ? num2 : num3;
72 }
73
74 #endif