module LightGBM class Booster def initialize(model_file:) @handle = ::FFI::MemoryPointer.new(:pointer) if model_file out_num_iterations = ::FFI::MemoryPointer.new(:int) check_result FFI.LGBM_BoosterCreateFromModelfile(model_file, out_num_iterations, @handle) end ObjectSpace.define_finalizer(self, self.class.finalize(handle_pointer)) end def self.finalize(pointer) -> { FFI.LGBM_BoosterFree(pointer) } end def predict(input) raise TypeError unless input.is_a?(Array) singular = input.first.is_a?(Array) input = [input] unless singular data = ::FFI::MemoryPointer.new(:float, input.count * input.first.count) data.put_array_of_float(0, input.flatten) out_len = ::FFI::MemoryPointer.new(:int64) out_result = ::FFI::MemoryPointer.new(:double, input.count) parameter = "" check_result FFI.LGBM_BoosterPredictForMat(handle_pointer, data, 0, input.count, input.first.count, 1, 0, 0, parameter, out_len, out_result) out = out_result.read_array_of_double(out_len.read_int64) singular ? out : out.first end private def check_result(err) if err != 0 raise FFI.LGBM_GetLastError end end def handle_pointer @handle.read_pointer end end end