श्रृंखला में सभी पोस्ट:
भाग 1. परिचय और सेटअपभाग 2. कोड सीखनाभाग 3. वीएसटी और एयूभाग 4. डिजिटल विरूपणभाग 5. प्रीसेट और जीयूआईभाग 6. सिग्नल संश्लेषणभाग 7. मिडी संदेश प्राप्त करनाभाग 8. आभासी कीबोर्डभाग 9. लिफाफेभाग 10. जीयूआई में सुधारभाग 11. फ़िल्टरभाग 12. कम आवृत्ति वाला थरथरानवालाभाग 13. नया स्वरूपभाग 14. पॉलीफोनी 1भाग 15. पॉलीफोनी 2भाग 16. एंटीलियासिंग
यह हमारा पहला प्लगइन लिखना शुरू करने का समय है। यह एक गंदे डिजिटल विरूपण होगा। अधिक विशेष रूप से, प्लगइन बस ऑडियो सिग्नल के आयाम में चोटियों को
ट्रिम करेगा।
डिजिटल विरूपण
एक निश्चित सीमा से अधिक होने वाले सिग्नल मान सीमित होंगे ताकि वे इसके पार न जाएं:

"अधिक" कहने से मेरा मतलब है "एक निश्चित सकारात्मक सीमा से अधिक या एक निश्चित नकारात्मक सीमा से नीचे गिरना"।
अच्छी पुरानी
duplicate स्क्रिप्ट का उपयोग करके, आप किसी भी प्रोजेक्ट को एक नया नाम देकर कॉपी कर सकते हैं। और हमें उन सभी परिवर्तनों को करने की ज़रूरत नहीं है जो मैंने प्रत्येक नई परियोजना के लिए पहले वर्णित किए थे।
एक टर्मिनल खोलें, इसमें
IPlugExamples निर्देशिका पर जाएं और इसे दर्ज करें:
./duplicate.py MyFirstPlugin/ DigitalDistortion YourNameयदि आपने पिछली पोस्ट नहीं पढ़ी हैं, तो उनके परिणाम
यहां से डाउनलोड किए जा सकते
हैं । यदि आप एक मैक पर ऐसा करते हैं, तो सुनिश्चित करें कि Xcode में कोई अन्य परियोजनाएं नहीं हैं। हौसले से बनाई गई
DigitalDistortion फ़ोल्डर में
DigitalDistortion.xcodeproj फ़ाइल है। इसे खोलें, जांचें कि एपीपी लक्ष्य विधानसभा त्रुटियों के बिना शुरू होती है। स्कीमा संपादित करें जैसा कि मैंने पहले बताया था ताकि REAPER VST और AU के लिए चलता रहे। यह मत भूलो कि
लॉन्च पर पास किए गए तर्क वांछित
.rpp फ़ाइल को इंगित करें।
अब REAPER शुरू करते समय, यह
MyFirstPlugin को लोड नहीं करता है, लेकिन
DigitalDistomy । चमत्कार। ऐसा इसलिए है क्योंकि REAPER में प्रोजेक्ट फाइलें केवल संरचित पाठ फाइलें होती हैं जिसमें
duplicate स्क्रिप्ट को सभी "MyFirstPlugin" को "DigitalDistortion" से बदल दिया जाता है।
पहले
mGain के
mGain पैरामीटर का नाम बदलें।
DigitalDistortion.h खोलें और
private चर का नाम बदलें:
private: double mThreshold;
अब
DigitalDistortion.cpp में, Threshold साथ सामना किया गया (Cmd + Alt + F) बदलें। जब कोडांतरण, कोई त्रुटि पॉप अप नहीं होनी चाहिए निर्माणकर्ता में, पैरामीटर इनिशियलाइज़ेशन लाइन में, न्यूनतम मान के रूप में
0.01 और डिफ़ॉल्ट मान के रूप में
100.0 निर्दिष्ट करें:
GetParam(kThreshold)->InitDouble("Threshold", 100.0, 0.01, 100.0, 0.01, "%");
अब डिजिटल सिग्नल प्रोसेसिंग को सीधे लिखते हैं:
void DigitalDistortion::ProcessDoubleReplacing( double** inputs, double** outputs, int nFrames) {
यदि कोई त्रुटि
fmin कि
fmin और
fmax परिभाषित नहीं
fmax , तो उन्हें केवल
min और
max करने का नाम बदलने का प्रयास करें। यदि यह मदद नहीं करता है, तो
DigitalDistortion.cpp के
हेडर में निम्नलिखित जोड़ें:
#include <math.h>
यदि यह समस्या हल नहीं करता है, तो इसे पिछली पंक्ति के बजाय जोड़ें:
#include <algorithm>
और
fmin को
std::min साथ बदलें, और
fmax को
std::max साथ बदलें।
इस तथ्य के बावजूद कि
channelCount मान हार्ड-कोडेड है, हमने चैनलों पर पुनरावृति करने के लिए लूप के लिए बाहरी का उपयोग करके कुछ अतिरेक को हटा दिया। यही है, पहले प्लगइन एक चैनल से कई नमूनों को संसाधित करता है, और फिर दूसरे के नमूनों के साथ भी ऐसा ही करता है।
if साथ सशर्त एक दिलचस्प बिंदु है। आयाम के सकारात्मक मूल्यों के लिए, हम दो में से छोटे का चयन करते हैं: या तो इनपुट मूल्य या सीमा। नकारात्मक लोगों के लिए, इसके विपरीत, हम बड़े को चुनते हैं: या तो
*input या एक नकारात्मक सीमा मूल्य। संक्षेप में, हम हमेशा उस मूल्य को चुनते हैं जो शून्य के करीब है।
REAPER में प्लगइन लॉन्च करें और इसे टेस्ट साउंड पर ड्राइव करें। जब घुंडी को दाईं ओर मोड़ दिया जाता है, तो एक स्पष्ट ध्वनि सुनाई देगी। जितना अधिक नॉब वामावर्त रूप से मुड़ता है, उतना ही विकृत संकेत बन जाता है।
जैसे ही विकृति बढ़ती है, सिग्नल शांत हो जाता है - यह इसलिए है क्योंकि हम थ्रेशोल्ड वैल्यू को करीब और शून्य के करीब ले जाते हैं, और, तदनुसार, कभी शांत मूल्यों के आयाम को काट देते हैं। इसकी भरपाई के लिए, इनपुट मूल्य को एक सीमा से विभाजित करें:
if(*input >= 0) { *output = fmin(*input, mThreshold); } else { *output = fmax(*input, -mThreshold); } *output /= mThreshold;
थोड़ा अधिक है, हम पैरामीटर के लिए न्यूनतम मान
0.01 सेट करते हैं। इस प्रकार, हम कभी भी शून्य से विभाजित नहीं करेंगे, भले ही हम घुंडी को बाईं ओर मोड़ दें।
अब, यदि आप फिर से प्लगइन चलाते हैं, तो आयाम समान स्तर पर रहेगा। लेकिन मात्रा अधिक प्रतीत होगी: आयाम का कटऑफ हमारी साइन वेव को
मेन्डर्स के करीब आकार में लाता है, जिसमें एक बड़ा
आरएमएस मूल्य होता है ।
अब तक, मैं जानबूझकर डिजिटल सिग्नल प्रोसेसिंग के जंगल में नहीं जाने का प्रयास करता हूं। मेरी राय में, एक अच्छा प्लगइन सिर्फ सिग्नल प्रोसेसिंग एल्गोरिदम नहीं है। यह एक मिश्रण है जिसमें शामिल है
- विश्वसनीय होस्ट संगतता (सेटिंग्स, स्थिर संचालन)
- अच्छी आवाज (यहाँ शुद्ध डिजिटल प्रसंस्करण है)
- सहज यूजर इंटरफेस
- सुंदर उपस्थिति
इसलिए अगली पोस्ट में ध्वनि प्रसंस्करण एल्गोरिदम में गोता लगाने से पहले हम प्रीसेट और एक अधिक सुखद इंटरफ़ेस जोड़ते हैं।
मूल लेख:
martin-finke.de/blog/articles/audio-plugins-005-digital-distortion