Why is the cross-entropy in Neural Network trained w/ GPU different from that in CPU trained one?
1 回表示 (過去 30 日間)
古いコメントを表示
I've been trying to use GPU to train an neural network. I've followed the instruction (https://www.mathworks.com/help/nnet/ug/neural-networks-with-parallel-and-gpu-computing.html) to build an NN and everything looks working well.
data:image/s3,"s3://crabby-images/512fd/512fd8ca0707de89f32a7a49bc39797c76409eb1" alt=""
But when I plot performance, the cross-entropy doesn't change.
data:image/s3,"s3://crabby-images/27fc6/27fc63400e5e72d1c2f20d178b0920307da9afea" alt=""
The cross-entropy decreases continuously when I perform the same training with CPU.
data:image/s3,"s3://crabby-images/6917d/6917d78b3ab0a684edd33387065894dd741d7524" alt=""
What causes this difference? And how can I make GPU training works just as how it works in CPU? Here's my code.
x = nndata2gpu(data50');
t = nndata2gpu(label50');
trainFcn = 'trainscg';
hiddenLayerSize = 10;
net = patternnet(hiddenLayerSize, trainFcn);
net.divideParam.trainRatio = 70/100;
net.divideParam.valRatio = 15/100;
net.divideParam.testRatio = 15/100;
net = configure(net,data50',label50');
[net,tr] = train(net,x,t,'useGPU','yes');
0 件のコメント
回答 (1 件)
Naoya
2017 年 4 月 14 日
GPU モードと CPU モードでの実行結果の違いですが、乱数の状態の相違が原因であるものと推測します。 ニューラルネットワークの初期重みやバイアス値は、通常、rand 関数を用いた乱数で与えられます。 その為、乱数のシードを固定化しない場合は、gpu/cpu上限らず、で毎回、実行結果が異なることになります。
下記のように、 rng() でシードを固定化することより、実行結果が統一されるか確認できますでしょうか?
ex)
rng(10,'twister');
....
net = patternnet(hiddenLayerSize, trainFcn);
....
[net,tr] = train(net,x,t,'useGPU','yes');
rng(10,'twister');
....
net = patternnet(hiddenLayerSize, trainFcn);
....
[net,tr] = train(net,x,t,'useGPU','no');
参考
カテゴリ
Help Center および File Exchange で Sequence and Numeric Feature Data Workflows についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!