API رایگان C++ برای ترکیب صدا و پردازش سیگنال دیجیتال

کتابخانه پیشرو منبع باز C++ STK (Synthesis ToolKit)، به توسعه‌دهندگان نرم‌افزار امکان ترکیب صدا و پردازش سیگنال دیجیتال را می‌دهد. ویژگی‌های کلیدی، قابلیت‌های صدا در زمان واقعی و مثال‌های کد عملی برای توسعه‌دهندگان را بررسی کنید.

STK (Synthesis ToolKit) چیست؟

ابزارک ترکیب صدا در C++ (STK) یک کتابخانه منبع باز معتبر است که برای پردازش سیگنال صوتی و ترکیب موسیقی الگوریتمی طراحی شده است. این کتابخانه در CCRMA دانشگاه استنفورد توسعه یافته و مجموعه‌ای قوی از کلاس‌های C++ را در اختیار توسعه‌دهندگان قرار می‌دهد که ساخت نرم‌افزارهای صوتی پیچیده را ساده می‌کند. برخلاف برنامه‌های یکپارچه، STK مجموعه‌ای از تولیدکنندگان واحد—بلوک‌های مدولار ساختمانی—است که امکان توسعه سریع سینث‌سازها، پردازشگرهای افکت و سازهای موسیقی را فراهم می‌آورد. کتابخانه STK برای توسعه‌دهندگانی که با سازهای دیجیتال موسیقی، نرم‌افزارهای افکت صوتی، موتورهای صوتی بازی، پژوهش ترکیب صدا، پروژه‌های آموزشی DSP و غیره کار می‌کنند، ارزشمند است.

ابزارک ترکیب صدا در C++ (STK) یک کتابخانه منبع باز C++ است که کلاس‌های قابل استفاده مجدد برای پردازش سیگنال صوتی، ترکیب دیجیتال و مدل‌سازی سازهای موسیقی فراهم می‌کند. این کتابخانه به‌ویژه به‌دلیل تأکید بر قابلیت حمل و سادگی استفاده مفید است. این کتابخانه توسعه‌دهندگان را از پیچیدگی‌های سطح پایین درایورهای صوتی چندپلتفرمی و مدیریت MIDI محافظت می‌کند و به آن‌ها اجازه می‌دهد بر جنبه‌های خلاقانه طراحی صدا تمرکز کنند. چه در حال ساخت یک افزونه حرفه‌ای باشید و چه یک ابزار آموزشی، STK پایداری و انعطاف‌پذیری مورد نیاز برای صوت زمان واقعی با عملکرد بالا را ارائه می‌دهد. برخلاف چارچوب‌های صوتی بزرگ، STK معماری ساده و شفاف خود را حفظ می‌کند. توسعه‌دهندگان می‌توانند به راحتی درک کنند الگوریتم‌های صوتی چگونه کار می‌کنند و آن‌ها را برای آزمایش‌های خود تغییر دهند. همچنین مدل‌های ساز آماده‌استفاده‌ای مانند شاخ، کلارینت و شبیه‌سازی سیم‌های کشیده را فراهم می‌کند که آن را نقطه شروع عالی برای ساخت سینث‌سازهای نرم‌افزاری می‌سازد.

Previous Next

شروع کار با STK

لطفاً برای نصب کامل از فرمان زیر استفاده کنید.

نصب STK از گیت‌هاب

 git clone https://github.com/thestk/stk.git

ترکیب صوتی زمان واقعی

یکی از قدرتمندترین قابلیت‌های STK پشتیبانی آن از تولید صدا به‌صورت زمان واقعی است. توسعه‌دهندگان می‌توانند سیگنال‌های صوتی را به‌صورت پویا در طول اجرای برنامه تولید کنند به‌جای این‌که به نمونه‌های پیش‌ضبط‌شده وابسته باشند. این برای برنامه‌هایی مانند سینث‌سایزرهای دیجیتال، ابزارهای تولید موسیقی و نرم‌افزارهای اجرای زنده صوتی ضروری است. STK توابع پردازشی کارآمدی فراهم می‌کند که فریم‌های صوتی را به‌صورت پیوسته تولید می‌کنند در حالی که تأخیر کم را حفظ می‌نمایند. به‌دلیل این قابلیت، STK اغلب در محیط‌های پژوهشی و فناوری موسیقی که به ترکیب صوتی پاسخگو نیاز دارند، استفاده می‌شود. در اینجا یک مثال ساده آورده شده است که نشان می‌دهد STK چگونه می‌تواند صدا را به‌صورت برنامه‌نویسی تولید کند.

