লজিক প্রোগ্রামিংয়ের ক্ষেত্রে প্রোলোগ এবং মিনিক্যানরেনের মধ্যে প্রধান প্রযুক্তিগত পার্থক্যগুলি কী কী? [বন্ধ]


123

আমি যখন লজিক প্রোগ্রামিং পড়তে চাই তখন আমি আজকাল সবসময় দুটি "প্রধান" উপায়ে হোঁচট খাচ্ছি:

  • miniKanren , একটি minilanguage চালু কারণগত স্কিমার কারণে মুহূর্তে এবং জনপ্রিয় core.logic
  • প্রোলোগ , প্রথম "বড়" লজিক প্রোগ্রামিং ভাষা।

আমি এখন যা সম্পর্কে আগ্রহী: দুজনের মধ্যে প্রধান প্রযুক্তিগত পার্থক্যগুলি কী কী? এগুলি কি পদ্ধতির এবং বাস্তবায়নের ক্ষেত্রে খুব একই রকম, বা লজিক প্রোগ্রামিংয়ের ক্ষেত্রে তারা সম্পূর্ণ ভিন্ন পন্থা নেয়? তারা গণিতের কোন শাখা থেকে আসে এবং তাত্ত্বিক ভিত্তি কী?


3
এই প্রশ্নটি বন্ধ দেখে দুঃখ হয়েছে। খুব সংক্ষিপ্ত উত্তর এবং বিপুল সংখ্যক উপাখ্যান দ্বারা প্রদর্শিত হিসাবে, এটি নিখুঁতভাবে কার্যকর প্রশ্ন। আমি আবার খুলতে ভোট দিয়েছি ....
nealmcb

@nemcb প্রশ্নগুলি যা একবারে অনেকগুলি আপভোটের সাথে বিষয়বস্তুতে ছিল সেগুলি আর হতে পারে না, আপভোটের পরিমাণ এটি বৈধ বা না সংজ্ঞায়িত করে না।
টিয়াগো মার্টিনস পেরেস

উত্তর:


280

প্রথমে, আপনার সূক্ষ্ম pw0n1e আইকনটিতে আমাকে আপনার প্রশংসা করার অনুমতি দিন।

উত্তর দেওয়ার জন্য এটি একটি জটিল প্রশ্ন, মূলত কারণ মিনিকেনরেন এবং প্রোলোগ উভয়েরই অনেকগুলি রূপ রয়েছে। মিনিকেনরেন এবং প্রোলোগ হ'ল ভাষাগুলির পরিবার, যা তাদের বৈশিষ্ট্যগুলির তুলনা করা বা এমনকি বাস্তবে কীভাবে তারা ব্যবহার করা হয় তা তুলনা করা শক্ত করে তোলে। এর কারণে, দয়া করে আমি যা বলার বিষয়ে যাচ্ছি তার সাথে সাবধানতার সাথে বলুন: যদি আমি বলি যে প্রোলোগ গভীরতা-প্রথম অনুসন্ধান ব্যবহার করে তবে সচেতন থাকুন যে অনেক প্রোলোগ বাস্তবায়ন অন্যান্য অনুসন্ধান কৌশলকে সমর্থন করে এবং বিকল্প অনুসন্ধান কৌশলগুলিও মেটাতে এনকোড করা যেতে পারে - ইন্টারেটারেটর স্তর। তবুও, মিনিকেনরেন এবং প্রোলোগের বিভিন্ন ডিজাইনের দর্শন রয়েছে এবং তারা বিভিন্ন ট্রেড অফ করে।

