c_api.h 43.8 KB
Newer Older
1
2
3
4
/*!
 * Copyright (c) 2016 Microsoft Corporation. All rights reserved.
 * Licensed under the MIT License. See LICENSE file in the project root for license information.
 */
Guolin Ke's avatar
Guolin Ke committed
5
6
#ifndef LIGHTGBM_C_API_H_
#define LIGHTGBM_C_API_H_
ww's avatar
ww committed
7

8
9
#include <LightGBM/export.h>

10
#include <cstdint>
wxchan's avatar
wxchan committed
11
12
#include <cstring>

13
14
15
/*!
* To avoid type conversion on large data, most of our expose interface support both for float_32 and float_64.
* Except following:
wxchan's avatar
wxchan committed
16
* 1. gradients and hessians.
17
* 2. Get current score for training data and validation
wxchan's avatar
wxchan committed
18
* The reason is because they are called frequently, the type-conversion on them maybe time cost.
19
20
*/

Guolin Ke's avatar
typo  
Guolin Ke committed
21
typedef void* DatasetHandle;
Guolin Ke's avatar
Guolin Ke committed
22
23
typedef void* BoosterHandle;

Guolin Ke's avatar
Guolin Ke committed
24
25
26
27
#define C_API_DTYPE_FLOAT32 (0)
#define C_API_DTYPE_FLOAT64 (1)
#define C_API_DTYPE_INT32   (2)
#define C_API_DTYPE_INT64   (3)
28
#define C_API_DTYPE_INT8    (4)
Guolin Ke's avatar
Guolin Ke committed
29
30
31
32

#define C_API_PREDICT_NORMAL     (0)
#define C_API_PREDICT_RAW_SCORE  (1)
#define C_API_PREDICT_LEAF_INDEX (2)
33
#define C_API_PREDICT_CONTRIB    (3)
34

Guolin Ke's avatar
Guolin Ke committed
35
36
/*!
* \brief get string message of the last error
wxchan's avatar
wxchan committed
37
*  all function in this file will return 0 when succeed
Guolin Ke's avatar
Guolin Ke committed
38
39
40
*  and -1 when an error occured,
* \return const char* error inforomation
*/
41
LIGHTGBM_C_EXPORT const char* LGBM_GetLastError();
Guolin Ke's avatar
Guolin Ke committed
42

Guolin Ke's avatar
Guolin Ke committed
43
// --- start Dataset interface
Guolin Ke's avatar
Guolin Ke committed
44
45
46
47

/*!
* \brief load data set from file like the command_line LightGBM do
* \param filename the name of the file
Guolin Ke's avatar
Guolin Ke committed
48
* \param parameters additional parameters
Guolin Ke's avatar
Guolin Ke committed
49
50
* \param reference used to align bin mapper with other dataset, nullptr means don't used
* \param out a loaded dataset
wxchan's avatar
wxchan committed
51
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
52
*/
53
LIGHTGBM_C_EXPORT int LGBM_DatasetCreateFromFile(const char* filename,
54
55
56
                                                 const char* parameters,
                                                 const DatasetHandle reference,
                                                 DatasetHandle* out);
Guolin Ke's avatar
Guolin Ke committed
57

58
/*!
59
60
* \brief create a empty dataset by sampling data.
* \param sample_data sampled data, grouped by the column.
61
* \param sample_indices indices of sampled data.
62
* \param ncol number columns
63
64
* \param num_per_col Size of each sampling column
* \param num_sample_row Number of sampled rows
65
66
67
68
69
* \param num_total_row number of total rows
* \param parameters additional parameters
* \param out created dataset
* \return 0 when succeed, -1 when failure happens
*/
70
71
72
73
74
75
76
77
LIGHTGBM_C_EXPORT int LGBM_DatasetCreateFromSampledColumn(double** sample_data,
                                                          int** sample_indices,
                                                          int32_t ncol,
                                                          const int* num_per_col,
                                                          int32_t num_sample_row,
                                                          int32_t num_total_row,
                                                          const char* parameters,
                                                          DatasetHandle* out);
Guolin Ke's avatar
Guolin Ke committed
78
79
80
81
82
83
84
85
86

/*!
* \brief create a empty dataset by reference Dataset
* \param reference used to align bin mapper
* \param num_total_row number of total rows
* \param out created dataset
* \return 0 when succeed, -1 when failure happens
*/
LIGHTGBM_C_EXPORT int LGBM_DatasetCreateByReference(const DatasetHandle reference,
87
88
                                                    int64_t num_total_row,
                                                    DatasetHandle* out);
Guolin Ke's avatar
Guolin Ke committed
89
90
91
92
93
94
95
96
97
98
99
100

/*!
* \brief push data to existing dataset, if nrow + start_row == num_total_row, will call dataset->FinishLoad
* \param dataset handle of dataset
* \param data pointer to the data space
* \param data_type type of data pointer, can be C_API_DTYPE_FLOAT32 or C_API_DTYPE_FLOAT64
* \param nrow number of rows
* \param ncol number columns
* \param start_row row start index
* \return 0 when succeed, -1 when failure happens
*/
LIGHTGBM_C_EXPORT int LGBM_DatasetPushRows(DatasetHandle dataset,
101
102
103
104
105
                                           const void* data,
                                           int data_type,
                                           int32_t nrow,
                                           int32_t ncol,
                                           int32_t start_row);
Guolin Ke's avatar
Guolin Ke committed
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121

/*!
* \brief push data to existing dataset, if nrow + start_row == num_total_row, will call dataset->FinishLoad
* \param dataset handle of dataset
* \param indptr pointer to row headers
* \param indptr_type type of indptr, can be C_API_DTYPE_INT32 or C_API_DTYPE_INT64
* \param indices findex
* \param data fvalue
* \param data_type type of data pointer, can be C_API_DTYPE_FLOAT32 or C_API_DTYPE_FLOAT64
* \param nindptr number of rows in the matrix + 1
* \param nelem number of nonzero elements in the matrix
* \param num_col number of columns
* \param start_row row start index
* \return 0 when succeed, -1 when failure happens
*/
LIGHTGBM_C_EXPORT int LGBM_DatasetPushRowsByCSR(DatasetHandle dataset,
122
123
124
125
126
127
128
129
130
                                                const void* indptr,
                                                int indptr_type,
                                                const int32_t* indices,
                                                const void* data,
                                                int data_type,
                                                int64_t nindptr,
                                                int64_t nelem,
                                                int64_t num_col,
                                                int64_t start_row);
