Lucid (dasturlash tili) - Lucid (programming language)

Lucid
ParadigmaDataflow
LoyihalashtirilganEdvard A.Eshkroft
Uilyam V. Vadj
Birinchi paydo bo'ldi1976
Matnni yozishTuri yo'q
Mayor amalga oshirish
ravshan
Lahjalar
GIPSY, granüllü Lucid
Ta'sirlangan
ISWIM
Ta'sirlangan
SISAL, PureData, Yorqinlik

Lucid a ma'lumotlar oqimini dasturlash bo'lmagan tillar bilan tajriba o'tkazish uchun mo'ljallangan tilfon Neyman dasturlash modellari. Uni Bill Vadj va Ed Ashkroft ishlab chiqqan va 1985 yilgi kitobda tasvirlangan Lucid, Dataflow dasturlash tili.[1]

pLucid birinchi bo'ldi tarjimon Lucid uchun.

Model

Lucid ma'lumotlarni hisoblash uchun talabga asoslangan modeldan foydalanadi. Har bir gapni protsessorlar tarmog'ini va ular orasidagi ma'lumotlar uzatiladigan aloqa liniyalarini belgilaydigan tenglama deb tushunish mumkin. Har biri o'zgaruvchan qiymatlarning cheksiz oqimi va har qanday funktsiya filtr yoki transformatordir. Takrorlash "oqim" qiymatlari va "fby" ("keyingi" deb o'qing) operatori tomonidan simulyatsiya qilingan, bu oqimlarning tarkibiga kirishga imkon beradi.

Lucid an algebra tarixlar, tarix ma'lumotlar elementlarining cheksiz ketma-ketligi. Amaliy jihatdan tarixni o'zgaruvchining o'zgaruvchan qiymatlari yozuvi deb hisoblash mumkin, birinchi va keyingi kabi tarix operatsiyalari ularning nomlari tomonidan tavsiya etilgan usullar bilan tushunilishi mumkin. Lucid dastlab intizomli, matematik jihatdan toza, bitta topshiriq tili sifatida yaratilgan bo'lib, unda tekshirish soddalashtiriladi. Biroq, ma'lumotlar oqimi talqin Lucid rivojlangan yo'nalishiga muhim ta'sir ko'rsatdi.[1]

Tafsilotlar

Lucidda (va boshqalar) ma'lumotlar oqimi tillar) hali mavjud bo'lmagan o'zgaruvchini o'z ichiga olgan ibora bog'langan davom ettirishdan oldin o'zgaruvchini bog'lashni kutadi. O'xshash ibora x + y ifoda chiqishi bilan qaytishdan oldin x va y ikkalasi bog'languncha kutadi. Buning muhim natijasi shundaki, tegishli qadriyatlarni yangilash uchun aniq mantiqdan qochish kerak, bu asosiy tillarga nisbatan kodning sezilarli darajada pasayishiga olib keladi.

Luciddagi har bir o'zgaruvchi qiymatlar oqimidir. Ifoda n = 1 fby n + 1 "fby" (a.) operatorini oqimini belgilaydi mnemonik uchun "ortidan"). fby previoksepressiyadan keyin nima bo'lishini belgilaydi. (Bu holda oqim 1,2,3, ... hosil qiladi.) Oqimdagi qiymatlarga ushbu operatorlar murojaat qilishlari mumkin (agar x o'zgaruvchini ishlatilsa):

"birinchi x" - x oqimidagi birinchi qiymatni oladi,

"x" - oqimning joriy qiymati,

"keyingi x" - oqimdagi keyingi qiymatni oladi.

'kabi' - berilgan shart bajarilishi bilanoq biron bir narsani qiladigan operator.

"x ustiga p" - x oqimining eski qiymatini takrorlaydigan va faqat p p oqimi hosil bo'lganida yangi qiymatlarni yangilaydigan operator mavjud. to'g'ri mavjud bo'lgan qiymat. (Bu oqimni sekinlashtirishga xizmat qiladi), ya'ni: x ustiga p $ p $ haqiqatida paydo bo'lgan yangi qiymatlarga ega x oqimi.

Hisoblash ushbu vaqt o'zgaruvchan oqimlari ustida ishlaydigan filtrlarni yoki transformatsiya funktsiyalarini aniqlash orqali amalga oshiriladi.

Misollar

Faktorial

fac bu erda n = 0 fby (n + 1); fac = 1 fby (fac * (n + 1)); oxiri

Fibonachchi ketma-ketligi

fib bu erda fib = 0 fby (1 fby fib + keyingi fib); oxiri

Jami ketma-ketlik

total qaerda total = 0 fby total + x end;

O'rtacha ishlayapti

running_avg bu erda sum = birinchi (kirish) fby sum + keyingi (kirish); n = 1 fby n + 1; running_avg = sum / n; oxiri;

Asosiy raqamlar

tub bu erda bosh = 2 fby (n har doim) isprime (n)); n = 3 fby n + 2; isprime (n) = not (divs) asa divs yoki prime * prime> N bu erda N hozirgi n; divs = N mod tub ekv 0; oxiri; oxiri

Dataflow diagrammasi

Asosiy raqamlar ketma-ketligi ma'lumotlar oqimining diagrammasi (Lucid) .png

Tez saralash

qsort (a) = agar eof (avval a), keyin else amal qiladi (qsort (b0), qsort (b1)) fi bu erda p = birinchi a 

Ma'lumotlar oqimining diagrammasi

    --------> har doim -----> qsort --------- | ^ | | | | | emas | | ^ | | ---> birinchi | | | | | | | V | | | ---> kamroq --- | | | | | V V --- + --------> har doim -----> qsort -----> conc -------> ifthenelse -----> | ^ ^ | | | --------> keyingi ----> birinchi ------> iseod -------------- | | | -------------------------------------------------- ---------

O'rtacha kvadrat

sqroot (avg (kvadrat (a))) bu erda kvadrat (x) = x * x; avg (y) = o'rtacha n = 1 fby n + 1; o'rtacha = birinchi y fby o'rtacha + d; d = (keyingi y - o'rtacha) / (n + 1); oxiri; sqroot (z) = taxminan asa err <0.0001, bu erda Z joriy z; taxminan = Z / 2 fby (taxminan + Z / taxminan) / 2; err = abs (kvadrat (taxminan) -Z); oxiri; oxiri

Hamming muammosi

h bu erda h = 1 fby birlashma (birlashma (2 * h, 3 * h), 5 * h); birlashtirish (x, y) = agar xx <= yy keyin xx else yy fi bu erda xx = x ustiga xx <= yy; yy = y ustiga yy <= xx; oxiri; oxiri;

Dataflow diagrammasi

Hamming muammosi ma'lumotlar oqimining diagrammasi

Adabiyotlar

  1. ^ Vadj, Uilyam V.; Ashkroft, Edvard A. (1985). Lucid, Dataflow dasturlash tili. Akademik matbuot. ISBN  0-12-729650-6. Olingan 8 yanvar 2015.

Tashqi havolalar