微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

是否可以将我的 ML.Net 模型存储在我的 MSSQL 数据库中?

如何解决是否可以将我的 ML.Net 模型存储在我的 MSSQL 数据库中?

我有一些使用 ML.Net 创建的预测模型,我想将它们与我的其余数据一起存储在我的数据库中。

模型按用户计算。

这是我当前的代码,将我的模型保存到我的本地文件夹:

        //MLNET
        var contextML = new MLContext();

        //Load Data
        var trainData = contextML.Data.LoadFromEnumerable<BankaccountBalanceData>(convertedTransactions);
        
        var testTrainSplit = contextML.Data.TrainTestSplit(trainData,testFraction: 0.2);
        //Build Model
        var pipeline = contextML.Transforms.Text.FeaturizeText("DateF","Date")
            .Append(contextML.Transforms.Concatenate("Features","DateF")
            .Append(contextML.Regression.Trainers.LbfgsPoissonRegression()));

        var model = pipeline.Fit(testTrainSplit.TrainSet);

        //Evaluate
        var predictions = model.Transform(testTrainSplit.TestSet);

        var metrics = contextML.Regression.Evaluate(predictions);

        //Predict
        var newData = new BankaccountBalanceData
        {
            Date = "2020-12-25"
        };

        var predictionFunction = contextML.Model.CreatePredictionEngine<BankaccountBalanceData,Prediction>(model);

        var prediction = predictionFunction.Predict(newData);

        contextML.Model.Save(model,trainData.Schema,"Model.zip");

我尝试的是加载模型并将其保存到我的 sqlServer 中的字节数组,但我不知道这是否可行,如果可行,如何将其读回 ITransformer 作为我的原始模型。

        DataViewSchema modelSchema;
        ITransformer trainedModel = contextML.Model.Load("model.zip",out modelSchema);
        user.Model = System.IO.File.ReadAllBytes(trainedModel.ToString());

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。