argparse是深度學習項目調參時常用的python標準庫,使用argparse后,我們在命令行輸入的參數就可以以這種形式python filename.py --lr 1e-4 --batch_size 32
來完成對常見超參數的設置。,一般使用時可以歸納為以下三個步驟
成都創新互聯-專業網站定制、快速模板網站建設、高性價比池州網站開發、企業建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式池州網站制作公司更省心,省錢,快速模板網站建設找我們,業務覆蓋池州地區。費用合理售后完善,10余年實體公司更值得信賴。
ArgumentParser()
對象add_argument()
方法添加參數parse_args()
解析參數 在接下來的內容中,我們將以實際操作來學習argparse的使用方法import argparse
parser = argparse.ArgumentParser() # 創建一個解析對象
parser.add_argument() # 向該對象中添加你要關注的命令行參數和選項
args = parser.parse_args() # 調用parse_args()方法進行解析
python demo.py -h
或者python demo.py --help
可以查看該python文件參數說明Namespace(integers='5')
可使用arg.參數名
來提取這個參數parser.add_argument('integers', type=str, nargs='+',help='傳入的數字')
nargs是用來說明傳入的參數個數,'+' 表示傳入至少一個參數,'*' 表示參數可設置零個或多個,'?' 表示參數可設置零個或一個parser.add_argument('-n', '--name', type=str, required=True, default='', help='名')
required=True
表示必須參數, -n表示可以使用短選項使用該參數parser.add_argument("--test_action", default='False', action='store_true')
store_true 觸發時為真,不觸發則為假(test.py
,輸出為 False
,test.py --test_action
,輸出為 True
)為了使代碼更加簡潔和模塊化,可以將有關超參數的操作寫在config.py
,然后在train.py
或者其他文件導入就可以。具體的config.py
可以參考如下內容。
import argparse
def get_options(parser=argparse.ArgumentParser()):
parser.add_argument('--workers', type=int, default=0,
help='number of data loading workers, you had better put it '
'4 times of your gpu')
parser.add_argument('--batch_size', type=int, default=4, help='input batch size, default=64')
parser.add_argument('--niter', type=int, default=10, help='number of epochs to train for, default=10')
parser.add_argument('--lr', type=float, default=3e-5, help='select the learning rate, default=1e-3')
parser.add_argument('--seed', type=int, default=118, help="random seed")
parser.add_argument('--cuda', action='store_true', default=True, help='enables cuda')
parser.add_argument('--checkpoint_path',type=str,default='',
help='Path to load a previous trained model if not empty (default empty)')
parser.add_argument('--output',action='store_true',default=True,help="shows output")
opt = parser.parse_args()
if opt.output:
print(f'num_workers: {opt.workers}')
print(f'batch_size: {opt.batch_size}')
print(f'epochs (niters) : {opt.niter}')
print(f'learning rate : {opt.lr}')
print(f'manual_seed: {opt.seed}')
print(f'cuda enable: {opt.cuda}')
print(f'checkpoint_path: {opt.checkpoint_path}')
return opt
if __name__ == '__main__':
opt = get_options()
$ python config.py
num_workers: 0
batch_size: 4
epochs (niters) : 10
learning rate : 3e-05
manual_seed: 118
cuda enable: True
checkpoint_path:
隨后在train.py
等其他文件,我們就可以使用下面的這樣的結構來調用參數。
# 導入必要庫
...
import config
opt = config.get_options()
manual_seed = opt.seed
num_workers = opt.workers
batch_size = opt.batch_size
lr = opt.lr
niters = opt.niters
checkpoint_path = opt.checkpoint_path
# 隨機數的設置,保證復現結果
def set_seed(seed):
torch.manual_seed(seed)
torch.cuda.manual_seed_all(seed)
random.seed(seed)
np.random.seed(seed)
torch.backends.cudnn.benchmark = False
torch.backends.cudnn.deterministic = True
...
if __name__ == '__main__':
set_seed(manual_seed)
for epoch in range(niters):
train(model,lr,batch_size,num_workers,checkpoint_path)
val(model,lr,batch_size,num_workers,checkpoint_path)
參考:
https://zhuanlan.zhihu.com/p/
(14條消息) python argparse中action的可選參數store_true的作用_元氣少女wuqh的博客-CSDN博客
[6.6 使用argparse進行調參 — 深入淺出PyTorch (datawhalechina.github.io)](https://datawhalechina.github.io/thorough-pytorch/第六章/6.6 使用argparse進行調參.html)
新聞名稱:固定代碼,只使用命令行調參——argparse使用方法
本文鏈接:http://m.kartarina.com/article22/dsogjjc.html
成都網站建設公司_創新互聯,為您提供商城網站、手機網站建設、軟件開發、網站策劃、微信小程序、網站設計公司
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