FAUST (programlama dili) - FAUST (programming language)

FAUST
Orijinal yazar (lar)Yann Orlarey, Dominique Fober, Stéphane Letz
Geliştirici (ler)GRAME, Centre National de Création Musicale
İlk sürüm2002 (2002)
Kararlı sürüm
2.20.2[1] / 14 Ocak 2020 (2020-01-14)
YazılmışC ++
İşletim sistemiLinux, OS X, pencereler, Unix
TürSes sinyali işleme için fonksiyonel programlama dili
LisansGPL
İnternet sitesiFaust.grame.fr

FAUST (Fonksiyonel AUdio STream) bir alana özgü tamamen işlevsel Programlama dili uygulamak için sinyal işleme algoritmalar şeklinde kütüphaneler, ses eklentileri veya bağımsız uygulamalar. Bir FAUST programı, bir sinyal işlemcisini ifade eder: bazı giriş sinyallerine uygulanan ve daha sonra beslenen matematiksel bir fonksiyon.

Genel Bakış

FAUST programlama modeli birleştirir fonksiyonel programlama ile yaklaşım blok diyagramı sözdizimi:

  • İşlevsel programlama yaklaşımı, aşağıdakiler için doğal bir çerçeve sağlar: sinyal işleme. Dijital sinyaller şu şekilde modellenir: ayrık fonksiyonlar zamanın, sinyal işlemcileri ikinci dereceden fonksiyonlar bunlar üzerinde çalışan ve FAUST’ın blok şeması kompozisyon operatörleri, sinyal işlemcileri üçüncü dereceden işlevler olarak birleştirmek için kullanılır.
  • Blok diyagramlar, FAUST'ta olduğu gibi tamamen metinsel olsa bile, ses mühendislerinin ve ses geliştiricilerinin alışkanlıklarına uyan sinyal işlemeye modüler bir yaklaşımı teşvik eder.

FAUST programı bir sesi veya bir grup sesi tanımlamaz, ancak bir sinyal işlemcisi. Program kaynağı, bir dizi tanımlar en azından anahtar kelimenin tanımı ile süreç (eşdeğeri ana C):

süreç = ...;

FAUST derleyici FAUST kodunu bir C ++ nesne, daha sonra tam bir program oluşturmak için diğer C ++ koduyla arayüz oluşturabilir.

Üretilen kod, örnek düzeyinde çalışır. Bu nedenle, düşük seviyeli uygulamaya uygundur DSP gibi işlevler yinelemeli filtreler. Kod ayrıca gömülü. Bağımsızdır ve herhangi bir DSP kitaplığına veya çalışma zamanı sistemi. Çok deterministik bir davranışa ve sabit bir hafıza boyutuna sahiptir.

FAUST'ın semantiği, basit ve iyi tanımlanmış olmaya yönlendirilir. FAUST derleyicisinin anlamsal güdümlü. Bir programı tam anlamıyla derlemek yerine, ifade ettiği matematiksel işlevi derler. Bu, bileşenin yeniden kullanımını teşvik edebilir. Dahası, bir FAUST programının tam anlamına erişim, koruma sorunlarını basitleştirebilir.

FAUST bir metin dilidir ancak blok diyagram yönelimli. İki yaklaşımı birleştirir: fonksiyonel programlama ve cebirsel blok diyagramları üzerinden inşa edilen işlev bileşimi. FAUST bunun için bir blok diyagramı cebiri Beş kompozisyon işlemi.

Örnek kod

FAUST programları bir süreç gelen veriler üzerinde çalışan işlev. Bu, ana çoğu programlama dilinde çalışır. Aşağıda sessizlik oluşturan bir örnek verilmiştir:

süreç = 0;

İkinci örnek, giriş sinyalini çıkışa kopyalar. İçerir _ gösteren ilkel kimlik işlevi sinyaller için:

süreç = _;

Başka bir örnek, stereo sinyalini mono sinyale toplar. + ilkel:

süreç = +;
Faust tarafından bazı basit programlardan oluşturulan blok diyagramlar

FAUST ilkellerinin çoğu, sayılardaki C karşılığına benzer, ancak sinyallere yükseltilmiştir. Örneğin, FAUST ilkel günah uygulayarak bir X sinyali üzerinde çalışır C işlevi günah her numuneye X [t]. Tüm C sayısal işlevlerinin karşılığı FAUST'ta bulunur. sinyal işleme ilkeller FAUST'a özgüdür. Örneğin, gecikme operatörü @ iki giriş sinyali alır: X (geciktirilecek sinyal) ve D (uygulanacak gecikme) ve Y (t) = X (t - D (t)) olacak şekilde bir Y çıkış sinyali üretir.

Blok diyagram oluşturma

Aksine Max benzeri görsel programlama dilleri kullanıcının manuel bağlantıları yaptığı yerlerde, FAUST ilkelleri blok diyagramları bir dizi üst düzey blok diyagram kullanarak kompozisyon operasyonlar.

