پرش به محتوا

الگول

از ویکی‌پدیا، دانشنامهٔ آزاد
الگول
طراحی شده توسطفردریش ال بائر، جان بکوس، جان مک‌کارتی، پیتر نائور، آلن پرلیس و…
ظهوریافته در۱۹۵۸- ۵۵ سال پیش

الگول (مخفف عبارت زبان الگوریتمی Algorithmic Language) از خانوادهٔ زبان‌های برنامه‌نویسی امری کامپیوتری است و در اصل در میانه‌های سال ۱۹۵۰ توسعه یافته که بسیاری از زبان‌های دیگر را تحت تأثیر قرار داده است. عملاً راهی شده است که الگوریتم‌ها در کتاب‌های درسی و فعالیت‌های علمی برای تقریباً ۳۰ سال آینده توصیف شوند. الگول برای دوری از برخی مشکلات که در فورترن دیده شده بود طراحی شد و سرانجام باعث پیشرفت بسیاری از زبان‌های برنامه‌نویسی دیگر شد. الگول کدها را به‌صورت بلوکی معرفی کرد و اولین زبانی بود که از دو جفت begin و end برای مرزبندی بلوک‌ها استفاده کرد. قسمت‌هایی از الگول مانند syntax بعضی اوقات برای ثبت و یادداشت الگوریتم‌ها استفاده می‌شود. به همین خاطر به آن Pidgin Algol (الگول دست و پا شکسته) می‌گفتند. سه خصوصیت اصلی الگول به شرح زیر است:

  • الگول ۵۸ با عنوان IAL (زبان الگوریتمی جهانی) شناخته شد.
  • الگول ۶۰ در سال ۱۹۶۳ عرضه شد.
  • الگول ۶۸ در سال ۱۹۷۳ عرضه شد.

نیکلاس ورس Algol –W را در الگول ۶۰ قبل از توسعهٔ پاسکال پایه‌گذاری کرد. Algol –W به منظور نسل بعدی الگول در نظر گرفته شد. ولی کمیتهٔ الگول ۶۸ تصمیم به طراحی الگولی گرفتند که خیلی جامع‌تر و پیشرفته‌تر از الگول ساده شدهٔ ۶۰ بود. نسخهٔ رسمی الگول بعد از یک سال از اولین انتشار آن نام‌گذاری شد. الگول ۶۸ در واقع متفاوت از الگول ۶۰ است اما به خوبی پذیرفته نشد و در نتیجه الگول رایج و عام الگول ۶۰ بود.

اهمیت و اجرا

[ویرایش]

IAL (زبان الگول جهانی) بسیار تأثیرگذار بود و به‌طور عام مورد توجه زبان‌های برنامه‌نویسی جدید قرار گرفت. شرکت Burroughs خطوط کامپیوترهای آن را ساخت تا مستقیماً آن را به مرحلهٔ اجرا برساند. به علاوه در علم کامپیوتر کد موضوعی الگول، یک‌سری دستورالعمل‌های معماری ساده و جمع و جوری بود که بیشتر در آموزش ساخت کامپایلر و بقیهٔ زبان‌های سطح بالای امری پیاده‌سازی عملی مانند Lisp - machines و P – code machines مورد استفاده قرار گرفته شد. الگول توسط دو کمیتهٔ علمی کامپیوتر آمریکا و اروپا در جلسه‌ای در سال ۱۹۵۸ در زوریخ توسعه داده شد.

سه دستور زبان متفاوت مشخص شده برای زبان الگول عبارتند از:

۱ – نحو مرجع

۲ – نحو نشر

۳ – نحو اجرا

