पायथन के साथ एअर इंडिया - अनुमानी खोज
कृत्रिम बुद्धि में ह्यूरिस्टिक खोज एक महत्वपूर्ण भूमिका निभाता है। इस अध्याय में, आप इसके बारे में विस्तार से जानेंगे।
एअर इंडिया में हेयुरिस्टिक सर्च की अवधारणा
ह्यूरिस्टिक अंगूठे का एक नियम है जो हमें संभावित समाधान की ओर ले जाता है। कृत्रिम बुद्धिमत्ता में अधिकांश समस्याएं घातीय प्रकृति की हैं और इसके कई संभावित समाधान हैं। आपको ठीक से पता नहीं है कि कौन से समाधान सही हैं और सभी समाधानों की जांच करना बहुत महंगा होगा।
इस प्रकार, हेयुरिस्टिक का उपयोग समाधान की खोज को धीमा कर देता है और गलत विकल्पों को समाप्त करता है। सर्च स्पेस में सर्च का नेतृत्व करने के लिए हेयुरिस्टिक का उपयोग करने की विधि को हेयुरिस्टिक सर्च कहा जाता है। ह्यूरिस्टिक तकनीक बहुत उपयोगी है क्योंकि जब आप उनका उपयोग करते हैं तो खोज को बढ़ाया जा सकता है।
Uninformed और Informed Search के बीच अंतर
दो प्रकार की नियंत्रण रणनीतियाँ या खोज तकनीक हैं: बिना सूचना और सूचना के। उन्हें विस्तार से बताया गया है जैसा कि यहाँ दिया गया है -
बेख़बर खोज
इसे ब्लाइंड सर्च या ब्लाइंड कंट्रोल स्ट्रैटेजी भी कहा जाता है। इसका नाम इसलिए रखा गया है क्योंकि केवल समस्या की परिभाषा के बारे में जानकारी है, और राज्यों के बारे में कोई अतिरिक्त जानकारी उपलब्ध नहीं है। इस तरह की खोज तकनीक पूरे राज्य में समाधान प्राप्त करने के लिए खोज करेगी। चौड़ाई पहली खोज (BFS) और गहराई पहली खोज (DFS) बिन खोज के उदाहरण हैं।
सूचित किया गया खोज
इसे हेयुरिस्टिक सर्च या हेयुरिस्टिक कंट्रोल स्ट्रेटेजी भी कहा जाता है। इसका नाम इसलिए रखा गया है क्योंकि राज्यों के बारे में कुछ अतिरिक्त जानकारी है। यह अतिरिक्त जानकारी बच्चे के नोड्स में वरीयता का पता लगाने और विस्तार करने के लिए गणना करने के लिए उपयोगी है। प्रत्येक नोड के साथ जुड़ा हुआ एक यकृत समारोह होगा। सर्वश्रेष्ठ पहली खोज (BFS), A *, माध्य और विश्लेषण सूचित खोज के उदाहरण हैं।
बाधा संतुष्टि समस्याएं (सीएसपी)
बाधा का अर्थ है प्रतिबंध या सीमा। एअर इंडिया में, बाधा संतुष्टि समस्याएं वे समस्याएं हैं जिन्हें कुछ बाधाओं के तहत हल किया जाना चाहिए। इस तरह की समस्याओं को हल करते समय बाधा का उल्लंघन न करने पर ध्यान केंद्रित किया जाना चाहिए। अंत में, जब हम अंतिम समाधान तक पहुँचते हैं, तो CSP को प्रतिबंध का पालन करना चाहिए।
वास्तविक विश्व समस्या बाधा द्वारा हल की गई
पिछले अनुभागों ने बाधा संतोष समस्याएं पैदा करने से निपटा। अब, हम इसे वास्तविक विश्व की समस्याओं पर भी लागू करते हैं। वास्तविक संतुष्टि द्वारा हल की गई विश्व की समस्याओं के कुछ उदाहरण इस प्रकार हैं -
बीजगणितीय संबंध हल करना
बाधा संतुष्टि समस्या की सहायता से, हम बीजीय संबंधों को हल कर सकते हैं। इस उदाहरण में, हम एक सरल बीजीय संबंध को हल करने का प्रयास करेंगेa*2 = b। इसका मान लौटाएगाa तथा b उस सीमा के भीतर जिसे हम परिभाषित करेंगे।
इस पायथन कार्यक्रम को पूरा करने के बाद, आप बाधा संतुष्टि के साथ समस्याओं को हल करने की मूल बातें समझने में सक्षम होंगे।
ध्यान दें कि प्रोग्राम लिखने से पहले, हमें पायथन पैकेज को पायथन-कॉन्सट्रेंट नामक स्थापित करना होगा। आप इसे निम्न कमांड की सहायता से स्थापित कर सकते हैं -
pip install python-constraint
निम्नलिखित कदम आपको बाधा संतुष्टि का उपयोग करके बीजीय संबंध को हल करने के लिए पायथन कार्यक्रम दिखाते हैं -
आयात करें constraint निम्नलिखित कमांड का उपयोग कर पैकेज -
from constraint import *
अब, नामित मॉड्यूल का एक ऑब्जेक्ट बनाएं problem() जैसा कि नीचे दिखाया गया है -
problem = Problem()
अब, चरों को परिभाषित करें। ध्यान दें कि हमारे पास दो चर a और b हैं, और हम 10 को उनकी सीमा के रूप में परिभाषित कर रहे हैं, जिसका अर्थ है कि हमें पहले 10 नंबरों के भीतर समाधान मिला।
problem.addVariable('a', range(10))
problem.addVariable('b', range(10))
इसके बाद, उस विशेष बाधा को परिभाषित करें जिसे हम इस समस्या पर लागू करना चाहते हैं। निरीक्षण करें कि यहाँ हम बाधा का उपयोग कर रहे हैंa*2 = b।
problem.addConstraint(lambda a, b: a * 2 == b)
अब, का उद्देश्य बनाएँ getSolution() निम्नलिखित कमांड का उपयोग कर मॉड्यूल -
solutions = problem.getSolutions()
अंत में, निम्न कमांड का उपयोग कर आउटपुट प्रिंट करें -
print (solutions)
आप उपरोक्त कार्यक्रम का आउटपुट निम्नानुसार देख सकते हैं -
[{'a': 4, 'b': 8}, {'a': 3, 'b': 6}, {'a': 2, 'b': 4}, {'a': 1, 'b': 2}, {'a': 0, 'b': 0}]
मैजिक स्क्वायर
एक मैजिक स्क्वायर अलग-अलग संख्याओं की एक व्यवस्था है, आम तौर पर पूर्णांक, एक वर्ग ग्रिड में, जहां प्रत्येक पंक्ति में संख्याएं, और प्रत्येक स्तंभ में और विकर्ण में संख्याएँ, सभी एक ही संख्या को जोड़ते हैं जिसे "जादू स्थिरांक" कहा जाता है। ।
निम्नलिखित जादू वर्गों के निर्माण के लिए सरल पायथन कोड का एक चरणबद्ध निष्पादन है -
नाम के एक फंक्शन को परिभाषित करें magic_square, जैसा कि नीचे दिखाया गया है -
def magic_square(matrix_ms):
iSize = len(matrix_ms[0])
sum_list = []
निम्नलिखित कोड वर्गों के ऊर्ध्वाधर के लिए कोड दिखाता है -
for col in range(iSize):
sum_list.append(sum(row[col] for row in matrix_ms))
निम्नलिखित कोड वर्गों के क्षितिज के लिए कोड दिखाता है -
sum_list.extend([sum (lines) for lines in matrix_ms])
निम्नलिखित कोड वर्गों के क्षैतिज के लिए कोड दिखाता है -
dlResult = 0
for i in range(0,iSize):
dlResult +=matrix_ms[i][i]
sum_list.append(dlResult)
drResult = 0
for i in range(iSize-1,-1,-1):
drResult +=matrix_ms[i][i]
sum_list.append(drResult)
if len(set(sum_list))>1:
return False
return True
अब, मैट्रिक्स का मूल्य दें और आउटपुट की जांच करें -
print(magic_square([[1,2,3], [4,5,6], [7,8,9]]))
आप देख सकते हैं कि आउटपुट होगा False जैसे कि योग समान संख्या तक नहीं है।
print(magic_square([[3,9,2], [3,5,7], [9,1,6]]))
आप देख सकते हैं कि आउटपुट होगा True जैसा कि योग एक ही संख्या है, वह है 15 यहाँ।