VBR के लिए FFmpeg का उपयोग करके wav में एमपी 3 कन्वर्ट करें


27

किसी mp3फ़ाइल को wavजिसकी बिटरेट परिवर्तनशील है उसे बदलने के लिए मुझे किस कमांड का उपयोग करना चाहिए । या बेहतर मुझे कैसे पता चलेगा कि स्रोत ऑडियो fixedबिटरेट है या नहीं variable?


3
मुझे नहीं लगता कि WAV फ़ाइल प्रारूप परिवर्तनीय बिट दरों का समर्थन करता है। चूंकि सभी एमपी 3 डिकोडर को मानकों के अनुरूप होने के लिए इसका समर्थन करना चाहिए, आपको किसी भी एमपी 3 फ़ाइल को एक निश्चित-बिटरेट डब्ल्यूएवी में बदलने में सक्षम होना चाहिए, हालांकि आपके परिणाम स्रोत एमपी 3 की गुणवत्ता और डब्ल्यूएवी के लिए चुने गए निश्चित-बिटरेट के आधार पर अलग-अलग होंगे। बनाया था। अधिकांश एमपी 3 प्लेइंग सॉफ्टवेयर, फ़ाइल के गुणों को देखने का एक तरीका प्रदान करता है, जिससे आप यह देख सकते हैं कि आप किस तरह की स्रोत फ़ाइलों के साथ काम कर रहे हैं।
मार्टीन्यू

और कमांड के बारे में क्या? आप क्या सलाह देते हैं?
सोहम दासगुप्ता

कृपया मार्टीन्यू का उत्तर फिर से पढ़ें। मैंने कुछ गलतियों को सुधारा। विशेष रूप से, आप PCM- एन्कोडेड WAV फ़ाइलों के लिए बिटरेट सेट नहीं कर सकते।
slhck

जवाबों:


36

आप ffprobe song.mp3कमांड का उपयोग करके अपनी इनपुट फ़ाइलों की बिटरेट के बारे में कुछ जानकारी प्राप्त कर सकते हैं । हालाँकि यह केवल आपको पहले फ्रेम की बिटरेट बताता है। एमपी 3 फ़ाइलों में वीबीआर आमतौर पर प्रत्येक फ्रेम के लिए बिटरेट को बदलकर लागू किया जाता है, इसलिए इसका उपयोग किया जा रहा है या नहीं, यह केवल पहले फ्रेम के हेडर को पढ़कर निर्धारित नहीं किया जा सकता है। मैं आमतौर पर कुछ अन्य ऑडियो फ़ाइल प्लेयर सॉफ़्टवेयर का उपयोग यह निर्धारित करने के लिए करता हूं कि क्या वीबीआर का उपयोग किया जा रहा है, क्योंकि कई प्रदर्शित करेंगे कि (उदाहरण के लिए Foobar2000 करता है)।

जब आप हानिपूर्ण आउटपुट कोडेक्स (जैसे MPEG-1 लेयर III या AAC) का उपयोग करते हैं, तो ffmpeg आउटपुट स्ट्रीम या एक वैरिएबल बिटरेट के लिए डिफ़ॉल्ट बिटरेट चुनता है। यह एनकोडर पर ही निर्भर करता है।

दोषरहित कोडेक्स के लिए, आप एक चर बिटरेट सेट नहीं कर सकते, क्योंकि प्रत्येक नमूना बिट्स की पूर्वनिर्धारित संख्या लेता है। ffmpeg -i song.mp3 song.wavइसलिए आपको 44,100 हर्ट्ज नमूना दर और प्रति नमूने 16 बिट्स के साथ एक पीसीएम-एन्कोडेड डब्ल्यूएवी फ़ाइल मिलेगी । यह लगभग 1411 kBit / s पूरे कंटेनर के लिए परिणाम देता है, संभवतः, एमपी 3 इनपुट फ़ाइल की तुलना में बहुत बड़ा है।

