c_api.h 42.1 KB
Newer Older
Guolin Ke's avatar
Guolin Ke committed
1
2
#ifndef LIGHTGBM_C_API_H_
#define LIGHTGBM_C_API_H_
ww's avatar
ww committed
3

4
#include <cstdint>
wxchan's avatar
wxchan committed
5
6
#include <cstring>

7
8
9
/*!
* 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
10
* 1. gradients and hessians.
11
* 2. Get current score for training data and validation
wxchan's avatar
wxchan committed
12
* The reason is because they are called frequently, the type-conversion on them maybe time cost.
13
14
*/

15
#include <LightGBM/export.h>
Guolin Ke's avatar
Guolin Ke committed
16

Guolin Ke's avatar
typo  
Guolin Ke committed
17
typedef void* DatasetHandle;
Guolin Ke's avatar
Guolin Ke committed
18
19
typedef void* BoosterHandle;

Guolin Ke's avatar
Guolin Ke committed
20
21
22
23
#define C_API_DTYPE_FLOAT32 (0)
#define C_API_DTYPE_FLOAT64 (1)
#define C_API_DTYPE_INT32   (2)
#define C_API_DTYPE_INT64   (3)
24
#define C_API_DTYPE_INT8    (4)
Guolin Ke's avatar
Guolin Ke committed
25
26
27
28

#define C_API_PREDICT_NORMAL     (0)
#define C_API_PREDICT_RAW_SCORE  (1)
#define C_API_PREDICT_LEAF_INDEX (2)
29
#define C_API_PREDICT_CONTRIB    (3)
30

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

Guolin Ke's avatar
Guolin Ke committed
39
// --- start Dataset interface
Guolin Ke's avatar
Guolin Ke committed
40
41
42
43

/*!
* \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
44
* \param parameters additional parameters
Guolin Ke's avatar
Guolin Ke committed
45
46
* \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
47
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
48
*/
49
LIGHTGBM_C_EXPORT int LGBM_DatasetCreateFromFile(const char* filename,
50
51
52
                                                 const char* parameters,
                                                 const DatasetHandle reference,
                                                 DatasetHandle* out);
Guolin Ke's avatar
Guolin Ke committed
53

54
/*!
55
56
* \brief create a empty dataset by sampling data.
* \param sample_data sampled data, grouped by the column.
57
* \param sample_indices indices of sampled data.
58
* \param ncol number columns
59
60
* \param num_per_col Size of each sampling column
* \param num_sample_row Number of sampled rows
61
62
63
64
65
* \param num_total_row number of total rows
* \param parameters additional parameters
* \param out created dataset
* \return 0 when succeed, -1 when failure happens
*/
66
67
68
69
70
71
72
73
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
74
75
76
77
78
79
80
81
82

