पायथन के साथ एआई - गेमिंग
खेल एक रणनीति के साथ खेले जाते हैं। प्रत्येक खिलाड़ी या टीम खेल शुरू करने से पहले एक रणनीति बनाएगी और उन्हें खेल में वर्तमान स्थिति (स्थितियों) के अनुसार नई रणनीति बदलनी होगी या निर्माण करना होगा।
एल्गोरिदम खोजें
आपको कंप्यूटर गेम पर भी उसी रणनीति के साथ विचार करना होगा जैसा कि ऊपर बताया गया है। ध्यान दें कि खोज एल्गोरिदम वे हैं जो कंप्यूटर गेम में रणनीति का पता लगाते हैं।
यह काम किस प्रकार करता है
खोज एल्गोरिदम का लक्ष्य चालों का इष्टतम सेट ढूंढना है ताकि वे अंतिम गंतव्य तक पहुंच सकें और जीत सकें। ये एल्गोरिदम सर्वश्रेष्ठ चाल को खोजने के लिए, हर गेम के लिए अलग-अलग स्थितियों के जीतने वाले सेट का उपयोग करते हैं।
पेड़ के रूप में एक कंप्यूटर गेम की कल्पना करें। हम जानते हैं कि पेड़ में नोड्स होते हैं। जड़ से शुरू करके, हम अंतिम विजेता नोड पर आ सकते हैं, लेकिन इष्टतम चाल के साथ। यह खोज एल्गोरिदम का काम है। ऐसे पेड़ में प्रत्येक नोड भविष्य की स्थिति का प्रतिनिधित्व करता है। गेम के प्रत्येक चरण या नोड पर निर्णय लेने के लिए खोज एल्गोरिदम इस पेड़ के माध्यम से खोज करते हैं।
संयुक्त खोज
खोज एल्गोरिदम का उपयोग करने का मुख्य नुकसान यह है कि वे प्रकृति में संपूर्ण हैं, यही वजह है कि वे समाधान खोजने के लिए पूरे खोज स्थान का पता लगाते हैं जो संसाधनों का अपव्यय करता है। यह अधिक बोझिल होगा यदि इन एल्गोरिदम को अंतिम समाधान खोजने के लिए पूरे खोज स्थान की खोज करनी होगी।
इस तरह की समस्या को खत्म करने के लिए, हम कॉम्बिनेशन सर्च का उपयोग कर सकते हैं जो सर्च स्पेस का पता लगाने के लिए हेयुरिस्टिक का उपयोग करता है और संभावित गलत चालों को समाप्त करके इसके आकार को कम करता है। इसलिए, ऐसे एल्गोरिदम संसाधनों को बचा सकते हैं। अंतरिक्ष को खोजने और संसाधनों को बचाने के लिए कुछ एल्गोरिदम का उपयोग किया जाता है, यहां चर्चा की गई है -
मिनिमैक्स एल्गोरिथम
यह कॉम्बीनेशन खोज द्वारा उपयोग की जाने वाली रणनीति है जो खोज रणनीति को गति देने के लिए अनुमानी का उपयोग करती है। मिनिमैक्स रणनीति की अवधारणा को दो खिलाड़ी खेलों के उदाहरण से समझा जा सकता है, जिसमें प्रत्येक खिलाड़ी प्रतिद्वंद्वी के अगले कदम की भविष्यवाणी करने की कोशिश करता है और उस फ़ंक्शन को कम करने की कोशिश करता है। इसके अलावा, जीतने के लिए, खिलाड़ी हमेशा मौजूदा स्थिति के आधार पर अपने स्वयं के फ़ंक्शन को अधिकतम करने का प्रयास करता है।
इस तरह की रणनीतियों में हेयिमिस्टिक एक महत्वपूर्ण भूमिका निभाता है जैसे कि मिनीमैक्स। पेड़ के प्रत्येक नोड के साथ जुड़ा हुआ एक यकृत समारोह होगा। उस अनुमान के आधार पर, यह नोड की ओर एक कदम बनाने का निर्णय लेगा जिससे उन्हें सबसे अधिक लाभ होगा।
अल्फा-बीटा प्रूनिंग
मिनिमैक्स एल्गोरिथ्म के साथ एक प्रमुख मुद्दा यह है कि यह पेड़ के उन हिस्सों का पता लगा सकता है जो अप्रासंगिक हैं, संसाधनों की बर्बादी की ओर जाता है। इसलिए यह तय करने की रणनीति होनी चाहिए कि पेड़ का कौन सा हिस्सा प्रासंगिक है और कौन सा अप्रासंगिक है और अप्रासंगिक भाग को अस्पष्टीकृत छोड़ दें। अल्फा-बीटा प्रूनिंग इस तरह की एक रणनीति है।
अल्फा-बीटा प्रूनिंग एल्गोरिदम का मुख्य लक्ष्य पेड़ के उन हिस्सों की खोज से बचना है जिनके पास कोई समाधान नहीं है। अल्फा-बीटा प्रूनिंग की मुख्य अवधारणा नाम की दो सीमाओं का उपयोग करना हैAlphaअधिकतम निचला बाउंड, और Beta, न्यूनतम ऊपरी सीमा। ये दो पैरामीटर मान हैं जो संभव समाधान के सेट को प्रतिबंधित करते हैं। यह अल्फा और बीटा मापदंडों के मूल्य के साथ वर्तमान नोड के मूल्य की तुलना करता है, ताकि यह उस पेड़ के हिस्से में जा सके जिसके पास समाधान है और बाकी को त्याग दें।
नेगामैक्स एल्गोरिथम
यह एल्गोरिथ्म मिनिमैक्स एल्गोरिथ्म से अलग नहीं है, लेकिन इसमें अधिक सुरुचिपूर्ण कार्यान्वयन है। मिनिमैक्स एल्गोरिथ्म का उपयोग करने का मुख्य नुकसान यह है कि हमें दो अलग-अलग हेयुरिस्टिक कार्यों को परिभाषित करने की आवश्यकता है। इन हेयुरिस्टिक के बीच संबंध यह है कि, एक खिलाड़ी के लिए एक खेल की बेहतर स्थिति दूसरे खिलाड़ी के लिए उतना ही बुरा है। नेगामैक्स एल्गोरिथ्म में, दो हेयुरिस्टिक फ़ंक्शन का एक ही काम एकल हेयुरिस्टिक फ़ंक्शन की सहायता से किया जाता है।
बिल्डिंग बॉट्स टू गेम्स गेम्स
एअर इंडिया में दो खिलाड़ी खेल खेलने के लिए बॉट बनाने के लिए, हमें स्थापित करने की आवश्यकता है easyAIपुस्तकालय। यह एक आर्टिफिशियल इंटेलिजेंस फ्रेमवर्क है जो दो-प्लेयर गेम बनाने के लिए सभी कार्यक्षमता प्रदान करता है। आप इसे निम्न कमांड की सहायता से डाउनलोड कर सकते हैं -
pip install easyAI
अंतिम सिक्का खड़े होने के लिए एक बॉट
इस खेल में, सिक्कों का ढेर होता। प्रत्येक खिलाड़ी को उस ढेर से कई सिक्के लेने होते हैं। खेल का लक्ष्य ढेर में अंतिम सिक्का लेने से बचना है। हम कक्षा का उपयोग करेंगेLastCoinStanding से विरासत में मिला TwoPlayersGame की कक्षा easyAIपुस्तकालय। निम्नलिखित कोड इस खेल के लिए पायथन कोड दिखाता है -
दिखाए गए अनुसार आवश्यक पैकेज आयात करें -
from easyAI import TwoPlayersGame, id_solve, Human_Player, AI_Player
from easyAI.AI import TT
अब, वर्ग को इनहेरिट करें TwoPlayerGame खेल के सभी संचालन को संभालने के लिए वर्ग -
class LastCoin_game(TwoPlayersGame):
def __init__(self, players):
अब, उन खिलाड़ियों और खिलाड़ी को परिभाषित करें जो खेल शुरू करने जा रहे हैं।
self.players = players
self.nplayer = 1
अब, खेल में सिक्कों की संख्या को परिभाषित करें, यहाँ हम खेल के लिए 15 सिक्कों का उपयोग कर रहे हैं।
self.num_coins = 15
एक चाल में अधिकतम जितने सिक्के एक खिलाड़ी ले सकता है, उसे परिभाषित करें।
self.max_coins = 4
अब निम्नलिखित कोड में दिखाए अनुसार परिभाषित करने के लिए कुछ निश्चित चीजें हैं। संभावित चाल को परिभाषित करें।
def possible_moves(self):
return [str(a) for a in range(1, self.max_coins + 1)]
सिक्कों को हटाने को परिभाषित करें
def make_move(self, move):
self.num_coins -= int(move)
परिभाषित करें कि अंतिम सिक्का किसने लिया।
def win_game(self):
return self.num_coins <= 0
खेल को रोकने के लिए परिभाषित करें, जब कोई जीतता है।
def is_over(self):
return self.win()
स्कोर की गणना कैसे करें परिभाषित करें।
def score(self):
return 100 if self.win_game() else 0
ढेर में शेष सिक्कों की संख्या निर्धारित करें।
def show(self):
print(self.num_coins, 'coins left in the pile')
if __name__ == "__main__":
tt = TT()
LastCoin_game.ttentry = lambda self: self.num_coins
निम्नलिखित कोड ब्लॉक के साथ खेल को हल करना -
r, d, m = id_solve(LastCoin_game,
range(2, 20), win_score=100, tt=tt)
print(r, d, m)
निर्णय लेना कि कौन खेल शुरू करेगा
game = LastCoin_game([AI_Player(tt), Human_Player()])
game.play()
आप निम्न आउटपुट और इस खेल का एक सरल खेल पा सकते हैं -
d:2, a:0, m:1
d:3, a:0, m:1
d:4, a:0, m:1
d:5, a:0, m:1
d:6, a:100, m:4
1 6 4
15 coins left in the pile
Move #1: player 1 plays 4 :
11 coins left in the pile
Player 2 what do you play ? 2
Move #2: player 2 plays 2 :
9 coins left in the pile
Move #3: player 1 plays 3 :
6 coins left in the pile
Player 2 what do you play ? 1
Move #4: player 2 plays 1 :
5 coins left in the pile
Move #5: player 1 plays 4 :
1 coins left in the pile
Player 2 what do you play ? 1
Move #6: player 2 plays 1 :
0 coins left in the pile
टिक टीएसी को पैर की अंगुली खेलने के लिए एक बॉट
टिक-टैक-टो बहुत परिचित है और सबसे लोकप्रिय खेलों में से एक है। आइए हम इस गेम का उपयोग करके बनाते हैंeasyAIपाइथन में पुस्तकालय। निम्नलिखित कोड इस खेल का पायथन कोड है -
दिखाए अनुसार पैकेज आयात करें -
from easyAI import TwoPlayersGame, AI_Player, Negamax
from easyAI.Player import Human_Player
से वर्ग इनहेरिट करें TwoPlayerGame खेल के सभी संचालन को संभालने के लिए वर्ग -
class TicTacToe_game(TwoPlayersGame):
def __init__(self, players):
अब, खेल शुरू करने जा रहे खिलाड़ियों और खिलाड़ी को परिभाषित करें -
self.players = players
self.nplayer = 1
बोर्ड के प्रकार को परिभाषित करें -
self.board = [0] * 9
अब इस प्रकार परिभाषित करने के लिए कुछ निश्चित चीजें हैं -
संभावित चाल को परिभाषित करें
def possible_moves(self):
return [x + 1 for x, y in enumerate(self.board) if y == 0]
खिलाड़ी की चाल को परिभाषित करें -
def make_move(self, move):
self.board[int(move) - 1] = self.nplayer
एआई को बढ़ावा देने के लिए, परिभाषित करें कि कोई खिलाड़ी कब कदम रखता है -
def umake_move(self, move):
self.board[int(move) - 1] = 0
उस हार की स्थिति को परिभाषित करें जो एक प्रतिद्वंद्वी के पास एक पंक्ति में तीन है
def condition_for_lose(self):
possible_combinations = [[1,2,3], [4,5,6], [7,8,9],
[1,4,7], [2,5,8], [3,6,9], [1,5,9], [3,5,7]]
return any([all([(self.board[z-1] == self.nopponent)
for z in combination]) for combination in possible_combinations])
खेल की समाप्ति के लिए एक जांच को परिभाषित करें
def is_over(self):
return (self.possible_moves() == []) or self.condition_for_lose()
खेल में खिलाड़ियों की वर्तमान स्थिति दिखाएं
def show(self):
print('\n'+'\n'.join([' '.join([['.', 'O', 'X'][self.board[3*j + i]]
for i in range(3)]) for j in range(3)]))
अंकों की गणना करें।
def scoring(self):
return -100 if self.condition_for_lose() else 0
एल्गोरिथ्म को परिभाषित करने और खेल शुरू करने के लिए मुख्य विधि को परिभाषित करें -
if __name__ == "__main__":
algo = Negamax(7)
TicTacToe_game([Human_Player(), AI_Player(algo)]).play()
आप निम्न आउटपुट और इस खेल का एक सरल खेल देख सकते हैं -
. . .
. . .
. . .
Player 1 what do you play ? 1
Move #1: player 1 plays 1 :
O . .
. . .
. . .
Move #2: player 2 plays 5 :
O . .
. X .
121
. . .
Player 1 what do you play ? 3
Move #3: player 1 plays 3 :
O . O
. X .
. . .
Move #4: player 2 plays 2 :
O X O
. X .
. . .
Player 1 what do you play ? 4
Move #5: player 1 plays 4 :
O X O
O X .
. . .
Move #6: player 2 plays 8 :
O X O
O X .
. X .