Chainer – Python – 逻辑回归

我使用Python和Chainer创建了一个简单的逻辑回归模型,但对最终结果不太满意。因此,我想寻求一些帮助。有一个限制:我不希望用已有的功能替换已实现的功能。我知道Chainer中有几乎相同的损失函数,但我正在创建一个更复杂的模型,使用自定义的损失函数。代码在这里:

https://gist.github.com/kmjjacobs/62fc96ece695b47af8d667b060a64559

我希望模型代码尽可能简洁,但如你所见,call方法是损失方法的前向调用,我怀疑在训练循环中调用损失方法有更简洁的方法。我认为如果call方法输出预测结果,并有一个单独的损失方法来计算损失会更清晰。你对此有何看法?

我对转换函数也不是很确定。有没有更好的方法来实现相同的结果?

你对编写Chainer代码有任何评论或最佳实践吗?

提前感谢!


回答:

首先,你的主要问题是什么?是将损失函数和预测函数分开定义的最佳方式吗?

我看了你的代码,我认为init_scopeLinkChain中的功能是不同的。你不能在Chain中使用它来注册可学习的参数来达到这个目的。(你当前的使用方式适用于Link,而不适用于Chain。)

在你的情况下,我认为你可以直接在LogisticRegressionModel中使用chainer.links.Linear,或者你可以定义自己的Link类,其中包含可学习的参数W,并在LogisticRegressionModel中使用这个自定义的link类。

Related Posts

使用LSTM在Python中预测未来值

这段代码可以预测指定股票的当前日期之前的值,但不能预测…

如何在gensim的word2vec模型中查找双词组的相似性

我有一个word2vec模型,假设我使用的是googl…

dask_xgboost.predict 可以工作但无法显示 – 数据必须是一维的

我试图使用 XGBoost 创建模型。 看起来我成功地…

ML Tuning – Cross Validation in Spark

我在https://spark.apache.org/…

如何在React JS中使用fetch从REST API获取预测

我正在开发一个应用程序,其中Flask REST AP…

如何分析ML.NET中多类分类预测得分数组?

我在ML.NET中创建了一个多类分类项目。该项目可以对…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注