How to find the Relative Root Mean Square Error for the given data?
Ältere Kommentare anzeigen
I have some data as given below:
u=[-30 30 -50 50];% desired vector
low = [-90 -90 -90 -90];
up = [90 90 90 90];
b = low + (up - low) .* randn(1,4);% Estimated vetors
How will we find the Relative Root Mean Sqaure Error (RRMSE) for this? Further, what does the RRMSE show?
6 Kommentare
Manikanta Aditya
am 6 Mär. 2024
Bearbeitet: Manikanta Aditya
am 6 Mär. 2024
Hello,
The Relative Root Mean Square Error (RRMSE) is a normalized measure of the differences between values predicted by a model and the values actually observed. It is calculated as the Root Mean Square Error (RMSE) divided by the mean of the observed values.
Here’s how you can calculate the RRMSE in MATLAB for your given data:
u = [-30 30 -50 50]; % desired vector
low = [-90 -90 -90 -90];
up = [90 90 90 90];
b = low + (up - low) .* randn(1,4); % Estimated vectors
% Step 1: Calculate squared differences
squared_diffs = (u - b).^2;
% Step 2: Calculate mean of squared differences
mean_squared_diffs = mean(squared_diffs);
% Step 3: Calculate RMSE
rmse = sqrt(mean_squared_diffs);
% Steps 4 and 5: Calculate the square root of the mean squared desired values
mean_squared_u = mean(u.^2);
sqrt_mean_squared_u = sqrt(mean_squared_u);
% Step 6: Calculate RRMSE
rrmse = rmse / sqrt_mean_squared_u;
% Display the RRMSE
disp(['RRMSE: ', num2str(rrmse)]);
Hope this helps!
Sadiq Akbar
am 6 Mär. 2024
Manikanta Aditya
am 6 Mär. 2024
Hey,
Try out this example code and see once:
% Load the data from the .mat file
load('2sn0dB.mat', 'two'); % 'two' is the variable name in the file
% Your desired vector
u = [-30 30 -50 50]; % You might need to adjust this based on your actual desired values
% Reshape or adjust 'u' and 'two' if necessary to ensure they match in dimensions
% This step is crucial if 'u' and 'two' do not have the same dimensions
% For the sake of this example, let's assume 'two' is a 2D matrix where each row represents an estimation corresponding to 'u'
% Thus, we need to replicate 'u' to match the number of rows in 'two'
u_replicated = repmat(u, size(two, 1), 1); % Replicate 'u' to match 'two's dimensions
% Now, calculate the RRMSE
% Step 1: Calculate squared differences
squared_diffs = (u_replicated - two).^2;
% Step 2: Calculate mean of squared differences
mean_squared_diffs = mean(squared_diffs, 'all'); % Use 'all' to average over all elements
% Step 3: Calculate RMSE
rmse = sqrt(mean_squared_diffs);
% Step 4 and 5: Calculate the square root of the mean squared desired values
mean_squared_u = mean(u.^2);
sqrt_mean_squared_u = sqrt(mean_squared_u);
% Step 6: Calculate RRMSE
rrmse = rmse / sqrt_mean_squared_u;
% Display the RRMSE
disp(['RRMSE: ', num2str(rrmse)]);
Thanks.
Sadiq Akbar
am 7 Mär. 2024
Dyuman Joshi
am 7 Mär. 2024
Bearbeitet: Dyuman Joshi
am 7 Mär. 2024
@Sadiq Akbar, you should read the comments included in the code above.
Sadiq Akbar
am 8 Mär. 2024
Antworten (1)
Divyam
am 30 Okt. 2024
@Manikanta Aditya's comment (https://www.mathworks.com/matlabcentral/answers/2091226-how-to-find-the-relative-root-mean-square-error-for-the-given-data#comment_3090826) perfectly summarizes the workflow for finding the RRMSE.
To compare by drawing a plot for RMSE and RRMSE, you can simply use a barplot and check the values for each using the code below in addition to the code provided by Manikanta:
metrics = [rmse, rrmse];
metric_names = {'RMSE', 'RRMSE'};
figure;
bar(metrics);
set(gca, 'xticklabel', metric_names);
ylabel('Error');
title('Comparison of RMSE and RRMSE');
The key difference between RMSE and RRMSE is that RRMSE normalizes the RMSE value by dividing RMSE by the mean of the observed values. RRMSE is a better measure for comparing error values across different datasets. RRMSE thus makes the error relative to the size of the data and hence removes the influence of scaling on datasets.
Dataset 1:
observed = [100, 120, 150]
predicted = [98, 123, 147]
RMSE = 2.708
RRMSE = 0.021788
Dataset 2:
observed = [1000, 1200, 1500]
predicted = [980, 1230, 1470]
RMSE = 27.0801
RRMSE = 0.021788
Notice how the values for RMSE in the above example vary heavily with the values in the dataset but RRMSE stays constant despite the scaling.
Kategorien
Mehr zu Predictive Maintenance Toolbox finden Sie in Hilfe-Center und File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!