Guolin Ke's avatar
Guolin Ke committed
131

Guolin Ke's avatar
Guolin Ke committed
132
133
134
/*!
* \brief create a dataset from CSR format
* \param indptr pointer to row headers
wxchan's avatar
wxchan committed
135
* \param indptr_type type of indptr, can be C_API_DTYPE_INT32 or C_API_DTYPE_INT64
Guolin Ke's avatar
Guolin Ke committed
136
137
* \param indices findex
* \param data fvalue
wxchan's avatar
wxchan committed
138
* \param data_type type of data pointer, can be C_API_DTYPE_FLOAT32 or C_API_DTYPE_FLOAT64
Guolin Ke's avatar
Guolin Ke committed
139
* \param nindptr number of rows in the matrix + 1
Guolin Ke's avatar
Guolin Ke committed
140
* \param nelem number of nonzero elements in the matrix
wxchan's avatar
wxchan committed
141
* \param num_col number of columns
Guolin Ke's avatar
Guolin Ke committed
142
* \param parameters additional parameters
Guolin Ke's avatar
Guolin Ke committed
143
144
* \param reference used to align bin mapper with other dataset, nullptr means don't used
* \param out created dataset
wxchan's avatar
wxchan committed
145
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
146
*/
147
LIGHTGBM_C_EXPORT int LGBM_DatasetCreateFromCSR(const void* indptr,
148
149
150
151
152
153
154
155
156
157
                                                int indptr_type,
                                                const int32_t* indices,
                                                const void* data,
                                                int data_type,
                                                int64_t nindptr,
                                                int64_t nelem,
                                                int64_t num_col,
                                                const char* parameters,
                                                const DatasetHandle reference,
                                                DatasetHandle* out);
Guolin Ke's avatar
Guolin Ke committed
158

159
160
161
162
163
164
165
166
167
168
169
170

/*!
* \brief create a dataset from CSR format through callbacks
* \param get_row_funptr pointer to std::function<void(int idx, std::vector<std::pair<int, double>>& ret). CAlled for every row and expected to clear and fill ret
* \param num_rows number of rows
* \param num_col number of columns
* \param parameters additional parameters
* \param reference used to align bin mapper with other dataset, nullptr means don't used
* \param out created dataset
* \return 0 when succeed, -1 when failure happens
*/
LIGHTGBM_C_EXPORT int LGBM_DatasetCreateFromCSRFunc(void* get_row_funptr,
171
172
173
174
175
                                                    int num_rows,
                                                    int64_t num_col,
                                                    const char* parameters,
                                                    const DatasetHandle reference,
                                                    DatasetHandle* out);
176
177


Guolin Ke's avatar
Guolin Ke committed
178
179
180
/*!
* \brief create a dataset from CSC format
* \param col_ptr pointer to col headers
wxchan's avatar
wxchan committed
181
* \param col_ptr_type type of col_ptr, can be C_API_DTYPE_INT32 or C_API_DTYPE_INT64
Guolin Ke's avatar
Guolin Ke committed
182
183
* \param indices findex
* \param data fvalue
wxchan's avatar
wxchan committed
184
185
* \param data_type type of data pointer, can be C_API_DTYPE_FLOAT32 or C_API_DTYPE_FLOAT64
* \param ncol_ptr number of cols in the matrix + 1
Guolin Ke's avatar
Guolin Ke committed
186
* \param nelem number of nonzero elements in the matrix
wxchan's avatar
wxchan committed
187
* \param num_row number of rows
Guolin Ke's avatar
Guolin Ke committed
188
189
190
* \param parameters additional parameters
* \param reference used to align bin mapper with other dataset, nullptr means don't used
* \param out created dataset
wxchan's avatar
wxchan committed
191
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
192
*/
193
LIGHTGBM_C_EXPORT int LGBM_DatasetCreateFromCSC(const void* col_ptr,
194
195
196
197
198
199
200
201
202
203
                                                int col_ptr_type,
                                                const int32_t* indices,
                                                const void* data,
                                                int data_type,
                                                int64_t ncol_ptr,
                                                int64_t nelem,
                                                int64_t num_row,
                                                const char* parameters,
                                                const DatasetHandle reference,
                                                DatasetHandle* out);
Guolin Ke's avatar
Guolin Ke committed
204
205
206
207

/*!
* \brief create dataset from dense matrix
* \param data pointer to the data space
wxchan's avatar
wxchan committed
208
* \param data_type type of data pointer, can be C_API_DTYPE_FLOAT32 or C_API_DTYPE_FLOAT64
Guolin Ke's avatar
Guolin Ke committed
209
210
* \param nrow number of rows
* \param ncol number columns
211
* \param is_row_major 1 for row major, 0 for column major
Guolin Ke's avatar
Guolin Ke committed
212
* \param parameters additional parameters
Guolin Ke's avatar
Guolin Ke committed
213
214
* \param reference used to align bin mapper with other dataset, nullptr means don't used
* \param out created dataset
wxchan's avatar
wxchan committed
215
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
216
*/
217
LIGHTGBM_C_EXPORT int LGBM_DatasetCreateFromMat(const void* data,
218
219
220
221
222
223
224
                                                int data_type,
                                                int32_t nrow,
                                                int32_t ncol,
                                                int is_row_major,
                                                const char* parameters,
                                                const DatasetHandle reference,
                                                DatasetHandle* out);
Guolin Ke's avatar
Guolin Ke committed
225

226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
/*!
* \brief create dataset from array of dense matrices
* \param data pointer to the data space
* \param data_type type of data pointer, can be C_API_DTYPE_FLOAT32 or C_API_DTYPE_FLOAT64
* \param nrow number of rows
* \param ncol number columns
* \param parameters additional parameters
* \param reference used to align bin mapper with other dataset, nullptr means don't used
* \param out created dataset
* \return 0 when succeed, -1 when failure happens
*/
LIGHTGBM_C_EXPORT int LGBM_DatasetCreateFromMats(int32_t nmat,
                                                 const void** data,
                                                 int data_type,
                                                 int32_t* nrow,
                                                 int32_t ncol,
                                                 int is_row_major,
                                                 const char* parameters,
                                                 const DatasetHandle reference,
                                                 DatasetHandle* out);

