पायथन के साथ एआई - भाषण मान्यता

इस अध्याय में, हम पायथन के साथ एआई का उपयोग करके भाषण मान्यता के बारे में जानेंगे।

भाषण वयस्क मानव संचार का सबसे बुनियादी साधन है। भाषण प्रसंस्करण का मूल लक्ष्य एक मानव और एक मशीन के बीच बातचीत प्रदान करना है।

भाषण प्रसंस्करण प्रणाली में मुख्य रूप से तीन कार्य होते हैं -

  • First, वाक् पहचान जो मशीन को शब्दों, वाक्यांशों और वाक्यों को पकड़ने की अनुमति देता है

  • Second, प्राकृतिक भाषा प्रसंस्करण मशीन को यह समझने की अनुमति देता है कि हम क्या बोलते हैं, और

  • Third, भाषण संश्लेषण मशीन को बोलने की अनुमति देने के लिए।

यह अध्याय इस पर केंद्रित है speech recognitionमनुष्य द्वारा बोले जाने वाले शब्दों को समझने की प्रक्रिया। याद रखें कि भाषण संकेतों को एक माइक्रोफोन की मदद से कैप्चर किया जाता है और फिर इसे सिस्टम द्वारा समझना पड़ता है।

एक भाषण पहचानकर्ता का निर्माण

भाषण मान्यता या स्वचालित भाषण मान्यता (एएसआर) रोबोटिक्स जैसी एआई परियोजनाओं के लिए ध्यान का केंद्र है। एएसआर के बिना, एक मानव के साथ बातचीत करने वाले संज्ञानात्मक रोबोट की कल्पना करना संभव नहीं है। हालांकि, भाषण पहचानकर्ता का निर्माण करना काफी आसान नहीं है।

भाषण पहचान प्रणाली विकसित करने में कठिनाइयाँ

उच्च गुणवत्ता वाली भाषण मान्यता प्रणाली विकसित करना वास्तव में एक कठिन समस्या है। भाषण मान्यता प्रौद्योगिकी की कठिनाई को मोटे तौर पर कई आयामों के साथ चित्रित किया जा सकता है जैसा कि नीचे चर्चा की गई है -

  • Size of the vocabulary- शब्दावली का आकार ASR विकसित करने में आसानी को प्रभावित करता है। बेहतर समझ के लिए शब्दावली के निम्नलिखित आकारों पर विचार करें।

    • एक छोटे आकार की शब्दावली में 2-100 शब्द होते हैं, उदाहरण के लिए, एक आवाज-मेनू प्रणाली में

    • एक मध्यम आकार की शब्दावली में कई 100 से 1,000 शब्द होते हैं, उदाहरण के लिए, डेटाबेस-पुनर्प्राप्ति कार्य के रूप में

    • एक बड़े आकार की शब्दावली में कई हजार शब्द होते हैं, जैसे कि एक सामान्य श्रुतलेख कार्य में।

    ध्यान दें, शब्दावली का आकार जितना बड़ा होगा, मान्यता प्रदर्शन करना उतना ही कठिन होगा।

  • Channel characteristics- चैनल की गुणवत्ता भी एक महत्वपूर्ण आयाम है। उदाहरण के लिए, मानव भाषण में पूर्ण आवृत्ति रेंज के साथ उच्च बैंडविड्थ होता है, जबकि एक टेलीफोन भाषण में सीमित आवृत्ति रेंज के साथ कम बैंडविड्थ होता है। ध्यान दें कि यह बाद में कठिन है।

  • Speaking mode- एक एएसआर विकसित करने में आसानी भी बोलने वाले मोड पर निर्भर करती है, यह है कि क्या भाषण अलग-अलग शब्द मोड में है, या कनेक्टेड वर्ड मोड, या निरंतर भाषण मोड में है। ध्यान दें कि एक निरंतर भाषण को पहचानना कठिन है।

  • Speaking style- एक वाक् भाषण औपचारिक शैली में हो सकता है, या आकस्मिक शैली के साथ सहज और संवादात्मक हो सकता है। उत्तरार्द्ध को पहचानना कठिन है।

  • Speaker dependency- भाषण स्पीकर पर निर्भर, स्पीकर अनुकूली या स्वतंत्र स्पीकर हो सकता है। एक वक्ता स्वतंत्र निर्माण के लिए सबसे कठिन है।

  • Type of noise- ASR विकसित करते समय विचार करने के लिए शोर एक अन्य कारक है। ध्वनि अनुपात के संकेत विभिन्न श्रेणियों में हो सकते हैं, जो ध्वनिक वातावरण पर निर्भर करता है जो कम बनाम अधिक पृष्ठभूमि शोर का अवलोकन करता है -

    • यदि शोर अनुपात का संकेत 30dB से अधिक है, तो इसे उच्च श्रेणी माना जाता है

    • यदि शोर अनुपात का संकेत 30dB से 10db के बीच होता है, तो इसे मध्यम SNR माना जाता है

    • यदि शोर अनुपात का संकेत 10dB से कम है, तो इसे कम रेंज माना जाता है

    उदाहरण के लिए, अन्य वक्ताओं द्वारा पृष्ठभूमि के शोर जैसे स्थिर, गैर-मानवीय शोर, पृष्ठभूमि भाषण और क्रॉसस्टॉक भी समस्या की कठिनाई में योगदान करते हैं।

  • Microphone characteristics- माइक्रोफोन की गुणवत्ता अच्छी, औसत या औसत से कम हो सकती है। इसके अलावा, मुंह और माइक्रो-फोन के बीच की दूरी अलग-अलग हो सकती है। इन कारकों को मान्यता प्रणालियों के लिए भी माना जाना चाहिए।

