1. 程式人生 > WINDOWS開發 >Detectron2 API 之 config | 十五

Detectron2 API 之 config | 十五

作者|facebookresearch
編譯|Flin
來源|Github

detectron2.config package

class detectron2.config.CfgNode(init_dict=None,key_list=None,new_allowed=False)
  1. 預設情況下使用不安全的Yaml載入。
    請注意,這可能會導致任意程式碼執行:在手動檢查檔案內容之前,切勿從不受信任的源中載入配置檔案。
  2. 支援配置版本控制。
    嘗試合併舊配置時,它將自動轉換舊配置。
merge_from_file(cfg_filename: str,allow_unsafe: bool = True) → None
dump(*args,**kwargs)
  • 返回值:str –配置的yaml字串表示形式
DEPRECATED_KEYS= ‘__deprecated_keys__‘
IMMUTABLE= ‘__immutable__‘
NEW_ALLOWED= ‘__new_allowed__‘
RENAMED_KEYS=‘__renamed_keys__‘
__init__(init_dict=None,new_allowed=False)
  • 引數:
    • init_dict(dict)–可能巢狀的字典,用於初始化CfgNode。
    • key_list(list [ str ])–名稱列表,從根目錄索引此CfgNode。當前僅用於記錄目的。
    • new_allowed(bool)–與其他配置合併時是否允許新增新金鑰。
clear() → None,從D刪除所有專案
clone()
  • 遞迴複製此CfgNode。
copy() → D的淺副本
defrost()
  • 使此CfgNode及其所有子級可變。
freeze()
  • 使此CfgNode及其所有子代不變。
fromkeys()
  • 使用可迭代的鍵並將值設定為value建立一個新字典。
get()
  • 如果key在字典中,則返回key的值,否則返回預設值。
is_frozen()
  • 返回可變性。
is_new_allowed()
items() → 提供D的專案檢視的類集合物件
key_is_deprecated(full_key)
  • 測試是否不贊成使用金鑰。
key_is_renamed(full_key)
  • 測試金鑰是否被重新命名。
keys() → 提供D鍵檢視的類集合物件
class method load_cfg(cfg_file_obj_or_str)
  • 載入cfg:param cfg_file_obj_or_str:支援從以下位置載入:

    • 由YAML檔案支援的檔案物件
    • 由Python原始檔支援的檔案物件,該檔案物件匯出dict或CfgNode屬性"cfg"
    • 可以解析為有效YAML的字串
static load_yaml_with_base(filename: str,allow_unsafe: bool = False)

就像yaml.load(open(filename))一樣,但是從其繼承屬性

  • 引數:
    • filename(str):當前配置的檔名。將用於查詢基本配置檔案。
    • allow_unsafe(bool):是否允許使用yaml.unsafe_load載入配置檔案 。
    • 返回值:(字典) 已載入的Yaml
merge_from_list(cfg_list: list)
  • 引數: cfg_list(list):要合併的配置列表。
merge_from_other_cfg(cfg_other)
  • 引數: cfg_other(CfgNode)要合併的配置。
pop(k[,d]) → v,remove specified key and return the corresponding value.
  • 如果找不到鍵,則返回d(如果給出),否則引發KeyError
popitem() → (k,v),remove and return some (key,value) pair as a
  • 2元組; 但如果D為空,則引發KeyError。
raise_key_rename_error(full_key)
register_deprecated_key(key)
  • 註冊金鑰(例如FOO.BAR)已棄用的選項。合併不贊成使用的金鑰時,將生成警告,並且該金鑰將被忽略。
register_renamed_key(old_name,new_name,message=None)
  • 將金鑰註冊為從old_name重新命名為new_name。合併重新命名的金鑰時,會引發異常,警告使用者該金鑰已被重新命名。
setdefault()
  • 如果key不在字典中,則插入具有預設值的key。

  • 如果key在字典中,否則返回預設值。

update([E,]**F) → None. Update D from dict/iterable E and F.
  • 如果E存在並且具有.keys()方法,則執行:for k in E: D[k] = E[k]
  • 如果E存在並且缺乏.keys()方法,則執行: for k,v in E: D[k] = v
  • 在任一情況下,都跟著: for k in F: D[k] = F[k]
values() → 提供D值檢視的物件
detectron2.config.get_cfg() → detectron2.config.config.CfgNode
detectron2.config.set_global_cfg(cfg: detectron2.config.config.CfgNode) → None

假定給定的"cfg"具有鍵"KEY",在呼叫 set_global_cfg(cfg)之後,可以通過以下方式訪問該鍵:

from detectron2.config import global_cfg
print(global_cfg.KEY)

通過使用hacky全域性配置,你可以在任何地方訪問這些配置,而不必將配置物件或值傳遞到程式碼中。這是為快速原型設計/研究探索而引入的一項功能強大的功能。

detectron2.config.downgrade_config(cfg: detectron2.config.config.CfgNode,to_version: int) → detectron2.config.config.CfgNode
注意

由於不同版本中的功能不同,通常無法對任意配置進行普遍降級。降級的目的僅是恢復舊版本中的預設設定,從而允許它載入舊的部分Yaml配置。因此,僅當無法進行一般降級時,實現才需要填寫舊版本中的預設值。

detectron2.config.upgrade_config(cfg: detectron2.config.config.CfgNode,to_version: Optional[int] = None) → detectron2.config.config.CfgNode