कमांड लाइन से वॉयस रिकॉर्डिंग की सफाई?


28

मैंने पहले रिकॉर्डिंग से शोर को हटाने के लिए ऑडेसिटी का उपयोग किया है , हालांकि इसमें कमांड लाइन का उपयोग बहुत सीमित है। मेरे पास ~ 100 लघु व्याख्यान वीडियो हैं जो मैं अगले कुछ महीनों में देखूंगा और उन सभी को एक बार में या देखने से पहले आवश्यकतानुसार साफ करना चाहूंगा।

क्या कोई कमांड लाइन उपकरण या लोकप्रिय भाषा पुस्तकालय है जिसे मैं यह करने के लिए उपयोग कर सकता हूं?

जवाबों:


17

पर एक नज़र डालें sox

उद्धरण man sox:

SoX - Sound eXchange, the Swiss Army knife of audio manipulation

[...]

SoX is a command-line audio processing  tool,  particularly  suited  to
making  quick,  simple  edits  and to batch processing.  If you need an
interactive, graphical audio editor, use audacity(1).

तो, यह एक अच्छी कमांड के लिए एक साथी कमांड लाइन के रूप में फिट होना चाहिए जो ऑडेसी के लिए वैकल्पिक हो!


रिकॉर्डिंग की सफाई के वास्तविक कार्य के बारे में, फ़िल्टर पर एक नज़र डालें noiseredजिसके लिए शोर में कमी फ़िल्टर ऑडेसिटी के बराबर है :

man sox | less -p 'noisered \['

           [...]
   noisered [profile-file [amount]]
           Reduce noise in the audio signal by profiling and filtering.
           This effect is moderately effective at  removing  consistent
           background  noise such as hiss or hum.  To use it, first run
           SoX with the noiseprof effect on a  section  of  audio  that
           ideally  would  contain silence but in fact contains noise -
           such sections are typically found at the  beginning  or  the
           end  of  a recording.  noiseprof will write out a noise pro‐
           file to profile-file, or to stdout if no profile-file or  if
           `-' is given.  E.g.
              sox speech.wav -n trim 0 1.5 noiseprof speech.noise-profil
           To  actually remove the noise, run SoX again, this time with
           the noisered effect; noisered will reduce noise according to
           a  noise  profile  (which  was generated by noiseprof), from
           profile-file, or from stdin if no profile-file or if `-'  is
           given.  E.g.
              sox speech.wav cleaned.wav noisered speech.noise-profile 0
           How  much  noise  should be removed is specified by amount-a
           number between 0 and 1 with a default of 0.5.   Higher  num‐
           bers will remove more noise but present a greater likelihood
           of removing wanted components of the audio  signal.   Before
           replacing  an  original  recording with a noise-reduced ver‐
           sion, experiment with different amount values  to  find  the
           optimal one for your audio; use headphones to check that you
           are happy with the results, paying particular  attention  to
           quieter sections of the audio.

           On  most systems, the two stages - profiling and reduction -
           can be combined using a pipe, e.g.
              sox noisy.wav -n trim 0 1 noiseprof | play noisy.wav noise
           [...]

7
दुर्भाग्य से मुझे यह वर्णन मिलता है कि मैनक्स में sox का उपयोग पढ़ने के लिए बहुत शोर करता है - उद्देश्य। क्या कोई बहुत सरल तरीका नहीं है, केवल एक ही आदेश के साथ अकेले घूमने के लिए।
शेवी