wxchan's avatar
wxchan committed
247
248
249
250
251
252
253
254
255
/*!
* \brief Create subset of a data
* \param handle handle of full dataset
* \param used_row_indices Indices used in subset
* \param num_used_row_indices len of used_row_indices
* \param parameters additional parameters
* \param out subset of data
* \return 0 when succeed, -1 when failure happens
*/
256
257
258
259
260
LIGHTGBM_C_EXPORT int LGBM_DatasetGetSubset(const DatasetHandle handle,
                                            const int32_t* used_row_indices,
                                            int32_t num_used_row_indices,
                                            const char* parameters,
                                            DatasetHandle* out);
wxchan's avatar
wxchan committed
261

Guolin Ke's avatar
Guolin Ke committed
262
263
264
265
266
267
268
/*!
* \brief save feature names to Dataset
* \param handle handle
* \param feature_names feature names
* \param num_feature_names number of feature names
* \return 0 when succeed, -1 when failure happens
*/
269
270
271
LIGHTGBM_C_EXPORT int LGBM_DatasetSetFeatureNames(DatasetHandle handle,
                                                  const char** feature_names,
                                                  int num_feature_names);
Guolin Ke's avatar
Guolin Ke committed
272

273
274
275
276
277
278
279
280

/*!
* \brief get feature names of Dataset
* \param handle handle
* \param feature_names feature names, should pre-allocate memory
* \param num_feature_names number of feature names
* \return 0 when succeed, -1 when failure happens
*/
281
282
283
LIGHTGBM_C_EXPORT int LGBM_DatasetGetFeatureNames(DatasetHandle handle,
                                                  char** feature_names,
                                                  int* num_feature_names);
284
285


Guolin Ke's avatar
Guolin Ke committed
286
287
/*!
* \brief free space for dataset
wxchan's avatar
wxchan committed
288
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
289
*/
290
LIGHTGBM_C_EXPORT int LGBM_DatasetFree(DatasetHandle handle);
Guolin Ke's avatar
Guolin Ke committed
291
292

/*!
293
* \brief save dataset to binary file
Guolin Ke's avatar
Guolin Ke committed
294
295
* \param handle a instance of dataset
* \param filename file name
wxchan's avatar
wxchan committed
296
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
297
*/
298
LIGHTGBM_C_EXPORT int LGBM_DatasetSaveBinary(DatasetHandle handle,
299
                                             const char* filename);
Guolin Ke's avatar
Guolin Ke committed
300

301
302
303
304
305
306
307
308
309
/*!
* \brief save dataset to text file, intended for debugging use only
* \param handle a instance of dataset
* \param filename file name
* \return 0 when succeed, -1 when failure happens
*/
LIGHTGBM_C_EXPORT int LGBM_DatasetDumpText(DatasetHandle handle,
                                           const char* filename);

Guolin Ke's avatar
Guolin Ke committed
310
311
/*!
* \brief set vector to a content in info
wxchan's avatar
wxchan committed
312
313
*        Note: group and group only work for C_API_DTYPE_INT32
*              label and weight only work for C_API_DTYPE_FLOAT32
Guolin Ke's avatar
Guolin Ke committed
314
* \param handle a instance of dataset
wxchan's avatar
wxchan committed
315
* \param field_name field name, can be label, weight, group, group_id
316
* \param field_data pointer to vector
Guolin Ke's avatar
Guolin Ke committed
317
* \param num_element number of element in field_data
wxchan's avatar
wxchan committed
318
319
* \param type C_API_DTYPE_FLOAT32 or C_API_DTYPE_INT32
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
320
*/
321
LIGHTGBM_C_EXPORT int LGBM_DatasetSetField(DatasetHandle handle,
322
323
324
325
                                           const char* field_name,
                                           const void* field_data,
                                           int num_element,
                                           int type);
Guolin Ke's avatar
Guolin Ke committed
326
327

/*!
328
* \brief get info vector from dataset
Guolin Ke's avatar
Guolin Ke committed
329
330
331
332
* \param handle a instance of data matrix
* \param field_name field name
* \param out_len used to set result length
* \param out_ptr pointer to the result
wxchan's avatar
wxchan committed
333
334
* \param out_type  C_API_DTYPE_FLOAT32 or C_API_DTYPE_INT32
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
335
*/
336
LIGHTGBM_C_EXPORT int LGBM_DatasetGetField(DatasetHandle handle,
337
338
339
340
                                           const char* field_name,
                                           int* out_len,
                                           const void** out_ptr,
                                           int* out_type);
Guolin Ke's avatar
Guolin Ke committed
341

342
343
344
345
346
347

/*!
* \brief Update parameters for a Dataset
* \param handle a instance of data matrix
* \param parameters parameters
*/
348
349
LIGHTGBM_C_EXPORT int LGBM_DatasetUpdateParam(DatasetHandle handle,
                                              const char* parameters);
350

Guolin Ke's avatar
Guolin Ke committed
351
352
353
354
/*!
* \brief get number of data.
* \param handle the handle to the dataset
* \param out The address to hold number of data
wxchan's avatar
wxchan committed
355
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
356
*/
357
LIGHTGBM_C_EXPORT int LGBM_DatasetGetNumData(DatasetHandle handle,
358
                                             int* out);
Guolin Ke's avatar
Guolin Ke committed
359
360
361
362
363

/*!
* \brief get number of features
* \param handle the handle to the dataset
* \param out The output of number of features
wxchan's avatar
wxchan committed
364
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
365
*/
366
LIGHTGBM_C_EXPORT int LGBM_DatasetGetNumFeature(DatasetHandle handle,
367
                                                int* out);
Guolin Ke's avatar
Guolin Ke committed
368

369
370
371
372
373
374
375
376
377
/*!
* \brief Add features from source to target, then free source
* \param target The handle of the dataset to add features to
* \param source The handle of the dataset to take features from
* \return 0 when succeed, -1 when failure happens
*/
LIGHTGBM_C_EXPORT int LGBM_DatasetAddFeaturesFrom(DatasetHandle target,
                                                  DatasetHandle source);

Guolin Ke's avatar
Guolin Ke committed
378
379
380
381
// --- start Booster interfaces