Blok diyagram kompozisyonunun basit örnekleri
Blok şeması kompozisyon operatörleri FAUST'ta kullanılır
f ~ gYinelemeli kompozisyon (öncelik 4)
f, gParalel kompozisyon (öncelik 3)
f: gSıralı kompozisyon (öncelik 2)
f <: gBölünmüş kompozisyon (öncelik 1)
f:> gKompozisyonu birleştir (öncelik 1)

Sıralı kompozisyon operatörünü kullanma : çıktısı + girişine yönlendirilebilir abs hesaplamak için mutlak değer sinyalin:

süreç = + : abs;

İşte paralel bileşimin bir örneği , sol ve sağ ifadelerini paralel olarak düzenleyen operatör. Bu bir stereo kabloya benzer.

süreç = _,_;

Bu operatörler isteğe bağlı olarak birleştirilebilir. Aşağıdaki kod, bir giriş sinyalini 0,5 ile çarpar:

süreç = _,0.5 : *;

Yukarıdakiler şurada yeniden yazılabilir: körili form:

süreç = *(0.5);

Yinelemeli kompozisyon operatörü ~ döngüleri olan blok diyagramları oluşturmak için kullanılabilir (örtük bir örnek gecikmesi içeren). Aşağıda, bir X giriş sinyali alan ve Y (t) = X (t) + Y (t − 1) olacak şekilde bir Y çıkış sinyali hesaplayan bir entegratör örneği verilmiştir:

süreç = + ~ _;

Tam uygulamalar oluşturma

Belirli kullanarak mimari dosyalar, bir FAUST programı çeşitli platformlar ve eklenti biçimleri için kod üretmek için kullanılabilir. Bu mimari dosyaları, sarmalayıcı görevi görür ve ana bilgisayar ses ve GUI sistemi ile etkileşimleri açıklar. 2015 itibariyle10'dan fazla mimari desteklenir ve yenileri herkes tarafından uygulanabilir.

Jack-qt mimarisini kullanan mixer.dsp ekran görüntüsü (FAUST dağıtımında mevcuttur)
FAUST için kullanılabilen bazı mimari dosyalar
alsa-gtk.cppALSA uygulaması + GTK
alsa-qt.cppALSA uygulaması + QT4
android.cppAndroid uygulamaları
au.cppAudio Unit eklentisi
ca-qt.cppCoreAudio uygulaması + QT4
ios-coreaudio.cppiPhone ve iPad uygulamaları
jack-gtk.cppJACK uygulaması + GTK
jack-qt.cppJACK uygulaması + QT4
ladspa.cppLADSPA eklentisi
max-msp.cppMax MSP eklentisi
pd.cppPuredata eklentisi
q.cppQ dil eklentisi
supercollider.cppSupercollider eklentisi
vst.cppVST eklentisi
vsti-mono.cppMonophonic VST Instrument eklentisi
vsti-poly.cppPolifonik VST Enstrüman eklentisi

Blok diyagramların oluşturulması

Kullanışlı bir seçenek, programın blok diyagram gösterimini bir veya daha fazla SVG grafik dosyası olarak oluşturmayı mümkün kılar.

Blok diyagramı ile oluşturulan C ++ kodu arasındaki farkı not etmek faydalıdır. Belirtildiği gibi, buradaki ana fikir, blok diyagramı tam anlamıyla derlemek değil, ifade ettiği matematiksel işlevi kullanmaktır. Modern C / C ++ derleyicileri de programları tam anlamıyla derlemez. Ancak C / C ++ 'nın karmaşık semantiği nedeniyle (yan etkiler, işaretçi takma adı vb. Nedeniyle) bu yönde çok ileri gidemezler. Bu, tamamen işlevsel bir dilin belirgin bir avantajıdır: derleyicilerin çok gelişmiş optimizasyonlar yapmasına izin verir.

Oklara benzer anlambilim

Faust semantiği neredeyse aynıdır. Haskell's Oklar Ancak, Arrow türü sınıfı sinyal işlemcilere bağlı değildir.

FAUST ve Ok birleştiriciler arasındaki eşdeğerler
f ~ gdöngü (((a,b) -> (b,a)) ^>> f >>> İD &&& (gecikme>>>g)) nerede gecikme bir yöntem değildir Ok tür sınıfı, ancak sinyal işleme oklarına özgüdür
f, gs * ktir
f: gf >>> g
f <: gf >> ^ h >>> g uygun işleve sahip h (veya &&& özel durumlarda)
f:> gf >> ^ h >>> g uygun işleve sahip h

Ok birleştiricileri, FAUST emsallerinden daha kısıtlayıcıdır, örneğin, paralel bileşimin yuvalanması korunur ve işlenenlerin girdileri &&& tam olarak eşleşmelidir.

Referanslar

Dış bağlantılar