প্রোলোগ হ'ল প্রতীকী কৃত্রিম বুদ্ধিমত্তা প্রোগ্রামিংয়ের জন্য দুটি ক্লাসিক ভাষার একটি (অন্য ক্লাসিক ভাষা লিস্প)। প্রোলজ প্রতীকী বিধি-ভিত্তিক সিস্টেমগুলি প্রয়োগ করতে পেরে ওঠে, যেখানে ঘোষণামূলক জ্ঞান প্রথম-আদেশের যুক্তিতে এনকোড থাকে। ভাষা এই ধরণের অ্যাপ্লিকেশনগুলির জন্য ভাব এবং দক্ষতার জন্য অনুকূলিত হয়, কখনও কখনও যৌক্তিক বিশুদ্ধতার ব্যয়ে। উদাহরণস্বরূপ, ডিফল্টরূপে প্রোলোগ একীকরণে "ঘটে যাওয়া চেক" ব্যবহার করে না। গণিত / যুক্তির দিক থেকে, একীকরণের এই সংস্করণটি ভুল। যাইহোক, দেখা চেক ব্যয়বহুল, এবং বেশিরভাগ ক্ষেত্রে দেখা চেকের অভাব কোনও সমস্যা নয়। প্রোলোগের গভীরতা-প্রথম অনুসন্ধানের ব্যবহার এবং কাটা ব্যবহারের মতোই এটি একটি খুব ব্যবহারিক নকশার সিদ্ধান্ত (!) ব্যাকট্র্যাকিং নিয়ন্ত্রণ করতে। আমি নিশ্চিত যে ১৯ decisions০ এর দশকে হার্ডওয়্যার চালানোর সময় এই সিদ্ধান্তগুলি একেবারে প্রয়োজনীয় ছিল এবং বড় সমস্যাগুলির সাথে কাজ করার সময় এবং বিশাল (প্রায়শই অসীম!) অনুসন্ধানের জায়গাগুলি নিয়ে কাজ করার সময় আজ খুব দরকারী।

প্রোলোগ অনেকগুলি "অতিরিক্ত-লজিকাল" বা "অ-লজিকাল" বৈশিষ্ট্যগুলিকে সমর্থন করে, কাটা সহ, assertএবং retract, পাটিগণিত ব্যবহার করে ভেরিয়েবলের অভিক্ষেপis, এবং আরও। এই বৈশিষ্ট্যগুলির মধ্যে অনেকগুলি জটিল নিয়ন্ত্রণ প্রবাহকে প্রকাশ করা সহজ করে তোলে এবং প্রোলোগের বিশ্বব্যাপী তথ্যগুলির ডেটাবেসগুলি ম্যানিপুলেট করে। প্রোলোগের একটি খুব আকর্ষণীয় বৈশিষ্ট্য হ'ল প্রোলগ কোডটি স্বয়ং তথ্যগুলির বিশ্বব্যাপী ডাটাবেসে সংরক্ষিত থাকে এবং রান সময় এটির বিরুদ্ধে অনুসন্ধান করা যেতে পারে। এটি মেটা-দোভাষীকে লিখতে তুচ্ছ করে তোলে যা ব্যাখ্যার অধীনে প্রোলোগ কোডের আচরণকে পরিবর্তন করে। উদাহরণস্বরূপ, মেগা-দোভাষী যা অনুসন্ধানের ক্রম পরিবর্তন করে ব্যবহার করে প্রোলগের প্রস্থে প্রথম প্রস্থের এনকোড করা সম্ভব। এটি একটি অত্যন্ত শক্তিশালী কৌশল যা প্রোলগ বিশ্বের বাইরে সুপরিচিত নয়। 'আর্ট অফ প্রোলজ' এই কৌশলটি বিশদভাবে বর্ণনা করে।

গুরুতর প্রচেষ্টা প্রোলোগ বাস্তবায়নের উন্নতিতে চলে গেছে, যার বেশিরভাগ ওয়ারেন অ্যাবস্ট্রাক্ট মেশিন (ডাব্লুএএম) এর উপর ভিত্তি করে। ডাব্লুএইএম একটি পার্শ্ব-প্রভাবকারী মডেল ব্যবহার করে যেখানে মানগুলি ধ্বংসাত্মকভাবে লজিক ভেরিয়েবলগুলিতে বরাদ্দ করা হয়, ব্যাকট্র্যাকিংয়ের পরে এই পার্শ্ব-প্রতিক্রিয়াগুলি পূর্বাবস্থায় ফিরে আসে। ডাব্লুএএমএর নির্দেশাবলী বাড়িয়ে প্রোগলগুলিতে অনেকগুলি বৈশিষ্ট্য যুক্ত করা যেতে পারে। এই পদ্ধতির একটি অসুবিধা হ'ল ডাব্লুএইচএএম সম্পর্কে দৃ of় বোঝা ছাড়াই প্রোলোগ বাস্তবায়ন কাগজপত্র পড়া কঠিন হতে পারে। অন্যদিকে, প্রোলগ বাস্তবায়নকারী বাস্তবায়নের বিষয়গুলি নিয়ে আলোচনার জন্য একটি সাধারণ মডেল রয়েছে। সমান্তরাল প্রোলোগ নিয়ে অনেক গবেষণা হয়েছে, যার সমাপ্তি ১৯৯০ এর দশকে আন্দোরার প্রোলোগে। কমপক্ষে এই ধারণাগুলির কয়েকটি সিও প্রোগলগে লাইভ রয়েছে। (সিওও প্রোলোগ আকর্ষণীয় ধারণাগুলিতে পূর্ণ, যার মধ্যে বেশিরভাগ প্রোলগ স্ট্যান্ডার্ড ছাড়িয়ে যায় go)