نحوهای مختلف به آن اجازه می‌داد تا از کلمات کلیدی متفاوتی برای ممیز اعشاری برای زبان‌های متفاوت استفاده کند. الگول بیشتر توسط دانشمندان کامپیوتر در آمریکا و اروپا استفاده می‌شد. مورد استفاده آن در کاربردهای تجاری به وسیلهٔ نبودن استاندارد امکانات ورودی و خروجی در تعریف آن و فقدان بهره و سود و جذابیت در زبان به وسیلهٔ فروشنده‌های بزرگ کامپیوتر به تأخیر انداخته شد. الگول ۶۰ نیز گر چه برای نشر الگوریتم‌ها استاندارد شد و تأثیر عمیقی بر توسعهٔ زبان‌های آینده داشت ولی به این سرنوشت دچار شد. جان بکوس روش شکل نرمال بکوس برای توصیف زبان‌های برنامه‌نویسی به‌ویژه برای الگول ۵۸ را ایجاد کرد که بوسیلهٔ پیتر نور برای الگول ۶۰ توسعه و عرضه شد و در پیشنهاد دونالد نوس به بکوس نور تغییر نام داد. پیتر نور می‌گوید: من به عنوان ویرایشگر پژوهشگر الگول در مذاکرات جهانی زبان قرعه‌کشی شدم و به عنوان عضوی از گروه طراحی زبان اروپا در نوامبر ۱۹۵۹ انتخاب گردیدم. تحت این اعتبار، من ویرایشگر گزارش الگول ۶۰ بودم که این محصول نتیجهٔ جلسهٔ الگول ۶۰ در نوامبر ۱۹۶۰در پاریس می‌باشد. این افراد در جلسهٔ پاریس (۱تا ۱۶ ژوئن) حضور داشتند: فردریش ال بائر، پیتر نور، هنس روتیشاوزر، کلاس سامل سون، برنارد واکیویس، آدرین ون وی جین گاردن و مایکل وجرد (از اروپا)، جان دبلیو بکوس، جولین گرین، چارلز کاتز، جان مک‌کارتی، آلن جی پرلیس و ژوزف هنری وی گستین (از آمریکا). آلن پرلیس توضیح واضحی از جلسه داده است: جلسه خسته‌کننده و بسیار طولانی بود. وقتی ایده‌های خوب شخصی با ایده‌های بد دیگران کنار گذاشته می‌شد، باعث خشم و عصبانیت می‌شد. با وجود این، سعی و پافشاری زیادی در طول این دوره می‌شد. جان بکوس و پیتر نور هر دو به این کمیته در تولید الگول ۶۰ خدمت کردند، همان‌طور که والی فرزیگ بعدها در به‌وجود آوردن زبان برنامه‌نویسی لوگو خدمات زیادی انجام داد. الگول ۶۰ الهام‌بخش و تأثیرگذار در بسیاری از زبان‌های پیرو آن بود. تونی هویر بیان کرد: این زبانی است که از زمان خودش خیلی جلوتر است و نه تنها پیشرفتهٔ زبان‌های گذشته است بلکه تأثیری در زبان‌های آینده نیز دارد.

سیر پیشرفت و پیاده‌سازی IAL

[ویرایش]
نام سال مولف کشور شرح هدفCPU
ZMMD-implementation۱۹۵۸فردریش ال بائر، Heinz Rutishauser, Klaus Samelson, Hermann BottenbruchGermanyimplementation of ALGOL 58Z22
Elliott ALGOL۱۹۶۰تونی هورUKSubject of the famous آلن تورینگ lectureNational-Elliott 803 & the Elliott ۵۰۳
JOVIAL۱۹۶۰Jules SchwarzUSWas the DOD HOL prior to ایدا (زبان برنامه‌نویسی)Various (see article)
Burroughs Algol
(Several variants)
۱۹۶۱Burroughs Corporation (with participation by Hoare، Dijkstra, and others)USBasis of the Burroughs (and now Unisys MCP based) computersBurroughs large systems
and their midrange as well.
Case ALGOL۱۹۶۱USسیمولا was originally contracted as a simulation extension of the Case ALGOLUNIVAC ۱۱۰۷
GOGOL۱۹۶۱Bill McKeemanUSFor اودین time-sharing systemPDP-۱
X1 Algol 60۱۹۶۱ادسخر دیکسترا and J.A. ZonneveldNetherlandsMathematical Centre, AmsterdamX1
Dartmouth ALGOL 30۱۹۶۲Thomas Eugene Kurtz et alUSLGP-۳۰
USS 90 Algol۱۹۶۲L. PetroneItaly
Algol Translator۱۹۶۲G. van der May and W.L. van der PoelNetherlandsStaatsbedrijf der Posterijen, Telegrafie en TelefonieZEBRA
Kidsgrove Algol۱۹۶۳F. G. DuncanUKEnglish Electric Company KDF9
VALGOL۱۹۶۳Val SchorreUSA test of the META II compiler compiler
Whetstone۱۹۶۴Brian Randell and L J RussellUKAtomic Power Division of English Electric Company. Precursor to Ferranti Pegasus (computer), National Physical Laboratories ACE (computer) and English Electric DEUCE implementations.English Electric Company KDF9
NU ALGOL۱۹۶۵NorwayUNIVAC
ALGEK۱۹۶۵اتحاد جماهیر شوروی سوسیالیستیMinsk-22АЛГЭК، based on ALGOL-60 and کوبول support, for economical tasks
MALGOL۱۹۶۶publ. A. Viil, M Kotli & M. Rakhendi،جمهوری سوسیالیستی استونی شورویMinsk-22
ALGAMS۱۹۶۷GAMS group (ГАМС، группа автоматизации программирования для машин среднего класса)، cooperation of Comecon Academies of ScienceکمکانMinsk-22، later ES EVM, BESM
ALGOL/ZAM۱۹۶۷PolandPolish ZAM computer
RegneCentralen ALGOL۱۹۶۷پیتر ناورDenmark
سیمولا۱۹۶۷اوله-یوهان دال and کریستین نیگاردNorwayAlgol 60 with classesUNIVAC ۱۱۰۷
Chinese Algol۱۹۷۲ChinaChinese characters, expressed via the Symbol system
DG/L۱۹۷۲USDG Eclipse family of computers

مشخصات

[ویرایش]

