تبلیغات :
آکوستیک ، فوم شانه تخم مرغی، صداگیر ماینر ، یونولیت
دستگاه جوجه کشی حرفه ای
فروش آنلاین لباس کودک
خرید فالوور ایرانی
خرید فالوور اینستاگرام
خرید ممبر تلگرام

[ + افزودن آگهی متنی جدید ]




نمايش نتايج 1 به 5 از 5

نام تاپيک: مقاله در مورد پرولوگ وتاریخچه آن

  1. #1
    در آغاز فعالیت
    تاريخ عضويت
    Oct 2008
    پست ها
    1

    پيش فرض مقاله در مورد پرولوگ وتاریخچه آن

    سلام خدمت دوستان عزیز
    از دوستان عزیز تقاضا دارم اگه در مورد prolog (غیر از آموزش برنامه نویسی آن)مطلبی سراغ دارند کمک کنند.با سپاس

  2. #2
    حـــــرفـه ای
    تاريخ عضويت
    Jan 2007
    محل سكونت
    تهران
    پست ها
    1,568

    پيش فرض

    سلام.مطلب فارسی کاملی که من نتونستم پیدا بکنم.چنتا آموزش فقط بود.

    دوتا توضیح کلی هست که آخر پست میزارم.

    اینم هست:

    http://ece.ut.ac.ir/classpages/F83/Artificial%20Intelligence/prolog/Prolog1.doc

    این هم شاید به نوعی به کارتون بخوره ، فارسیه :

    http://www.irandoc.ac.ir/Data/E_J/vol5/mohammadi_k.htm

    اینگلیسی هم:

    http://en.wikipedia.org/wiki/Prolog

    ----------------------------------------------------------

    پرولوگ (مخفف عبارت «برنامه‌نویسی منطقی» به زبان فرانسوی) یک زبان برنامه‌نویسی رایانه است که برای برنامه‌نویسی منطقی به کار می‌رود. در این زبان که در حوالی ۱۹۷۰ میلادی اختراع شده است، بر خلاف اکثر زبان‌های دیگر برنامه‌نویسی رایانه، به جای دستورالعمل‌های امری از دانسته‌ها و قواعد منطقی برای حل مسئله استفاده می‌شود.

    زبان پرولوگ عموماً در حیطهٔ هوش مصنوعی (بالاخص برای پردازش زبان‌های طبیعی) مورد استفاده قرار می‌گیرد.

    پرولوگ در سال 1972 در دانشگاه مارسي و توسط Alain Colmerauer و همکاران ابداع شد. پرولوگ مخففي براي “PROgrammation en LOGique” يا «برنامه‌نويسي منطقي » مي¬باشد. مستندات اوليه در زمينه پرولوگ همگي به زبان فرانسه هستند. پس از مدتي در گوشه و کنار دنيا مخصوصاً در اروپا و ژاپن زبان پرولوگ طرفداراني پيدا کرد. گروهي که پرولوگ را ساختند اساساً يک گروه تحقيقاتي براي پردازش زبان‌هاي طبيعي براي زبان فرانسه بودند. پرولوگ يک زبان سطح بالا محسوب مي¬شود. بر خلاف اکثر زبان‌هاي ديگر برنامه‌نويسي رايانه، به جاي دستورالعمل‌هاي امري از دانسته‌ها و قواعد منطقي براي حل مسئله استفاده مي‌شود. به طور کلي پرولوگ بر روي دو بنيان رياضي يکسان¬سازي به صورت انطباق الگو و جستجو به صورت پيمايش به عقب بنا شده است. ادعا شده است که که به طور متوسط 55 الي 70 درصد زمان اجراي برنامه¬هاي به زبان پرولوگ مربوط به يکسان¬سازي مي¬شود. اصل مشهور Kowalski مي¬گويد که الگورييتم از کنترل و منطق تشکيل شده است. هر الگوريتم دو قسمت دارد: يک توصيف منطقي و يک شرح ازچگونگي اجراي اين توصيف. يک برنامه¬نويس منطقي خصوصيات جواب را بيان مي¬کند، اما کنترل را به سطح زيرين مي¬سپارد. به وضوح اين نوع از برنامه-نويسي يک سطح بالاتر از برنامه¬نويسي¬هاي دستوري چون C و يا پاسکال است، که در آنها برنامه نويس بايستي خود را درگير مسائل اجرايي عبارات کند. منطق محاسباتي نيز حول و حوش اين گونه مباحث مي¬گردد. زبان پرولوگ عموماً در حوزه¬ هوش مصنوعي و بالاخص براي پردازش زبان‌هاي طبيعي مورد استفاده قرار مي‌گيرد.

    --------------------------------------------------------------

    یكی از بهترین نمونه و مثال یك زبان برنامه نویسی منطقی است. یك برنامه منطقی دارای یك سری ویژگیهای قانون و منطق است . PROLOG از محاسبة اولیه استفاده می كند. در حقیقت خود این نام از برنامه نویسی PRO در LOGIC می آید یك مفسر برنامه را بر اساس یك منطق می نویسد. ایده استفاده توصیفی محاسبه اولیه برای بیان خصوصیات حل مسئله یكی از محوریت های مشاركتPROLOG می باشد كه برای علم كامپیوتر به طور كلی و به طور اخص برای زبان برنامه نویسی هوشمند مورد استفاده قرار می گیرند. نفع اسفتاده از محاسبه اولیه برای برنامه نویسی شامل یك ساختار ظریف و ساده و قابل معنی می شود.

    PROLOG یكی از بهترین نمونه و مثال یك زبان برنامه نویسی منطقی است. یك برنامه منطقی دارای یك سری ویژگیهای قانون و منطق است . PROLOG از محاسبة اولیه استفاده می كند. در حقیقت خود این نام از برنامه نویسی PRO در LOGIC می آید یك مفسر برنامه را بر اساس یك منطق می نویسد. ایده استفاده توصیفی محاسبه اولیه برای بیان خصوصیات حل مسئله یكی از محوریت های مشاركتPROLOG می باشد كه برای علم كامپیوتر به طور كلی و به طور اخص برای زبان برنامه نویسی هوشمند مورد استفاده قرار می گیرند. نفع اسفتاده از محاسبه اولیه برای برنامه نویسی شامل یك ساختار ظریف و ساده و قابل معنی می شود. به دلیل همین خصوصیات است كه PROLOG به عنوان یك محرك اصلی و مفید برای تحقیقاتی مثل موارد برنامه نویسی آزمایشی به عنوان یك كد، متغیر كردن برنامه و طراحی ویـــژگیهـای زبان سطح بالا، مطرح است. PROLOG و دیگر زبانهای منطقی یك سبك برنامه نویسی مشخصی را دنبال می كنند كه در آنها برنامه ها به صورت دستورات پشت سرهم و متوالی برای ایجاد یك الگوریتم، نوشته می شوند. این نوع برنامه اصولاً به كامپیوتر می گوید كه «چه چیزی درست است» و «چه چیزی باید صورت گیرد» و این به برنامه نویس اجازه می دهد كه بر روی حل مسئله به صورت یك سری خصوصیات از یك محدوده تأكید كند تا اینكه بخواهد به جزئیات نوشتاری سطح پائین ساختارهای الگوریتمی برای بعد بپردازد.

    اولین برنامه PROLOG در مارسی فرانسه در اوایل 1970 به عنوان بخشی از زبان معمول یك پروژه نوشته شد. تئوری نهفته در پشت این زبان در كارهای كوالسكی،‌هیز و دیگران آورده شده است. عمدة توسعة PROLOG بین سالهای 1975 تا 1979 در بخش هوش مصنوعی دانشگاه ادینبورگ صورت گرفت.

    در آنجا یك گروه مسئولیت كاربرد اولین PROLOG را به عهده داشتند كه آقای David H.D مسئول آن بود. این گروه اولین PROLOG را ساخت كه می توانست محاسبات كلی را انجام دهد. این محصول بر اساس سیستم DEC-10 ساخته شده بود و می توانست در مدهای توصیفی و مقایسه ای كارآئی داشته باشد.

    مزیت این زبان به وسیله پروژه هایی كه برای ارزیابی و گسترش قدرت بیان برنامه های منطقی نوشته شده اند،‌ اثبات شده است.

    بحث دربارة یك چنین كاربردهایی می تواند در سمینار و گردهمائی های مربوط به زبان برنامه نویسی هوش مصنوعی در سطح بین المللی مطرح شود.

  3. #3
    داره خودمونی میشه samaneh87's Avatar
    تاريخ عضويت
    Jul 2008
    پست ها
    93

    پيش فرض

    سلام دوستان میتونند یه چند مثال ساده و مشکل از پرولوگ برام بزارند؟ممنون میشم

  4. #4
    در آغاز فعالیت
    تاريخ عضويت
    Nov 2012
    پست ها
    7

    پيش فرض

    تاریخچه

    این زبان برای اولین بار در اوایل ۱۹۷۰ توسط یک گروه دربرگرفته شده توسط آلن کلمرار در مارسی فرانسه بوده‌است. به گفته رابرت کوالسکی، اولین سیستم Prolog در سال ۱۹۷۲ توسط آلن فیلیپ راسل توسعه داده شد و پیاده‌سازان اولین مترجم Prolog بودند، با این حال، دیوید اچ دی وارن با ایجاد ماشین خلاصه وارن در اوایل کامپایلر Prolog با نفوذ را نوشت و «Edinburgh Prolog» را تعریف نمود که گویشی است که اساس برای نحو بسیاری از پیاده‌سازی مدرن است. Prolog یکی از زبان‌های برنامه نویسی به منطق اول بود، و باقی مانده‌است در میان از رایج‌ترین زبانها مانند امروز، بخاطر پیاده سازی آزاد و تجاری به وجود آمده‌است. در حالی که در ابتدا در با هدف پردازش زبان طبیعی ساخته شد اما به تدریج بخاطر استفاده و پشتیبانی سیستم‌های خبره، بازی‌ها، سیستم پاسخ خودکار، ontologies و سیستم‌های کنترل پیچیده، تغییر کرد و محیط‌های Prolog مدرن و با حمایت از ایجاد واسط کاربر گرافیکی، به عنوان برنامه‌های اداری و شبکه.. معرفی گردید و الحاقات بعدی از Prolog که توسط تیم اصلی ایجاد گشت محدودیت توانایی در منطق برنامه نویسی را در پیاده سازی از بین بردند.
    زمزمه‌های ایجاد یک زبان منطق گرا از دهه ۷۰ میلادی از شمال امریکا شکل گرفته‌است. بعداً در نسل پنجم کامپیوترها از پرلوگ برای نوشتن کرنل سیستم‌عامل نیز در ایجاد پروژه سیستم FGCS استفاده شده‌است.

    انواع داده ها

    نوع داده در پرلوگ به صورت ترم‌ها تعریف می‌شود که این ترم‌ها می‌توانند اتم، اعداد، متغیرها و یا ترکیبی از ترم‌های دیگر باشند. اتم‌ها به طور کلی هیچ معنای ذاتی ندارند و یک سری رشته از حروف یا ... هستند که خواننده پرلوگ آنها را تجزیه کرده است. اتم کلمات آشکار در کد می‌باشند که هیچ نحو خاصی برای آنها در نظر گرفته نشده است مثل : x, blue,some,atom اعداد که می‌توانند به صورت اعداد شناور و یا صحیح باشند و حتی اعدا گویا متغیر که یک رشتهٔ متشکل از حروف است که می‌تواند نشان دهندهٔ یک واژه باشند و ارزش آنها با توجه به پرلوگ مقداردهی داده می‌شود. یک واژه مرکب (عمل کننده یا functor) ترکیبی از اتم‌ها است که به صورت یک متغیر با آن رفتار می کنیم و نیز مجموعه‌ای از استدلال هاست که یک نتیجه نهایی درست یا غلط را دربرمی گیرد. .واژه‌های مرکب در یک پرانتز تعریف می‌شوند و به انها عبارت‌های مرکب نیز اطلاق می‌شود. مثل

    truck_year('Mazda', 1986) 'Person_Friends'(zelda, [tom,jim]) لیست‌ها که یک حالت خاص عبارت‌ها ترکیبی هستند و ساختمان داده ایی پیشرفته برای نگهداشت استدلال‌ها و منطق هاست و به طور کلی لیستی از اتم‌ها هستندو بوسیله پرانتز، نقطه و کاما نشان داده می‌شود. رشته‌ها که مجموعه ایی از کارکترها هستند برای نگهداری یونیکدها و نام‌های شخصیت‌های محلی.


    برنامه نویسی در پرولوگ

    برنامه پرلوگ مجموعه‌ای از روابط است که توسط بندهای خاص تعریف شده اند . این بندها محدود به بندهای horn و تورینگ است که زیر مجموعه کاملی از منطق منظور اول است (first-order predicate logic) . بندها به دو دستهٔ قوانین و حقیقت‌ها تقسیم می‌شوند . یک مثال از قانون: Head :- Body. سر : -- بدن است. سر یک عضوی از بدن است . و بعد با پرس و جوهای انجام شده با توجه به قوانین موجود و حقایق اولیه نتایج ثانویه که حقایق جدیدی هستند شکل می‌گیرد. پرس و جوها می‌توانند براساس لیست‌های پیوندی نیز باشد و طبق قوانین از پیش تعیین شده نتایجی را در اختیار کاربر گذاشت . مثل اندازه لیست . عنصر آخر لیست و ... . بهمین خاطر مجموعه‌ای از کتابخانه‌های این زبان شکل گرفته است و در راستای آن هم دستوراتی برای چاپ داده‌ها و امثال آن شکل گرفته است .
    بررسی

    بررسی ابتدا با یک پرس و جو شروع می‌شود و با توجه به حقایق موجود که درست یا غلط است نتیجه منتقل می‌شود. اساس کار بدین گونه است که به‌دنبال اولین غلط و یا تکذیب مساله می‌یابد و با توجه به نوع مساله در صورت نیافتن آن همین روال را برای دیگر داده‌ها نیز انجام می‌دهد و در صورت حصول نتیجه حقیقت داده‌های قبلی بصورت بازگشتی معلوم می‌گردد. با این استراتژی که Backtracking نیز گفته می‌شود اساس یافت جواب در زبان پرلوگ اطلاق می‌شود. به طور مثال:
    mother_child(trude, sally).
    father_child(tom, sally). father_child(tom, erica). father_child(mike, tom).
    sibling(X, Y) :- parent_child(Z, X), parent_child(Z, Y).
    parent_child(X, Y) :- father_child(X, Y). parent_child(X, Y) :- mother_child(X, Y).
    و سوال پرسیده شده در دنباله آن
    ?- sibling(sally, erica).
    Yes
    طبق قانون وقتی دونفر خواهر و برادرند که والدین آنها یکی باشد پس زبان به دنبال والدین می‌گردد و آنها را بر می گرداند و جواب را به جای گزاره‌های مذکور می گذارد و طبق قانون اگر دو گزاره یکی باشند درست برمی گرداند. پس روش کلی روشی بازگشتی اثبات بندهاست و جایگزینی نتایج آنها.
    حلقه‌ها و بازگشت

    الگوریتمهای Iterative (پشت سرهمی) می‌توانید بوسیله predicates بازگشتی به اجرا درآیند. سیستم‌های Prolog معمولاً به روش بهینه سازی معروفی به نام تماس دم (tco) پایبندند که ملتزم به بازگشت قطعی است و حتماً در این روش بهینه سازی می بایست به دم برسد. بهمین خاطر در روش بازگشتی از یک پشته با یک نوع محدودیت بهره می‌گیرد و بدین وسیله می‌تواند حلقه‌های متعدد و بازگشتی را با اطمینان به بازگشت به جواب را جوابگو باشد.
    خنثی سازی

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

    یکسری قوانینی تعبیه شده است که در آن کاربر با استفاده از آن می‌تواند از ایجاد لوپ‌های تودرتو جلوگیری کند. و البته با نظم دادن به دستورات می‌توان از ایجاد آنها جلوگیری کرد به طور مثال:
    predicate1(X) :-

    predicate2(X,X). predicate2(X,Y) :-

    predicate1(X), X \= Y. برای پرسش
    ?- predicate1(atom).
    ایجاد یک حلقه بی نهایت توسط کاربر می‌کند ولی اگر دستورات را اینگونه نظم دهیم چنین اتفاقی نمی افتد
    predicate2(X,Y) :-

    X \= Y, predicate1(X). تجزیه DCGها

    یک نماد ویژه‌ای به نام گرامرهای بند قطعی (DCGs) وجود دارد . یک قاعده تعریف شده به عنوان --> به جای -: که با استفاده از آن می‌توان به تجزیه کردن و ایجاد یک رابط مناسب برای یک لیست بکار گرفت. در زیر یک مثال از این مورد را می بینید:

    <sentence> ::= <stat_part> < stat_part> ::= <statement> | <stat_part> < statement> <statement> ::= <id> = < expression> ; <expression> ::= <operand> | < expression> <operator> <operand> < operand> ::= <id> | <digit> <id> ::= a | b <digit> ::= 0..9 <operator> ::= + | - | * و با استفاده از DCG sentence(S) --> statement(S0), sentence_r(S0, S). sentence_r(S, S) --> []. sentence_r(S0, seq(S0, S)) --> statement(S1), sentence_r(S1, S).
    statement(assign(Id,E)) --> id(Id), [=], expression(E), [;].
    expression(E) --> term(T), expression_r(T, E). expression_r(E, E) --> []. expression_r(E0, E) --> [+], term(T), expression_r(plus(E0,T), E). expression_r(E0, E) --> [-], term(T), expression_r(minus(E0, T), E).
    term(T) --> factor(F), term_r(F, T). term_r(T, T) --> []. term_r(T0, T) --> [*], factor(F), term_r(times(T0, F), T).
    factor(id(ID)) --> id(ID). factor(digit(D)) --> [D], { (number(D) ; var(D)), between(0, 9, D)}.
    id(a) --> [a]. id(b) --> [b]. همان طور که می بینید علاوه بر مزیت‌های گفته شده موجب بزرگتر شدن کد نیز می‌شود.
    برنامه نویسی سفارشی

    یکی دیگر امکاناتی که در پرلوگ با توجه به ماهیت آن بوجود آمده است برنامه نویسی سفارشی است . با توجه به روند BachTracking و روش بهینه سازی بازگشت قطعی می‌توانیم حالاتی را ایجاد کنیم که از آن طریق برنامه به طور خودکار و تنها با داشتن یک قاعده ساده به دنبال جواب در یک لیست پیوندی بگردد. به طور مثال شمارش اعداد و پیدا کردن اعداد اول. perfect(N) :-

    between(1, inf, N), U is N // 2, findall(D, (between(1,U,D), N mod D =:= 0), Ds), sumlist(Ds, N). متا - مترجم و انعکاس

    یک زبان homoiconic فراهم شده است و بسیاری از امکانات را برای انعکاس را در اختیار ما می گذارد.. این زبان امکان نوشتن meta-circular evaluator را نیز فراهم می سازد که اغلب از آن به عنوان متا- مترجم یاد می‌شود. بدلیل آنکه برنامه‌های به زبان پرلوگ دنباله‌ای از اصطلاحات خود این زبان است بهمین دلیل خواندن آن راحت و مکانیزم ساده ایی جهت ترجمه را خواستار است.
    روش‌های پیاده سازی

    برای بهره وری از کد Prolog معمولاً به صورت کد ماشین انتزاعی ترجمه می‌شود و اغلب تحت تاثیر مجموعه دستورات ثبت نامی براساس ماشین انتراعی وارن (Warren Abstract Machine (WAM)) است.برای پیاده سازی انتزاعی متناسب به نوع اصطلاحات و اطلاعات در زمان کامپایل است. برای ترجمه بهتر و نزدیک تر بودن به زبان ماشین واقعی برای عملکرد بهتر نیاز به تحقیقات مبتنی بر جامعه منطقی برنامه ریزی شده است که دو کار اساسی براساس قواعد منطقی انجام می‌دهد یک باینری کردن عبارات و بندها و دیگری فراهم کردن پشته مبتنی بر ماشین مجازی.در نسل پنجم سعی شده است ماشین‌ها و سیستم‌های مبتنی بر پرلوگ نیازهای سخت‌افزاری این نوع برنامه سازی منطقی را نیز فراهم سازند تا سرعت اجرای آن هزاران برابر شود. بعلاوه این پرلوگ این توانایی را نیز دارد که با پردازش موازی بندها سرعت را بهبود بخشد.
    مثال ها

    در اینجا مثال هایی از برنامه ساخته شده به زبان پرلوگ را می بینیم.
    الگوریتم مرتب سازی سریع

    partition([], _, [], []). partition([X|Xs], Pivot, Smalls, Bigs) :-

    ( X @< Pivot -> Smalls = [X|Rest], partition(Xs, Pivot, Rest, Bigs) ; Bigs = [X|Rest], partition(Xs, Pivot, Smalls, Rest) ). quicksort([]) --> []. quicksort([X|Xs]) -->

    { partition(Xs, X, Smaller, Bigger) }, quicksort(Smaller), [X], quicksort(Bigger). ماشین تورینگ

    turing(Tape0, Tape) :-

    perform(q0, [], Ls, Tape0, Rs), reverse(Ls, Ls1), append(Ls1, Rs, Tape). perform(qf, Ls, Ls, Rs, Rs) :- !. perform(Q0, Ls0, Ls, Rs0, Rs) :-

    symbol(Rs0, Sym, RsRest), once(rule(Q0, Sym, Q1, NewSym, Action)), action(Action, Ls0, Ls1, [NewSym|RsRest], Rs1), perform(Q1, Ls1, Ls, Rs1, Rs). symbol([], b, []). symbol([Sym|Rs], Sym, Rs).
    action(left, Ls0, Ls, Rs0, Rs) :- left(Ls0, Ls, Rs0, Rs). action(stay, Ls, Ls, Rs, Rs). action(right, Ls0, [Sym|Ls0], [Sym|Rs], Rs).
    left([], [], Rs0, [b|Rs0]). left([L|Ls], Ls, Rs, [L|Rs]). مثالی ساده از برنامه پیاده سازی ماشین تورینگ rule(q0, 1, q0, 1, right). rule(q0, b, qf, 1, stay).
    ?- turing([1,1,1], Ts). Ts = [1, 1, 1, 1] ;

    برنامه نویسی پویا

    برنامه Prolog زیر استفاده می‌کند برنامه نویسی پویا برای یافتن توالی مشترک طولانی از دو فهرست در زمان چند جملهای: پایگاه داده بند برای memoization استفاده شده است :

    - dynamic(stored/1).memo(Goal) :- ( stored(Goal) -> true ; Goal, assertz(stored(Goal)) ).
    lcs([], _, []) :- !. lcs(_, [], []) :- !. lcs([X|Xs], [X|Ys], [X|Ls]) :- !, memo(lcs(Xs, Ys, Ls)). lcs([X|Xs], [Y|Ys], Ls) :-

    memo(lcs([X|Xs], Ys, Ls1)), memo(lcs(Xs, [Y|Ys], Ls2)), length(Ls1, L1), length(Ls2, L2), ( L1 >= L2 -> Ls = Ls1 ; Ls = Ls2 ). مثال پرس و جو ?- lcs([x,m,j,y,a,u,z], [m,z,j,a,w,x,u], Ls). Ls = [m, j, a, u]
    ضمیمه ها

    درحال حاضرتلاش در راستای توسعه این زبان برای گسترش قابلیت‌های برنامه سازی در جهات مختلف می‌باشند که این قابلیت‌ها عبارتند از محدودیت‌های برنامه نویسی منطقی (CLP)(بیشتر در تنظیمات صنعتی مانند جدول‌های زمان بندی)، برنامه نویسی شی گرای منطقی (OOLP)، همزمانی، منطق خطی و قابلیت همکاری با پایگاه‌های دانش. بدین منظور نسخه‌هایی همچون نمونه‌های زیر تهیه شده است: HiLog و λProlog تمدید Prolog با بالاتربردن ویژگی‌های برنامه نویسی سفارشی. اف منطق گسترش Prolog با قاب / اشیاء را برای نمایش دانش. OW Prolog ایجاد شده است به منظور پاسخ به عدم Prolog است از گرافیک و رابط. Logtalk یک شیء گرا منطق زبان برنامه نویسی است (بهمراه ایجاد خاصیت چندریختی و وراثت و همچنین چند نخی و همزمانی) Prolog - MPI یک منبع باز SWI - Prolog می‌باشد که برای محاسبات توزیع شده از طریق واسط پیام رسان اینکار را انجام می‌دهد. Oblog کوچک، قابل حمل، شیء گرا را به فرمت - Prolog توسط McDougall مارگارت از EdCAAD، دانشگاه ادینبورگ است.


    زبان‌های مرتبط

    Datalog که در واقع یک زیر مجموعه از Prolog است و شرایط ترکیب را بخوبی اجازه نمی‌دهد و در مقابل به Prolog ، Datalog تورینگ نشده است. ویژوال پرلوگ که بیشتر به عنوان PDC prolog شناخته می‌شود و شی گرا می‌باشد و با ایجاد محیطی شی گرا فهم را در هنگام کدزنی بالا می‌برد. InterProlog که یک کتابخانه برنامه نویسی شده بین جاوا و پرلوگ است. JPL که پلی بین جاوا و پرلوگ است. Prova یک زبان اسکریپ نویسی بر اساس پرلوگ است .
    Prolog Gnu چیست؟

    gnu Prolog (همچنین به نام gprolog) یک کامپایلرکد باز توسط دانیل دیاز با یک اشکال زدایی محیط تعاملی برای Prolog در دسترس در یونیکس و ویندوزمی باشد. همچنین پشتیبانی از برخی از الحاقات را به Prolog از جمله محدودیت‌های برنامه نویسی بیش از یک دامنه محدود، با استفاده از تجزیه grammars بند تصریح شده، و یک سیستم‌عامل و رابط را داراست. کامپایلر تبدیل کد منبع را تبدیل به بایت کد می‌کند که می‌تواند توسط یک دستگاه مترجم و یا مفسر وارون انتزاعی آن را به کد اجرایی رایج تبدیل کند.

  5. #5
    در آغاز فعالیت
    تاريخ عضويت
    Apr 2013
    پست ها
    2

    پيش فرض

    prolog

    سلام دوستان
    یه برنامه میخوام به زبون پرولوگ که یه دنباله ای از اعداد پشت سر هم رو بکیره که از اون اعداد اونی که جا افتاده رو بهت برگردونه.ممنون میشم اگه کمکم کنید
    به عنوان نمونه مجموعه روبرو رو بگیره و عد 6 رو برگردونه
    {7و9و8}
    ممنون
    تروخدا کمکم کنید

Thread Information

Users Browsing this Thread

هم اکنون 1 کاربر در حال مشاهده این تاپیک میباشد. (0 کاربر عضو شده و 1 مهمان)

User Tag List

قوانين ايجاد تاپيک در انجمن

  • شما نمی توانید تاپیک ایحاد کنید
  • شما نمی توانید پاسخی ارسال کنید
  • شما نمی توانید فایل پیوست کنید
  • شما نمی توانید پاسخ خود را ویرایش کنید
  •