/*!
* \brief create an new boosting learner
Guolin Ke's avatar
Guolin Ke committed
382
* \param train_data training data set
Guolin Ke's avatar
Guolin Ke committed
383
384
* \param parameters format: 'key1=value1 key2=value2'
* \prama out handle of created Booster
wxchan's avatar
wxchan committed
385
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
386
*/
387
LIGHTGBM_C_EXPORT int LGBM_BoosterCreate(const DatasetHandle train_data,
388
389
                                         const char* parameters,
                                         BoosterHandle* out);
Guolin Ke's avatar
Guolin Ke committed
390
391

/*!
Guolin Ke's avatar
Guolin Ke committed
392
* \brief load an existing boosting from model file
Guolin Ke's avatar
Guolin Ke committed
393
* \param filename filename of model
wxchan's avatar
wxchan committed
394
* \param out_num_iterations number of iterations of this booster
Guolin Ke's avatar
Guolin Ke committed
395
* \param out handle of created Booster
wxchan's avatar
wxchan committed
396
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
397
*/
398
399
400
LIGHTGBM_C_EXPORT int LGBM_BoosterCreateFromModelfile(const char* filename,
                                                      int* out_num_iterations,
                                                      BoosterHandle* out);
Guolin Ke's avatar
Guolin Ke committed
401

402
403
404
405
406
407
408
/*!
* \brief load an existing boosting from string
* \param model_str model string
* \param out_num_iterations number of iterations of this booster
* \param out handle of created Booster
* \return 0 when succeed, -1 when failure happens
*/
409
410
411
LIGHTGBM_C_EXPORT int LGBM_BoosterLoadModelFromString(const char* model_str,
                                                      int* out_num_iterations,
                                                      BoosterHandle* out);
wxchan's avatar
wxchan committed
412

Guolin Ke's avatar
Guolin Ke committed
413
414
415
/*!
* \brief free obj in handle
* \param handle handle to be freed
wxchan's avatar
wxchan committed
416
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
417
*/
418
LIGHTGBM_C_EXPORT int LGBM_BoosterFree(BoosterHandle handle);
Guolin Ke's avatar
Guolin Ke committed
419

420
421
422
/*!
* \brief Shuffle Models
*/
423
424
425
LIGHTGBM_C_EXPORT int LGBM_BoosterShuffleModels(BoosterHandle handle,
                                                int start_iter,
                                                int end_iter);
426

wxchan's avatar
wxchan committed
427
428
429
430
431
432
/*!
* \brief Merge model in two booster to first handle
* \param handle handle, will merge other handle to this
* \param other_handle
* \return 0 when succeed, -1 when failure happens
*/
433
LIGHTGBM_C_EXPORT int LGBM_BoosterMerge(BoosterHandle handle,
434
                                        BoosterHandle other_handle);
wxchan's avatar
wxchan committed
435
436
437
438
439
440
441

/*!
* \brief Add new validation to booster
* \param handle handle
* \param valid_data validation data set
* \return 0 when succeed, -1 when failure happens
*/
442
LIGHTGBM_C_EXPORT int LGBM_BoosterAddValidData(BoosterHandle handle,
443
                                               const DatasetHandle valid_data);
wxchan's avatar
wxchan committed
444
445
446
447
448
449
450

/*!
* \brief Reset training data for booster
* \param handle handle
* \param train_data training data set
* \return 0 when succeed, -1 when failure happens
*/
451
LIGHTGBM_C_EXPORT int LGBM_BoosterResetTrainingData(BoosterHandle handle,
452
                                                    const DatasetHandle train_data);
wxchan's avatar
wxchan committed
453
454
455
456
457
458
459

/*!
* \brief Reset config for current booster
* \param handle handle
* \param parameters format: 'key1=value1 key2=value2'
* \return 0 when succeed, -1 when failure happens
*/
460
461
LIGHTGBM_C_EXPORT int LGBM_BoosterResetParameter(BoosterHandle handle,
                                                 const char* parameters);
wxchan's avatar
wxchan committed
462
463

/*!
Guolin Ke's avatar
Guolin Ke committed
464
* \brief Get number of class
wxchan's avatar
wxchan committed
465
466
467
468
* \param handle handle
* \param out_len number of class
* \return 0 when succeed, -1 when failure happens
*/
469
470
LIGHTGBM_C_EXPORT int LGBM_BoosterGetNumClasses(BoosterHandle handle,
                                                int* out_len);
wxchan's avatar
wxchan committed
471

Guolin Ke's avatar
Guolin Ke committed
472
473
474
/*!
* \brief update the model in one round
* \param handle handle
Guolin Ke's avatar
Guolin Ke committed
475
* \param is_finished 1 means finised(cannot split any more)
wxchan's avatar
wxchan committed
476
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
477
*/
478
479
LIGHTGBM_C_EXPORT int LGBM_BoosterUpdateOneIter(BoosterHandle handle,
                                                int* is_finished);
Guolin Ke's avatar
Guolin Ke committed
480

Guolin Ke's avatar
Guolin Ke committed
481
482
483
484
485
486
487
488
/*!
* \brief Refit the tree model using the new data (online learning)
* \param handle handle
* \param leaf_preds 
* \param nrow number of rows of leaf_preds
* \param ncol number of columns of leaf_preds
* \return 0 when succeed, -1 when failure happens
*/
489
490
491
492
LIGHTGBM_C_EXPORT int LGBM_BoosterRefit(BoosterHandle handle,
                                        const int32_t* leaf_preds,
                                        int32_t nrow,
                                        int32_t ncol);
Guolin Ke's avatar
Guolin Ke committed
493

Guolin Ke's avatar
Guolin Ke committed
494
495
496
497
498
499
/*!
* \brief update the model, by directly specify gradient and second order gradient,
*       this can be used to support customized loss function
* \param handle handle
* \param grad gradient statistics
* \param hess second order gradient statistics
Guolin Ke's avatar
Guolin Ke committed
500
* \param is_finished 1 means finised(cannot split any more)
wxchan's avatar
wxchan committed
501
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
502
*/
503
LIGHTGBM_C_EXPORT int LGBM_BoosterUpdateOneIterCustom(BoosterHandle handle,
504
505
506
                                                      const float* grad,
                                                      const float* hess,
                                                      int* is_finished);
Guolin Ke's avatar
Guolin Ke committed
507
508

