How to Add random noise to a signal

1.051 visualizaciones (últimos 30 días)
lady bird
lady bird el 20 de Mayo de 2015
Comentada: Enac Gallardo-Diaz el 10 de Oct. de 2024
hello all
please can ou help me out adding a noise signal to my system.
i tried adding a sinus function , but i would like to add a random noise signal rather than the sinus function. I'm running simulation from 1 to 3000
if k>1000 & k<2000
dk(k)=sin(12*k*pi*ts);
x=A*x+B*u(k)+B*dk(k);
else
dk(k)=0;
x=A*x+B*u(k);
end
Thank you so much
Best regards
  2 comentarios
chris matthew
chris matthew el 14 de Mzo. de 2020
Movida: DGM el 4 de Mzo. de 2023
how to add noise to audio not for signal
Image Analyst
Image Analyst el 14 de Mzo. de 2020
Movida: DGM el 4 de Mzo. de 2023
What does that mean? Audio IS a signal. You can't add noise to audio without adding it to the signal that defines the audio waveform.

Iniciar sesión para comentar.

Respuestas (6)

Thorsten
Thorsten el 20 de Mayo de 2015
x = linspace(-2*pi, 2*pi);
plot(sin(x) + 0.5*rand(size(x)))
  6 comentarios
Tuhin Choudhury
Tuhin Choudhury el 16 de Mzo. de 2020
Editada: Tuhin Choudhury el 16 de Mzo. de 2020
Hi,
Thanks. This would be more of a flexible scaling of the noise w.r.t the input signal.
BR- Tuhin
Enac Gallardo-Diaz
Enac Gallardo-Diaz el 10 de Oct. de 2024
Hi,
This is a great solution. I want to point a subtle improvement. Using this algorithm you would end up with a noisy signal that is always above the original one. This is because rand() gives random numbers ranging from 0 to 1.
Usually, when you want to add noise to a given data you want the noisy function to be centered in the original. To do so you just need to generate random numbers going from -1 to 1. Simply replace
rand(size(noise_free_signal))
with
2*(rand(size(noise_free_signal))-0.5)

Iniciar sesión para comentar.


Image Analyst
Image Analyst el 20 de Mayo de 2015
So just use rand() instead of sin().
  4 comentarios
Prajakta Yeola
Prajakta Yeola el 29 de Oct. de 2017
Can we use the same code if audio signal is .wav file? i.e. if x is a .wav file
Image Analyst
Image Analyst el 29 de Oct. de 2017
Sure, just figure out the amplitude and add it
yNoisy = yOriginal + amplitude * rand(1, length(yOriginal));

Iniciar sesión para comentar.


KL
KL el 20 de Mayo de 2015
Did you check the gaussian noise function?
  2 comentarios
lady bird
lady bird el 20 de Mayo de 2015
i found a awgn function but i dont know how to use it in my case?
KL
KL el 20 de Mayo de 2015
There's a difference between wgn() and awgn(). With the latter, you add noise throughout the whole range. I understand you want to add noise between certain time intervals. So in this case, I would suggest to use wgn(). At the moment I do not have the toolbox to use this function. Anyhow you shall use this function to calculate the noiseSignal variable according to @Image Analyst's code.

Iniciar sesión para comentar.


Aparna Gupta
Aparna Gupta el 21 de Jun. de 2017
Can anyone please help me with the code to add awgn noise to an eeg signal,which i have taken from a database and the file is of .mat type?
  1 comentario
Image Analyst
Image Analyst el 21 de Jun. de 2017
Yes, probably. You can post the code in a new question.

Iniciar sesión para comentar.


Mohammad Sohail Khan
Mohammad Sohail Khan el 3 de Nov. de 2017
Editada: DGM el 4 de Mzo. de 2023
t = 0:pi/100:40;
x = cos(pi/10*t)+0.5*randn(size(t));
plot(t,x)
Then you know where pi/2, 3pi/4 etc are.

Adewale Obaro
Adewale Obaro el 24 de Sept. de 2018
Editada: DGM el 4 de Mzo. de 2023
N = 1000;
t = 0:1/N:2;
x = sin(2*pi*5*t);
Noise = x + randn(1,N)';
plot(t,Noise);
title('Noise in the Amplitude interval (0,0,1,0)');
ylabel('Amplitude [m]')
xlabel('Time [s]')

Categorías

Más información sobre Large Files and Big Data en Help Center y File Exchange.

Etiquetas

Community Treasure Hunt

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

Start Hunting!

Translated by