A machine learning game framework based on Pygame
Project description
MLGame
這是一個遊戲AI競賽的框架,依照此框架所開發的遊戲,可以透過AI來玩遊戲,並進行AI競賽。
使用方式
終端機範例
-
列出 help 文件
python -m mlgame -h
-
命令列格式
python -m mlgame [options] <game_folder> [game_params]
- 執行打磚塊遊戲
python -m mlgame \ -f 120 -i ./path/to/ai/ai_client_file_name.py \ ./path/to/game/arkanoid \ --difficulty NORMAL --level 3
- AI和遊戲的資料夾路徑可以使用
相對路徑或是絕對路徑 - 遊戲參數
game_params須參考各個遊戲
- AI和遊戲的資料夾路徑可以使用
- 執行打磚塊遊戲
位置引數(Positional Argument)
game_folderrequired- 遊戲資料夾所在的路徑,此路徑下需有
config.py
功能性引數(Functional Argument)
options
-
--version顯示MLGame版本號 -
-h,--help- 提供參數的說明
-
-fFPS,--fpsFPS- 設定遊戲的遊戲更新率(frame per second),遊戲預設為每秒更新30次。
default:30
-
-1,--one-shot- 表示遊戲只執行一次,沒有加上這個參數,遊戲皆會不斷重新執行。
default:False
-
--nd,--no-display- 加上此參數就不會顯示螢幕畫面。
default:False
-
--ws_urlWS_URL- 加上此參數,會建立一個websocket connection,並將遊戲過程中的資料傳到指定的路徑,若路徑失效,則遊戲無法啟動。
-
-iAI_Client,--input-aiAI_Client- 指定要玩遊戲的AI,AI的檔案中,需要包含
MLPlay這個class。 - 若有多個玩家,可直接參考下方案例,路徑可以使用絕對路徑與相對路徑。
-i ./path/to/ai/ai_01.py -i ./path/to/ai/ai_02.py - AI數量需符合遊戲需求,每個遊戲都會有最小值與最大值,不足的會以最後一個AI自動補足,多的會自動刪去。
- 遊戲若需要2個AI,給到1個AI則會同時扮演1P 2P
- 遊戲若需要2個AI,給到3個AI則會自動排除最後一個
- 指定要玩遊戲的AI,AI的檔案中,需要包含
-
-ooutput_folder,--output-folderoutput_folder- 將遊戲過程儲存到特定資料夾中,會自動建立一個時間戳記資料夾來儲存每一幀的圖片。
- 此資料夾需要可讀寫,並且為有效路徑。
- 若是沒有加上
-1,會不斷的紀錄遊戲結果。 - 此選項會影響到執行效能,開啟後覺得卡頓屬於正常現象。
-
-rprogress-folder,--progress-folderprogress-folder- 將遊戲每個 frame 儲存到特定資料夾中,會自動建立一個時間戳記資料夾來儲存各 frame 的內容,以檔案分開。
- 可透過
-p,--progress-frame-frequency指定一個檔案內的 frame 數量。 - 檔案內容為 json,檔案名稱代表此檔案由哪個 frame 開始紀錄。
- 此資料夾需要可讀寫,並且為有效路徑。
-
-pprogress-frame-frequency,--progress-frame-frequencyprogress-frame-frequency- 與
-r,--progress-folder搭配。 - 可指定一個檔案內的 frame 數量。
- 與
-
--ns,--no-sound- 預設會開啟音效設定,加上此參數會關閉音效。
-
--debug- 顯示debug 資訊,並紀錄
debug.log檔案
- 顯示debug 資訊,並紀錄
--az_upload_urlAZ_UPLOAD_URL- 將遊戲過程紀錄檔案上傳至azure blob,
AZ_UPLOAD_URL需包含連結字串
- 將遊戲過程紀錄檔案上傳至azure blob,
game_params
optional- 執行遊戲的參數依照每個遊戲有所不同,格式為
--name_of_paramsvalue_of_params - type
- int :
01-11.5 - str :
"0""hello""NORMAL" - list:
0,1-1,1000,111abc,cde,12 - path:
./relative_path_to_file/file.txt,/absoulute_path_to_file/file.dat
- int :
畫面控制
- 遊戲執行可以使用
IJKL進行平移 - 使用
UO放大縮小 - 使用
H開啟或關閉部分資訊 - 使用
P暫停遊戲畫面,暫停期間,遊戲邏輯不會運作,但仍可以調整畫面。 - 使用
M在遊戲過程中開關音樂與音效。
相關專案
- PAIA-Desktop
- 範例遊戲 easy_game
- 打磚塊 arkanoid
- 乒乓球 pingpong
- 賽車 Racing Car
- 迷宮自走車 Maze Car
Future Work
- Non-python Client Support
- test case
- 遊戲開發文件
Change Log
View CHANGELOG.md
開發與測試
環境變數設定
MLGame 框架支援使用環境變數來設定開發和測試時的路徑,避免硬編碼敏感資訊。所有環境變數都定義在 mlgame/tests/env.py 中。
可用的環境變數
MLGAME_BASE_PATH: MLGame 專案的基礎路徑MLGAME_GAMES_PATH: 遊戲目錄的路徑MLGAME_AI_CLIENTS_PATH: AI 客戶端目錄的路徑MLGAME_OUTPUT_PATH: 輸出目錄的路徑MLGAME_VERBOSE_TESTS: 啟用測試時的詳細路徑記錄MLGAME_AZURE_CONTAINER_URL: azure blob container 路徑MLGAME_AZURE_BLOB_URL: azure blob 路徑
使用 .env 檔案
您可以在測試資料夾中建立 .env 檔案來設定環境變數。專案中提供了 .env.sample 作為範例。
# .env 檔案範例
MLGAME_BASE_PATH=/path/to/your/mlgame
要使用 .env 檔案,需安裝 python-dotenv 套件:
pip install python-dotenv
在程式中使用環境變數
要在您的程式中使用這些環境變數,只需從 env 模組匯入它們:
from mlgame.tests.env import BASE_PATH, GAMES_PATH, AI_CLIENTS_PATH, get_path
# 使用環境變數生成路徑
game_path = get_path(GAMES_PATH, 'my_game')
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mlgame-10.7.1.tar.gz.
File metadata
- Download URL: mlgame-10.7.1.tar.gz
- Upload date:
- Size: 5.3 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.10.17
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0357672a6afdb6ffe13b97c318c6c140ad4f2c66149bd2ff49c25a5e7c031196
|
|
| MD5 |
a951f1f4559906b7aa9987aa4542d11c
|
|
| BLAKE2b-256 |
819c0c8c4cb0b6eda49d032a14bf8917148287fd1a8c6d7679e4df1b85fa4f2e
|
File details
Details for the file mlgame-10.7.1-py3-none-any.whl.
File metadata
- Download URL: mlgame-10.7.1-py3-none-any.whl
- Upload date:
- Size: 5.3 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.10.17
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b43665146f68f62b0a31e2aaa18fe5cbe2c7c9ff679641c4408e4a850b0fb58a
|
|
| MD5 |
f1ceea43f2d2d26d252eeeae1f62f78a
|
|
| BLAKE2b-256 |
c8902fa3abd1f86cd66b21111858a0f3c4e343d812def043f197a3aa1ebbb776
|