/*!
wxchan's avatar
wxchan committed
509
* \brief Rollback one iteration
Guolin Ke's avatar
Guolin Ke committed
510
* \param handle handle
wxchan's avatar
wxchan committed
511
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
512
*/
513
LIGHTGBM_C_EXPORT int LGBM_BoosterRollbackOneIter(BoosterHandle handle);
wxchan's avatar
wxchan committed
514
515
516
517
518
519

/*!
* \brief Get iteration of current boosting rounds
* \param out_iteration iteration of boosting rounds
* \return 0 when succeed, -1 when failure happens
*/
520
521
LIGHTGBM_C_EXPORT int LGBM_BoosterGetCurrentIteration(BoosterHandle handle,
                                                      int* out_iteration);
Guolin Ke's avatar
Guolin Ke committed
522

523
524
525
526
527
/*!
* \brief Get number of tree per iteration
* \param out_tree_per_iteration number of tree per iteration
* \return 0 when succeed, -1 when failure happens
*/
528
529
LIGHTGBM_C_EXPORT int LGBM_BoosterNumModelPerIteration(BoosterHandle handle,
                                                       int* out_tree_per_iteration);
530
531
532
533
534
535

/*!
* \brief Get number of weak sub-models
* \param out_models number of weak sub-models
* \return 0 when succeed, -1 when failure happens
*/
536
537
LIGHTGBM_C_EXPORT int LGBM_BoosterNumberOfTotalModel(BoosterHandle handle,
                                                     int* out_models);
538

Guolin Ke's avatar
Guolin Ke committed
539
/*!
Guolin Ke's avatar
Guolin Ke committed
540
* \brief Get number of eval
wxchan's avatar
wxchan committed
541
542
543
* \param out_len total number of eval results
* \return 0 when succeed, -1 when failure happens
*/
544
545
LIGHTGBM_C_EXPORT int LGBM_BoosterGetEvalCounts(BoosterHandle handle,
                                                int* out_len);
wxchan's avatar
wxchan committed
546
547

/*!
wxchan's avatar
wxchan committed
548
* \brief Get name of eval
wxchan's avatar
wxchan committed
549
* \param out_len total number of eval results
Guolin Ke's avatar
typo  
Guolin Ke committed
550
* \param out_strs names of eval result, need to pre-allocate memory before call this
wxchan's avatar
wxchan committed
551
552
* \return 0 when succeed, -1 when failure happens
*/
553
554
555
LIGHTGBM_C_EXPORT int LGBM_BoosterGetEvalNames(BoosterHandle handle,
                                               int* out_len,
                                               char** out_strs);
wxchan's avatar
wxchan committed
556

wxchan's avatar
wxchan committed
557
558
559
560
561
562
/*!
* \brief Get name of features
* \param out_len total number of features
* \param out_strs names of features, need to pre-allocate memory before call this
* \return 0 when succeed, -1 when failure happens
*/
563
564
565
LIGHTGBM_C_EXPORT int LGBM_BoosterGetFeatureNames(BoosterHandle handle,
                                                  int* out_len,
                                                  char** out_strs);
wxchan's avatar
wxchan committed
566
567
568
569
570
571

/*!
* \brief Get number of features
* \param out_len total number of features
* \return 0 when succeed, -1 when failure happens
*/
572
573
LIGHTGBM_C_EXPORT int LGBM_BoosterGetNumFeature(BoosterHandle handle,
                                                int* out_len);
wxchan's avatar
wxchan committed
574

wxchan's avatar
wxchan committed
575
576
/*!
* \brief get evaluation for training data and validation data
Guolin Ke's avatar
Guolin Ke committed
577
578
Note: 1. you should call LGBM_BoosterGetEvalNames first to get the name of evaluation results
2. should pre-allocate memory for out_results, you can get its length by LGBM_BoosterGetEvalCounts
Guolin Ke's avatar
Guolin Ke committed
579
* \param handle handle
wxchan's avatar
wxchan committed
580
* \param data_idx 0:training data, 1: 1st valid data, 2:2nd valid data ...
Guolin Ke's avatar
Guolin Ke committed
581
* \param out_len len of output result
wxchan's avatar
wxchan committed
582
583
* \param out_result float arrary contains result
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
584
*/
585
LIGHTGBM_C_EXPORT int LGBM_BoosterGetEval(BoosterHandle handle,
586
587
588
                                          int data_idx,
                                          int* out_len,
                                          double* out_results);
Guolin Ke's avatar
Guolin Ke committed
589
590
591
592
593
594
595
596
597
598

/*!
* \brief Get number of predict for inner dataset
this can be used to support customized eval function
Note:  should pre-allocate memory for out_result, its length is equal to num_class * num_data
* \param handle handle
* \param data_idx 0:training data, 1: 1st valid data, 2:2nd valid data ...
* \param out_len len of output result
* \return 0 when succeed, -1 when failure happens
*/
599
LIGHTGBM_C_EXPORT int LGBM_BoosterGetNumPredict(BoosterHandle handle,
600
601
                                                int data_idx,
                                                int64_t* out_len);
Guolin Ke's avatar
Guolin Ke committed
602

Guolin Ke's avatar
Guolin Ke committed
603
/*!
Guolin Ke's avatar
Guolin Ke committed
604
* \brief Get prediction for training data and validation data
Guolin Ke's avatar
Guolin Ke committed
605
606
this can be used to support customized eval function
Note:  should pre-allocate memory for out_result, its length is equal to num_class * num_data
Guolin Ke's avatar
Guolin Ke committed
607
* \param handle handle
wxchan's avatar
wxchan committed
608
* \param data_idx 0:training data, 1: 1st valid data, 2:2nd valid data ...
Guolin Ke's avatar
Guolin Ke committed
609
* \param out_len len of output result
Guolin Ke's avatar
Guolin Ke committed
610
* \param out_result used to set a pointer to array, should allocate memory before call this function
wxchan's avatar
wxchan committed
611
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
612
*/
613
LIGHTGBM_C_EXPORT int LGBM_BoosterGetPredict(BoosterHandle handle,
614
615
616
                                             int data_idx,
                                             int64_t* out_len,
                                             double* out_result);
Guolin Ke's avatar
Guolin Ke committed
617