প্রোলোগের একটি সুন্দর একীকরণ-ভিত্তিক "প্যাটার্ন-ম্যাচিং"-স্টাইল সিনট্যাক্স রয়েছে যা খুব সংক্ষিপ্ত প্রোগ্রামগুলির ফলাফল। প্রচারকারীরা তাদের বাক্যবিন্যাসকে পছন্দ করেন ঠিক যেমন লিস্পাররা তাদের এস-এক্সপ্রেশনকে পছন্দ করে। প্রোলগের কাছে স্ট্যান্ডার্ড পূর্বাভাসের একটি বৃহত লাইব্রেরি রয়েছে। ডাব্লুএমএইএম দ্রুত তৈরি করার ক্ষেত্রে যে সমস্ত ইঞ্জিনিয়ারিং চলছে সেগুলির কারণে খুব দক্ষ এবং পরিপক্ক প্রোলোগ বাস্তবায়ন রয়েছে। ফলস্বরূপ, অনেক বড় জ্ঞান-ভিত্তিক সিস্টেম সম্পূর্ণরূপে সম্পূর্ণ লেখা হয়েছে।

miniKanren একটি ছোট, সহজেই বোধগম্য এবং সহজেই হ্যাকযোগ্য প্রয়োগকরণ সহ একটি ন্যূনতম যুক্তিযুক্ত প্রোগ্রামিং ভাষা হিসাবে ডিজাইন করা হয়েছিল। miniKanren মূলত স্কিমে এম্বেড করা ছিল এবং গত দশকে ধরে কয়েক ডজন অন্যান্য হোস্ট ভাষায় পোর্ট করা হয়েছে। সর্বাধিক জনপ্রিয় মিনিক্যানরেন বাস্তবায়ন হ'ল ক্লোজারে 'কোর.লগিক', যার এখন অনেকগুলি প্রোলোগুলির মতো এক্সটেনশন এবং বেশ কয়েকটি অপ্টিমাইজেশন রয়েছে। সম্প্রতি মিনিকেনরেন বাস্তবায়নের মূলটিকে আরও আরও সরল করা হয়েছে, যার ফলে "মাইক্রো ক্যানরেন" নামে একটি ক্ষুদ্র "মাইক্রো কার্নেল" তৈরি হয়েছে। miniKanren এর পরে এই মাইক্রো ক্যানরেন কোরের শীর্ষে প্রয়োগ করা যেতে পারে। মাইক্রো ক্যানরেন বা মিনি ক্যানেনেনকে একটি নতুন হোস্ট ভাষায় পোর্টিং করা প্রোগ্রামারদের miniKanren শেখার জন্য একটি আদর্শ অনুশীলনে পরিণত হয়েছে। ফলস্বরূপ,