इन कठिनाइयों के बावजूद, शोधकर्ताओं ने भाषण के विभिन्न पहलुओं पर बहुत काम किया जैसे कि भाषण संकेत को समझना, स्पीकर, और उच्चारण की पहचान करना।

भाषण पहचानकर्ता बनाने के लिए आपको नीचे दिए गए चरणों का पालन करना होगा -

ऑडियो सिग्नल विज़ुअलाइज़ करना - एक फ़ाइल से पढ़ना और उस पर काम करना

भाषण पहचान प्रणाली के निर्माण में यह पहला कदम है क्योंकि यह इस बात की समझ देता है कि ऑडियो सिग्नल कैसे संरचित है। ऑडियो संकेतों के साथ काम करने के लिए कुछ सामान्य कदम इस प्रकार हैं -

रिकॉर्डिंग

जब आपको किसी फाइल से ऑडियो सिग्नल पढ़ना हो, तो उसे पहले माइक्रोफ़ोन का उपयोग करके रिकॉर्ड करें।

सैम्पलिंग

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

उदाहरण

निम्न उदाहरण पायथन का उपयोग करते हुए, एक ऑडियो सिग्नल का विश्लेषण करने के लिए एक चरणबद्ध दृष्टिकोण दिखाता है, जो एक फ़ाइल में संग्रहीत है। इस ऑडियो सिग्नल की आवृत्ति 44,100 HZ है।

यहां दिखाए गए अनुसार आवश्यक पैकेज आयात करें -

import numpy as np
import matplotlib.pyplot as plt
from scipy.io import wavfile

अब, संग्रहीत ऑडियो फ़ाइल पढ़ें। यह दो मान लौटाएगा: नमूना आवृत्ति और ऑडियो सिग्नल। ऑडियो फ़ाइल का पथ प्रदान करें जहाँ इसे संग्रहीत किया गया है, जैसा कि यहाँ दिखाया गया है -

frequency_sampling, audio_signal = wavfile.read("/Users/admin/audio_file.wav")

दिखाए गए आदेशों का उपयोग करते हुए ऑडियो सिग्नल, डेटा प्रकार के सिग्नल और इसकी अवधि के नमूने की आवृत्ति जैसे मापदंडों को प्रदर्शित करें -

print('\nSignal shape:', audio_signal.shape)
print('Signal Datatype:', audio_signal.dtype)
print('Signal duration:', round(audio_signal.shape[0] / 
float(frequency_sampling), 2), 'seconds')

इस कदम में नीचे दिखाए गए संकेत को सामान्य करना शामिल है -