چگونه صدا را به‌صورت برنامه‌نویسی از طریق کتابخانه C++ تولید کنیم؟

#include "SineWave.h"
#include "RtAudio.h"

int main() { stk::SineWave oscillator; oscillator.setFrequency(440.0); // نت A4

for (int i = 0; i < 100; i++) { double sample = oscillator.tick(); std::cout << sample << std::endl; }

return 0; } 

ابزارهای مدل‌سازی فیزیکی

کتابخانه منبع باز STK شامل کلاس‌های داخلی است که با استفاده از الگوریتم‌های مدل‌سازی فیزیکی، سازهای موسیقی واقعی را شبیه‌سازی می‌کنند. این مدل‌ها رفتار سازها را در دنیای فیزیکی بازتولید می‌کنند. برای مثال فلوت، کلارینت، ماندولین و سازهای زه‌ای با کمان. مدل‌سازی فیزیکی مفید است زیرا به توسعه‌دهندگان امکان می‌دهد پارامترهای بیانگر مانند فشار نفس، نیروی کمان یا ارتعاش سیم را کنترل کنند.

چگونه سازهای دیجیتال واقع‌گرایانه را از طریق کتابخانه STK ایجاد کنیم؟

#include \"Clarinet.h\"

int main() { stk::Clarinet clarinet;
    
clarinet.noteOn(440.0, 0.8);

for(int i = 0; i < 200; i++) { double sound = clarinet.tick(); std::cout << sound << std::endl; }

clarinet.noteOff(0.5);

return 0; }  

پشتیبانی داخلی صوت و MIDI

کتابخانه STK همچنین پشتیبانی از ورودی/خروجی صوتی و MIDI به‌صورت زمان واقعی را شامل می‌شود. این امکان را به برنامه‌ها می‌دهد تا با دستگاه‌های خارجی مانند کیبوردهای MIDI و رابط‌های صوتی تعامل داشته باشند. با یکپارچه‌سازی MIDI، توسعه‌دهندگان می‌توانند پارامترهای ترکیب را به‌صورت زمان واقعی کنترل کنند و امکان ایجاد سینث‌سایزرهای نرم‌افزاری، برنامه‌های موسیقی تعاملی، ابزارهای اجرای زنده و غیره را فراهم می‌آورند. مثال زیر برنامه‌ای را ایجاد می‌کند که به پیام‌های ورودی MIDI گوش می‌دهد.

چگونه پیام‌های MIDI را در برنامه‌های C++ گوش داده و ذخیره کنیم؟

#include \"RtMidi.h\"

int main() { RtMidiIn midi;

if (midi.getPortCount() == 0) { std::cout << \"پورت MIDI موجود نیست!\" << std::endl; return 0; }

midi.openPort(0);

std::cout << \"در حال گوش دادن به ورودی MIDI...\" << std::endl;

while (true) { std::vector message; midi.getMessage(&message);

if (!message.empty()) { std::cout << \"پیام MIDI دریافت شد!\" << std::endl; } }

return 0; }

 

مولدهای واحد مدولار از طریق C++

کتابخانه STK پیروی از فلسفه طراحی مدولار دارد و مجموعه وسیعی از "ژنراتورهای واحد" (UGens) را ارائه می‌دهد. این‌ها شامل نوسان‌سازها، فیلترها، پاکت‌ها و افکت‌های تأخیر هستند که می‌توانند مانند یک سینت‌سایزر مدولار مجازی به هم متصل شوند. این جزئیات به توسعه‌دهندگان کنترل کامل بر زنجیره سیگنال می‌دهد. از آنجا که هر کلاس برای پردازش کارآمد فریم‌های صوتی طراحی شده است، می‌توانید همه چیز را از ژنراتورهای موج سینوسی ساده تا موتورهای ترکیبی گرانولار چندمرحله‌ای پیچیده، تنها با اتصال اشیاء مختلف STK بسازید.

 فارسی