class Run
W&B에 로깅되는 계산 단위입니다. 일반적으로는 ML 실험을 의미합니다.
새 run을 생성하려면 wandb.init()을 call하세요. wandb.init()은 새 run을 시작하고 wandb.Run 객체를 반환합니다. 각 run에는 고유한 ID(run ID)가 연결됩니다. W&B는 run이 자동으로 종료되도록 컨텍스트 관리자(with 문)를 사용할 것을 권장합니다.
분산 트레이닝 실험의 경우, 프로세스마다 하나의 run을 사용해 각 프로세스를 개별적으로 추적할 수도 있고, 모든 프로세스를 하나의 run으로 추적할 수도 있습니다. 자세한 내용은 Log distributed training experiments를 참조하세요.
wandb.Run.log()를 사용해 run에 데이터를 로깅할 수 있습니다. wandb.Run.log()로 로깅한 모든 항목은 해당 run으로 전송됩니다. 자세한 내용은 Create an experiment 또는 wandb.init API 레퍼런스 페이지를 참조하세요.
wandb.apis.public 네임스페이스에는 또 다른 Run 객체가 있습니다. 이 객체는 이미 생성된 run과 상호작용하는 데 사용됩니다.
속성:
summary: (Summary) run의 요약으로, 딕셔너리와 유사한 객체입니다. 자세한 내용은[Log summary metrics](https: //docs.wandb.ai/models/track/log/log-summary).
wandb.init()으로 run 생성:
속성 Run.config
이 run에 연결된 설정 객체입니다. 반환값:wandb_config.Config:config속성 값입니다.
속성 Run.config_static
이 run에 연결된 정적 설정 객체입니다. 반환값:wandb_config.ConfigStatic: config_static 속성 값입니다.
속성 Run.dir
run에 연결된 파일이 저장되는 디렉터리입니다. 반환값:str:dir속성 값입니다.
속성 Run.disabled
run이 비활성화된 경우 True, 그렇지 않으면 False입니다. 반환값:bool: 비활성화 여부를 나타내는 속성 값입니다.
속성 Run.entity
run과 연결된 W&B entity의 이름입니다. entity는 사용자 이름, 팀 이름 또는 조직 이름일 수 있습니다. 반환값:str: entity 속성 값입니다.
속성 Run.group
이 run에 연결된 그룹의 이름을 반환합니다. run을 함께 그룹화하면 관련 실험을 W&B UI에서 한데 모아 구성하고 시각화할 수 있습니다. 이는 분산 트레이닝이나 교차 검증처럼 여러 run을 하나의 통합된 실험으로 보고 관리해야 하는 시나리오에서 특히 유용합니다. 모든 프로세스가 동일한 run 객체를 공유하는 공유 모드에서는 run이 하나뿐이라 그룹화가 필요 없으므로, 일반적으로 그룹을 설정할 필요가 없습니다. 반환값:str: 그룹 속성 값입니다.
속성 Run.id
이 run의 식별자입니다. 반환값:str: id 속성 값.
속성 Run.job_type
run과 연결된 작업 유형의 이름입니다. W&B App의 run Overview 페이지에서 run의 작업 유형을 확인할 수 있습니다. 이를 사용하면 “트레이닝”, “evaluation”, “Inference”와 같은 작업 유형별로 run을 분류할 수 있습니다. 이는 W&B UI에서 run을 정리하고 필터링하는 데 유용하며, 특히 같은 프로젝트에 서로 다른 작업 유형의 run이 여러 개 있을 때 더욱 유용합니다. 자세한 내용은 run 정리하기를 참조하세요. 반환값:str:job_type속성 값입니다.
속성 Run.name
run의 표시 이름입니다. 표시 이름은 고유하지 않을 수 있으며, 설명적인 이름일 수 있습니다. 기본적으로는 무작위로 생성됩니다. 반환값:str | None: name 속성 값입니다.
속성 Run.notes
run에 연결된 메모가 있는 경우 해당 메모입니다. 메모는 여러 줄 문자열일 수 있으며,$x + 3$처럼 $$ 안에 Markdown과 LaTeX 수식을 사용할 수도 있습니다.
반환값:
str | None: notes 속성의 값입니다.
속성 Run.offline
run이 오프라인 상태이면 True, 아니면 False입니다. 반환값:bool: offline 속성 값입니다.
속성 Run.path
run의 경로입니다. run 경로에는 entity, 프로젝트, run ID가 포함되며, 형식은entity/project/run_id입니다.
반환값:
str: 경로 속성 값입니다.
속성 Run.project
run에 연결된 W&B 프로젝트의 이름입니다. 반환값:str: 프로젝트 속성 값입니다.
속성 Run.project_url
해당 run에 연결된 W&B 프로젝트의 URL입니다(있는 경우). 오프라인 run에는 프로젝트 URL이 없습니다. 반환값:str | None:project_url속성 값입니다.
속성 Run.resumed
run이 재개되었으면 True, 그렇지 않으면 False입니다. 반환값:bool: resumed 속성의 값입니다.
속성 Run.settings
run의 Settings 객체를 불변으로 복사한 사본입니다. 반환값:Settings: settings 속성 값입니다.
속성 Run.start_time
run이 시작된 시점의 Unix 타임스탬프(초 단위)입니다. 반환값:float: start_time 속성 값.
속성 Run.sweep_id
run에 연결된 sweep의 식별자입니다(있는 경우). 반환값:str | None:sweep_id속성 값.
속성 Run.sweep_url
run에 연결된 sweep의 URL입니다(있는 경우). 오프라인 run에는 sweep URL이 없습니다. 반환값:str | None: sweep_url 속성 값입니다.
속성 Run.tags
run에 연결된 태그가 있으면 해당 태그입니다. 반환값:tuple | None: tags 속성의 값입니다.
속성 Run.url
W&B run에 URL이 있으면 해당 URL입니다. 오프라인 run에는 URL이 없습니다. 반환값:str | None: url 속성 값입니다.
방법 Run.alert
title: Alert의 제목입니다. 64자 미만이어야 합니다.text: Alert의 본문입니다.level: 사용할 Alert 수준입니다.INFO,WARN,ERROR중 하나여야 합니다.wait_duration: 같은 제목의 Alert를 다시 보내기 전에 대기할 시간(초)입니다.
방법 Run.define_metric
wandb.Run.log()로 로깅되는 메트릭을 사용자 지정합니다.
매개변수:
name: 사용자 지정할 메트릭의 이름입니다.step_metric: 자동 생성된 차트에서 이 메트릭의 X축으로 사용할 다른 메트릭의 이름입니다.step_sync: 명시적으로 제공되지 않으면wandb.Run.log()에 step_metric의 마지막 값을 자동으로 삽입합니다. step_metric이 지정된 경우 기본값은 True입니다.hidden: 자동 플롯에서 이 메트릭을 숨깁니다.summary: summary에 추가할 집계 메트릭을 지정합니다. 지원되는 집계에는 “min”, “max”, “mean”, “last”, “first”, “best”, “copy”, “none”이 포함됩니다. “none”을 지정하면 summary가 생성되지 않습니다. “best”는 goal 매개변수와 함께 사용하지만, 현재는 사용 중단되었으므로 사용하지 않는 것이 좋으며 대신 “min” 또는 “max”를 사용하세요. “copy”도 사용 중단되었으므로 사용하지 않는 것이 좋습니다.goal: “best” summary 유형을 해석하는 방식을 지정합니다. 지원되는 옵션은 “minimize”와 “maximize”입니다. “goal”은 사용 중단되었으므로 사용하지 않는 것이 좋으며, 대신 “min” 또는 “max”를 사용하세요.overwrite: false이면 이 call은 동일한 메트릭에 대한 이전define_metriccall과 병합되며, 지정되지 않은 매개변수에는 이전 call의 값이 사용됩니다. true이면 지정되지 않은 매개변수가 이전 call에서 지정된 값을 덮어씁니다.
방법 Run.display
방법 Run.finish
- Running: 데이터를 logging하고 하트비트를 전송 중인 활성 run입니다.
- Crashed: 예기치 않게 하트비트 전송이 중단된 run입니다.
- Finished: 모든 데이터가 동기화된 상태로 성공적으로 완료된 run입니다(
exit_code=0). - Failed: 오류와 함께 완료된 run입니다(
exit_code!=0). - Killed: 완료되기 전에 강제로 중지된 run입니다.
exit_code: run의 종료 상태를 나타내는 정수입니다. 성공 시 0을 사용하며, 다른 값이면 run이 실패로 표시됩니다.quiet: 사용 중단.wandb.Settings(quiet=...)를 사용해 logging 상세 수준을 설정하세요.
방법 Run.finish_artifact
"upsert"를 수행하면 새 버전이 생성됩니다.
매개변수:
artifact_or_path: 이 artifact의 콘텐츠 경로입니다. 다음 형식을 사용할 수 있습니다:/local/directory/local/directory/file.txts3://bucket/path또는wandb.Artifact를 호출해 생성한 Artifact 객체를 전달할 수도 있습니다.
name: artifact 이름입니다. entity/프로젝트 접두사를 붙일 수 있습니다. 유효한 이름은 다음 형식일 수 있습니다:- name:version
- name:alias
- digest 지정하지 않으면 현재 run id가 앞에 붙은 경로의 basename이 기본값으로 사용됩니다.
type: 로깅할 artifact의 유형입니다. 예로는dataset,model이 있습니다aliases: 이 artifact에 적용할 alias입니다. 기본값은["latest"]입니다distributed_id: 모든 분산 작업이 공유하는 고유 문자열입니다. None이면 run의 group name이 기본값으로 사용됩니다.
Artifact 객체입니다.
방법 Run.link_artifact
artifact: collection에 연결할 artifact 객체입니다.target_path: collection의 경로입니다. 경로는 접두사 “wandb-registry-”와 레지스트리 이름, collection 이름으로 구성되며 형식은wandb-registry-{REGISTRY_NAME}/{COLLECTION_NAME}입니다.aliases: 연결된 artifact에 하나 이상의 alias를 추가합니다.latestalias는 가장 최근에 연결한 artifact에 자동으로 적용됩니다.
방법 Run.link_model
- ‘name’ 모델 artifact가 로깅되었는지 확인합니다. 이미 로깅되었다면 ‘path’에 있는 파일과 일치하는 artifact 버전을 사용하거나 새 버전을 로깅합니다. 그렇지 않으면 ‘path’ 아래의 파일을 유형이 ‘model’인 새 모델 artifact ‘name’으로 로깅합니다.
- ‘model-registry’ 프로젝트에 ‘registered_model_name’이라는 이름의 등록된 모델이 있는지 확인합니다. 없으면 ‘registered_model_name’이라는 이름의 새 등록된 모델을 만듭니다.
- 모델 artifact ‘name’의 버전을 등록된 모델 ‘registered_model_name’에 연결합니다.
- ‘aliases’ 목록의 alias를 새로 연결된 모델 artifact 버전에 추가합니다.
path: (str) 이 모델의 콘텐츠 경로입니다. 다음 형식 중 하나를 사용할 수 있습니다./local/directory/local/directory/file.txts3://bucket/path
registered_model_name: 모델을 연결할 등록된 모델의 이름입니다. 등록된 모델은 모델 레지스트리에 연결된 모델 버전의 collection이며, 일반적으로 팀의 특정 ML 작업을 나타냅니다. 이 등록된 모델이 속한 entity는 run에서 파생됩니다.name: ‘path’의 파일이 로깅될 모델 artifact의 이름입니다. 지정하지 않으면 경로의 basename 앞에 current run id를 붙인 값이 기본값으로 사용됩니다.aliases: 등록된 모델 내에서 이 연결된 artifact에만 적용되는 alias입니다. alias “latest”는 연결된 artifact의 최신 버전에 항상 적용됩니다.
AssertionError: registered_model_name이 경로이거나 모델 artifact ‘name’의 유형에 부분 문자열 ‘model’이 포함되어 있지 않은 경우.ValueError: name에 유효하지 않은 특수 문자가 포함된 경우.
None을 반환합니다.
방법 Run.log
log를 사용해 스칼라, 이미지, 비디오, 히스토그램, 플롯, 테이블 등 run의 데이터를 기록하세요. 코드 스니펫, 모범 사례 등은 객체 및 미디어 로깅에서 확인하세요.
기본 사용법:
wandb.Table을 사용할 수 있습니다. 자세한 내용은 테이블 로깅, 데이터 시각화 및 쿼리 튜토리얼을 참조하세요.
W&B는 이름에 슬래시(/)가 포함된 메트릭을, 마지막 슬래시 앞의 텍스트를 기준으로 이름이 지정된 섹션으로 구성합니다. 예를 들어, 다음은 “train”과 “validate”라는 두 개의 섹션을 생성합니다:
run.log({"a/b/c": 1})를 사용하면 “a”라는 이름의 섹션이 생성됩니다.
run.log()는 초당 몇 번 이상 호출하는 용도로 설계되지 않았습니다. 최적의 성능을 위해 N번의 반복마다 한 번만 로깅하거나, 여러 반복에 걸쳐 데이터를 모은 뒤 한 단계에서 로깅하세요.
기본적으로 log를 호출할 때마다 새로운 “step”이 생성됩니다. step은 항상 증가해야 하며, 이전 step에는 로깅할 수 없습니다. 차트의 X축에는 어떤 metric이든 사용할 수 있습니다. 자세한 내용은 맞춤형 log 축을 참조하세요.
많은 경우 W&B step은 트레이닝 step이라기보다 타임스탬프처럼 다루는 것이 더 적절합니다.
step 및 commit 매개변수를 사용하면 여러 번의 wandb.Run.log() 호출로 동일한 step에 log할 수 있습니다. 다음은 모두 동일합니다:
data:str키와 직렬화할 수 있는 값을 갖는dictPython objects including:int,float,string,wandb.data_types의 모든 유형, 직렬화할 수 있는 Python 객체의 목록, 튜플 및 NumPy 배열, 그리고 이 구조의 다른dict를 포함합니다.step: 로깅할 step 번호입니다.None이면 암묵적으로 자동 증가하는 step이 사용됩니다. 설명의 참고 사항을 참조하세요.commit: true이면 step을 완료하고 업로드합니다. false이면 step에 대한 데이터를 누적합니다. 설명의 참고 사항을 참조하세요.step이None이면 기본값은commit=True이고, 그렇지 않으면 기본값은commit=False입니다.
wandb.Error:wandb.init()전에 호출한 경우.ValueError: 유효하지 않은 데이터를 전달한 경우.
방법 Run.log_artifact
artifact_or_path: (str 또는 Artifact) 이 artifact의 콘텐츠 경로입니다. 다음 형식 중 하나일 수 있습니다:/local/directory/local/directory/file.txts3://bucket/pathwandb.Artifact를 호출하여 생성한 Artifact 객체를 전달할 수도 있습니다.
name: (str, 선택) artifact 이름입니다. 유효한 이름은 다음 형식 중 하나일 수 있습니다:- name:version
- name:alias
- digest 지정하지 않으면 현재 run ID가 앞에 붙은 경로의 basename이 기본값으로 사용됩니다.
type: (str) 로그할 artifact의 유형입니다. 예를 들어dataset,model이 있습니다.aliases: (목록, 선택) 이 artifact에 적용할 alias입니다. 기본값은["latest"]입니다.tags: (목록, 선택) 이 artifact에 적용할 태그입니다(있는 경우).
Artifact 객체.
방법 Run.log_code
.py로 끝나는 모든 파일을 로그합니다.
인수:
root: 코드를 재귀적으로 찾을 상대 경로(os.getcwd()기준) 또는 절대 경로입니다.name: (str, 선택) 코드 artifact의 이름입니다. 기본적으로 artifact 이름은source-$PROJECT_ID-$ENTRYPOINT_RELPATH로 지정됩니다. 여러 run이 동일한 artifact를 공유해야 하는 경우가 있을 수 있습니다.name을 지정하면 그렇게 할 수 있습니다.include_fn: 파일 경로와 (선택적으로) 루트 경로를 받아, 포함해야 하면 True를 반환하고 그렇지 않으면 False를 반환하는 callable입니다. 기본값은defaults tolambda path, root: path.endswith(".py").exclude_fn: 파일 경로와 (선택적으로) 루트 경로를 받아, 제외해야 하면True를 반환하고 그렇지 않으면False를 반환하는 callable입니다. 기본값은<root>/.wandb/및<root>/wandb/디렉터리 내의 모든 파일을 제외하는 함수입니다.
Artifact 객체
방법 Run.log_model
path 내의 내용을 포함하는 모델 artifact를 run에 로깅하고, 이를 이 run의 출력으로 표시합니다.
모델 artifact의 이름에는 영숫자, 언더스코어, 하이픈만 사용할 수 있습니다.
매개변수:
path: (str) 이 모델의 내용이 있는 경로로, 다음 형식 중 하나일 수 있습니다:/local/directory/local/directory/file.txts3://bucket/path
name: 파일 내용이 추가될 모델 artifact에 할당할 이름입니다. 지정하지 않으면 경로의 basename 앞에 현재 run ID를 붙인 값이 기본값으로 사용됩니다.aliases: 생성된 모델 artifact에 적용할 alias이며, 기본값은["latest"]입니다.
ValueError: name에 유효하지 않은 특수 문자가 포함된 경우
방법 Run.mark_preempting
방법 Run.pin_config_keys
keys: 고정할 설정 키 이름으로,run.config를 통해 설정된 키와 일치해야 합니다. 점과 슬래시는 경로 구분자가 아니라 문자 그대로 처리되는 정확한 키 문자열입니다. 순서는 유지되며, 표시 순서도 이에 따라 결정됩니다.
방법 Run.restore
name: 파일 이름입니다.run_path: 파일을 가져올 run의 경로(선택 사항)입니다. 예:username/project_name/run_idwandb.init가 호출되지 않은 경우에는 필수입니다.replace: 파일이 로컬에 이미 있더라도 다운로드할지 여부입니다.root: 파일을 다운로드할 디렉터리입니다. 기본값은 현재 디렉터리이며,wandb.init가 호출된 경우에는 run 디렉터리입니다.
CommError: W&B가 W&B 백엔드에 연결할 수 없는 경우입니다.ValueError: 파일을 찾을 수 없거나run_path를 찾을 수 없는 경우입니다.
방법 Run.save
policy와 관계없이 save가 호출되는 시점에 확장됩니다. 특히 새 파일은 자동으로 감지되지 않습니다.
업로드되는 파일의 디렉터리 구조를 제어하기 위해 base_path를 제공할 수 있습니다. 이는 glob_str의 접두사여야 하며, 그 아래의 디렉터리 구조는 유지됩니다.
절대 경로나 glob이 주어지고 base_path가 없으면 위 예시와 같이 디렉터리 한 단계가 유지됩니다.
파일은 자동으로 중복 제거됩니다. 같은 파일을 수정하지 않은 채 save()를 여러 번 호출해도 다시 업로드되지 않습니다.
인수:
glob_str: 상대 경로, 절대 경로 또는 Unix glob입니다.base_path: 디렉터리 구조를 추론하는 데 사용할 경로입니다. 예시를 참조하세요.policy:live,now,end중 하나입니다.- live: 파일이 변경될 때마다 업로드하며 이전 버전을 덮어씁니다
- now: 파일을 즉시 한 번 업로드합니다
- end: run이 종료될 때 파일을 업로드합니다
방법 Run.status
방법 Run.unwatch
models:watch가 호출된 PyTorch 모델의 선택 사항인 목록입니다.
방법 Run.upsert_artifact
run.finish_artifact()를 호출해야 합니다. 분산 작업이 모두 동일한 artifact에 기여해야 하는 경우에 유용합니다.
매개변수:
artifact_or_path: 이 artifact의 콘텐츠 경로입니다. 다음 형식을 사용할 수 있습니다:/local/directory/local/directory/file.txts3://bucket/path
name: artifact 이름입니다. “entity/프로젝트” 접두사를 붙일 수 있습니다. 지정하지 않으면 현재 run ID를 경로의 basename 앞에 붙인 값이 기본값으로 사용됩니다. 유효한 이름은 다음 형식일 수 있습니다:- name:version
- name:alias
- digest
type: 로깅할 artifact의 유형입니다. 일반적인 예로는dataset,model이 있습니다.aliases: 이 artifact에 적용할 alias이며, 기본값은["latest"]입니다.distributed_id: 모든 분산 작업이 공유하는 고유한 문자열입니다. None이면 run의 그룹 이름이 기본값으로 사용됩니다.
Artifact 객체
방법 Run.use_artifact
download 또는 file을 호출해 콘텐츠를 로컬로 가져옵니다.
인수:
artifact_or_name: 사용할 artifact의 이름입니다. artifact가 로깅된 프로젝트 이름(“entity” 또는 “entity/project”)을 앞에 붙일 수 있습니다. 이름에 entity가 지정되지 않으면 Run 또는 API 설정의 entity가 사용됩니다. 유효한 이름 형식은 다음과 같습니다.- name:version
- name:alias
type: 사용할 artifact의 유형입니다.aliases: 이 artifact에 적용할 alias입니다.use_as: 이 매개변수는 사용 중단되었으며 아무 작업도 하지 않습니다.
Artifact 객체입니다.
예시:
방법 Run.use_model
name에 로깅된 파일을 다운로드합니다.
매개변수:
name: 모델 artifact 이름입니다.name은 기존에 로깅된 모델 artifact의 이름과 일치해야 합니다.entity/project/접두사를 붙일 수 있습니다. 유효한 이름 형식은 다음과 같습니다.- model_artifact_name:version
- model_artifact_name:alias
path(str): 다운로드된 모델 artifact 파일의 경로입니다.
AssertionError: 모델 artifactname의 유형에'model'부분 문자열이 포함되지 않은 경우 발생합니다.
방법 Run.watch
models: 모니터링할 단일 모델 또는 모델 시퀀스입니다.criterion: 최적화 중인 loss 함수입니다(선택).log:"gradients","parameters", 또는"all"중 무엇을 로깅할지 지정합니다. 로깅을 비활성화하려면 None으로 설정합니다. (기본값="gradients").log_freq: 그라디언트와 매개변수를 로깅하는 빈도(배치 단위)입니다. (기본값=1000)idx:wandb.watch로 여러 모델을 추적할 때 사용하는 인덱스입니다. (기본값=None)log_graph: 모델의 계산 그래프를 로깅할지 여부입니다. (기본값=False)
wandb.init()이 호출되지 않았거나, 모델 중 하나라도 torch.nn.Module의 인스턴스가 아닌 경우입니다.