我有一个 90×8 的数据集,我从 90 个字符图像(即数字 1-9)中提取特征(通过对每个 10×10 单元格中的 1 求和)。每一行代表一个图像。 我正在尝试使用以下代码来训练神经网络并识别新的输入图像(即 1 到 9 之间的数字):
net.trainFcn='traingdx';
net.performFcn='sse';
net.trainParam.goal=0.1;
net.trainParam.show=20;
net.trainParam.epochs=5000;
net.trainParam.mc=0.95;
net =newff(minmax(datasetNormalized'),[20 9],{'logsig' 'logsig'});
T=reshape(repmat([1:9],10,1),1,90);
[net,tr]=train(net,datasetNormalized,T);
之后我想使用以下内容来使用经过训练的网络来识别新图像。 m是也经过特征提取的图像字符。
[a,m]=max(sim(net,m));
disp(b);
我收到以下错误,但我不知道如何解决它:
使用 trainlm 时出错(第 109 行)
输入和目标具有不同数量的样本。
网络/列车错误(第 106 行)[net,tr] = feval(net.trainFcn,net,X,T,Xi,Ai,EW,net.trainParam);
神经网络错误(第 55 行)[net,tr]=train(net,datasetNormalized,T);
注意:datasetNormalized 是我在 [0,1] 中标准化的数据集。 哪个部分导致了问题?
输入和目标具有不同数量的样本。看来是问题所在
T=reshape(repmat([1:9],10,1),1,90) --> T=reshape(repmat([1:9],10,1),90,1)
[net,tr]=train(net,datasetNormalized,T); --> [net,tr]=train(net,datasetNormalized',T);
T 将用作网络的目标;因此,根据朋友的建议,我将 T 定义为 9*90 数组,前 10 列的第一行为 1,其他行为零,后 10 列的第二行为 1,依此类推开
T=zeros(9,90);
for j=1:90
i=ceil(j/10);
T(i,j)=1;
end
[net,tr]=train(net,datasetNormalized',T);
这解决了我在训练网络时遇到的错误,尽管我仍然不确定它将如何映射到输入字符并确定它们。