মিনিক্যানরেন এবং মাইক্রো ক্যানরেনের স্ট্যান্ডার্ড বাস্তবায়নে কোনও একক ব্যতিক্রম ছাড়া কোনও রূপান্তর বা অন্যান্য পার্শ্ব-প্রতিক্রিয়া নেই: মিনিক্যানরেনের কিছু সংস্করণ যুক্তিযুক্ত ভেরিয়েবলের তুলনায় পয়েন্টার সমতা ব্যবহার করে। আমি এটিকে একটি "সৌম্য প্রভাব" হিসাবে বিবেচনা করি, যদিও বাস্তবায়নের মাধ্যমে কাউন্টার পেরিয়ে অনেক বাস্তবায়ন এমনকি এই প্রভাবকে এড়িয়ে চলে। কোনও গ্লোবাল ফ্যাক্ট ডাটাবেসও নেই। miniKanren এর বাস্তবায়ন দর্শন কার্যকরী প্রোগ্রামিং দ্বারা অনুপ্রাণিত: মিউটেশন এবং প্রভাবগুলি এড়ানো উচিত এবং সমস্ত ভাষা নির্মাতাকে লেক্সিকাল স্কোপকে সম্মান করা উচিত। আপনি যদি বাস্তবায়নের দিকে মনোযোগ সহকারে তাকান তবে আপনি এমনকি বেশ কয়েকটি মনডও দেখতে পাবেন। অনুসন্ধানের প্রয়োগটি মিউটেশনটি ব্যবহার না করে আবার অলস প্রবাহগুলির সংমিশ্রণ এবং হেরফেরের উপর ভিত্তি করে। এই প্রয়োগের পছন্দগুলি প্রোলোগের তুলনায় খুব আলাদা বাণিজ্য-বাণিজ্য করে to প্রোগলগুলিতে, ভেরিয়েবল লুকের জন্য ধ্রুবক সময় হয় তবে ব্যাকট্র্যাকিংয়ের জন্য পার্শ্ব-প্রতিক্রিয়াগুলি পূর্বাবস্থায় ফেরানো দরকার। মিনিক্যানারে ভেরিয়েবলের চেহারা আরও ব্যয়বহুল, তবে ব্যাকট্র্যাকিং "ফ্রি"। আসলে, কীভাবে স্ট্রিমগুলি পরিচালনা করা হয় তার কারণে মিনিক্যানারে কোনও ব্যাকট্র্যাকিং নেই।

মিনিকেনরেন বাস্তবায়নের একটি আকর্ষণীয় দিক হ'ল কোডটি সহজাতভাবে থ্রেড-নিরাপদ এবং --- কমপক্ষে তত্ত্বে --- তুচ্ছভাবে সমান্তরাল। অবশ্যই, কোডটিকে ধীর না করে সমান্তরাল করা তুচ্ছ নয়, তবে প্রতিটি থ্রেড বা প্রক্রিয়াটিকে সমান্তরালনের ওভারহেডের জন্য যথেষ্ট পরিমাণ কাজ দিতে হবে। তবুও, এটি মিনিকেনরেন বাস্তবায়নের একটি ক্ষেত্র যা আমি আশা করি আরও মনোযোগ এবং পরীক্ষা গ্রহণ করব।

miniKanren একীকরণের জন্য ঘটে যাওয়া চেকটি ব্যবহার করে এবং গভীরতা-প্রথম অনুসন্ধানের পরিবর্তে একটি সম্পূর্ণ ইন্টারলেভেভিং অনুসন্ধান ব্যবহার করে। ইন্টারলেভিং অনুসন্ধান গভীরতা-প্রথম অনুসন্ধানের চেয়ে বেশি মেমরি ব্যবহার করে তবে কিছু ক্ষেত্রে উত্তর পেতে পারে যে ক্ষেত্রে গভীরতা-প্রথম অনুসন্ধান চিরতরে ডাইভারেজ / লুপ ডাইর করবে। miniKanren করে কিছু অতিরিক্ত-লজিক্যাল অপারেটর --- সমর্থন conda, conduএবং project, জন্য উদাহরণ। condaএবং conduপ্রোলোগুলের কাটা অনুকরণ করতে ব্যবহার করা projectযেতে পারে এবং লজিক ভেরিয়েবলের সাথে মান যুক্ত করতে ব্যবহার করা যেতে পারে।

উপস্থিতি conda, conduএবংproject--- এবং সহজেই অনুসন্ধান কৌশলটি সংশোধন করার ক্ষমতা --- প্রোগ্রামারদের এম্বেড থাকা প্রোলোগ-জাতীয় ভাষা হিসাবে মিনিকেনরেন ব্যবহার করতে দেয়। এটি ক্লোজুরের 'কোর.লগিক' ব্যবহারকারীদের জন্য বিশেষত সত্য, যার মধ্যে অনেকগুলি প্রোলোগ-এর মতো এক্সটেনশন রয়েছে। মিনিক্যানরেনের এই "ব্যবহারিক" ব্যবহারটি শিল্পে মিনি ক্যানরেনের বেশিরভাগ ব্যবহারের জন্য দায়ী বলে মনে হয়। প্রোগ্রামাররা যারা ক্লোজার বা পাইথন বা জাভাস্ক্রিপ্টে লিখিত একটি বিদ্যমান অ্যাপ্লিকেশনটিতে একটি জ্ঞান-ভিত্তিক যুক্তি ব্যবস্থা যুক্ত করতে চান তারা সাধারণত তাদের পুরো অ্যাপ্লিকেশন প্রোগলে পুনর্লিখন করতে আগ্রহী নন। ক্লোজার বা পাইথনে একটি ছোট লজিক প্রোগ্রামিং ভাষা এম্বেড করা আরও বেশি আবেদনময়ী। একটি এম্বেড থাকা প্রোলোগ বাস্তবায়ন সম্ভবত এই উদ্দেশ্যে, ঠিক পাশাপাশি কাজ করবে।

