2014-08-30 10:26:41 +02:00

110 lines
4.3 KiB
C#

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Runtime.InteropServices;
namespace xgboost_sharp_wrapper
{
public class xgboost
{
private const string dll_path = "..\\x64\\Release\\";
[DllImport(dll_path + "xgboost_wrapper.dll", CallingConvention = CallingConvention.Cdecl)]
public static extern IntPtr XGDMatrixCreateFromFile(string fname, int silent);
public IntPtr SharpXGDMatrixCreateFromFile(string fname, int silent)
{
return XGDMatrixCreateFromFile(fname, silent);
}
/*!
* \brief set float vector to a content in info
* \param handle a instance of data matrix
* \param field field name, can be label, weight
* \param array pointer to float vector
* \param len length of array
*/
[DllImport(dll_path + "xgboost_wrapper.dll", CallingConvention = CallingConvention.Cdecl)]
public static extern void XGDMatrixSetFloatInfo(IntPtr handle, string field, IntPtr array, System.UInt32 len);
[DllImport(dll_path + "xgboost_wrapper.dll", CallingConvention = CallingConvention.Cdecl)]
public static extern void XGBoosterSetParam(IntPtr handle, string name, string value);
public void SharpXGBoosterSetParam(IntPtr handle, string name, string value)
{
XGBoosterSetParam(handle,name,value);
}
[DllImport(dll_path + "xgboost_wrapper.dll")]
public static extern IntPtr XGBoosterCreate(IntPtr[] dmats, System.UInt32 len);
public IntPtr SharpXGBoosterCreate(IntPtr[] dmats, System.UInt32 len)
{
return XGBoosterCreate(dmats, len);
}
[DllImport(dll_path + "xgboost_wrapper.dll")]
public static extern void XGBoosterUpdateOneIter(IntPtr handle, int iter, IntPtr dtrain);
public void SharpXGBoosterUpdateOneIter(IntPtr handle, int iter, IntPtr dtrain)
{
XGBoosterUpdateOneIter(handle, iter, dtrain);
}
[DllImport(dll_path + "xgboost_wrapper.dll")]
public static extern string XGBoosterEvalOneIter(IntPtr handle, int iter, IntPtr[] dmats,
string[] evnames, System.UInt32 len);
public string SharpXGBoosterEvalOneIter(IntPtr handle, int iter, IntPtr[] dmats,
string[] evnames, System.UInt32 len)
{
return XGBoosterEvalOneIter(handle, iter, dmats, evnames, len);
}
/*!
* \brief make prediction based on dmat
* \param handle handle
* \param dmat data matrix
* \param output_margin whether only output raw margin value
* \param len used to store length of returning result
*/
[DllImport(dll_path + "xgboost_wrapper.dll")]
public static extern IntPtr XGBoosterPredict(IntPtr handle, IntPtr dmat, int output_margin, ref System.UInt32 len);
public float[] SharpXGBoosterPredict(IntPtr handle, IntPtr dmat, int output_margin, System.UInt32 len)
{
IntPtr buf = XGBoosterPredict(handle, dmat, output_margin, ref len);
float[] buffer = new float[len];
Marshal.Copy(buf, buffer, 0, buffer.Length);
return buffer;
}
/*!
* \brief load model from existing file
* \param handle handle
* \param fname file name
*/
[DllImport(dll_path + "xgboost_wrapper.dll")]
public static extern void XGBoosterLoadModel(IntPtr handle, string fname);
/*!
* \brief save model into existing file
* \param handle handle
* \param fname file name
*/
[DllImport(dll_path + "xgboost_wrapper.dll")]
public static extern void XGBoosterSaveModel(IntPtr handle, string fname);
/*!
* \brief dump model, return array of strings representing model dump
* \param handle handle
* \param fmap name to fmap can be empty string
* \param out_len length of output array
* \return char *data[], representing dump of each model
*/
[DllImport(dll_path + "xgboost_wrapper.dll")]
public static extern string XGBoosterDumpModel(IntPtr handle, string fmap,
System.UInt32 out_len);
}
}