सोडवले: व्होकल रिमूव्हर सोर्स कोड पायथन

व्होकल रिमूव्हर सोर्स कोड पायथनची मुख्य समस्या ही आहे की तो ओपन सोर्स नाही. याचा अर्थ असा की कोड कोणासाठीही पुनरावलोकन करण्यासाठी आणि संभाव्यत: सुधारण्यासाठी उपलब्ध नाही. यामुळे सॉफ्टवेअरची विश्वासार्हता आणि एकूण गुणवत्तेमध्ये समस्या निर्माण होऊ शकतात.

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)

मजकूर आणि वस्तू

पायथनमध्ये, मजकूर युनिकोड वर्णांच्या क्रमाने दर्शविला जातो. ऑब्जेक्ट्स देखील युनिकोड वर्णांचे अनुक्रम आहेत, परंतु त्यामध्ये इतर डेटा प्रकार देखील असू शकतात, जसे की संख्या आणि स्ट्रिंग.

संबंधित पोस्ट:

एक टिप्पणी द्या