Port XGBoost model trained in python to another system written in C/C++

旧街凉风 提交于 2020-05-25 19:55:11

问题


Suppose I have successfully trained a XGBoost machine learning model in python.

x_train, x_test, y_train, y_test = train_test_split(x, y, test_size=0.2, random_state=7)
model = XGBClassifier()
model.fit(x_train, y_train)
y_pred = model.predict(x_test)

I want to port this model to another system which will be writte in C/C++. To do this, I need to know the internal logic of the XGboost trained model and translate them into a series of if-then-else statements like decision trees, if I am not wrong.

How can this be done? How to find out the internal logic of the XGBoost trained model to implement it on another system?

I am using python 3.7.


回答1:


m2cgen Is an awesome package that will convert Scikit-Learn compatible models into raw code. If you are using XGBoosts sklearn wrappers (which it looks like you are), then you can simply call something like this:

model = XGBClassifier()
model.fit(x_train, y_train)
 ...
import m2cgen as m2c

with open('./model.c','w') as f:
    code = m2c.export_to_c(model)
    f.write(code)

The really awesome thing about this package, is that it supports many different types of models, such as

  • Linear
  • SVM
  • Tree
  • Random Forest
  • Boosting

One more thing. m2cgen also supports multiple languages such as

  • C
  • C#
  • Dart
  • Go
  • Haskell
  • Java
  • JavaScript
  • PHP
  • PowerShell
  • Python
  • R
  • Visual Basic

I hope this helps!




回答2:


Someone wrote a script that does exactly this. Check out https://github.com/popcorn/xgb2cpp




回答3:


The recommended way of using any ml/dl model is making simple RESTful API with flask/bottle (these are lightweight python frameworks) and use them globally with any language.

You can also containerize RESTful API with docker in case you are developing a big project with a lot of models. Even containerized Restful APIs are used to deploy models on the cloud, ex- aws.

If you are interested in getting the logic behind any ml model, always have a look on its source code (on GitHub).



来源:https://stackoverflow.com/questions/58143075/port-xgboost-model-trained-in-python-to-another-system-written-in-c-c

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!