প্রোলোগের সাথে একইভাবে ব্যবহারিক এমবেডেড লজিক প্রোগ্রামিং ল্যাঙ্গুয়েজ হিসাবে মিনিক্যানরেনকে ব্যবহার করার পাশাপাশি, "রিলেশনাল" প্রোগ্রামিংয়ের গবেষণার জন্য miniKanren ব্যবহার করা হচ্ছে। এটি হ'ল প্রোগ্রামগুলিতে লিখিত যেগুলি গাণিতিক ফাংশনের চেয়ে গাণিতিক সম্পর্ক হিসাবে আচরণ করে। উদাহরণস্বরূপ, স্কিম মধ্যে appendফাংশন দুটি তালিকা সংযুক্ত করতে পারবেন, একটি নতুন তালিকা ফেরার: ফাংশন কল (append '(a b c) '(d e))তালিকা ফেরৎ (a b c d e)। আমরা যাইহোক, appendদ্বি-আর্গুমেন্ট ফাংশন না করে তিন স্থানের সম্পর্ক হিসাবেও আচরণ করতে পারি । কলটি (appendo '(a b c) '(d e) Z)তখন যুক্তির সাথে চলকের Zতালিকার সাথে যুক্ত হবে (a b c d e)। অবশ্যই যখন আমরা অন্যান্য অবস্থানে লজিক ভেরিয়েবল রাখি তখন জিনিসগুলি আরও আকর্ষণীয় হয়। কল (appendo X '(d e) '(a b c d e))সহযোগীদের Xসঙ্গে (a b c), যখন কল(appendo X Y '(a b c d e))সহযোগী Xএবং Yতালিকার জোড়গুলির সাথে যা যুক্ত করা হলে সমান (a b c d e)। উদাহরণস্বরূপ X= (a b)এবং Y= (c d e)মানগুলির মধ্যে এমন একটি জোড়া। আমরা লিখতে পারি (appendo X Y Z), যা তালিকার অসীম অনেক triples উত্পাদন করা হবে X, Yএবং Zএই ধরনের সংযোজন যে Xকরতে Yউৎপন্ন Z

এই সম্পর্কিত সংস্করণটি appendসহজেই প্রোলগে প্রকাশ করা যায় এবং প্রকৃতপক্ষে অনেক প্রোলোগ টিউটোরিয়ালে প্রদর্শিত হয়। অনুশীলনে, আরও জটিল প্রোলোগ প্রোগ্রামগুলি কমপক্ষে কয়েকটি অতিরিক্ত-লজিক্যাল বৈশিষ্ট্যগুলি ব্যবহার করে, যেমন কাটা, যা ফলস্বরূপ প্রোগ্রামটিকে একটি সম্পর্ক হিসাবে গণ্য করার ক্ষমতাকে বাধা দেয়। বিপরীতে, miniKanren স্পষ্টতই এই স্টাইলটি রিলেশনাল প্রোগ্রামিং সমর্থন করার জন্য ডিজাইন করা হয়েছে। MiniKanren এর আরো সাম্প্রতিক সংস্করণে (প্রতীকী বাধ্যতা সমাধানের জন্য সমর্থন আছে symbolo, numbero,absento, বৈষম্য সীমাবদ্ধতা, নামমাত্র লজিক প্রোগ্রামিং) সম্পর্ক হিসাবে তুচ্ছ-তুচ্ছ প্রোগ্রাম লিখতে আরও সহজ করে তোলে। অনুশীলনে আমি কখনই মিনিকেনরেনের অতিরিক্ত-লজিকাল বৈশিষ্ট্যগুলি ব্যবহার করি না এবং আমি আমার মিনি ক্যানারেনের সমস্ত প্রোগ্রামকে সম্পর্ক হিসাবে লিখি। সবচেয়ে আকর্ষণীয় রিলেশনাল প্রোগ্রামগুলি হ'ল স্কিমের একটি উপসেটের জন্য সম্পর্কযুক্ত দোভাষী। এই দোভাষীদের অনেক আকর্ষণীয় ক্ষমতা রয়েছে যেমন তালিকার মূল্যায়ন করে এমন এক মিলিয়ন স্কিম প্রোগ্রাম তৈরি করা (I love you)বা তুচ্ছভাবে কুইন উত্পন্ন করা (যে প্রোগ্রামগুলি নিজেরাই মূল্যায়ন করে)।