618
619
620
621
/*!
* \brief make prediction for file
* \param handle handle
* \param data_filename filename of data file
wxchan's avatar
wxchan committed
622
623
624
625
626
627
* \param data_has_header data file has header or not
* \param predict_type
*          C_API_PREDICT_NORMAL: normal prediction, with transform (if needed)
*          C_API_PREDICT_RAW_SCORE: raw score
*          C_API_PREDICT_LEAF_INDEX: leaf index
* \param num_iteration number of iteration for prediction, <= 0 means no limit
Guolin Ke's avatar
Guolin Ke committed
628
* \param parameter Other parameters for the parameters, e.g. early stopping for prediction.
629
* \param result_filename filename of result file
wxchan's avatar
wxchan committed
630
* \return 0 when succeed, -1 when failure happens
631
*/
632
LIGHTGBM_C_EXPORT int LGBM_BoosterPredictForFile(BoosterHandle handle,
633
634
635
636
                                                 const char* data_filename,
                                                 int data_has_header,
                                                 int predict_type,
                                                 int num_iteration,
637
                                                 const char* parameter,
638
                                                 const char* result_filename);
639

Guolin Ke's avatar
Guolin Ke committed
640
641
642
/*!
* \brief Get number of prediction
* \param handle handle
Guolin Ke's avatar
Guolin Ke committed
643
* \param num_row
Guolin Ke's avatar
Guolin Ke committed
644
645
646
647
648
* \param predict_type
*          C_API_PREDICT_NORMAL: normal prediction, with transform (if needed)
*          C_API_PREDICT_RAW_SCORE: raw score
*          C_API_PREDICT_LEAF_INDEX: leaf index
* \param num_iteration number of iteration for prediction, <= 0 means no limit
649
* \param out_len length of prediction
Guolin Ke's avatar
Guolin Ke committed
650
651
* \return 0 when succeed, -1 when failure happens
*/
652
LIGHTGBM_C_EXPORT int LGBM_BoosterCalcNumPredict(BoosterHandle handle,
653
654
655
656
                                                 int num_row,
                                                 int predict_type,
                                                 int num_iteration,
                                                 int64_t* out_len);
Guolin Ke's avatar
Guolin Ke committed
657

Guolin Ke's avatar
Guolin Ke committed
658
659
/*!
* \brief make prediction for an new data set
Guolin Ke's avatar
Guolin Ke committed
660
*        Note:  should pre-allocate memory for out_result,
661
*               for normal and raw score: its length is equal to num_class * num_data
wxchan's avatar
wxchan committed
662
*               for leaf index, its length is equal to num_class * num_data * num_iteration
Guolin Ke's avatar
Guolin Ke committed
663
664
* \param handle handle
* \param indptr pointer to row headers
wxchan's avatar
wxchan committed
665
* \param indptr_type type of indptr, can be C_API_DTYPE_INT32 or C_API_DTYPE_INT64
Guolin Ke's avatar
Guolin Ke committed
666
667
* \param indices findex
* \param data fvalue
wxchan's avatar
wxchan committed
668
* \param data_type type of data pointer, can be C_API_DTYPE_FLOAT32 or C_API_DTYPE_FLOAT64
Guolin Ke's avatar
Guolin Ke committed
669
* \param nindptr number of rows in the matrix + 1
Guolin Ke's avatar
Guolin Ke committed
670
671
672
* \param nelem number of nonzero elements in the matrix
* \param num_col number of columns; when it's set to 0, then guess from data
* \param predict_type
wxchan's avatar
wxchan committed
673
674
675
676
*          C_API_PREDICT_NORMAL: normal prediction, with transform (if needed)
*          C_API_PREDICT_RAW_SCORE: raw score
*          C_API_PREDICT_LEAF_INDEX: leaf index
* \param num_iteration number of iteration for prediction, <= 0 means no limit
Guolin Ke's avatar
Guolin Ke committed
677
* \param parameter Other parameters for the parameters, e.g. early stopping for prediction.
wxchan's avatar
wxchan committed
678
* \param out_len len of output result
Guolin Ke's avatar
Guolin Ke committed
679
* \param out_result used to set a pointer to array, should allocate memory before call this function
wxchan's avatar
wxchan committed
680
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
681
*/
682
LIGHTGBM_C_EXPORT int LGBM_BoosterPredictForCSR(BoosterHandle handle,
683
684
685
686
687
688
689
690
691
692
                                                const void* indptr,
                                                int indptr_type,
                                                const int32_t* indices,
                                                const void* data,
                                                int data_type,
                                                int64_t nindptr,
                                                int64_t nelem,
                                                int64_t num_col,
                                                int predict_type,
                                                int num_iteration,
693
                                                const char* parameter,
694
695
                                                int64_t* out_len,
                                                double* out_result);
Guolin Ke's avatar
Guolin Ke committed
696

697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
/*!
* \brief make prediction for an new data set. This method re-uses the internal predictor structure 
*        from previous calls and is optimized for single row invocation.
*        Note:  should pre-allocate memory for out_result,
*               for normal and raw score: its length is equal to num_class * num_data
*               for leaf index, its length is equal to num_class * num_data * num_iteration
* \param handle handle
* \param indptr pointer to row headers
* \param indptr_type type of indptr, can be C_API_DTYPE_INT32 or C_API_DTYPE_INT64
* \param indices findex
* \param data fvalue
* \param data_type type of data pointer, can be C_API_DTYPE_FLOAT32 or C_API_DTYPE_FLOAT64
* \param nindptr number of rows in the matrix + 1
* \param nelem number of nonzero elements in the matrix
* \param num_col number of columns; when it's set to 0, then guess from data
* \param predict_type
*          C_API_PREDICT_NORMAL: normal prediction, with transform (if needed)
*          C_API_PREDICT_RAW_SCORE: raw score
*          C_API_PREDICT_LEAF_INDEX: leaf index
* \param num_iteration number of iteration for prediction, <= 0 means no limit
* \param parameter Other parameters for the parameters, e.g. early stopping for prediction.
* \param out_len len of output result
* \param out_result used to set a pointer to array, should allocate memory before call this function
* \return 0 when succeed, -1 when failure happens
*/
LIGHTGBM_C_EXPORT int LGBM_BoosterPredictForCSRSingleRow(BoosterHandle handle,
723
724
725
726
727
728
729
730
731
732
733
734
735
                                                         const void* indptr,
                                                         int indptr_type,
                                                         const int32_t* indices,
                                                         const void* data,
                                                         int data_type,
                                                         int64_t nindptr,
                                                         int64_t nelem,
                                                         int64_t num_col,
                                                         int predict_type,
                                                         int num_iteration,
                                                         const char* parameter,
                                                         int64_t* out_len,
                                                         double* out_result);