निश्चित रूप से, कोई समस्या नहीं है - बस एक साधारण वाक्य में लिखें जिसे आप बदलना चाहते हैं - लेकिन तकनीकी रूप से स्पष्ट होने के लिए पर्याप्त सटीक ... ठीक है, यह इस तरह काम नहीं करेगा क्योंकि आपको यह समझने की आवश्यकता है कि शोर क्या है, और सुधार के कौन से हिस्से हैं वह शोर जिसे आप दूर करना चाहते हैं, जिसे आप कम कर सकते हैं और ध्वनि की गुणवत्ता को कम कर सकते हैं अन्यथा शोर को कम कर सकते हैं। शोर में कमी के साथ चारों ओर घूमने के लिए, आपको अपने बाजीगर क्लबों को जानना होगा - शोर करने के प्रकारों को टटोलना, और जब वे मध्य हवा में टकराते हैं तो उन्हें कैसे संतुलित किया जा सकता है। फिर, sox आपका टूलबॉक्स और प्राथमिक चिकित्सा किट है!
वोल्कर सेगेल

12

स्वीकृत उत्तर व्यावहारिक उदाहरण नहीं देता है (पहले टिप्पणी देखें) तो मैं यहां एक देने की कोशिश कर रहा हूं। उपयुक्त के साथ उबंटू पर आपको स्थापित करना चाहिए soxऔर ऑडियो प्रारूप का समर्थन करना चाहिए

sox

soxप्रारूपों के लिए पहला इंस्टॉल और समर्थन (एमपी 3 सहित):

sudo apt install sox libsox-fmt-*

फिर इससे पहले कि आप फाइल / फाइलों पर अपना कमांड चलाएं, पहले आपको एक प्रोफाइल बनाने की जरूरत है, शोर का एक नमूना बनाएं, यह सबसे महत्वपूर्ण हिस्सा है जब आपको सबसे अच्छा समय चुनना होता है जब शोर होता है, तो सुनिश्चित करें कि आप नहीं करते हैं इस नमूने में आवाज़ (या संगीत / संकेत जिसे आप रखने की कोशिश करते हैं):

ffmpeg -i source.mp3 -ss 00:00:18 -t 00:00:20 noisesample.wav

अब उस स्रोत से एक प्रोफ़ाइल बनाएं:

sox noisesample.wav -n noiseprof noise_profile_file

और अंत में फाइल पर शोर को कम करें:

sox source.mp3 output.mp3 noisered noise_profile_file 0.31

जहां noise_profile_fileप्रोफ़ाइल है और 0.30मूल्य है। मान 0.20 और 0.30 के बीच सबसे अच्छा कहीं जाता है, 0.3 से अधिक बहुत आक्रामक है, 0.20 के तहत नरम है और बहुत शोर ऑडियो के लिए अच्छी तरह से काम करता है।

कोशिश करें और उस के साथ खेलें और यदि आपको अन्य सेटिंग ट्रिक्स मिलें और कृपया निष्कर्ष और ट्यूनिंग सेटिंग्स के साथ टिप्पणी करें।

उन्हें कैसे प्रोसेस करना है

यदि शोर समान है, तो आप सभी MP3 के लिए एक ही प्रोफ़ाइल का उपयोग कर सकते हैं

ls -r -1 *.mp3 | xargs -L1 -I{} sox {}  {}_noise_reduced.mp3  noisered noise_profile_file 0.31

या यदि कोई फ़ोल्डर संरचना है:

tree -fai . | grep -P ".mp3$" | xargs -L1 -I{} sox {}  {}_noise_reduced.mp3  noisered noise_profile_file 0.31

1
अगर यह बोले गए ऑडियो और अलग बाएं-दाएं चैनलों अनावश्यक है है, तो आप जोड़ सकते हैं remix -करने के लिए मिश्रण से नीचे सभी इनपुट चैनलों की मोनो
जेक बर्जर

2
@EduardFlorinescu आपका जवाब हाजिर है। मेरे पास प्रत्येक रिकॉर्डिंग की पृष्ठभूमि पर एक स्थिर शोर रिकॉर्डिंग थी। मैंने आपका उत्तर पढ़ा और, प्रोफ़ाइल बनाने के लिए मेरी ध्वनि फ़ाइल से पहले 2 सेकंड का उपयोग किया और अंत में, रिकॉर्डिंग से शोर को हटाने के लिए इसका उपयोग किया। इस लिए आपका बहुत - बहुत धन्यवाद।
अबरार हुसैन
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.