audio_signal = audio_signal / np.power(2, 15)

इस चरण में, हम इस संकेत से पहले 100 मानों को कल्पना करने के लिए निकाल रहे हैं। इस प्रयोजन के लिए निम्नलिखित कमांड का उपयोग करें -

audio_signal = audio_signal [:100]
time_axis = 1000 * np.arange(0, len(signal), 1) / float(frequency_sampling)

अब, नीचे दिए गए आदेशों का उपयोग करके संकेत की कल्पना करें -

plt.plot(time_axis, signal, color='blue')
plt.xlabel('Time (milliseconds)')
plt.ylabel('Amplitude')
plt.title('Input audio signal')
plt.show()

आप ऊपर दिए गए ऑडियो सिग्नल के लिए निकाले गए आउटपुट ग्राफ और डेटा को देख पाएंगे जैसा कि यहाँ चित्र में दिखाया गया है

Signal shape: (132300,)
Signal Datatype: int16
Signal duration: 3.0 seconds

ऑडियो सिग्नल की विशेषता: आवृत्ति डोमेन में बदलना

ऑडियो सिग्नल की विशेषता में टाइम डोमेन सिग्नल को फ़्रीक्वेंसी डोमेन में बदलना और इसके फ़्रीक्वेंसी घटकों को समझना शामिल है। यह एक महत्वपूर्ण कदम है क्योंकि यह सिग्नल के बारे में बहुत सारी जानकारी देता है। आप इस परिवर्तन को करने के लिए फूरियर ट्रांसफॉर्म जैसे गणितीय उपकरण का उपयोग कर सकते हैं।

उदाहरण

निम्न उदाहरण दिखाता है, चरण-दर-चरण, सिग्नल को कैसे चिह्नित करना है, पायथन का उपयोग करके, जो एक फ़ाइल में संग्रहीत है। ध्यान दें कि यहाँ हम फूरियर ट्रांसफॉर्म गणितीय टूल का उपयोग करके इसे फ़्रीक्वेंसी डोमेन में परिवर्तित कर सकते हैं।

आवश्यक पैकेज आयात करें, जैसा कि यहाँ दिखाया गया है -

import numpy as np
import matplotlib.pyplot as plt
from scipy.io import wavfile

अब, संग्रहीत ऑडियो फ़ाइल पढ़ें। यह दो मान लौटाएगा: नमूना आवृत्ति और ऑडियो सिग्नल। जहाँ यह कमांड में दिखाया गया है, वहाँ ऑडियो फ़ाइल का पथ प्रदान करें -

frequency_sampling, audio_signal = wavfile.read("/Users/admin/sample.wav")

इस चरण में, हम नीचे दिए गए आदेशों का उपयोग करते हुए, ऑडियो सिग्नल के नमूने की आवृत्ति, डेटा प्रकार के संकेत और इसकी अवधि जैसे मापदंडों को प्रदर्शित करेंगे।

print('\nSignal shape:', audio_signal.shape)
print('Signal Datatype:', audio_signal.dtype)
print('Signal duration:', round(audio_signal.shape[0] / 
float(frequency_sampling), 2), 'seconds')

इस चरण में, हमें सिग्नल को सामान्य करने की आवश्यकता है, जैसा कि निम्नलिखित कमांड में दिखाया गया है -

audio_signal = audio_signal / np.power(2, 15)

इस चरण में सिग्नल की लंबाई और आधी लंबाई को निकालना शामिल है। इस प्रयोजन के लिए निम्नलिखित कमांड का उपयोग करें -

length_signal = len(audio_signal)
half_length = np.ceil((length_signal + 1) / 2.0).astype(np.int)

अब, हमें फ़्रीक्वेंसी डोमेन में बदलने के लिए गणित उपकरण लागू करने की आवश्यकता है। यहां हम फूरियर ट्रांसफॉर्म का उपयोग कर रहे हैं।

signal_frequency = np.fft.fft(audio_signal)

अब, फ़्रीक्वेंसी डोमेन सिग्नल का सामान्यीकरण करें और इसे वर्गाकार करें -

signal_frequency = abs(signal_frequency[0:half_length]) / length_signal
signal_frequency **= 2

