最佳答案
我正在使用 这个图书馆来实现一个学习代理。
我已经生成了培训案例,但是我不确定验证和测试集是什么。
老师说:
70% 应该是培训案例,10% 将是测试案例,其余20% 应该是验证案例。
编辑
我有这个训练代码,但是我不知道什么时候进行 别说了训练。
def train(self, train, validation, N=0.3, M=0.1):
# N: learning rate
# M: momentum factor
accuracy = list()
while(True):
error = 0.0
for p in train:
input, target = p
self.update(input)
error = error + self.backPropagate(target, N, M)
print "validation"
total = 0
for p in validation:
input, target = p
output = self.update(input)
total += sum([abs(target - output) for target, output in zip(target, output)]) #calculates sum of absolute diference between target and output
accuracy.append(total)
print min(accuracy)
print sum(accuracy[-5:])/5
#if i % 100 == 0:
print 'error %-14f' % error
if ? < ?:
break
编辑
使用验证数据我可以得到0.2的平均误差,也许经过20次训练迭代之后,这个误差应该是80% ?
平均误差 = 给定验证数据输入/验证数据大小的验证目标和输出之间的绝对差之和。
1
avg error 0.520395
validation
0.246937882684
2
avg error 0.272367
validation
0.228832420879
3
avg error 0.249578
validation
0.216253590304
...
22
avg error 0.227753
validation
0.200239244714
23
avg error 0.227905
validation
0.199875013416