python - 如何使用 pybrain 黑盒优化训练神经网络以监督数据集?

标签 python artificial-intelligence neural-network pybrain

我玩过一些 pybrain,了解如何使用自定义架构生成神经网络,并使用反向传播算法将它们训练为有监督的数据集。

但是,我对优化算法以及任务、学习代理和环境的概念感到困惑。

例如: 如何使用 pybrain 遗传算法 (2) 实现诸如 (1) 的神经网络来对 XOR 数据集进行分类?

(1) pybrain.tools.shortcuts.buildNetwork(2, 3, 1)

(2) pybrain.optimization.GA()

最佳答案

我终于解决了!!一旦你知道如何,它总是很容易!

本质上,GA 的第一个参数是适应度函数(在文档中称为评估器),它必须将第二个参数(个体,在文档中称为可评估)作为其唯一参数。

在这个例子中将训练到 XOR

from pybrain.datasets.classification import ClassificationDataSet
# below line can be replaced with the algorithm of choice e.g.
# from pybrain.optimization.hillclimber import HillClimber
from pybrain.optimization.populationbased.ga import GA
from pybrain.tools.shortcuts import buildNetwork

# create XOR dataset
d = ClassificationDataSet(2)
d.addSample([0., 0.], [0.])
d.addSample([0., 1.], [1.])
d.addSample([1., 0.], [1.])
d.addSample([1., 1.], [0.])
d.setField('class', [ [0.],[1.],[1.],[0.]])

nn = buildNetwork(2, 3, 1)
# d.evaluateModuleMSE takes nn as its first and only argument
ga = GA(d.evaluateModuleMSE, nn, minimize=True)
for i in range(100):
    nn = ga.learn(0)[0]

上述脚本后的测试结果:

In [68]: nn.activate([0,0])
Out[68]: array([-0.07944574])

In [69]: nn.activate([1,0])
Out[69]: array([ 0.97635635])

In [70]: nn.activate([0,1])
Out[70]: array([ 1.0216745])

In [71]: nn.activate([1,1])
Out[71]: array([ 0.03604205])

关于python - 如何使用 pybrain 黑盒优化训练神经网络以监督数据集?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15751723/

相关文章:

algorithm - 同一玩家的 Alpha-beta 修剪连续 Action

c++ - 我不确定如何引用此神经网络训练方法中的权重

machine-learning - 使用多层感知器对不平衡数据集进行分类

python - Django prefetch_related 缓存不反射(reflect)更改

javascript - 光线转换使敌人跳跃

使用 Openshift 时出现 Python Rest Http 错误 (Flask)

python - 用于文本分类的 SkLearn 模型

neural-network - 人工神经网络能预测体育比赛的结果吗?

python - 当我们安装了较新版本的Python时,如何安装旧版本的Python

python - 为什么 Pytorch autograd 需要标量?