अगला, आवृत्ति रूपांतरित सिग्नल की लंबाई और आधी लंबाई निकालें -

len_fts = len(signal_frequency)

ध्यान दें कि फूरियर तब्दील संकेत को समायोजित किया जाना चाहिए और साथ ही विषम मामले के लिए भी।

if length_signal % 2:
   signal_frequency[1:len_fts] *= 2
else:
   signal_frequency[1:len_fts-1] *= 2

अब डेसिबल (dB) में पावर निकालें -

signal_power = 10 * np.log10(signal_frequency)

एक्स-अक्ष के लिए kHz में आवृत्ति समायोजित करें -

x_axis = np.arange(0, len_half, 1) * (frequency_sampling / length_signal) / 1000.0

अब, संकेत के लक्षण वर्णन की कल्पना इस प्रकार है -

plt.figure()
plt.plot(x_axis, signal_power, color='black')
plt.xlabel('Frequency (kHz)')
plt.ylabel('Signal power (dB)')
plt.show()

आप उपरोक्त कोड का आउटपुट ग्राफ देख सकते हैं जैसा कि नीचे दी गई छवि में दिखाया गया है -

मोनोटोन ऑडियो सिग्नल उत्पन्न करना

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

उदाहरण

निम्नलिखित उदाहरण में, हम पायथन का उपयोग करके एक मोनोटोन सिग्नल उत्पन्न करने जा रहे हैं, जिसे एक फ़ाइल में संग्रहीत किया जाएगा। इसके लिए आपको निम्नलिखित कदम उठाने होंगे -

दिखाए गए अनुसार आवश्यक पैकेज आयात करें -

import numpy as np
import matplotlib.pyplot as plt
from scipy.io.wavfile import write

वह फ़ाइल प्रदान करें जहाँ आउटपुट फ़ाइल को सहेजा जाना चाहिए

output_file = 'audio_signal_generated.wav'

अब, अपनी पसंद के मापदंडों को निर्दिष्ट करें, जैसा कि दिखाया गया है -

duration = 4 # in seconds
frequency_sampling = 44100 # in Hz
frequency_tone = 784
min_val = -4 * np.pi
max_val = 4 * np.pi

इस चरण में, हम ऑडियो सिग्नल उत्पन्न कर सकते हैं, जैसा कि दिखाया गया है -

t = np.linspace(min_val, max_val, duration * frequency_sampling)
audio_signal = np.sin(2 * np.pi * tone_freq * t)

अब, आउटपुट फ़ाइल में ऑडियो फ़ाइल सहेजें -

write(output_file, frequency_sampling, signal_scaled)

हमारे ग्राफ के लिए पहले 100 मान निकालें, जैसा कि दिखाया गया है -

audio_signal = audio_signal[:100]
time_axis = 1000 * np.arange(0, len(signal), 1) / float(sampling_freq)

अब, निम्नानुसार उत्पन्न ऑडियो सिग्नल की कल्पना करें -

plt.plot(time_axis, signal, color='blue')
plt.xlabel('Time in milliseconds')
plt.ylabel('Amplitude')
plt.title('Generated audio signal')
plt.show()

आप यहां दिए गए चित्र में दिखाए गए अनुसार कथानक देख सकते हैं -

भाषण से फ़ीचर निकालना

भाषण पहचानकर्ता के निर्माण में यह सबसे महत्वपूर्ण कदम है क्योंकि स्पीच सिग्नल को फ़्रीक्वेंसी डोमेन में परिवर्तित करने के बाद, हमें इसे फीचर वेक्टर के प्रयोग करने योग्य रूप में परिवर्तित करना होगा। हम इस उद्देश्य के लिए विभिन्न फीचर निष्कर्षण तकनीकों जैसे कि MFCC, PLP, PLP-RASTA आदि का उपयोग कर सकते हैं।

उदाहरण

निम्नलिखित उदाहरण में, हम सिग्नल, कदम-दर-चरण, पायथन का उपयोग करके, MFCC तकनीक का उपयोग करके सुविधाओं को निकालने जा रहे हैं।

