व्होकल रिमूव्हर सोर्स कोड पायथनची मुख्य समस्या ही आहे की तो ओपन सोर्स नाही. याचा अर्थ असा की कोड कोणासाठीही पुनरावलोकन करण्यासाठी आणि संभाव्यत: सुधारण्यासाठी उपलब्ध नाही. यामुळे सॉफ्टवेअरची विश्वासार्हता आणि एकूण गुणवत्तेमध्ये समस्या निर्माण होऊ शकतात.
import numpy as np import matplotlib.pyplot as plt from scipy.io import wavfile from scipy import signal from scipy.fftpack import fft, ifft import os def vocal_remover(filename): # read in audio file fs, data = wavfile.read(filename) # take the absolute value of the signal data = np.absolute(data) # find the length of the signal N = len(data) # take the Fourier Transform of the signal fourier = fft(data) # create a list of frequencies corresponding to the length of the signal freqs = np.fft.fftfreq(N, 1/fs) # find all frequencies above 1000 Hz (1 kHz) and set them to 0 in Fourier Transform for i in range (len(fourier)): if abs(freqs[i]) > 1000: fourier[i] = 0+0j # take inverse Fourier Transform to get back to time domain inverse_fourier = ifft(fourier).real return inverse_fourier
हा कोड विविध लायब्ररी आयात करत आहे ज्याचा वापर व्होकल_रिमूव्हर फंक्शनमध्ये केला जाईल.
vocal_remover फंक्शन फाईलच्या नावाचे इनपुट घेते आणि wavfile लायब्ररी वापरून ऑडिओ फाइलमध्ये वाचते.
ते नंतर सिग्नलचे परिपूर्ण मूल्य घेते आणि सिग्नलची लांबी शोधते.
त्यानंतर सिग्नलला फूरियर ट्रान्सफॉर्मद्वारे ठेवले जाते, जे सिग्नलच्या लांबीशी संबंधित फ्रिक्वेन्सीची सूची तयार करते.
1000 Hz वरील सर्व फ्रिक्वेन्सी फूरियर ट्रान्सफॉर्ममध्ये 0 वर सेट केल्या आहेत. याचे कारण असे की बहुतेक स्वर या फ्रिक्वेन्सीच्या श्रेणीमध्ये असतात.
टाइम डोमेनवर परत येण्यासाठी इनव्हर्स फूरियर ट्रान्सफॉर्म घेतले जाते आणि हा अंतिम सिग्नल फंक्शनद्वारे परत केला जातो.
पात्रांसह कार्य करा
Python मध्ये वर्णांसह कार्य करण्याचे काही मार्ग आहेत. वर्णाचे स्ट्रिंग प्रतिनिधित्व मिळवण्यासाठी str() फंक्शन वापरणे हा एक मार्ग आहे. उदाहरणार्थ, खालील कोड स्क्रीनवर “a” अक्षर मुद्रित करतो:
प्रिंट ("अक्षर 'अ'.")
पायथनमधील वर्णांसह कार्य करण्याचा दुसरा मार्ग म्हणजे chr() फंक्शन वापरणे. हे फंक्शन इनपुट म्हणून पूर्णांक घेते आणि त्या संख्येशी संबंधित वर्ण परत करते. उदाहरणार्थ, खालील कोड स्क्रीनवर “a” अक्षर मुद्रित करतो:
प्रिंट ("अक्षर 'a' आहे")
chr(1)
मजकूर आणि वस्तू
पायथनमध्ये, मजकूर युनिकोड वर्णांच्या क्रमाने दर्शविला जातो. ऑब्जेक्ट्स देखील युनिकोड वर्णांचे अनुक्रम आहेत, परंतु त्यामध्ये इतर डेटा प्रकार देखील असू शकतात, जसे की संख्या आणि स्ट्रिंग.