736
737


Guolin Ke's avatar
Guolin Ke committed
738
739
740
/*!
* \brief make prediction for an new data set
*        Note:  should pre-allocate memory for out_result,
741
*               for normal and raw score: its length is equal to num_class * num_data
Guolin Ke's avatar
Guolin Ke committed
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
*               for leaf index, its length is equal to num_class * num_data * num_iteration
* \param handle handle
* \param col_ptr pointer to col headers
* \param col_ptr_type type of col_ptr, can be C_API_DTYPE_INT32 or C_API_DTYPE_INT64
* \param indices findex
* \param data fvalue
* \param data_type type of data pointer, can be C_API_DTYPE_FLOAT32 or C_API_DTYPE_FLOAT64
* \param ncol_ptr number of cols in the matrix + 1
* \param nelem number of nonzero elements in the matrix
* \param num_row number of rows
* \param predict_type
*          C_API_PREDICT_NORMAL: normal prediction, with transform (if needed)
*          C_API_PREDICT_RAW_SCORE: raw score
*          C_API_PREDICT_LEAF_INDEX: leaf index
* \param num_iteration number of iteration for prediction, <= 0 means no limit
Guolin Ke's avatar
Guolin Ke committed
757
* \param parameter Other parameters for the parameters, e.g. early stopping for prediction.
Guolin Ke's avatar
Guolin Ke committed
758
759
760
761
* \param out_len len of output result
* \param out_result used to set a pointer to array, should allocate memory before call this function
* \return 0 when succeed, -1 when failure happens
*/
762
LIGHTGBM_C_EXPORT int LGBM_BoosterPredictForCSC(BoosterHandle handle,
763
764
765
766
767
768
769
770
771
772
                                                const void* col_ptr,
                                                int col_ptr_type,
                                                const int32_t* indices,
                                                const void* data,
                                                int data_type,
                                                int64_t ncol_ptr,
                                                int64_t nelem,
                                                int64_t num_row,
                                                int predict_type,
                                                int num_iteration,
773
                                                const char* parameter,
774
775
                                                int64_t* out_len,
                                                double* out_result);
Guolin Ke's avatar
Guolin Ke committed
776
777
778

/*!
* \brief make prediction for an new data set
wxchan's avatar
wxchan committed
779
*        Note:  should pre-allocate memory for out_result,
780
*               for normal and raw score: its length is equal to num_class * num_data
wxchan's avatar
wxchan committed
781
*               for leaf index, its length is equal to num_class * num_data * num_iteration
Guolin Ke's avatar
Guolin Ke committed
782
783
* \param handle handle
* \param data pointer to the data space
wxchan's avatar
wxchan committed
784
* \param data_type type of data pointer, can be C_API_DTYPE_FLOAT32 or C_API_DTYPE_FLOAT64
Guolin Ke's avatar
Guolin Ke committed
785
786
* \param nrow number of rows
* \param ncol number columns
Guolin Ke's avatar
Guolin Ke committed
787
* \param is_row_major 1 for row major, 0 for column major
Guolin Ke's avatar
Guolin Ke committed
788
* \param predict_type
wxchan's avatar
wxchan committed
789
790
791
792
*          C_API_PREDICT_NORMAL: normal prediction, with transform (if needed)
*          C_API_PREDICT_RAW_SCORE: raw score
*          C_API_PREDICT_LEAF_INDEX: leaf index
* \param num_iteration number of iteration for prediction, <= 0 means no limit
Guolin Ke's avatar
Guolin Ke committed
793
* \param parameter Other parameters for the parameters, e.g. early stopping for prediction.
wxchan's avatar
wxchan committed
794
* \param out_len len of output result
Guolin Ke's avatar
Guolin Ke committed
795
* \param out_result used to set a pointer to array, should allocate memory before call this function
wxchan's avatar
wxchan committed
796
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
797
*/
798
LIGHTGBM_C_EXPORT int LGBM_BoosterPredictForMat(BoosterHandle handle,
799
800
801
802
803
804
805
                                                const void* data,
                                                int data_type,
                                                int32_t nrow,
                                                int32_t ncol,
                                                int is_row_major,
                                                int predict_type,
                                                int num_iteration,
806
                                                const char* parameter,
807
808
                                                int64_t* out_len,
                                                double* out_result);
Guolin Ke's avatar
Guolin Ke committed
809

810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
/*!
* \brief make prediction for an new data set. This method re-uses the internal predictor structure 
*        from previous calls and is optimized for single row invocation.
*        Note:  should pre-allocate memory for out_result,
*               for normal and raw score: its length is equal to num_class * num_data
*               for leaf index, its length is equal to num_class * num_data * num_iteration
* \param handle handle
* \param data pointer to the data space
* \param data_type type of data pointer, can be C_API_DTYPE_FLOAT32 or C_API_DTYPE_FLOAT64
* \param nrow number of rows
* \param ncol number columns
* \param is_row_major 1 for row major, 0 for column major
* \param predict_type
*          C_API_PREDICT_NORMAL: normal prediction, with transform (if needed)
*          C_API_PREDICT_RAW_SCORE: raw score
*          C_API_PREDICT_LEAF_INDEX: leaf index
* \param num_iteration number of iteration for prediction, <= 0 means no limit
* \param parameter Other parameters for the parameters, e.g. early stopping for prediction.
* \param out_len len of output result
* \param out_result used to set a pointer to array, should allocate memory before call this function
* \return 0 when succeed, -1 when failure happens
*/LIGHTGBM_C_EXPORT int LGBM_BoosterPredictForMatSingleRow(BoosterHandle handle,
832
833
834
835
836
837
838
839
840
                                                           const void* data,
                                                           int data_type,
                                                           int ncol,
                                                           int is_row_major,
                                                           int predict_type,
                                                           int num_iteration,
                                                           const char* parameter,
                                                           int64_t* out_len,
                                                           double* out_result);
841