यदि आप PCM- एन्कोडेड WAV फ़ाइल के लिए एक छोटा फ़ाइल आकार चाहते हैं, तो कम बिट गहराई के साथ एक नमूना प्रारूप सेट करें ( -encodersउनमें से एक पूरी सूची के लिए विकल्प देखें ) और / या कम नमूना दर चुनें ( -ar 22050उदाहरण के लिए 22.05 kHz का उपयोग करें)।

यहाँ दोनों करने का एक उदाहरण दिया गया है:

ffmpeg -i song.mp3 -acodec pcm_u8 -ar 22050 song.wav

5
यदि आप एक WAV कंटेनर में PCM ऑडियो एनकोड करते हैं, तो आप बिटरेट सेट नहीं कर सकते। इसका कोई मतलब नहीं निकलता। पीसीएम एक असम्पीडित प्रारूप है - आप इसे प्रति सेकंड अधिक या कम बिट्स का उपयोग करने के लिए नहीं कह सकते हैं। आकार को समायोजित करने का एकमात्र तरीका एक अलग नमूना आकार ( -sample_fmtsविकल्प देखें ) का उपयोग करना है। -ar 128kइसका मतलब है कि नमूना दर सामान्य 44,1 या 48 kHz के बजाय 128,000 हर्ट्ज होगी।
slhck

12
आप शायद बेहतर कर रहे हैं ffmpeg -i song.mp3 song.wav, क्योंकि वह उपयुक्त बिटरेट का चयन करेगा (जो कि संभवतः 44.1khz है)। यदि आप
लहराते

@ naught101 सही था, इसे इनपुट डेटा के ffpmegअनुसार सही सैंपलिंग बिटरेट चुनने देना बेहतर है song.mp3। इस तरह से आउटपुट बिटमैप wavफ़ाइल में सबसे अच्छा बिटरेट होगा। इसका मतलब यह है कि फ़ाइल का आकार बहुत अच्छा होगा, लेकिन डेटा के ओवरफिटिंग के साथ: `स्ट्रीम # 0: 0: ऑडियो: एमपी 3, 44100 हर्ट्ज, स्टीरियो, s16p, 128 kb / s`
लोरेटोपरार

1
यह मान लेना काफी सुरक्षित है, पूछने वाले का उद्देश्य ऑडियो सीडी में परिणामी WAV- फाइलों को जलाना है। उसके लिए एकमात्र उपयुक्त आवृत्ति 44100 हर्ट्ज है, इसलिए -ar 44100यह भी जरूरी है कि अगर ffmpeg स्वचालित रूप से एक उपयुक्त 16-बिट कोडेक का उपयोग करेगा।
मिखाइल टी।

3

@ Naught101 टिप्पणी के अनुसार, मैं सर्वश्रेष्ठ का पता लगाने के लिए इस प्रक्रिया का पालन करूंगा acodec:

$ ffmpeg -formats | grep PCM 

 DE f32be           PCM 32-bit floating-point big-endian
 DE f32le           PCM 32-bit floating-point little-endian
 DE f64be           PCM 64-bit floating-point big-endian
 DE f64le           PCM 64-bit floating-point little-endian
 DE s16be           PCM signed 16-bit big-endian
 DE s16le           PCM signed 16-bit little-endian
 DE s24be           PCM signed 24-bit big-endian
 DE s24le           PCM signed 24-bit little-endian
 DE s32be           PCM signed 32-bit big-endian
 DE s32le           PCM signed 32-bit little-endian
 DE u16be           PCM unsigned 16-bit big-endian
 DE u16le           PCM unsigned 16-bit little-endian
 DE u24be           PCM unsigned 24-bit big-endian
 DE u24le           PCM unsigned 24-bit little-endian
 DE u32be           PCM unsigned 32-bit big-endian
 DE u32le           PCM unsigned 32-bit little-endian

इस बिंदु पर, के बीच चयन करने के लिए अपने मंच पर विचार big-endian, little-endian, बिटरेट चुनें:

