/*! * Copyright (c) 2021 Microsoft Corporation. All rights reserved. * Licensed under the MIT License. See LICENSE file in the project root for * license information. */ #ifdef USE_CUDA_EXP #include "cuda_regression_objective.hpp" #include #include namespace LightGBM { CUDARegressionL2loss::CUDARegressionL2loss(const Config& config): RegressionL2loss(config) { cuda_block_buffer_ = nullptr; cuda_trans_label_ = nullptr; } CUDARegressionL2loss::CUDARegressionL2loss(const std::vector& strs): RegressionL2loss(strs) {} CUDARegressionL2loss::~CUDARegressionL2loss() { DeallocateCUDAMemory(&cuda_block_buffer_, __FILE__, __LINE__); DeallocateCUDAMemory(&cuda_trans_label_, __FILE__, __LINE__); } void CUDARegressionL2loss::Init(const Metadata& metadata, data_size_t num_data) { RegressionL2loss::Init(metadata, num_data); cuda_labels_ = metadata.cuda_metadata()->cuda_label(); cuda_weights_ = metadata.cuda_metadata()->cuda_weights(); num_get_gradients_blocks_ = (num_data_ + GET_GRADIENTS_BLOCK_SIZE_REGRESSION - 1) / GET_GRADIENTS_BLOCK_SIZE_REGRESSION; AllocateCUDAMemory(&cuda_block_buffer_, static_cast(num_get_gradients_blocks_), __FILE__, __LINE__); if (sqrt_) { InitCUDAMemoryFromHostMemory(&cuda_trans_label_, trans_label_.data(), trans_label_.size(), __FILE__, __LINE__); cuda_labels_ = cuda_trans_label_; } } void CUDARegressionL2loss::GetGradients(const double* score, score_t* gradients, score_t* hessians) const { LaunchGetGradientsKernel(score, gradients, hessians); } double CUDARegressionL2loss::BoostFromScore(int) const { return LaunchCalcInitScoreKernel(); } void CUDARegressionL2loss::ConvertOutputCUDA(const data_size_t num_data, const double* input, double* output) const { LaunchConvertOutputCUDAKernel(num_data, input, output); } void CUDARegressionL2loss::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 { global_timer.Start("CUDARegressionL2loss::LaunchRenewTreeOutputCUDAKernel"); LaunchRenewTreeOutputCUDAKernel(score, data_indices_in_leaf, num_data_in_leaf, data_start_in_leaf, num_leaves, leaf_value); SynchronizeCUDADevice(__FILE__, __LINE__); global_timer.Stop("CUDARegressionL2loss::LaunchRenewTreeOutputCUDAKernel"); } } // namespace LightGBM #endif // USE_CUDA_EXP