Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Loss of audio volume & clarity with noise #43

Open
viveksj opened this issue Jul 23, 2020 · 7 comments
Open

Loss of audio volume & clarity with noise #43

viveksj opened this issue Jul 23, 2020 · 7 comments

Comments

@viveksj
Copy link

viveksj commented Jul 23, 2020

I tested this on multiple audio files (16kHz telephony audio) with prop_decrease ranging from (0,0.1,0.5,0.75,1)

My 3 observations were:

  1. It does a decent job of removing consistent noise like windy audio.
  2. Not so good with noise bursts
  3. The final sample often has too low of a volume and isn't clear for additional processing (like transcription)

Could you help me identify if there's something wrong with my use of it or if there are any improvements that can be made.

(Also, I got floating point expected error so instead of using wavfile.read(), I used librosa.load(filepath,sr=None))

@timsainb
Copy link
Owner

Hi Vivek,

For 1 and 2, that is because this algorithm is designed for stationary noise (relatively constant noise).

For 3, you could renormalize after noise reduction. If you set the threshold too low, you're probably going to remove more signal with the noise as well.

For the floating point error, there should probably be a better warning for when you are using 16bit vs 32bit input in noisereduce, I should add that to a future release.

@viveksj
Copy link
Author

viveksj commented Aug 17, 2020

Just saw this, Thank you.

Wasn't aware of the stationary noise; That probably can't work with telephony disturbance.

I'll try 3 again.

@varunp2k
Copy link

Hi @viveksj
Did happen to find any solution which works for telephony disturbance?

@sergios-ferreira
Copy link

Is there a way to dynamically clean up audio? Should I use something like a neural network algorithm to train dynamic cleaning of noisy audios?

@timsainb
Copy link
Owner

That's one way of doing it. Stay tuned... I'm also planning on writing a non-stationary noise reduction version of this, which works well for preliminary results when I get some spare time.

@sergios-ferreira
Copy link

Tim, your knowledge is amazing and a project like this is very interesting! I will take a moment to study it better. Just to be clear in my mind would I be able to use this filter in real time (not necessarily recording)?

@DanTremonti
Copy link

DanTremonti commented Sep 21, 2023

In case of applying stationary noise reduce effect to an offline (non-realtime) audio signal (mono), I'm losing speech clarity.

Higher values of n_std_thresh_stationary started dampening the speech (kind of a muffling effect if you will) taking a hit in its crispness, whiltst reducing the stationary noise better (as expected). I've played around with other applicable parameters for the stationary case. Have finally settled on right combination of values for my use case with an acceptiible tradeoff between loss of crispness of speech and removal of noise.

Is there any adjustable parameter that I could have missed, that could make noise removal more aggressive over the noise frequency bands while staying less aggressive or softly smoothening over neighboring bands?

Small pointer, I did not face reduction in volume.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants