Am I computing cross entropy incorrectly?
Ältere Kommentare anzeigen
I am working on a neural network and would like to use cross entropy as my error function. I noticed from a previous question that MATLAB added this functionality starting with R2013b. I decided to test the crossentropy function by running the simple example provided in the documentation. The code is reprinted below for convenience:
[x,t] = iris_dataset;
net = patternnet(10);
net = train(net,x,t);
y = net(x);
perf = crossentropy(net,t,y)
When I run this code, I get perf = 0.0367. To verify this result, I ran the code:
ce = -mean(sum(t.*log(y)+(1-t).*log(1-y)))
which resulted in ce = 0.1100. Why are perf and ce unequal? Do I have an error in my calculation?
Akzeptierte Antwort
Weitere Antworten (3)
Greg Heath
am 21 Aug. 2014
You are using the Xent form for outputs and targets that do not have to sum to 1. The corresponding output transfer function is logsig.
For targets that are constrained to sum to 1, use softmax and the first tern of the sum.
For extensive discussions search in comp.ai.neural-nets using
greg cross entropy
Hope this helps.
Thank you for formally accepting my answer
Greg
2 Kommentare
Matthew Eicholtz
am 21 Aug. 2014
Bearbeitet: Matthew Eicholtz
am 21 Aug. 2014
Greg Heath
am 21 Aug. 2014
You are welcome for the reply. It did answer your question.
The next time you check make sure that you initialize the RNG before you train so that you can duplicate your calculation.
Or Shamir
am 23 Sep. 2017
ce = -t .* log(y);
perf = sum(ce(:))/numel(ce);
1 Kommentar
Greg Heath
am 26 Sep. 2017
isn't that the same as
perf = mean(ce(:)); % ?
Tian Li
am 13 Okt. 2017
0 Stimmen
ce = -t .* log(y); perf = sum(ce(:))/numel(ce);
This is the right answer for muti-class classification error problem
1 Kommentar
Greg Heath
am 15 Okt. 2017
Why do you think that is different from the last 2 answers???
Kategorien
Mehr zu Sequence and Numeric Feature Data Workflows finden Sie in Hilfe-Center und File Exchange
Produkte
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!