स्थिति गणना: Difference between revisions
mNo edit summary |
m (→अवलोकन) |
||
Line 11: | Line 11: | ||
एक कार्यक्षेत्र को कई सूत्रों द्वारा औपचारिक रूप दिया जाता है, अर्थात्: | एक कार्यक्षेत्र को कई सूत्रों द्वारा औपचारिक रूप दिया जाता है, अर्थात्: | ||
* | *प्रत्येक क्रिया के लिए एक पूर्वपेक्षित सिद्धांत क्रिया | ||
* | *प्रत्येक [[धाराप्रवाह (कृत्रिम बुद्धि)|स्पष्टता]] के लिए एक अनुक्रम स्थिति सिद्धांत | ||
*विभिन्न स्थितियों में दुनिया का वर्णन करने वाले सिद्धांत | *विभिन्न स्थितियों में दुनिया का वर्णन करने वाले सिद्धांत | ||
*स्थिति गणना के मूलभूत सिद्धांत | *स्थिति गणना के मूलभूत सिद्धांत | ||
Line 28: | Line 28: | ||
===परिस्थितियाँ=== | ===परिस्थितियाँ=== | ||
स्थिति गणना में, एक गतिशील दुनिया को दुनिया के भीतर किए जा रहे विभिन्न कार्यों के परिणामस्वरूप स्थितियों की एक श्रृंखला के माध्यम से प्रगति के रूप में तैयार किया गया है। एक स्थिति क्रिया घटित होने के इतिहास का प्रतिनिधित्व करती है। यहां वर्णित स्थिति गणना के रेइटर संस्करण में, एक स्थिति एक | स्थिति गणना में, एक गतिशील दुनिया को दुनिया के भीतर किए जा रहे विभिन्न कार्यों के परिणामस्वरूप स्थितियों की एक श्रृंखला के माध्यम से प्रगति के रूप में तैयार किया गया है। एक स्थिति क्रिया घटित होने के इतिहास का प्रतिनिधित्व करती है। यहां वर्णित स्थिति गणना के रेइटर संस्करण में, एक स्थिति एक स्थिति का प्रतिनिधित्व नहीं करती है, शब्द के शाब्दिक अर्थ के विपरीत और मैककार्थी और हेस द्वारा मूल परिभाषा के विपरीत। इस बिंदु को रेइटर द्वारा इस प्रकार संक्षेप में प्रस्तुत किया गया है: | ||
: एक स्थिति क्रियाओं का एक सीमित क्रम है। अवधि। यह कोई | : एक स्थिति क्रियाओं का एक सीमित क्रम है। अवधि। यह कोई स्थिति नहीं है, यह कोई स्नैपशॉट नहीं है, यह एक इतिहास है।<ref>{{Cite web|url=http://www.ida.liu.se/ext/etai/rac/notes/1997/09/note.html|title = ECSTER Debate Contribution}}</ref> | ||
किसी भी कार्य को करने से पहले की स्थिति को आम तौर पर दर्शाया जाता है {{tmath|S_0}} और प्रारंभिक स्थिति को बुलाया। किसी क्रिया के निष्पादन से उत्पन्न नई स्थिति को फ़ंक्शन प्रतीक का उपयोग करके दर्शाया जाता है {{mvar|do}} (कुछ अन्य सन्दर्भ{{Which|date=January 2020}} इसका भी प्रयोग करें {{mvar|result}}). इस फ़ंक्शन प्रतीक में तर्क के रूप में एक स्थिति और एक क्रिया होती है, और परिणाम के रूप में एक स्थिति होती है, बाद वाली स्थिति वह स्थिति होती है जो दी गई स्थिति में दी गई कार्रवाई को करने के परिणामस्वरूप होती है। | किसी भी कार्य को करने से पहले की स्थिति को आम तौर पर दर्शाया जाता है {{tmath|S_0}} और प्रारंभिक स्थिति को बुलाया। किसी क्रिया के निष्पादन से उत्पन्न नई स्थिति को फ़ंक्शन प्रतीक का उपयोग करके दर्शाया जाता है {{mvar|do}} (कुछ अन्य सन्दर्भ{{Which|date=January 2020}} इसका भी प्रयोग करें {{mvar|result}}). इस फ़ंक्शन प्रतीक में तर्क के रूप में एक स्थिति और एक क्रिया होती है, और परिणाम के रूप में एक स्थिति होती है, बाद वाली स्थिति वह स्थिति होती है जो दी गई स्थिति में दी गई कार्रवाई को करने के परिणामस्वरूप होती है। | ||
तथ्य यह है कि परिस्थितियाँ क्रियाओं का क्रम हैं न कि अवस्थाएँ, यह कहते हुए एक | तथ्य यह है कि परिस्थितियाँ क्रियाओं का क्रम हैं न कि अवस्थाएँ, यह कहते हुए एक सिद्धांत द्वारा लागू किया जाता है <math>do(a,s)</math> के बराबर है <math>do(a',s')</math> अगर और केवल अगर <math>a=a'</math> और <math>s=s'</math>. इस स्थिति का कोई मतलब नहीं है यदि स्थितियाँ स्थिति की हों, क्योंकि दो अलग-अलग स्थितिों में निष्पादित दो अलग-अलग कार्रवाइयों का परिणाम एक ही स्थिति में हो सकता है। | ||
उदाहरण रोबोट की दुनिया में, यदि रोबोट की पहली क्रिया स्थान पर जाना है <math>(2,3)</math>, पहली क्रिया है <math>move(2,3)</math> और परिणामी स्थिति है <math>do(move(2,3),S_{0})</math>. यदि इसकी अगली क्रिया गेंद को उठाना है, तो परिणामी स्थिति यह होगी <math>do(pickup(Ball),do(move(2,3),S_{0}))</math>. स्थितियां जैसे शर्तें <math>do(move(2,3),S_{0})</math> और <math>do(pickup(Ball),do(move(2,3),S_{0}))</math> निष्पादित कार्यों के अनुक्रम को निरूपित करें, न कि निष्पादन के परिणामस्वरूप होने वाली स्थिति का विवरण। | उदाहरण रोबोट की दुनिया में, यदि रोबोट की पहली क्रिया स्थान पर जाना है <math>(2,3)</math>, पहली क्रिया है <math>move(2,3)</math> और परिणामी स्थिति है <math>do(move(2,3),S_{0})</math>. यदि इसकी अगली क्रिया गेंद को उठाना है, तो परिणामी स्थिति यह होगी <math>do(pickup(Ball),do(move(2,3),S_{0}))</math>. स्थितियां जैसे शर्तें <math>do(move(2,3),S_{0})</math> और <math>do(pickup(Ball),do(move(2,3),S_{0}))</math> निष्पादित कार्यों के अनुक्रम को निरूपित करें, न कि निष्पादन के परिणामस्वरूप होने वाली स्थिति का विवरण। | ||
Line 63: | Line 63: | ||
===क्रिया प्रभाव=== | ===क्रिया प्रभाव=== | ||
यह देखते हुए कि किसी स्थिति में कोई कार्रवाई संभव है, किसी को धाराप्रवाह पर उस कार्रवाई के प्रभाव को निर्दिष्ट करना होगा। यह प्रभाव | यह देखते हुए कि किसी स्थिति में कोई कार्रवाई संभव है, किसी को धाराप्रवाह पर उस कार्रवाई के प्रभाव को निर्दिष्ट करना होगा। यह प्रभाव सिद्धांतों द्वारा किया जाता है। उदाहरण के लिए, तथ्य यह है कि किसी वस्तु को उठाने से रोबोट उसे ले जाता है, इसे इस प्रकार दर्शाया जा सकता है: | ||
: <math> | : <math> | ||
Line 77: | Line 77: | ||
===फ़्रेम समस्या=== | ===फ़्रेम समस्या=== | ||
हालाँकि उपरोक्त सूत्र कार्यों के प्रभावों के बारे में तर्क करने के लिए उपयुक्त प्रतीत होते हैं, लेकिन उनमें एक गंभीर कमजोरी है - उनका उपयोग कार्यों के गैर-प्रभावों को प्राप्त करने के लिए नहीं किया जा सकता है। उदाहरण के लिए, यह निष्कर्ष निकालना संभव नहीं है कि किसी वस्तु को उठाने के बाद रोबोट का स्थान अपरिवर्तित रहता है। इसके लिए एक तथाकथित फ़्रेम | हालाँकि उपरोक्त सूत्र कार्यों के प्रभावों के बारे में तर्क करने के लिए उपयुक्त प्रतीत होते हैं, लेकिन उनमें एक गंभीर कमजोरी है - उनका उपयोग कार्यों के गैर-प्रभावों को प्राप्त करने के लिए नहीं किया जा सकता है। उदाहरण के लिए, यह निष्कर्ष निकालना संभव नहीं है कि किसी वस्तु को उठाने के बाद रोबोट का स्थान अपरिवर्तित रहता है। इसके लिए एक तथाकथित फ़्रेम सिद्धांत, एक सूत्र की आवश्यकता होती है: | ||
: <math> | : <math> | ||
Poss(pickup(o),s)\wedge location(s)=(x,y)\rightarrow location(do(pickup(o),s))=(x,y) | Poss(pickup(o),s)\wedge location(s)=(x,y)\rightarrow location(do(pickup(o),s))=(x,y) | ||
</math> | </math> | ||
फ़्रेम | फ़्रेम सिद्धांतों को निर्दिष्ट करने की आवश्यकता को गतिशील दुनिया को सिद्धांत करने में एक समस्या के रूप में लंबे समय से पहचाना गया है, और इसे फ़्रेम समस्या के रूप में जाना जाता है। चूंकि आम तौर पर ऐसे सिद्धांतों की एक बहुत बड़ी संख्या होती है, इसलिए डिजाइनर के लिए एक आवश्यक फ्रेम सिद्धांत को छोड़ना, या दुनिया के विवरण में बदलाव करते समय सभी उपयुक्त सिद्धांतों को संशोधित करना भूल जाना बहुत आसान होता है। | ||
===उत्तरवर्ती | ===उत्तरवर्ती स्थिति सिद्धांत=== | ||
अनुक्रम स्थिति सिद्धांत स्थिति गणना में फ़्रेम समस्या को हल करते हैं। इस समाधान के अनुसार, डिज़ाइनर को प्रभाव सिद्धांतों के रूप में उन सभी तरीकों की गणना करनी चाहिए जिनसे किसी विशेष धाराप्रवाह का मूल्य बदला जा सकता है। धाराप्रवाह के मूल्य को प्रभावित करने वाले प्रभाव सिद्धांत <math>F(\overrightarrow{x},s)</math> इसे सामान्यीकृत रूप में सकारात्मक और नकारात्मक प्रभाव वाले सिद्धांत के रूप में लिखा जा सकता है: | |||
: <math> | : <math> | ||
Line 94: | Line 94: | ||
Poss(a,s)\wedge\gamma_{F}^{-}(\overrightarrow{x},a,s)\rightarrow\neg F(\overrightarrow{x},do(a,s)) | Poss(a,s)\wedge\gamma_{F}^{-}(\overrightarrow{x},a,s)\rightarrow\neg F(\overrightarrow{x},do(a,s)) | ||
</math> | </math> | ||
सूत्र <math>\gamma_{F}^{+}</math> उन परिस्थितियों का वर्णन करता है जिनके तहत कार्रवाई की जाती है {{mvar|a}} स्थिति में {{mvar|s}} धाराप्रवाह बनाता है {{mvar|F}} | सूत्र <math>\gamma_{F}^{+}</math> उन परिस्थितियों का वर्णन करता है जिनके तहत कार्रवाई की जाती है {{mvar|a}} स्थिति में {{mvar|s}} धाराप्रवाह बनाता है {{mvar|F}}अनुक्रम स्थिति में सत्य हो जाता है <math>do(a,s)</math>. वैसे ही, <math>\gamma_{F}^{-}</math> उन परिस्थितियों का वर्णन करता है जिनके तहत कार्रवाई की जाती है {{mvar|a}} स्थिति में {{mvar|s}} धाराप्रवाह बनाता है {{mvar|F}}अनुक्रम स्थिति में असत्य। | ||
यदि सिद्धांतों की यह जोड़ी धाराप्रवाह सभी तरीकों का वर्णन करती है {{mvar|F}} मान बदल सकते हैं, उन्हें एकल | यदि सिद्धांतों की यह जोड़ी धाराप्रवाह सभी तरीकों का वर्णन करती है {{mvar|F}} मान बदल सकते हैं, उन्हें एकल सिद्धांत के रूप में फिर से लिखा जा सकता है: | ||
: <math> | : <math> | ||
Line 103: | Line 103: | ||
शब्दों में, यह सूत्र बताता है: यह देखते हुए कि कार्रवाई करना संभव है {{mvar|a}} स्थिति में {{mvar|s}}, धाराप्रवाह {{mvar|F}} परिणामी स्थिति में सत्य होगा <math>do(a,s)</math> यदि और केवल यदि प्रदर्शन किया जा रहा है {{mvar|a}} में {{mvar|s}} इसे सच बना देगा, या यह स्थिति में सच है {{mvar|s}} और प्रदर्शन कर रहे हैं {{mvar|a}} में {{mvar|s}} इसे झूठा नहीं बनाएंगे. | शब्दों में, यह सूत्र बताता है: यह देखते हुए कि कार्रवाई करना संभव है {{mvar|a}} स्थिति में {{mvar|s}}, धाराप्रवाह {{mvar|F}} परिणामी स्थिति में सत्य होगा <math>do(a,s)</math> यदि और केवल यदि प्रदर्शन किया जा रहा है {{mvar|a}} में {{mvar|s}} इसे सच बना देगा, या यह स्थिति में सच है {{mvar|s}} और प्रदर्शन कर रहे हैं {{mvar|a}} में {{mvar|s}} इसे झूठा नहीं बनाएंगे. | ||
उदाहरण के तौर पर, धाराप्रवाह का मूल्य {{mvar|broken}} ऊपर प्रस्तुत निम्नलिखित | उदाहरण के तौर पर, धाराप्रवाह का मूल्य {{mvar|broken}} ऊपर प्रस्तुत निम्नलिखित अनुक्रम स्थिति सिद्धांत द्वारा दिया गया है: | ||
: <math> | : <math> | ||
Line 111: | Line 111: | ||
=== | ===स्थिति=== | ||
प्रारंभिक या किसी अन्य स्थिति के गुणों को केवल सूत्रों के रूप में बताकर निर्दिष्ट किया जा सकता है। उदाहरण के लिए, प्रारंभिक अवस्था के बारे में दावे करके किसी तथ्य को औपचारिक रूप दिया जाता है <math>S_{0}</math> (जो एक अवस्था नहीं, बल्कि एक स्थिति है)। निम्नलिखित कथनों से पता चलता है कि प्रारंभ में, रोबोट कुछ भी नहीं ले जाता है | प्रारंभिक या किसी अन्य स्थिति के गुणों को केवल सूत्रों के रूप में बताकर निर्दिष्ट किया जा सकता है। उदाहरण के लिए, प्रारंभिक अवस्था के बारे में दावे करके किसी तथ्य को औपचारिक रूप दिया जाता है <math>S_{0}</math> (जो एक अवस्था नहीं, बल्कि एक स्थिति है)। निम्नलिखित कथनों से पता चलता है कि प्रारंभ में, रोबोट कुछ भी नहीं ले जाता है | ||
Line 142: | Line 142: | ||
==स्थिति गणना का मूल संस्करण== | ==स्थिति गणना का मूल संस्करण== | ||
मैक्कार्थी और हेस द्वारा मूल स्थिति गणना और आज उपयोग में आने वाली गणना के बीच मुख्य अंतर स्थितियों की व्याख्या है। स्थितिजन्य गणना के आधुनिक संस्करण में, स्थिति क्रियाओं का एक क्रम है। मूल रूप से, स्थितियों को समय के एक पल में ब्रह्मांड की पूर्ण स्थिति के रूप में परिभाषित किया गया था। यह शुरू से ही स्पष्ट था कि ऐसी स्थितियों का पूरी तरह से वर्णन नहीं किया जा सकता है; विचार बस स्थितियों के बारे में कुछ बयान देने और उनसे परिणाम निकालने का था। यह उस दृष्टिकोण से भी अलग है जो धाराप्रवाह गणना द्वारा अपनाया जाता है, जहां एक | मैक्कार्थी और हेस द्वारा मूल स्थिति गणना और आज उपयोग में आने वाली गणना के बीच मुख्य अंतर स्थितियों की व्याख्या है। स्थितिजन्य गणना के आधुनिक संस्करण में, स्थिति क्रियाओं का एक क्रम है। मूल रूप से, स्थितियों को समय के एक पल में ब्रह्मांड की पूर्ण स्थिति के रूप में परिभाषित किया गया था। यह शुरू से ही स्पष्ट था कि ऐसी स्थितियों का पूरी तरह से वर्णन नहीं किया जा सकता है; विचार बस स्थितियों के बारे में कुछ बयान देने और उनसे परिणाम निकालने का था। यह उस दृष्टिकोण से भी अलग है जो धाराप्रवाह गणना द्वारा अपनाया जाता है, जहां एक स्थिति ज्ञात तथ्यों का एक संग्रह हो सकता है, यानी, ब्रह्मांड का संभवतः अधूरा विवरण। | ||
स्थिति गणना के मूल संस्करण में, धाराप्रवाहों का पुनरीक्षण नहीं किया जाता है। दूसरे शब्दों में, जो स्थितियाँ बदल सकती हैं उन्हें विधेय द्वारा दर्शाया जाता है न कि कार्यों द्वारा। दरअसल, मैक्कार्थी और हेस ने धाराप्रवाह को एक ऐसे कार्य के रूप में परिभाषित किया जो स्थिति पर निर्भर करता है, लेकिन फिर वे धाराप्रवाह का प्रतिनिधित्व करने के लिए हमेशा विधेय का उपयोग करते हुए आगे बढ़े। उदाहरण के लिए, यह तथ्य कि जगह-जगह बारिश हो रही है {{mvar|x}} स्थिति में {{mvar|s}} को शाब्दिक रूप से दर्शाया गया है <math>raining(x,s)</math>. मैक्कार्थी द्वारा सिचुएशन गणना के 1986 संस्करण में, कार्यात्मक प्रवाह का उपयोग किया जाता है। उदाहरण के लिए, किसी वस्तु की स्थिति {{mvar|x}} स्थिति में {{mvar|s}} के मान से दर्शाया जाता है <math>location(x,s)</math>, कहाँ {{mvar|location}} एक फ़ंक्शन है. ऐसे कार्यों के बारे में कथन समानता का उपयोग करके दिए जा सकते हैं: <math>location(x,s)=location(x,s')</math> इसका मतलब है कि वस्तु का स्थान {{mvar|x}} दोनों स्थितियों में समान है {{mvar|s}} और <math>s'</math>. | स्थिति गणना के मूल संस्करण में, धाराप्रवाहों का पुनरीक्षण नहीं किया जाता है। दूसरे शब्दों में, जो स्थितियाँ बदल सकती हैं उन्हें विधेय द्वारा दर्शाया जाता है न कि कार्यों द्वारा। दरअसल, मैक्कार्थी और हेस ने धाराप्रवाह को एक ऐसे कार्य के रूप में परिभाषित किया जो स्थिति पर निर्भर करता है, लेकिन फिर वे धाराप्रवाह का प्रतिनिधित्व करने के लिए हमेशा विधेय का उपयोग करते हुए आगे बढ़े। उदाहरण के लिए, यह तथ्य कि जगह-जगह बारिश हो रही है {{mvar|x}} स्थिति में {{mvar|s}} को शाब्दिक रूप से दर्शाया गया है <math>raining(x,s)</math>. मैक्कार्थी द्वारा सिचुएशन गणना के 1986 संस्करण में, कार्यात्मक प्रवाह का उपयोग किया जाता है। उदाहरण के लिए, किसी वस्तु की स्थिति {{mvar|x}} स्थिति में {{mvar|s}} के मान से दर्शाया जाता है <math>location(x,s)</math>, कहाँ {{mvar|location}} एक फ़ंक्शन है. ऐसे कार्यों के बारे में कथन समानता का उपयोग करके दिए जा सकते हैं: <math>location(x,s)=location(x,s')</math> इसका मतलब है कि वस्तु का स्थान {{mvar|x}} दोनों स्थितियों में समान है {{mvar|s}} और <math>s'</math>. |
Revision as of 13:10, 4 August 2023
स्थिति गणना एक तर्क औपचारिकता है जिसे गतिशील कार्यक्षेत्र के बारे में प्रतिनिधित्व और तर्क करने के लिए डिज़ाइन किया गया है। इसे पहली बार 1963 में जॉन मैक्कार्थी (कंप्यूटर वैज्ञानिक) द्वारा प्रस्तुत किया गया था।[1] इस आलेख में प्रस्तुत स्थितिजन्य गणना का मुख्य संस्करण 1991 में रे रेइटर द्वारा प्रस्तुत किए गए संस्करण पर आधारित है। इसके बाद मैक्कार्थी के 1986 संस्करण और एक तर्क क्रमादेशन सूत्रीकरण के बारे में अनुभाग दिए गए हैं।
अवलोकन
स्थिति कलन प्रथम-क्रम तर्क सूत्रों के एक समूह के रूप में बदलते परिदृश्यों का प्रतिनिधित्व करता है। गणना के मूल तत्व हैं:
- संसार में जो कार्य किये जा सकते हैं
- स्पष्टता (कृत्रिम बुद्धि) जो विश्व की स्थिति का वर्णन करती है
- परिस्थितियाँ
एक कार्यक्षेत्र को कई सूत्रों द्वारा औपचारिक रूप दिया जाता है, अर्थात्:
- प्रत्येक क्रिया के लिए एक पूर्वपेक्षित सिद्धांत क्रिया
- प्रत्येक स्पष्टता के लिए एक अनुक्रम स्थिति सिद्धांत
- विभिन्न स्थितियों में दुनिया का वर्णन करने वाले सिद्धांत
- स्थिति गणना के मूलभूत सिद्धांत
एक साधारण रोबोट दुनिया को एक चालू उदाहरण के रूप में तैयार किया जाएगा। इस दुनिया में एक रोबोट और कई निर्जीव वस्तुएं हैं। दुनिया को एक ग्रिड के अनुसार व्यवस्थित किया गया है ताकि स्थानों को इसके अनुसार निर्दिष्ट किया जा सके समन्वय बिंदु. रोबोट के लिए दुनिया भर में घूमना और वस्तुओं को उठाना और छोड़ना संभव है। कुछ वस्तुएं रोबोट के उठाने के लिए बहुत भारी हो सकती हैं, या इतनी नाजुक हो सकती हैं कि गिराए जाने पर वे टूट जाएं। रोबोट अपने पास मौजूद किसी भी टूटी हुई वस्तु की मरम्मत करने की भी क्षमता रखता है।
तत्व
स्थिति गणना के मुख्य तत्व क्रियाएं, प्रवाह और स्थितियां हैं। दुनिया के वर्णन में आमतौर पर कई वस्तुएं भी शामिल होती हैं। स्थिति गणना तीन प्रकार के क्रमबद्ध कार्यक्षेत्र पर आधारित है: क्रियाएं, स्थितियां और वस्तुएं, जहां वस्तुओं में वह सब कुछ शामिल होता है जो कोई क्रिया या स्थिति नहीं है। प्रत्येक प्रकार के वेरिएबल का उपयोग किया जा सकता है। जबकि क्रियाएँ, परिस्थितियाँ और वस्तुएँ कार्यक्षेत्र के तत्व हैं, प्रवाह को या तो विधेय या कार्यों के रूप में तैयार किया जाता है।
कार्रवाई
क्रियाएँ एक प्रकार का कार्यक्षेत्र बनाती हैं। सॉर्ट एक्शन के वेरिएबल्स का उपयोग किया जा सकता है। क्रियाओं को परिमाणित किया जा सकता है। उदाहरण रोबोट की दुनिया में, संभावित कार्य शर्तें होंगी रोबोट को एक नए स्थान पर ले जाने का मॉडल बनाना , और किसी वस्तु को उठाने वाले रोबोट का मॉडल बनाना o. एक विशेष विधेय Poss का उपयोग यह इंगित करने के लिए किया जाता है कि कोई कार्रवाई कब निष्पादन योग्य है।
परिस्थितियाँ
स्थिति गणना में, एक गतिशील दुनिया को दुनिया के भीतर किए जा रहे विभिन्न कार्यों के परिणामस्वरूप स्थितियों की एक श्रृंखला के माध्यम से प्रगति के रूप में तैयार किया गया है। एक स्थिति क्रिया घटित होने के इतिहास का प्रतिनिधित्व करती है। यहां वर्णित स्थिति गणना के रेइटर संस्करण में, एक स्थिति एक स्थिति का प्रतिनिधित्व नहीं करती है, शब्द के शाब्दिक अर्थ के विपरीत और मैककार्थी और हेस द्वारा मूल परिभाषा के विपरीत। इस बिंदु को रेइटर द्वारा इस प्रकार संक्षेप में प्रस्तुत किया गया है:
- एक स्थिति क्रियाओं का एक सीमित क्रम है। अवधि। यह कोई स्थिति नहीं है, यह कोई स्नैपशॉट नहीं है, यह एक इतिहास है।[2]
किसी भी कार्य को करने से पहले की स्थिति को आम तौर पर दर्शाया जाता है और प्रारंभिक स्थिति को बुलाया। किसी क्रिया के निष्पादन से उत्पन्न नई स्थिति को फ़ंक्शन प्रतीक का उपयोग करके दर्शाया जाता है do (कुछ अन्य सन्दर्भ[which?] इसका भी प्रयोग करें result). इस फ़ंक्शन प्रतीक में तर्क के रूप में एक स्थिति और एक क्रिया होती है, और परिणाम के रूप में एक स्थिति होती है, बाद वाली स्थिति वह स्थिति होती है जो दी गई स्थिति में दी गई कार्रवाई को करने के परिणामस्वरूप होती है।
तथ्य यह है कि परिस्थितियाँ क्रियाओं का क्रम हैं न कि अवस्थाएँ, यह कहते हुए एक सिद्धांत द्वारा लागू किया जाता है के बराबर है अगर और केवल अगर और . इस स्थिति का कोई मतलब नहीं है यदि स्थितियाँ स्थिति की हों, क्योंकि दो अलग-अलग स्थितिों में निष्पादित दो अलग-अलग कार्रवाइयों का परिणाम एक ही स्थिति में हो सकता है।
उदाहरण रोबोट की दुनिया में, यदि रोबोट की पहली क्रिया स्थान पर जाना है , पहली क्रिया है और परिणामी स्थिति है . यदि इसकी अगली क्रिया गेंद को उठाना है, तो परिणामी स्थिति यह होगी . स्थितियां जैसे शर्तें और निष्पादित कार्यों के अनुक्रम को निरूपित करें, न कि निष्पादन के परिणामस्वरूप होने वाली स्थिति का विवरण।
धाराप्रवाह
ऐसे कथन जिनका सत्य मान बदल सकता है, उन्हें संबंधपरक प्रवाह, विधेय द्वारा प्रतिरूपित किया जाता है जो किसी स्थिति को अपने अंतिम तर्क के रूप में लेते हैं। कार्यात्मक प्रवाह भी संभव हैं, फ़ंक्शन जो किसी स्थिति को अपने अंतिम तर्क के रूप में लेते हैं और स्थिति-निर्भर मूल्य लौटाते हैं। फ़्लुएंट्स को दुनिया की संपत्ति माना जा सकता है'।
उदाहरण में, धाराप्रवाह इसका उपयोग यह इंगित करने के लिए किया जा सकता है कि रोबोट किसी विशेष स्थिति में किसी विशेष वस्तु को ले जा रहा है। यदि रोबोट प्रारंभ में कुछ भी नहीं ले जाता है, जबकि झूठ है क्या सच है। रोबोट के स्थान को एक कार्यात्मक धाराप्रवाह का उपयोग करके मॉडल किया जा सकता है जो स्थान लौटाता है किसी विशेष स्थिति में रोबोट का।
सूत्र
एक गतिशील दुनिया का वर्णन तीन प्रकार के सूत्रों का उपयोग करके द्वितीय-क्रम_लॉजिक में एन्कोड किया गया है: कार्यों के बारे में सूत्र (पूर्व शर्त और प्रभाव), दुनिया की स्थिति के बारे में सूत्र, और मूलभूत सिद्धांत।
कार्रवाई पूर्वशर्तें
कुछ कार्रवाइयां किसी दी गई स्थिति में निष्पादन योग्य नहीं हो सकती हैं। उदाहरण के लिए, किसी वस्तु को तब तक नीचे रखना असंभव है जब तक कोई वास्तव में उसे उठा न रहा हो। कार्यों के निष्पादन पर प्रतिबंध प्रपत्र के शाब्दिक अर्थों द्वारा प्रतिरूपित होते हैं , कहाँ a एक क्रिया है, s एक स्थिति, और Poss क्रियाओं की निष्पादन क्षमता को दर्शाने वाला एक विशेष द्विआधारी विधेय है। उदाहरण में, यह स्थिति कि किसी वस्तु को गिराना केवल तभी संभव है जब कोई उसे ले जा रहा हो, इस प्रकार मॉडलिंग की गई है:
अधिक जटिल उदाहरण के रूप में, निम्नलिखित मॉडल बताते हैं कि रोबोट एक समय में केवल एक ही वस्तु ले जा सकता है, और कुछ वस्तुएँ रोबोट के उठाने के लिए बहुत भारी हैं (विधेय द्वारा दर्शाया गया है) heavy):
क्रिया प्रभाव
यह देखते हुए कि किसी स्थिति में कोई कार्रवाई संभव है, किसी को धाराप्रवाह पर उस कार्रवाई के प्रभाव को निर्दिष्ट करना होगा। यह प्रभाव सिद्धांतों द्वारा किया जाता है। उदाहरण के लिए, तथ्य यह है कि किसी वस्तु को उठाने से रोबोट उसे ले जाता है, इसे इस प्रकार दर्शाया जा सकता है:
सशर्त प्रभावों को निर्दिष्ट करना भी संभव है, जो ऐसे प्रभाव हैं जो वर्तमान स्थिति पर निर्भर करते हैं। निम्नलिखित मॉडल बताते हैं कि कुछ वस्तुएं नाजुक हैं (विधेय द्वारा दर्शाया गया है fragile) और उन्हें गिराने से वे टूट जाते हैं (धाराप्रवाह द्वारा इंगित)। broken):
हालाँकि यह सूत्र क्रियाओं के प्रभाव का सही वर्णन करता है, लेकिन फ्रेम समस्या के कारण तर्क में क्रिया का सही वर्णन करने के लिए यह पर्याप्त नहीं है।
फ़्रेम समस्या
हालाँकि उपरोक्त सूत्र कार्यों के प्रभावों के बारे में तर्क करने के लिए उपयुक्त प्रतीत होते हैं, लेकिन उनमें एक गंभीर कमजोरी है - उनका उपयोग कार्यों के गैर-प्रभावों को प्राप्त करने के लिए नहीं किया जा सकता है। उदाहरण के लिए, यह निष्कर्ष निकालना संभव नहीं है कि किसी वस्तु को उठाने के बाद रोबोट का स्थान अपरिवर्तित रहता है। इसके लिए एक तथाकथित फ़्रेम सिद्धांत, एक सूत्र की आवश्यकता होती है:
फ़्रेम सिद्धांतों को निर्दिष्ट करने की आवश्यकता को गतिशील दुनिया को सिद्धांत करने में एक समस्या के रूप में लंबे समय से पहचाना गया है, और इसे फ़्रेम समस्या के रूप में जाना जाता है। चूंकि आम तौर पर ऐसे सिद्धांतों की एक बहुत बड़ी संख्या होती है, इसलिए डिजाइनर के लिए एक आवश्यक फ्रेम सिद्धांत को छोड़ना, या दुनिया के विवरण में बदलाव करते समय सभी उपयुक्त सिद्धांतों को संशोधित करना भूल जाना बहुत आसान होता है।
उत्तरवर्ती स्थिति सिद्धांत
अनुक्रम स्थिति सिद्धांत स्थिति गणना में फ़्रेम समस्या को हल करते हैं। इस समाधान के अनुसार, डिज़ाइनर को प्रभाव सिद्धांतों के रूप में उन सभी तरीकों की गणना करनी चाहिए जिनसे किसी विशेष धाराप्रवाह का मूल्य बदला जा सकता है। धाराप्रवाह के मूल्य को प्रभावित करने वाले प्रभाव सिद्धांत इसे सामान्यीकृत रूप में सकारात्मक और नकारात्मक प्रभाव वाले सिद्धांत के रूप में लिखा जा सकता है:
सूत्र उन परिस्थितियों का वर्णन करता है जिनके तहत कार्रवाई की जाती है a स्थिति में s धाराप्रवाह बनाता है Fअनुक्रम स्थिति में सत्य हो जाता है . वैसे ही, उन परिस्थितियों का वर्णन करता है जिनके तहत कार्रवाई की जाती है a स्थिति में s धाराप्रवाह बनाता है Fअनुक्रम स्थिति में असत्य।
यदि सिद्धांतों की यह जोड़ी धाराप्रवाह सभी तरीकों का वर्णन करती है F मान बदल सकते हैं, उन्हें एकल सिद्धांत के रूप में फिर से लिखा जा सकता है:
शब्दों में, यह सूत्र बताता है: यह देखते हुए कि कार्रवाई करना संभव है a स्थिति में s, धाराप्रवाह F परिणामी स्थिति में सत्य होगा यदि और केवल यदि प्रदर्शन किया जा रहा है a में s इसे सच बना देगा, या यह स्थिति में सच है s और प्रदर्शन कर रहे हैं a में s इसे झूठा नहीं बनाएंगे.
उदाहरण के तौर पर, धाराप्रवाह का मूल्य broken ऊपर प्रस्तुत निम्नलिखित अनुक्रम स्थिति सिद्धांत द्वारा दिया गया है:
स्थिति
प्रारंभिक या किसी अन्य स्थिति के गुणों को केवल सूत्रों के रूप में बताकर निर्दिष्ट किया जा सकता है। उदाहरण के लिए, प्रारंभिक अवस्था के बारे में दावे करके किसी तथ्य को औपचारिक रूप दिया जाता है (जो एक अवस्था नहीं, बल्कि एक स्थिति है)। निम्नलिखित कथनों से पता चलता है कि प्रारंभ में, रोबोट कुछ भी नहीं ले जाता है जगह , और कोई टूटी हुई वस्तु नहीं है:
बुनियादी सिद्धांत
स्थिति गणना के मूलभूत सिद्धांत इस विचार को औपचारिक बनाते हैं कि परिस्थितियाँ इतिहास हैं . उनमें अन्य गुण भी शामिल हैं जैसे स्थितियों पर दूसरे क्रम का प्रेरण।
प्रतिगमन
प्रतिगमन स्थिति गणना में परिणाम साबित करने के लिए एक तंत्र है। यह स्थिति को समाहित करने वाले एक सूत्र को व्यक्त करने पर आधारित है क्रिया युक्त एक सूत्र के संदर्भ में a और स्थिति s, लेकिन स्थिति नहीं . इस प्रक्रिया को दोहराकर, कोई व्यक्ति केवल प्रारंभिक स्थिति वाले समकक्ष सूत्र के साथ समाप्त हो सकता है S_0. मूल सूत्र की तुलना में इस सूत्र से परिणाम सिद्ध करना संभवतः अधिक सरल है।
नग्न
GOLOG स्थिति गणना पर आधारित एक तर्क प्रोग्रामिंग भाषा है।[3][4]
स्थिति गणना का मूल संस्करण
मैक्कार्थी और हेस द्वारा मूल स्थिति गणना और आज उपयोग में आने वाली गणना के बीच मुख्य अंतर स्थितियों की व्याख्या है। स्थितिजन्य गणना के आधुनिक संस्करण में, स्थिति क्रियाओं का एक क्रम है। मूल रूप से, स्थितियों को समय के एक पल में ब्रह्मांड की पूर्ण स्थिति के रूप में परिभाषित किया गया था। यह शुरू से ही स्पष्ट था कि ऐसी स्थितियों का पूरी तरह से वर्णन नहीं किया जा सकता है; विचार बस स्थितियों के बारे में कुछ बयान देने और उनसे परिणाम निकालने का था। यह उस दृष्टिकोण से भी अलग है जो धाराप्रवाह गणना द्वारा अपनाया जाता है, जहां एक स्थिति ज्ञात तथ्यों का एक संग्रह हो सकता है, यानी, ब्रह्मांड का संभवतः अधूरा विवरण।
स्थिति गणना के मूल संस्करण में, धाराप्रवाहों का पुनरीक्षण नहीं किया जाता है। दूसरे शब्दों में, जो स्थितियाँ बदल सकती हैं उन्हें विधेय द्वारा दर्शाया जाता है न कि कार्यों द्वारा। दरअसल, मैक्कार्थी और हेस ने धाराप्रवाह को एक ऐसे कार्य के रूप में परिभाषित किया जो स्थिति पर निर्भर करता है, लेकिन फिर वे धाराप्रवाह का प्रतिनिधित्व करने के लिए हमेशा विधेय का उपयोग करते हुए आगे बढ़े। उदाहरण के लिए, यह तथ्य कि जगह-जगह बारिश हो रही है x स्थिति में s को शाब्दिक रूप से दर्शाया गया है . मैक्कार्थी द्वारा सिचुएशन गणना के 1986 संस्करण में, कार्यात्मक प्रवाह का उपयोग किया जाता है। उदाहरण के लिए, किसी वस्तु की स्थिति x स्थिति में s के मान से दर्शाया जाता है , कहाँ location एक फ़ंक्शन है. ऐसे कार्यों के बारे में कथन समानता का उपयोग करके दिए जा सकते हैं: इसका मतलब है कि वस्तु का स्थान x दोनों स्थितियों में समान है s और .
क्रियाओं का निष्पादन फ़ंक्शन द्वारा दर्शाया जाता है result: कार्रवाई का निष्पादन a स्थिति में s स्थिति है . क्रियाओं के प्रभाव को स्थिति से संबंधित सूत्र द्वारा व्यक्त किया जाता है s और स्थितियों में धाराप्रवाह . उदाहरण के लिए, दरवाज़ा खोलने की क्रिया के परिणामस्वरूप दरवाज़ा बंद न होने पर भी खुला रहता है, इसे निम्न द्वारा दर्शाया जाता है:
विधेय locked और open एक दरवाजे के क्रमशः बंद और खुले होने की स्थितियों का प्रतिनिधित्व करता है। चूँकि ये स्थितियाँ भिन्न-भिन्न हो सकती हैं, इसलिए इन्हें स्थिति तर्क के साथ विधेय द्वारा दर्शाया जाता है। सूत्र कहता है कि यदि किसी स्थिति में दरवाज़ा बंद नहीं है, तो खोलने की क्रिया निष्पादित करने के बाद दरवाज़ा खुला है, इस क्रिया को स्थिरांक द्वारा दर्शाया जाता है opens.
ये सूत्र उन सभी चीज़ों को प्राप्त करने के लिए पर्याप्त नहीं हैं जिन्हें प्रशंसनीय माना जाता है। वास्तव में, विभिन्न स्थितियों में धाराप्रवाह केवल तभी संबंधित होते हैं यदि वे कार्यों की पूर्व शर्त और प्रभाव हों; यदि कोई धाराप्रवाह किसी क्रिया से प्रभावित नहीं होता है, तो यह निष्कर्ष निकालने का कोई तरीका नहीं है कि उसमें कोई परिवर्तन नहीं हुआ है। उदाहरण के लिए, उपरोक्त सूत्र का यह अर्थ नहीं है से अनुसरण करता है , जिसकी कोई अपेक्षा कर सकता है (दरवाजा खोलकर उसे बंद नहीं किया जाता है)। जड़ता को बनाए रखने के लिए, फ़्रेम एक्सिओम्स नामक सूत्रों की आवश्यकता होती है। ये सूत्र क्रियाओं के सभी गैर-प्रभावों को निर्दिष्ट करते हैं:
स्थिति कलन के मूल सूत्रीकरण में, प्रारंभिक स्थिति, जिसे बाद में निरूपित किया गया , स्पष्ट रूप से पहचाना नहीं गया है। यदि स्थितियों को संसार का वर्णन मान लिया जाए तो प्रारंभिक स्थिति की आवश्यकता नहीं है। उदाहरण के लिए, उस परिदृश्य का प्रतिनिधित्व करने के लिए जिसमें दरवाज़ा बंद था लेकिन लॉक नहीं किया गया था और इसे खोलने की क्रिया को एक स्थिरांक लेकर औपचारिक रूप दिया गया है s प्रारंभिक स्थिति और इसके बारे में बयान देने का मतलब है (उदाहरण के लिए, ). परिवर्तन के बाद दरवाजा खुला है यह सूत्र द्वारा परिलक्षित होता है शामिल किया जा रहा है. इसके बजाय प्रारंभिक स्थिति आवश्यक है, यदि आधुनिक स्थिति गणना की तरह, किसी स्थिति को कार्यों का इतिहास माना जाता है, क्योंकि प्रारंभिक स्थिति कार्यों के खाली अनुक्रम का प्रतिनिधित्व करती है।
1986 में मैक्कार्थी द्वारा प्रस्तुत स्थिति गणना का संस्करण कार्यात्मक प्रवाह के उपयोग के लिए मूल संस्करण से भिन्न है (उदाहरण के लिए, की स्थिति का प्रतिनिधित्व करने वाला एक शब्द है x स्थिति में s) और फ्रेम एक्सिओम्स को बदलने के लिए परिधि (तर्क)तर्क) का उपयोग करने के प्रयास के लिए।
एक तर्क कार्यक्रम के रूप में स्थिति गणना
स्थिति कलन को एक तर्क कार्यक्रम के रूप में लिखना भी संभव है (उदाहरण के लिए कोवाल्स्की 1979, एप्ट और बेज़ेम 1990, शानहन 1997):
यहाँ Holds एक मेटा-विधेय और चर है f धाराप्रवाह से अधिक होती है। विधेय Poss, Initiates और Terminates विधेय के अनुरूप है Poss, , और क्रमश। बायां तीर ← समतुल्यता ↔ का आधा है। अन्य आधा हिस्सा कार्यक्रम के पूरा होने में निहित है, जिसमें नकार को विफलता के रूप में नकार के रूप में व्याख्या किया जाता है। प्रेरण अभिगृहीत भी अंतर्निहित हैं, और केवल प्रोग्राम गुणों को साबित करने के लिए आवश्यक हैं। एसएलडी संकल्प के रूप में पिछड़ा तर्क, जो तर्क कार्यक्रमों को निष्पादित करने के लिए उपयोग किया जाने वाला सामान्य तंत्र है, प्रतिगमन को अंतर्निहित रूप से लागू करता है।
यह भी देखें
- फ़्रेम समस्या
- घटना गणना
संदर्भ
- ↑ McCarthy, John (1963). "स्थितियाँ, कार्य और कारण नियम।" (PDF). Stanford University Technical Report. Archived from the original (PDF) on March 21, 2020.
- ↑ "ECSTER Debate Contribution".
- ↑ Lakemeyer, Gerhard. "The Situation Calculus and Golog: A Tutorial" (PDF). www.hybrid-reasoning.org. Retrieved 16 July 2014.
- ↑ "GOLOG के बारे में प्रकाशन". Retrieved 16 July 2014.
- J. McCarthy and P. Hayes (1969). Some philosophical problems from the standpoint of artificial intelligence. In B. Meltzer and D. Michie, editors, Machine Intelligence, 4:463–502. Edinburgh University Press, 1969.
- R. Kowalski (1979). Logic for Problem Solving - Elsevier North Holland.
- K.R. Apt and M. Bezem (1990). Acyclic Programs. In: 7th International Conference on Logic Programming. MIT Press. Jerusalem, Israel.
- R. Reiter (1991). The frame problem in the situation calculus: a simple solution (sometimes) and a completeness result for goal regression. In Vladimir Lifshitz, editor, Artificial intelligence and mathematical theory of computation: papers in honour of John McCarthy, pages 359–380, San Diego, CA, USA. Academic Press Professional, Inc. 1991.
- M. Shanahan (1997). Solving the Frame Problem: a Mathematical Investigation of the Common Sense Law of Inertia. MIT Press.
- H. Levesque, F. Pirri, and R. Reiter (1998). Foundations for the situation calculus. Electronic Transactions on Artificial Intelligence, 2(3–4):159-178.
- F. Pirri and R. Reiter (1999). Some contributions to the metatheory of the Situation Calculus. Journal of the ACM, 46(3):325–361. doi:10.1145/316542.316545
- R. Reiter (2001). Knowledge in Action: Logical Foundations for Specifying and Implementing Dynamical Systems. The MIT Press.