As Dan pointed out in his comment, precision and recall are usually defined for binary classification problems only.
But you can calculate precision and recall separately for each class. Let's annotate your confusion matrix a little bit:
| true |
| | seto | vers | virg |
-----------------------------------
| seto | 50 0 0
predicted | vers | 0 48 2
| virg | 0 4 46
Here I assumed the usual convention holds, i.e. columns are used for true values and rows for values predicted by your learning algorithm. (If your matrix was built the other way round, simply take the transpose of the confusion matrix.)
The true positives (tp(i)
) for each class (=row/column index) i
is given by the diagonal element in that row/column. The true negatives (tn
) then are given by the sum of the remaining diagonal elements. Note that we simply define the negatives for each class i
as "not class i
".
If we define false positives (fp
) and false negatives (fn
) analogously as the sum of off-diagonal entries in a given row or column, respectively, we can calculate precision and recall for each class:
precision(seto) = tp(seto) / (tp(seto) + fp(seto)) = 50 / (50 + (0 + 0)) = 1.0
precision(vers) = 48 / (48 + (0 + 2)) = 0.96
precision(virg) = 46 / (46 + (0 + 4)) = 0.92
recall(seto) = tp(seto) / (tp(seto) + fn(seto)) = 50 / (50 + (0 + 0)) = 1.0
recall(vers) = 48 / (48 + (0 + 4)) = 0.9231
recall(virg) = 46 / (46 + (0 + 2)) = 0.9583
Here I used the class names instead of the row indices for illustration.
Please have a look at the answers to this question for further information on performance measures in the case of multi-class classification problems - particularly if you want to end up with single number instead of one number for each class. Of course, the easiest way to do this is just averaging the values for each class.
Update
I realized that you were actually looking for a Matlab function to do this. I don't think there is any built-in function, and on the Matlab File Exchange I only found a function for binary classification problems. However, the task is so easy you can easily define your own functions like so:
function y = precision(M)
y = diag(M) ./ sum(M,2);
end
function y = recall(M)
y = diag(M) ./ sum(M,1)';
end
This will return a column vector containing the precision and recall values for each class, respectively. Now you can simply call
>> mean(precision(M))
ans =
0.9600
>> mean(recall(M))
ans =
0.9605
to obtain the average precision and recall values of your model.