application.h 2.15 KB
Newer Older
Guolin Ke's avatar
Guolin Ke committed
1
2
3
4
5
6
7
#ifndef LIGHTGBM_APPLICATION_H_
#define LIGHTGBM_APPLICATION_H_

#include <LightGBM/meta.h>
#include <LightGBM/config.h>

#include <vector>
Guolin Ke's avatar
Guolin Ke committed
8
#include <memory>
Guolin Ke's avatar
Guolin Ke committed
9
10
11

namespace LightGBM {

Guolin Ke's avatar
Guolin Ke committed
12
class DatasetLoader;
Guolin Ke's avatar
Guolin Ke committed
13
14
15
16
17
18
class Dataset;
class Boosting;
class ObjectiveFunction;
class Metric;

/*!
Qiwei Ye's avatar
Qiwei Ye committed
19
* \brief The main entrance of LightGBM. this application has two tasks:
20
21
*        Train and Predict.
*        Train task will train a new model
zhangyafeikimi's avatar
zhangyafeikimi committed
22
23
*        Predict task will predict the scores of test data using exsisting model,
*        and save the score to disk.
Guolin Ke's avatar
Guolin Ke committed
24
25
26
27
28
29
30
31
*/
class Application {
public:
  Application(int argc, char** argv);

  /*! \brief Destructor */
  ~Application();

zhangyafeikimi's avatar
zhangyafeikimi committed
32
  /*! \brief To call this funciton to run application*/
Guolin Ke's avatar
Guolin Ke committed
33
34
35
36
  inline void Run();

private:

zhangyafeikimi's avatar
zhangyafeikimi committed
37
  /*! \brief Load parameters from command line and config file*/
Guolin Ke's avatar
Guolin Ke committed
38
39
40
41
42
  void LoadParameters(int argc, char** argv);

  /*! \brief Load data, including training data and validation data*/
  void LoadData();

Qiwei Ye's avatar
Qiwei Ye committed
43
  /*! \brief Initialization before training*/
Guolin Ke's avatar
Guolin Ke committed
44
45
  void InitTrain();

Qiwei Ye's avatar
Qiwei Ye committed
46
  /*! \brief Main Training logic */
Guolin Ke's avatar
Guolin Ke committed
47
48
  void Train();

Qiwei Ye's avatar
Qiwei Ye committed
49
  /*! \brief Initializations before prediction */
Guolin Ke's avatar
Guolin Ke committed
50
51
  void InitPredict();

Qiwei Ye's avatar
Qiwei Ye committed
52
  /*! \brief Main predicting logic */
Guolin Ke's avatar
Guolin Ke committed
53
54
  void Predict();

55
56
57
  /*! \brief Main Convert model logic */
  void ConvertModel();

Guolin Ke's avatar
Guolin Ke committed
58
59
60
  /*! \brief All configs */
  OverallConfig config_;
  /*! \brief Training data */
Guolin Ke's avatar
Guolin Ke committed
61
  std::unique_ptr<Dataset> train_data_;
Guolin Ke's avatar
Guolin Ke committed
62
  /*! \brief Validation data */
Guolin Ke's avatar
Guolin Ke committed
63
  std::vector<std::unique_ptr<Dataset>> valid_datas_;
Guolin Ke's avatar
Guolin Ke committed
64
  /*! \brief Metric for training data */
Guolin Ke's avatar
Guolin Ke committed
65
  std::vector<std::unique_ptr<Metric>> train_metric_;
Guolin Ke's avatar
Guolin Ke committed
66
  /*! \brief Metrics for validation data */
Guolin Ke's avatar
Guolin Ke committed
67
  std::vector<std::vector<std::unique_ptr<Metric>>> valid_metrics_;
Guolin Ke's avatar
Guolin Ke committed
68
  /*! \brief Boosting object */
Guolin Ke's avatar
Guolin Ke committed
69
  std::unique_ptr<Boosting> boosting_;
Guolin Ke's avatar
Guolin Ke committed
70
  /*! \brief Training objective function */
Guolin Ke's avatar
Guolin Ke committed
71
  std::unique_ptr<ObjectiveFunction> objective_fun_;
Guolin Ke's avatar
Guolin Ke committed
72
73
74
75
};


inline void Application::Run() {
76
  if (config_.task_type == TaskType::kPredict || config_.task_type == TaskType::KRefitTree) {
Guolin Ke's avatar
Guolin Ke committed
77
78
    InitPredict();
    Predict();
79
80
  } else if (config_.task_type == TaskType::kConvertModel) {
    ConvertModel();
Guolin Ke's avatar
Guolin Ke committed
81
82
83
84
85
86
87
88
  } else {
    InitTrain();
    Train();
  }
}

}  // namespace LightGBM

Guolin Ke's avatar
Guolin Ke committed
89
#endif   // LightGBM_APPLICATION_H_