/*!
* \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,
83
84
                                                    int64_t num_total_row,
                                                    DatasetHandle* out);
Guolin Ke's avatar
Guolin Ke committed
85
86
87
88
89
90
91
92
93
94
95
96

/*!
* \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,
97
98
99
100
101
                                           const void* data,
                                           int data_type,
                                           int32_t nrow,
                                           int32_t ncol,
                                           int32_t start_row);
Guolin Ke's avatar
Guolin Ke committed
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117

/*!
* \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,
118
119
120
121
122
123
124
125
126
                                                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
127

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

155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173

/*!
* \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,
                                                int num_rows,
                                                int64_t num_col,
                                                const char* parameters,
                                                const DatasetHandle reference,
                                                DatasetHandle* out);


Guolin Ke's avatar
Guolin Ke committed
174
175
176
/*!
* \brief create a dataset from CSC format
* \param col_ptr pointer to col headers
wxchan's avatar
wxchan committed
177
* \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
178
179
* \param indices findex
* \param data fvalue
wxchan's avatar
wxchan committed
180
181
* \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
182
* \param nelem number of nonzero elements in the matrix
wxchan's avatar
wxchan committed
183
* \param num_row number of rows
Guolin Ke's avatar
Guolin Ke committed
184
185
186
* \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
187
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
188
*/
189
LIGHTGBM_C_EXPORT int LGBM_DatasetCreateFromCSC(const void* col_ptr,
190
191
192
193
194
195
196
197
198
199
                                                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
200
201
202
203

/*!
* \brief create dataset from dense matrix
* \param data pointer to the data space
wxchan's avatar
wxchan committed
204
* \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
205
206
* \param nrow number of rows
* \param ncol number columns
207
* \param is_row_major 1 for row major, 0 for column major
Guolin Ke's avatar
Guolin Ke committed
208
* \param parameters additional parameters
Guolin Ke's avatar
Guolin Ke committed
209
210
* \param reference used to align bin mapper with other dataset, nullptr means don't used
* \param out created dataset
wxchan's avatar
wxchan committed
211
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
212
*/
213
LIGHTGBM_C_EXPORT int LGBM_DatasetCreateFromMat(const void* data,
214
215
216
217
218
219
220
                                                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
221

222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
/*!
* \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
243
244
245
246
247
248
249
250
251
/*!
* \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
*/
252
LIGHTGBM_C_EXPORT int LGBM_DatasetGetSubset(
253
  const DatasetHandle handle,
wxchan's avatar
wxchan committed
254
255
256
  const int32_t* used_row_indices,
  int32_t num_used_row_indices,
  const char* parameters,
Guolin Ke's avatar
typo  
Guolin Ke committed
257
  DatasetHandle* out);
wxchan's avatar
wxchan committed
258

Guolin Ke's avatar
Guolin Ke committed
259
260
261
262
263
264
265
/*!
* \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
*/
266
LIGHTGBM_C_EXPORT int LGBM_DatasetSetFeatureNames(
Guolin Ke's avatar
typo  
Guolin Ke committed
267
  DatasetHandle handle,
Guolin Ke's avatar
Guolin Ke committed
268
  const char** feature_names,
Guolin Ke's avatar
Guolin Ke committed
269
  int num_feature_names);
Guolin Ke's avatar
Guolin Ke committed
270

271
272
273
274
275
276
277
278

/*!
* \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
*/
279
LIGHTGBM_C_EXPORT int LGBM_DatasetGetFeatureNames(
280
281
  DatasetHandle handle,
  char** feature_names,
Guolin Ke's avatar
Guolin Ke committed
282
  int* num_feature_names);
283
284


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

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

300
301
302
303
304
305
306
307
308
/*!
* \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
309
310
/*!
* \brief set vector to a content in info
wxchan's avatar
wxchan committed
311
312
*        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
313
* \param handle a instance of dataset
wxchan's avatar
wxchan committed
314
* \param field_name field name, can be label, weight, group, group_id
315
* \param field_data pointer to vector
Guolin Ke's avatar
Guolin Ke committed
316
* \param num_element number of element in field_data
wxchan's avatar
wxchan committed
317
318
* \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
319
*/
320
LIGHTGBM_C_EXPORT int LGBM_DatasetSetField(DatasetHandle handle,
321
322
323
324
                                           const char* field_name,
                                           const void* field_data,
                                           int num_element,
                                           int type);
Guolin Ke's avatar
Guolin Ke committed
325
326

/*!
327
* \brief get info vector from dataset
Guolin Ke's avatar
Guolin Ke committed
328
329
330
331
* \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
332
333
* \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
334
*/
335
LIGHTGBM_C_EXPORT int LGBM_DatasetGetField(DatasetHandle handle,
336
337
338
339
                                           const char* field_name,
                                           int* out_len,
                                           const void** out_ptr,
                                           int* out_type);
Guolin Ke's avatar
Guolin Ke committed
340

341
342
343
344
345
346
347
348

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

Guolin Ke's avatar
Guolin Ke committed
349
350
351
352
/*!
* \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
353
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
354
*/
355
LIGHTGBM_C_EXPORT int LGBM_DatasetGetNumData(DatasetHandle handle,
356
                                             int* out);
Guolin Ke's avatar
Guolin Ke committed
357
358
359
360
361

/*!
* \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
362
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
363
*/
364
LIGHTGBM_C_EXPORT int LGBM_DatasetGetNumFeature(DatasetHandle handle,
365
                                                int* out);
Guolin Ke's avatar
Guolin Ke committed
366

367
368
369
370
371
372
373
374
375
/*!
* \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
376
377
378
379
// --- start Booster interfaces

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

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

401
402
403
404
405
406
407
408
409
410
411
/*!
* \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
*/
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
LIGHTGBM_C_EXPORT int LGBM_BoosterShuffleModels(BoosterHandle handle, int start_iter, int end_iter);
424

wxchan's avatar
wxchan committed
425
426
427
428
429
430
/*!
* \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
*/
431
LIGHTGBM_C_EXPORT int LGBM_BoosterMerge(BoosterHandle handle,
432
                                        BoosterHandle other_handle);
wxchan's avatar
wxchan committed
433
434
435
436
437
438
439

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

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

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

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

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

Guolin Ke's avatar
Guolin Ke committed
476
477
478
479
480
481
482
483
484
485
/*!
* \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
*/
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
486
487
488
489
490
491
/*!
* \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
492
* \param is_finished 1 means finised(cannot split any more)
wxchan's avatar
wxchan committed
493
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
494
*/
495
LIGHTGBM_C_EXPORT int LGBM_BoosterUpdateOneIterCustom(BoosterHandle handle,
496
497
498
                                                      const float* grad,
                                                      const float* hess,
                                                      int* is_finished);
Guolin Ke's avatar
Guolin Ke committed
499
500

/*!
wxchan's avatar
wxchan committed
501
* \brief Rollback one iteration
Guolin Ke's avatar
Guolin Ke committed
502
* \param handle handle
wxchan's avatar
wxchan committed
503
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
504
*/
505
LIGHTGBM_C_EXPORT int LGBM_BoosterRollbackOneIter(BoosterHandle handle);
wxchan's avatar
wxchan committed
506
507
508
509
510
511

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

514
515
516
517
518
519
520
521
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
*/
LIGHTGBM_C_EXPORT int LGBM_BoosterNumModelPerIteration(BoosterHandle handle, int* out_tree_per_iteration);

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

Guolin Ke's avatar
Guolin Ke committed
528
/*!
Guolin Ke's avatar
Guolin Ke committed
529
* \brief Get number of eval
wxchan's avatar
wxchan committed
530
531
532
* \param out_len total number of eval results
* \return 0 when succeed, -1 when failure happens
*/
533
LIGHTGBM_C_EXPORT int LGBM_BoosterGetEvalCounts(BoosterHandle handle, int* out_len);
wxchan's avatar
wxchan committed
534
535

/*!
wxchan's avatar
wxchan committed
536
* \brief Get name of eval
wxchan's avatar
wxchan committed
537
* \param out_len total number of eval results
Guolin Ke's avatar
typo  
Guolin Ke committed
538
* \param out_strs names of eval result, need to pre-allocate memory before call this
wxchan's avatar
wxchan committed
539
540
* \return 0 when succeed, -1 when failure happens
*/
541
LIGHTGBM_C_EXPORT int LGBM_BoosterGetEvalNames(BoosterHandle handle, int* out_len, char** out_strs);
wxchan's avatar
wxchan committed
542

wxchan's avatar
wxchan committed
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
/*!
* \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
*/
LIGHTGBM_C_EXPORT int LGBM_BoosterGetFeatureNames(BoosterHandle handle, int* out_len, char** out_strs);

/*!
* \brief Get number of features
* \param out_len total number of features
* \return 0 when succeed, -1 when failure happens
*/
LIGHTGBM_C_EXPORT int LGBM_BoosterGetNumFeature(BoosterHandle handle, int* out_len);

wxchan's avatar
wxchan committed
558
559
/*!
* \brief get evaluation for training data and validation data
Guolin Ke's avatar
Guolin Ke committed
560
561
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
562
* \param handle handle
wxchan's avatar
wxchan committed
563
* \param data_idx 0:training data, 1: 1st valid data, 2:2nd valid data ...
Guolin Ke's avatar
Guolin Ke committed
564
* \param out_len len of output result
wxchan's avatar
wxchan committed
565
566
* \param out_result float arrary contains result
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
567
*/
568
LIGHTGBM_C_EXPORT int LGBM_BoosterGetEval(BoosterHandle handle,
569
570
571
                                          int data_idx,
                                          int* out_len,
                                          double* out_results);
Guolin Ke's avatar
Guolin Ke committed
572
573
574
575
576
577
578
579
580
581

/*!
* \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
*/
582
LIGHTGBM_C_EXPORT int LGBM_BoosterGetNumPredict(BoosterHandle handle,
583
584
                                                int data_idx,
                                                int64_t* out_len);
Guolin Ke's avatar
Guolin Ke committed
585

Guolin Ke's avatar
Guolin Ke committed
586
/*!
Guolin Ke's avatar
Guolin Ke committed
587
* \brief Get prediction for training data and validation data
Guolin Ke's avatar
Guolin Ke committed
588
589
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
590
* \param handle handle
wxchan's avatar
wxchan committed
591
* \param data_idx 0:training data, 1: 1st valid data, 2:2nd valid data ...
Guolin Ke's avatar
Guolin Ke committed
592
* \param out_len len of output result
Guolin Ke's avatar
Guolin Ke committed
593
* \param out_result used to set a pointer to array, should allocate memory before call this function
wxchan's avatar
wxchan committed
594
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
595
*/
596
LIGHTGBM_C_EXPORT int LGBM_BoosterGetPredict(BoosterHandle handle,
597
598
599
                                             int data_idx,
                                             int64_t* out_len,
                                             double* out_result);
Guolin Ke's avatar
Guolin Ke committed
600

601
602
603
604
/*!
* \brief make prediction for file
* \param handle handle
* \param data_filename filename of data file
wxchan's avatar
wxchan committed
605
606
607
608
609
610
* \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
611
* \param parameter Other parameters for the parameters, e.g. early stopping for prediction.
612
* \param result_filename filename of result file
wxchan's avatar
wxchan committed
613
* \return 0 when succeed, -1 when failure happens
614
*/
615
LIGHTGBM_C_EXPORT int LGBM_BoosterPredictForFile(BoosterHandle handle,
616
617
618
619
                                                 const char* data_filename,
                                                 int data_has_header,
                                                 int predict_type,
                                                 int num_iteration,
620
                                                 const char* parameter,
621
                                                 const char* result_filename);
622

Guolin Ke's avatar
Guolin Ke committed
623
624
625
/*!
* \brief Get number of prediction
* \param handle handle
Guolin Ke's avatar
Guolin Ke committed
626
* \param num_row
Guolin Ke's avatar
Guolin Ke committed
627
628
629
630
631
* \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
632
* \param out_len length of prediction
Guolin Ke's avatar
Guolin Ke committed
633
634
* \return 0 when succeed, -1 when failure happens
*/
635
LIGHTGBM_C_EXPORT int LGBM_BoosterCalcNumPredict(BoosterHandle handle,
636
637
638
639
                                                 int num_row,
                                                 int predict_type,
                                                 int num_iteration,
                                                 int64_t* out_len);
Guolin Ke's avatar
Guolin Ke committed
640

Guolin Ke's avatar
Guolin Ke committed
641
642
/*!
* \brief make prediction for an new data set
Guolin Ke's avatar
Guolin Ke committed
643
*        Note:  should pre-allocate memory for out_result,
644
*               for normal and raw score: its length is equal to num_class * num_data
wxchan's avatar
wxchan committed
645
*               for leaf index, its length is equal to num_class * num_data * num_iteration
Guolin Ke's avatar
Guolin Ke committed
646
647
* \param handle handle
* \param indptr pointer to row headers
wxchan's avatar
wxchan committed
648
* \param indptr_type type of indptr, can be C_API_DTYPE_INT32 or C_API_DTYPE_INT64
Guolin Ke's avatar
Guolin Ke committed
649
650
* \param indices findex
* \param data fvalue
wxchan's avatar
wxchan committed
651
* \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
652
* \param nindptr number of rows in the matrix + 1
Guolin Ke's avatar
Guolin Ke committed
653
654
655
* \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
656
657
658
659
*          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
660
* \param parameter Other parameters for the parameters, e.g. early stopping for prediction.
wxchan's avatar
wxchan committed
661
* \param out_len len of output result
Guolin Ke's avatar
Guolin Ke committed
662
* \param out_result used to set a pointer to array, should allocate memory before call this function
wxchan's avatar
wxchan committed
663
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
664
*/
665
LIGHTGBM_C_EXPORT int LGBM_BoosterPredictForCSR(BoosterHandle handle,
666
667
668
669
670
671
672
673
674
675
                                                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,
676
                                                const char* parameter,
677
678
                                                int64_t* out_len,
                                                double* out_result);
Guolin Ke's avatar
Guolin Ke committed
679

680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
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
/*!
* \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,
                                                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);


Guolin Ke's avatar
Guolin Ke committed
721
722
723
/*!
* \brief make prediction for an new data set
*        Note:  should pre-allocate memory for out_result,
724
*               for normal and raw score: its length is equal to num_class * num_data
Guolin Ke's avatar
Guolin Ke committed
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
*               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
740
* \param parameter Other parameters for the parameters, e.g. early stopping for prediction.
Guolin Ke's avatar
Guolin Ke committed
741
742
743
744
* \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
*/
745
LIGHTGBM_C_EXPORT int LGBM_BoosterPredictForCSC(BoosterHandle handle,
746
747
748
749
750
751
752
753
754
755
                                                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,
756
                                                const char* parameter,
757
758
                                                int64_t* out_len,
                                                double* out_result);
Guolin Ke's avatar
Guolin Ke committed
759
760
761

/*!
* \brief make prediction for an new data set
wxchan's avatar
wxchan committed
762
*        Note:  should pre-allocate memory for out_result,
763
*               for normal and raw score: its length is equal to num_class * num_data
wxchan's avatar
wxchan committed
764
*               for leaf index, its length is equal to num_class * num_data * num_iteration
Guolin Ke's avatar
Guolin Ke committed
765
766
* \param handle handle
* \param data pointer to the data space
wxchan's avatar
wxchan committed
767
* \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
768
769
* \param nrow number of rows
* \param ncol number columns
Guolin Ke's avatar
Guolin Ke committed
770
* \param is_row_major 1 for row major, 0 for column major
Guolin Ke's avatar
Guolin Ke committed
771
* \param predict_type
wxchan's avatar
wxchan committed
772
773
774
775
*          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
776
* \param parameter Other parameters for the parameters, e.g. early stopping for prediction.
wxchan's avatar
wxchan committed
777
* \param out_len len of output result
Guolin Ke's avatar
Guolin Ke committed
778
* \param out_result used to set a pointer to array, should allocate memory before call this function
wxchan's avatar
wxchan committed
779
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
780
*/
781
LIGHTGBM_C_EXPORT int LGBM_BoosterPredictForMat(BoosterHandle handle,
782
783
784
785
786
787
788
                                                const void* data,
                                                int data_type,
                                                int32_t nrow,
                                                int32_t ncol,
                                                int is_row_major,
                                                int predict_type,
                                                int num_iteration,
789
                                                const char* parameter,
790
791
                                                int64_t* out_len,
                                                double* out_result);
Guolin Ke's avatar
Guolin Ke committed
792

793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
/*!
* \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,
                                                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);

825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
/*!
* \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);
                                                
Guolin Ke's avatar
Guolin Ke committed
856
857
858
/*!
* \brief save model into file
* \param handle handle
wxchan's avatar
wxchan committed
859
* \param num_iteration, <= 0 means save all
Guolin Ke's avatar
Guolin Ke committed
860
* \param filename file name
wxchan's avatar
wxchan committed
861
* \return 0 when succeed, -1 when failure happens
Guolin Ke's avatar
Guolin Ke committed
862
*/
863
LIGHTGBM_C_EXPORT int LGBM_BoosterSaveModel(BoosterHandle handle,
864
                                            int start_iteration,
865
866
                                            int num_iteration,
                                            const char* filename);
Guolin Ke's avatar
Guolin Ke committed
867

868
869
870
871
872
873
874
875
876
877
/*!
* \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,
878
                                                    int start_iteration,
879
                                                    int num_iteration,
880
881
                                                    int64_t buffer_len,
                                                    int64_t* out_len,
882
                                                    char* out_str);
883

wxchan's avatar
wxchan committed
884
885
886
/*!
* \brief dump model to json
* \param handle handle
887
* \param num_iteration, <= 0 means save all
wxchan's avatar
wxchan committed
888
889
* \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
890
* \param out_str json format string of model, need to pre-allocate memory before call this
wxchan's avatar
wxchan committed
891
892
* \return 0 when succeed, -1 when failure happens
*/
893
LIGHTGBM_C_EXPORT int LGBM_BoosterDumpModel(BoosterHandle handle,
894
                                            int start_iteration,
895
                                            int num_iteration,
896
897
                                            int64_t buffer_len,
                                            int64_t* out_len,
898
                                            char* out_str);
899

Guolin Ke's avatar
Guolin Ke committed
900
/*!
Guolin Ke's avatar
Guolin Ke committed
901
* \brief Get leaf value
Guolin Ke's avatar
Guolin Ke committed
902
903
904
905
906
907
* \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
*/
908
LIGHTGBM_C_EXPORT int LGBM_BoosterGetLeafValue(BoosterHandle handle,
909
910
911
                                               int tree_idx,
                                               int leaf_idx,
                                               double* out_val);
Guolin Ke's avatar
Guolin Ke committed
912
913
914
915
916
917
918
919
920

/*!
* \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
*/
921
LIGHTGBM_C_EXPORT int LGBM_BoosterSetLeafValue(BoosterHandle handle,
922
923
924
                                               int tree_idx,
                                               int leaf_idx,
                                               double val);
925

926
927
928
929
930
931
932
933
934
935
936
937
938
/*!
* \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);

939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
/*!
* \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();

958
959
LIGHTGBM_C_EXPORT int LGBM_NetworkInitWithFunctions(int num_machines, int rank,
                                                    void* reduce_scatter_ext_fun,
960
                                                    void* allgather_ext_fun);
961

Guolin Ke's avatar
Guolin Ke committed
962
963

#if defined(_MSC_VER)
964
#define THREAD_LOCAL __declspec(thread)
Guolin Ke's avatar
Guolin Ke committed
965
966
967
#else
#define THREAD_LOCAL thread_local
#endif
968
// exception handle and error msg
969
static char* LastErrorMsg() { static THREAD_LOCAL char err_msg[512] = "Everything is fine"; return err_msg; }
970

971
#pragma warning(disable : 4996)
972
inline void LGBM_SetLastError(const char* msg) {
wxchan's avatar
wxchan committed
973
  std::strcpy(LastErrorMsg(), msg);
974
975
}

976
#endif  // LIGHTGBM_C_API_H_