842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
/*!
* \brief make prediction for an new data set
*        Note:  should pre-allocate memory for out_result,
*               for noraml and raw score: its length is equal to num_class * num_data
*               for leaf index, its length is equal to num_class * num_data * num_iteration
* \param handle handle
* \param data pointer to the data space
* \param data_type type of data pointer, can be C_API_DTYPE_FLOAT32 or C_API_DTYPE_FLOAT64
* \param nrow number of rows
* \param ncol number columns
* \param predict_type
*          C_API_PREDICT_NORMAL: normal prediction, with transform (if needed)
*          C_API_PREDICT_RAW_SCORE: raw score
*          C_API_PREDICT_LEAF_INDEX: leaf index
* \param num_iteration number of iteration for prediction, <= 0 means no limit
* \param parameter Other parameters for the parameters, e.g. early stopping for prediction.
* \param out_len len of output result
* \param out_result used to set a pointer to array, should allocate memory before call this function
* \return 0 when succeed, -1 when failure happens
*/
LIGHTGBM_C_EXPORT int LGBM_BoosterPredictForMats(BoosterHandle handle,
                                                 const void** data,
                                                 int data_type,
                                                 int32_t nrow,
                                                 int32_t ncol,
                                                 int predict_type,
                                                 int num_iteration,
                                                 const char* parameter,
                                                 int64_t* out_len,
                                                 double* out_result);
872

Guolin Ke's avatar
Guolin Ke committed
873
874
875
/*!
* \brief save model into file
* \param handle handle
wxchan's avatar
wxchan committed
876
* \param num_iteration, <= 0 means save all
Guolin Ke's avatar
Guolin Ke committed
877
* \param filename file name
wxchan's avatar
wxchan committed
878
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
879
*/
880
LIGHTGBM_C_EXPORT int LGBM_BoosterSaveModel(BoosterHandle handle,
881
                                            int start_iteration,
882
883
                                            int num_iteration,
                                            const char* filename);
Guolin Ke's avatar
Guolin Ke committed
884

885
886
887
888
889
890
891
892
893
894
/*!
* \brief save model to string
* \param handle handle
* \param num_iteration, <= 0 means save all
* \param buffer_len string buffer length, if buffer_len < out_len, re-allocate buffer
* \param out_len actual output length
* \param out_str string of model, need to pre-allocate memory before call this
* \return 0 when succeed, -1 when failure happens
*/
LIGHTGBM_C_EXPORT int LGBM_BoosterSaveModelToString(BoosterHandle handle,
895
                                                    int start_iteration,
896
                                                    int num_iteration,
897
898
                                                    int64_t buffer_len,
                                                    int64_t* out_len,
899
                                                    char* out_str);
900

wxchan's avatar
wxchan committed
901
902
903
/*!
* \brief dump model to json
* \param handle handle
904
* \param num_iteration, <= 0 means save all
wxchan's avatar
wxchan committed
905
906
* \param buffer_len string buffer length, if buffer_len < out_len, re-allocate buffer
* \param out_len actual output length
Guolin Ke's avatar
typo  
Guolin Ke committed
907
* \param out_str json format string of model, need to pre-allocate memory before call this
wxchan's avatar
wxchan committed
908
909
* \return 0 when succeed, -1 when failure happens
*/
910
LIGHTGBM_C_EXPORT int LGBM_BoosterDumpModel(BoosterHandle handle,
911
                                            int start_iteration,
912
                                            int num_iteration,
913
914
                                            int64_t buffer_len,
                                            int64_t* out_len,
915
                                            char* out_str);
916

Guolin Ke's avatar
Guolin Ke committed
917
/*!
Guolin Ke's avatar
Guolin Ke committed
918
* \brief Get leaf value
Guolin Ke's avatar
Guolin Ke committed
919
920
921
922
923
924
* \param handle handle
* \param tree_idx index of tree
* \param leaf_idx index of leaf
* \param out_val out result
* \return 0 when succeed, -1 when failure happens
*/
925
LIGHTGBM_C_EXPORT int LGBM_BoosterGetLeafValue(BoosterHandle handle,
926
927
928
                                               int tree_idx,
                                               int leaf_idx,
                                               double* out_val);
Guolin Ke's avatar
Guolin Ke committed
929
930
931
932
933
934
935
936
937

/*!
* \brief Set leaf value
* \param handle handle
* \param tree_idx index of tree
* \param leaf_idx index of leaf
* \param val leaf value
* \return 0 when succeed, -1 when failure happens
*/
938
LIGHTGBM_C_EXPORT int LGBM_BoosterSetLeafValue(BoosterHandle handle,
939
940
941
                                               int tree_idx,
                                               int leaf_idx,
                                               double val);
942

943
944
945
946
947
948
949
950
951
952
953
954
955
/*!
* \brief get model feature importance
* \param handle handle
* \param num_iteration, <= 0 means use all
* \param importance_type: 0 for split, 1 for gain
* \param out_results output value array
* \return 0 when succeed, -1 when failure happens
*/
LIGHTGBM_C_EXPORT int LGBM_BoosterFeatureImportance(BoosterHandle handle,
                                                    int num_iteration,
                                                    int importance_type,
                                                    double* out_results);

956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
/*!
* \brief Initilize the network
* \param machines represent the nodes, format: ip1:port1,ip2:port2
* \param local_listen_port
* \param listen_time_out
* \param num_machines
* \return 0 when succeed, -1 when failure happens
*/
LIGHTGBM_C_EXPORT int LGBM_NetworkInit(const char* machines,
                                       int local_listen_port,
                                       int listen_time_out,
                                       int num_machines);

/*!
* \brief Finalize the network
* \return 0 when succeed, -1 when failure happens
*/
LIGHTGBM_C_EXPORT int LGBM_NetworkFree();

975
976
LIGHTGBM_C_EXPORT int LGBM_NetworkInitWithFunctions(int num_machines, int rank,
                                                    void* reduce_scatter_ext_fun,
977
                                                    void* allgather_ext_fun);
978

Guolin Ke's avatar
Guolin Ke committed
979
980

#if defined(_MSC_VER)
981
#define THREAD_LOCAL __declspec(thread)
Guolin Ke's avatar
Guolin Ke committed
982
983
984
#else
#define THREAD_LOCAL thread_local
#endif
985
// exception handle and error msg
986
static char* LastErrorMsg() { static THREAD_LOCAL char err_msg[512] = "Everything is fine"; return err_msg; }
987

988
#pragma warning(disable : 4996)
989
inline void LGBM_SetLastError(const char* msg) {
wxchan's avatar
wxchan committed
990
  std::strcpy(LastErrorMsg(), msg);
991
992
}

993
#endif  // LIGHTGBM_C_API_H_