/*! * Copyright (c) 2016 Microsoft Corporation. All rights reserved. * Licensed under the MIT License. See LICENSE file in the project root for license information. */ #ifndef LIGHTGBM_OBJECTIVE_FUNCTION_H_ #define LIGHTGBM_OBJECTIVE_FUNCTION_H_ #include #include #include #include #include namespace LightGBM { /*! * \brief The interface of Objective Function. */ class ObjectiveFunction { public: /*! \brief virtual destructor */ virtual ~ObjectiveFunction() {} /*! * \brief Initialize * \param metadata Label data * \param num_data Number of data */ virtual void Init(const Metadata& metadata, data_size_t num_data) = 0; /*! * \brief calculating first order derivative of loss function * \param score prediction score in this round * \gradients Output gradients * \hessians Output hessians */ virtual void GetGradients(const double* score, score_t* gradients, score_t* hessians) const = 0; virtual const char* GetName() const = 0; virtual bool IsConstantHessian() const { return false; } virtual bool IsRenewTreeOutput() const { return false; } virtual double RenewTreeOutput(double ori_output, std::function, const data_size_t*, const data_size_t*, data_size_t) const { return ori_output; } virtual void RenewTreeOutputCUDA(const double* /*score*/, const data_size_t* /*data_indices_in_leaf*/, const data_size_t* /*num_data_in_leaf*/, const data_size_t* /*data_start_in_leaf*/, const int /*num_leaves*/, double* /*leaf_value*/) const {} virtual double BoostFromScore(int /*class_id*/) const { return 0.0; } virtual bool ClassNeedTrain(int /*class_id*/) const { return true; } virtual bool SkipEmptyClass() const { return false; } virtual int NumModelPerIteration() const { return 1; } virtual int NumPredictOneRow() const { return 1; } /*! \brief The prediction should be accurate or not. True will disable early stopping for prediction. */ virtual bool NeedAccuratePrediction() const { return true; } /*! \brief Return the number of positive samples. Return 0 if no binary classification tasks.*/ virtual data_size_t NumPositiveData() const { return 0; } virtual void ConvertOutput(const double* input, double* output) const { output[0] = input[0]; } virtual std::string ToString() const = 0; ObjectiveFunction() = default; /*! \brief Disable copy */ ObjectiveFunction& operator=(const ObjectiveFunction&) = delete; /*! \brief Disable copy */ ObjectiveFunction(const ObjectiveFunction&) = delete; /*! * \brief Create object of objective function * \param type Specific type of objective function * \param config Config for objective function */ LIGHTGBM_EXPORT static ObjectiveFunction* CreateObjectiveFunction(const std::string& type, const Config& config); /*! * \brief Load objective function from string object */ LIGHTGBM_EXPORT static ObjectiveFunction* CreateObjectiveFunction(const std::string& str); /*! * \brief Whether boosting is done on CUDA */ virtual bool IsCUDAObjective() const { return false; } #ifdef USE_CUDA /*! * \brief Convert output for CUDA version */ virtual const double* ConvertOutputCUDA(data_size_t /*num_data*/, const double* input, double* /*output*/) const { return input; } virtual bool NeedConvertOutputCUDA () const { return false; } #endif // USE_CUDA }; } // namespace LightGBM #endif // LightGBM_OBJECTIVE_FUNCTION_H_