MATLAB: Findpeaks function won’t plot all peaks.

ecgfind peakspeakssignal processing

I am currently trying to plot all the peaks of my data. Unfortunatley the last peak fails to be plotted using this function. It also happens to be the penultimate value in my data set so I'm not sure if this is where the problem is. It would be apprciated if someone could take a look and see if they can figure out where I am going wrong.
Thanks very much.
ECG = load('ECG.csv')
Frequency = 350; %Frequency of ECG [Hz]
Time = (0:length(ECG)-1)/Frequency; %Number of samples divided by frquency
Amp = ECG(:,1); %ECG Amplitude
figure
plot(Time,Amp)
findpeaks(Amp,Time,'MinPeakProminence',100);
[pks,locs] = findpeaks(Amp,Time,'MinPeakProminence',100);
meanCycle = mean(diff(locs));
BPM = 60/meanCycle;
fprintf('%.2f', BPM)

Best Answer

Thje last R-wave is not actually a peak as findpeaks defines it.
It is necessary to get creative in order to isolate and define it:
ECG = load('ECG.csv')
Frequency = 350; %Frequency of ECG [Hz]
Time = (0:length(ECG)-1)/Frequency; %Number of samples divided by frquency
Amp = ECG(:,1); %ECG Amplitude
figure
% plot(Time,Amp)
findpeaks(Amp,Time,'MinPeakProminence',100);
[pks,locs] = findpeaks(Amp,'MinPeakProminence',100); % Return Indices Instead of Times
ofst = locs(end)+1; % Last Peak ‘loc’ + 1
[Rwaves,idx] = max(Amp(ofst:end)); % Maximum Of Remaining Segment Of ‘Amp’
meanCycle = mean(diff(Time(locs)));
BPM = 60/meanCycle;
fprintf('%.2f\n', BPM)
figure
plot(Time,Amp)
hold on
plot(Time(locs), Amp(locs), '^r', 'MarkerFaceColor','r') % Plot Peaks That ‘findpeaks’ Returns
plot(Time(idx+ofst), Rwaves, 'pr', 'MarkerFaceColor','r') % Plot Last Incomplete Peak
hold off
Producing:
1Findpeaks function won't plot all peaks - 2020 01 06.png
With the last ‘peak’ plotted with a pentagram.