आवश्यक पैकेज आयात करें, जैसा कि यहाँ दिखाया गया है -

import numpy as np
import matplotlib.pyplot as plt
from scipy.io import wavfile
from python_speech_features import mfcc, logfbank

अब, संग्रहीत ऑडियो फ़ाइल पढ़ें। यह दो मान लौटाएगा - नमूना आवृत्ति और ऑडियो सिग्नल। ऑडियो फ़ाइल का पथ प्रदान करें जहाँ यह संग्रहीत है।

frequency_sampling, audio_signal = wavfile.read("/Users/admin/audio_file.wav")

ध्यान दें कि यहां हम विश्लेषण के लिए पहले 15000 नमूने ले रहे हैं।

audio_signal = audio_signal[:15000]

एमएफसीसी तकनीकों का उपयोग करें और एमएफसीसी सुविधाओं को निकालने के लिए निम्नलिखित कमांड निष्पादित करें -

features_mfcc = mfcc(audio_signal, frequency_sampling)

अब, एमएफसीसी मापदंडों को प्रिंट करें, जैसा कि दिखाया गया है -

print('\nMFCC:\nNumber of windows =', features_mfcc.shape[0])
print('Length of each feature =', features_mfcc.shape[1])

अब, नीचे दिए गए आदेशों का उपयोग करके MFCC सुविधाओं की साजिश और कल्पना करें -

features_mfcc = features_mfcc.T
plt.matshow(features_mfcc)
plt.title('MFCC')

इस चरण में, हम दिखाए गए अनुसार फ़िल्टर बैंक सुविधाओं के साथ काम करते हैं -

फ़िल्टर बैंक सुविधाएँ निकालें -

filterbank_features = logfbank(audio_signal, frequency_sampling)

अब, फ़िल्टरबैंक मापदंडों को प्रिंट करें।

print('\nFilter bank:\nNumber of windows =', filterbank_features.shape[0])
print('Length of each feature =', filterbank_features.shape[1])

अब, फ़िल्टरबैंक सुविधाओं की साजिश रचें और कल्पना करें।

filterbank_features = filterbank_features.T
plt.matshow(filterbank_features)
plt.title('Filter bank')
plt.show()

उपरोक्त चरणों के परिणामस्वरूप, आप निम्न आउटपुट देख सकते हैं: MFCC के लिए चित्र 1 और फ़िल्टर बैंक के लिए चित्र 2

स्पोकन वर्ड्स की मान्यता

भाषण मान्यता का मतलब है कि जब मनुष्य बोल रहे हैं, तो एक मशीन इसे समझती है। यहां हम ऐसा करने के लिए पायथन में Google भाषण एपीआई का उपयोग कर रहे हैं। हमें इसके लिए निम्नलिखित पैकेजों को स्थापित करना होगा -

  • Pyaudio - इसे इस्तेमाल करके इंस्टॉल किया जा सकता है pip install Pyaudio आदेश।

  • SpeechRecognition - इस पैकेज का उपयोग करके स्थापित किया जा सकता है pip install SpeechRecognition.

  • Google-Speech-API - इसे कमांड का इस्तेमाल करके इंस्टॉल किया जा सकता है pip install google-api-python-client

उदाहरण

बोले गए शब्दों की मान्यता के बारे में समझने के लिए निम्नलिखित उदाहरण देखें -

दिखाए गए अनुसार आवश्यक पैकेज आयात करें -

import speech_recognition as sr

नीचे दिखाए अनुसार एक वस्तु बनाएं -

recording = sr.Recognizer()

अब Microphone() मॉड्यूल इनपुट के रूप में आवाज लेगा -

with sr.Microphone() as source: recording.adjust_for_ambient_noise(source)
   print("Please Say something:")
   audio = recording.listen(source)

अब google API आवाज को पहचानता है और आउटपुट देता है।

try:
   print("You said: \n" + recording.recognize_google(audio))
except Exception as e:
   print(e)

आप निम्न आउटपुट देख सकते हैं -

Please Say Something:
You said:

उदाहरण के लिए, यदि आपने कहा tutorialspoint.com, तो सिस्टम इसे सही ढंग से पहचानता है -

tutorialspoint.com