الگول ۶۰ چنانچه رسماً تعریف شده بود، اما امکانات ورودی و خروجی نداشت. پیاده‌سازی‌ها خودشان را در راه‌هایی تعریف می‌کردند که کمتر با یکدیگر همساز بودند. در مقایسهٔ الگول ۶۸ امکانات وسیع کتابخانه‌ای Transput را پیشنهاد کرده بود. الگول ۶۰ دو استراتژی ارزیابی برای قبول پارامترها داشت:

۱ – فراخوانی با ارزش و مقدار

۲ – فراخوانی با نام

فراخوانی با نام محدودیت‌های معینی در مقایسه با فراخوانی با مرجع داشت که آن را ویژگی نامطلوبی در طراحی زبان امری ساخته بود. برای مثال، در الگول ۶۰ توسعهٔ یک procedure که ارزش دو پارامتر را تغییر خواهد داد غیرممکن است، اگر پارامترهای واقعی‌ای که قبول می‌شوند تا متغیر integer و آرایه‌ای که با مقدار مشابه integer شاخص شده باشند. هر چند فراخوانی با نام هنوز هم مورد علاقه اجراکننده‌های الگول برای اجرای آن است. دونالد کنوت یک man or boy test تعبیه کرده بود تا کامپایلرها را مجزا کند که توابع بازگشتی و مرجع‌های غیر محلی را درست اجرا کنند. این آزمایش یک مثال از فراخوانی با نام را دارا بود. الگول ۶۰ بوسیلهٔ آدرین ون گاردن که از یک گرامر رسمی دو قسمتی استفاده شده است اختراع شد که در بردارندهٔ نام او بود. Van Wijngaardan grammer از گرامر مستقل از متن استفاده می‌کرد تا مجموعه‌ای از دستورالعمل‌هایی را که برنامه‌های معمول الگول ۶۸ را پشتیبانی و تصدیق خواهد کرد را تولید کند.

کلمات رزرو شده وشناسه‌های محدود شده الگول ۶۰

[ویرایش]

۳۵ کلمه رزرو شده در زیر زبان استاندارد Burroughs large systems وجود دارد:

ALPHA, ARRAY, BEGIN, BOOLEAN, COMMENT, CONTINUE, DIRECT, DO, DOUBLE, ELSE, END, EVENT, FALSE, FILE, FOR, FORMAT, GO, IF, INTEGER, LABEL, LIST, LONG, OWN, POINTER, PROCEDURE, REAL, STEP, SWITCH, TASK, THEN, TRUE, UNTIL, VALUE, WHILE, ZIP

۷۱ شناسه محدود شده در زیر زبان استاندارد Burroughs large systems وجود دارد:

ACCEPT, AND, ATTACH, BY, CALL, CASE, CAUSE, CLOSE, DEALLOCATE, DEFINE, DETACH, DISABLE, DISPLAY, DIV, DUMP, ENABLE, EQL, EQV, EXCHANGE, EXTERNAL, FILL, FORWARD, GEQ, GTR, IMP, IN, INTERRUPT, IS, LB, LEQ, LIBERATE, LINE, LOCK, LSS, MERGE, MOD, MONITOR, MUX, NEQ, NO, NOT, ON, OPEN, OR, OUT, PICTURE, PROCESS, PROCURE, PROGRAMDUMP, RB, READ, RELEASE, REPLACE, RESET, RESIZE, REWIND, RUN, SCAN, SEEK, SET, SKIP, SORT, SPACE, SWAP, THRU, TIMES, TO, WAIT, WHEN, WITH, WRITE

مثال‌ها

[ویرایش]

نمونه کدها (الگول ۶۰)

procedure Absmax(a) Size:(n, m) Result:(y) Subscripts:(i, k);
    value n, m; array a; integer n, m, i, k; real y;
comment The absolute greatest element of the matrix a, of size n by m
is transferred to y, and the subscripts of this element to i and k;
begin integer p, q;
    y := 0; i := k := 1;
    for p:=1 step 1 until n do
    for q:=1 step 1 until m do
        if abs(a[p, q])> y then
            begin y := abs(a[p, q]);
            i := p; k := q
            end
end Absmax

این مثالی دربارهٔ چگونگی به‌وجود آوردن جدولی که از الیوت ۸۰۳ الگول استفاده کند، است.

FLOATING POINT ALGOL TEST'
 BEGIN REAL A,B,C,D'

 READ D'

 FOR A:= 0.0 STEP D UNTIL 6.3 DO
 BEGIN
   PRINT PUNCH(3),££L??'
   B := SIN(A)'
   C := COS(A)'
   PRINT PUNCH(3),SAMELINE,ALIGNED(1,6),A,B,C'
 END'
 END'

پانچ ۳ یک خروجی را به پرینتر تلفنی سریع‌تر از نوار پانچ می‌فرستد.

الاین (۶ و ۱) فرمت خروجی را با ۱ بیت قبل و ۶ بیت بعد ممیز اعشاری کنترل می‌کند.

جستارهای وابسته

[ویرایش]

منابع

[ویرایش]

    ALGOL-Algorithmic Language

    The ALGOL Programming language

    The Hello World Collection