miniKanren প্রোগ্রামিংয়ের এই সম্পর্কিত স্টাইলকে সক্ষম করতে বেশ কয়েকটি ট্রেড-অফ করে, যা ট্রেড-অফ প্রোলোগের তুলনায় খুব আলাদা। সময়ের সাথে সাথে মিনিকেনরে আরও প্রতীকী প্রতিবন্ধকতা যুক্ত করেছে, যা সত্যই প্রতীকীমুখী প্রতিবন্ধী লজিক প্রোগ্রামিং ভাষা হয়ে উঠেছে। অনেক ক্ষেত্রে এই প্রতীকী বাধাগুলি অতিরিক্ত-লজিকাল অপারেটরগুলি পছন্দ করতে conduএবং এড়াতে ব্যবহারিক করে তোলে project। অন্যান্য ক্ষেত্রে, এই প্রতীকী বাধাগুলি পর্যাপ্ত নয়। প্রতীকী সীমাবদ্ধতার জন্য আরও ভাল সমর্থন হ'ল মিনিকেনরেন গবেষণার একটি সক্রিয় ক্ষেত্র, সেইসাথে আরও বৃহত্তর এবং আরও জটিল প্রোগ্রামগুলি কীভাবে সম্পর্ক হিসাবে লিখতে হবে তার বিস্তৃত প্রশ্নের পাশাপাশি।

সংক্ষেপে, মিনিকেনরেন এবং প্রোলোগ উভয়েরই আকর্ষণীয় বৈশিষ্ট্য, বাস্তবায়ন এবং ব্যবহার রয়েছে এবং আমি মনে করি এটি উভয় ভাষা থেকে ধারণাগুলি শেখার পক্ষে উপযুক্ত। অন্যান্য খুব আকর্ষণীয় লজিক প্রোগ্রামিং ভাষা রয়েছে যেমন বুধ, কারি এবং গডেল, যার প্রত্যেকটির নিজস্ব যুক্তিযুক্ত প্রোগ্রামিং রয়েছে।

আমি কয়েক মিনি ক্যানারেন সংস্থান দিয়ে শেষ করব:

মূল মিনিকেনরেন ওয়েবসাইট: http://minikanren.org/

এক সাক্ষাৎকারে আমি রিলেশনাল প্রোগ্রামিং এবং miniKanren, Prolog সঙ্গে একটি তুলনামূলক সহ দিয়েছেন: http://www.infoq.com/interviews/byrd-relational-programming-minikanren

চিয়ার্স,

--ইচ্ছাশক্তি


9
আমাকে এখনই উড়িয়ে দেওয়া হলে ক্ষমা করবেন। আমি সবেমাত্র যুক্তি এবং সীমাবদ্ধতা ভিত্তিক প্রোগ্রামিংয়ে প্রথম চিন্তার পরীক্ষাগুলি শুরু করেছি এবং এটিই আমার জবাব। :) প্রকৃতপক্ষে, আপনি আপনার উত্তরে যেমন উল্লেখ করেছেন, আমার কাছে দৃ strong় সন্দেহের যুক্তিযুক্ত গণনা ছিল একটি মোনাড হিসাবে বাস্তবায়নের জন্য নিখুঁত প্রার্থী; দেখা যাচ্ছে এটি আরও একটি মোনাডপ্লাস এবং আপনার সহকর্মী ফ্রেডম্যানের দ্বারা একটি কাগজ এবং রেফারেন্স বাস্তবায়ন রয়েছে ! সুতরাং আমি এটি পড়ছি এবং এখন এটি নিয়ে খেলছি, এটি সম্পর্কে কোনও ধারণা?
প্রোফ্যাচটছ