$ ffmpeg -i sample.mp3 
[mp3 @ 0x7fb33180da00] Estimating duration from bitrate, this may be inaccurate
Input #0, mp3, from 'sample.mp3':
  Metadata:
    title           : Saturday
    artist          : Winterwood
    album           : Love In The Heart
    track           : 2/15
    TPA             : 1/1
    encoded_by      : iTunes 11.0.1
    genre           : Country & Folk
    date            : 1997
  Duration: 00:04:27.76, start: 0.000000, bitrate: 128 kb/s
    Stream #0:0: Audio: mp3, 44100 Hz, stereo, s16p, 128 kb/s

हम देख सकते हैं कि यह ऑडियो फ़ाइल एक है mp3(यह स्पष्ट नहीं है, इनपुट फ़ाइल के विस्तार के बावजूद, बस बाइट्स की जांच करें) की एक बिटरेट है 128 kb/s, कोडेक था s16p, नमूना था 44100 Hz, इसलिए हम तदनुसार चुनते हैं:

$ ffmpeg -i sample.mp3 -acodec pcm_s16le -ar 44100 sample.wav


Input #0, mp3, from 'sample.mp3':
  Metadata:
    title           : Saturday
    artist          : Winterwood
    album           : Love In The Heart
    track           : 2/15
    TPA             : 1/1
    encoded_by      : iTunes 11.0.1
    genre           : Country & Folk
    date            : 1997
  Duration: 00:04:27.76, start: 0.000000, bitrate: 128 kb/s
    Stream #0:0: Audio: mp3, 44100 Hz, stereo, s16p, 128 kb/s
File 'sample.wav' already exists. Overwrite ? [y/N] y
Output #0, wav, to 'sample.wav':
  Metadata:
    INAM            : Saturday
    IART            : Winterwood
    IPRD            : Love In The Heart
    IPRT            : 2/15
    TPA             : 1/1
    ITCH            : iTunes 11.0.1
    IGNR            : Country & Folk
    ICRD            : 1997
    ISFT            : Lavf56.4.101
    Stream #0:0: Audio: pcm_s16le ([1][0][0][0] / 0x0001), 44100 Hz, stereo, s16, 1411 kb/s
    Metadata:
      encoder         : Lavc56.1.100 pcm_s16le
Stream mapping:
  Stream #0:0 -> #0:0 (mp3 (native) -> pcm_s16le (native))
Press [q] to stop, [?] for help
size=   46125kB time=00:04:27.75 bitrate=1411.2kbits/s    
video:0kB audio:46125kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: 0.000457%

यदि आप मैक पर हैं, तो आप ऑडियो की जांच कर सकते हैं यदि इसकी white noiseशुरुआत / समाप्ति पर नहीं है (जब एमपी 3 मूल ऑडियो में कुछ मिसे / सेकंड के लिए कोई ऑडियो नहीं है):

$ afplay sample.wav

और निश्चित रूप से आप बिटमैप की दोहरी जांच कर सकते हैं:

$ ffmpeg -i sample.wav
Input #0, wav, from 'sample.wav':
  Metadata:
    artist          : Winterwood
    date            : 1997
    genre           : Country & Folk
    title           : Saturday
    album           : Love In The Heart
    track           : 2/15
    encoder         : Lavf56.4.101
    encoded_by      : iTunes 11.0.1
  Duration: 00:04:27.76, bitrate: 1411 kb/s
    Stream #0:0: Audio: pcm_s16le ([1][0][0][0] / 0x0001), 44100 Hz, 2 channels, s16, 1411 kb/s

0

मीडिया को परिवर्तित करने के लिए ffmpeg का उपयोग करें, पहले फ़ाइल विनिर्देश का उपयोग करें ffprobe का उपयोग करें। इस कमांड का उपयोग करें ffmpeg -i kimberly.wav -acodec pcm_s16le -ar 16000 -ac 1 song.wav

कहा पे -pcm_s16le is codec 16 bit conversion -ar is sampling rate (16000samples/sec) -ac no of audio channel

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.