Offset removal from a sinusoidal wave

12 vues (au cours des 30 derniers jours)
Mohammad Zulqarnain
Mohammad Zulqarnain le 18 Fév 2021
Commenté : Star Strider le 19 Fév 2021
Hello Everyone,
I have an input waveform as shown in the figure in blue. It is a sinusoidal wave but due to different offests during positive and negative half cycles, it looks distorted. Basically, there is a big jump whenever signal changes direction from positive to negative and vice versa. So, I want to remove offsets from individual half cycles. I want an output which looks as red in the figure, which is just shifting of top and bottom parts of the waveform, taking zero as the baseline, excluding the big jumps. I have attached the input csv file as well. If anyone has any idea, how to approach it, please let me know, I will be thankful.

Réponse acceptée

Star Strider
Star Strider le 18 Fév 2021
Try this:
D1 = readmatrix('Output.csv');
x = 1:numel(D1);
D1HL = min(D1(D1>0));
D1HI = (D1>D1HL); % Logical Index
D1LL = max(D1(D1<0));
D1LI = (D1<D1LL); % Logical Index
minH = zeros(size(D1))+min(D1(D1HI));
maxL = zeros(size(D1))+max(D1(D1LI));
D1C = zeros(size(D1));
D1C(D1HI) = D1(D1HI)-minH(D1HI);
D1C(D1LI) = D1(D1LI)-maxL(D1LI);
figure
plot(x, D1C)
grid
xlim([0 100]) % Delete Or Change To See Larger (Or Entire) Vector
producing:
I plotted the points as well as the connecting lines to demonstrate the continuity. Change the line style to '-' to plot it without the points.
.
  4 commentaires
Mohammad Zulqarnain
Mohammad Zulqarnain le 19 Fév 2021
Thank you very much Star Strider. That works perfectly.
Star Strider
Star Strider le 19 Fév 2021
As always, my pleasure!

Connectez-vous pour commenter.

Plus de réponses (1)

darova
darova le 18 Fév 2021
I have an idea
clc,clear
x = linspace(0,20,100);
y = sin(x);
ind = -0.5<y & y<0.5;
x1 = x(~ind);
y1 = y(~ind);
y1 = y1 - sign(y1)*0.3;
plot(x,y)
hold on
plot(x1,y1,'.r')
hold off
  1 commentaire
Mohammad Zulqarnain
Mohammad Zulqarnain le 19 Fév 2021
Thank you darova for your response.

Connectez-vous pour commenter.

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by