4
আমি সন্দেহ করি যে আপনি মাইক্রো ক্যানরেন পেপার এবং কোডটি আকর্ষণীয়ভাবে খুঁজে পাবেন: webyrd.net/scheme-2013/papers/HemannMuKanren2013.pdf এবং github.com/jasonhemann/microKanren
উইলিয়াম ই

5
এছাড়াও, আমি গুগল হ্যাঙ্গআউটে, রবিবার পূর্ব সময় বিকাল তিনটায় (জিএমটি -5: 00) একটি সাপ্তাহিক মিনিকেনরেন অনুষ্ঠান আয়োজন করি। আপনি আমাদের সাথে যোগ দিতে চাইলে আমি সর্বদা আমার @Wbyrd টুইটার অ্যাকাউন্ট থেকে লিঙ্কটি টুইট করি। পূর্ববর্তী রেকর্ডকৃত হ্যাঙ্গআউটগুলি এখানে রয়েছে: youtube.com/playlist?list=PLO4TbomOdn2cks2n5PvifialL8kQwt0aW
উইলিয়াম ই বাইার্ড

2
আমি মনে করি এটি মূলত '05 পেপারের মতো একই অনুসন্ধান মনড ad এছাড়াও, সেরেস এবং স্পাইভির
উইলিয়াম ই বাইর্ড

1
@ উইলিয়াম.বিয়ার্ড - দুর্দান্ত উত্তর! ধরে নেওয়া হচ্ছে একটি আছে, কোন সি / সি ++ প্রোগ্রামে এম্বেড করা যায় এমন সেরা মিনিকেনার বাস্তবায়ন কী? এছাড়াও, মিনিকেনারে কি প্রোলোগের জেনারেটর প্রকৃতি রয়েছে? অর্থাত্, কোনও অভিব্যক্তিটি ওপারগডে রেখে একটি ভেরিয়েবল রেখে যাওয়ার ক্ষমতা এবং মূল ইঞ্জিনটি প্রোগ্রাম দ্বারা ঘোষিত বর্তমান সম্পর্কের প্রেক্ষাপটে পার্শ্ববর্তী ভেরিয়েবলের জন্য সমস্ত সম্ভাব্য মান তৈরি করবে?
রবার্ট অসলারের

4

সাময়িক উত্তর:

আফাইক, "দ্য রিজেনড স্কিমার" একটি স্কিম-ওয়াই সিনট্যাক্স এবং ফাংশনাল প্রোগ্রামিং স্টাইলে বেসিক লজিক প্রোগ্রামিং চালু করেছে, বিশেষত ধ্রুবক লক্ষ্যগুলি "# ইউ" (ব্যর্থ) এবং "# এস" (স্যুইসড) বুলিয়ান মানগুলিতে "# টি যোগ করে" "এবং" # এফ "। এটি প্রজাল: একীকরণ এবং ব্যাকট্র্যাকিং অনুসন্ধান হিসাবে লজিক প্রোগ্রামিংয়ের একই পদ্ধতির ব্যবহার করেছে। উইকএন্ডে আমার শেল্ফ থেকে বইটি পুনরুদ্ধার করার জন্য আমার কিছু সময় আছে কিনা তা আমি দেখতে পাব। এই ক্ষেত্রে হর্ন ক্লজস এবং রেজোলিউশন ইউনিফিকেশন গণিতের শাখাটি প্রথম-আদেশের যুক্তিযুক্ত একটি সীমাবদ্ধ ফর্ম। দেখুন: গণনামূলক লজিক: জন অ্যালান রবিনসনের ভবিষ্যতের অতীত ও চ্যালেঞ্জগুলির স্মৃতি এবং শীত শুরু করার জন্য রবার্ট কোওলস্কির লজিক প্রোগ্রামিংয়ের প্রথম বছরগুলি


3
এই দুটি উদ্ধৃতি কানরেন, বা মিনিকেনরানের সাথে কী করবে?
ভুয়া

2
শেষ প্রশ্নটি দেখুন: "তারা গণিতের কোন শাখা থেকে আসে এবং তাত্ত্বিক ভিত্তিগুলি কী?"
ফ্রাঙ্ক শিয়েরার
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.