메인 콘텐츠로 건너뛰기
GitHub 소스 코드
W&B Report 및 Workspace API는 Public Preview 단계입니다.
프로그램에서 W&B Workspace API를 사용할 수 있게 해주는 Python 라이브러리입니다.
# 가져오는 방법
import wandb_workspaces.workspaces as ws

# 워크스페이스 생성 예시
ws.Workspace(
     name="Example W&B Workspace",
     entity="entity", # 워크스페이스를 소유하는 엔터티
     project="project", # 워크스페이스와 연결된 프로젝트
     sections=[
         ws.Section(
             name="Validation Metrics",
             panels=[
                 wr.LinePlot(x="Step", y=["val_loss"]),
                 wr.BarPlot(metrics=["val_accuracy"]),
                 wr.ScalarChart(metric="f1_score", groupby_aggfunc="mean"),
             ],
             is_open=True,
         ),
     ],
)
workspace.save()

class RunSettings

Runset 내 실행에 대한 설정(왼쪽 사이드바). 속성:
  • color (str): UI에서 실행을 나타내는 색상입니다. hex 코드(#ff0000), CSS 색상 이름(red), 또는 rgb 값(rgb(255, 0, 0))일 수 있습니다.
  • disabled (bool): 실행이 비활성화되었는지 여부(UI에서 눈 아이콘이 닫힌 상태). 기본값은 False입니다.

class RunsetSettings

워크스페이스에서 runset(실행이 표시되는 왼쪽 사이드바)에 대한 설정입니다. 속성:
  • query (str): runset을 필터링하기 위한 쿼리(정규식 표현식일 수 있음, 다음 매개변수를 참조).
  • regex_query (bool): 위의 쿼리를 정규식 표현식으로 해석할지 여부를 제어합니다. 기본값은 False입니다.
  • filters (Union[str, LList[expr.FilterExpr]]): runset에 적용할 필터 목록 또는 문자열 표현식입니다.
    • 리스트일 때: 필터는 AND 조건으로 결합됩니다. 필터 생성 방법은 FilterExpr를 참조하세요.
    • 문자열일 때: Python과 유사한 표현식을 사용합니다. 예: “Config(‘lr’) = 0.001 and State = ‘finished’”
  • Supports operators: =, ==, !=, <, >, <=, >=, in, not in
  • groupby (LList[expr.MetricType]): runset에서 그룹화할 지표 목록입니다. Metric, Summary, Config, Tags, KeysInfo 중 하나로 설정합니다.
  • order (LList[expr.Ordering]): runset에 적용할 지표와 정렬 순서 목록입니다.
  • run_settings (Dict[str, RunSettings]): 실행 설정 딕셔너리로, 키는 실행 ID이고 값은 RunSettings 객체입니다.
  • pinned_columns (LList[str]): 고정할 열 이름 목록입니다.
  • Column names use format: “run:displayName”, “summary:metric”, “config:param” 형식을 사용합니다.
  • run: displayName이 없으면 자동으로 추가됩니다.
  • Example: [“summary:accuracy”, “summary:loss”]
예시:
    # 문자열 필터 사용 (신규)
    RunsetSettings(
        filters="Config('learning_rate') = 0.001 and State = 'finished'",
        pinned_columns=["summary:accuracy", "summary:loss"],
    )

    # FilterExpr 목록 사용 (기존 방식)
    RunsetSettings(
        filters=[expr.Config("learning_rate") == 0.001],
        pinned_columns=["summary:accuracy", "summary:loss"],
    )

method convert_filterexpr_list_to_string

convert_filterexpr_list_to_string()
FilterExpr 리스트를 문자열 표현식(통합 내부 형식)으로 변환합니다.

method validate_and_setup_columns

validate_and_setup_columns()
run:displayName이 존재하는지 확인한 다음 내부 열 필드를 설정합니다.

class Section

워크스페이스의 섹션을 나타냅니다. 속성:
  • name (str): 섹션의 이름/제목입니다.
  • panels (LList[PanelTypes]): 섹션에 포함된 패널의 순서가 있는 목록입니다. 기본적으로 첫 번째는 좌측 상단, 마지막은 우측 하단입니다.
  • is_open (bool): 섹션이 열려 있는지 또는 닫혀 있는지 여부입니다. 기본값은 닫힘입니다.
  • pinned (bool): 섹션이 고정(pinned)되어 있는지 여부입니다. 고정된 섹션은 워크스페이스 상단에 표시됩니다. 기본값은 False입니다.
  • layout_settings (SectionLayoutSettings): 섹션 내 패널 레이아웃 설정입니다.
  • panel_settings: 섹션의 모든 패널에 적용되는 패널 단위 설정으로, Section에 대한 WorkspaceSettings와 유사합니다.

class SectionLayoutSettings

섹션의 패널 레이아웃 설정입니다. 일반적으로 W&B App Workspace UI의 섹션 오른쪽 상단에서 볼 수 있습니다. 속성:
  • columns (int): 레이아웃의 열 개수입니다. 기본값은 3입니다.
  • rows (int): 레이아웃의 행 개수입니다. 기본값은 2입니다.

class SectionPanelSettings

섹션에 대한 패널 설정으로, 섹션에 대한 WorkspaceSettings와 유사합니다. 여기에서 적용한 설정은 다음과 같은 우선순위에 따라 더 세분화된 패널 설정에 의해 재정의될 수 있습니다: Section < Panel. 속성:
  • x_axis (str): X축 메트릭 이름 설정입니다. 기본값은 “Step”입니다.
  • x_min Optional[float]: x축의 최소값입니다.
  • x_max Optional[float]: x축의 최대값입니다.
  • smoothing_type (Literal[‘exponentialTimeWeighted’, ‘exponential’, ‘gaussian’, ‘average’, ‘none’]): 모든 패널에 적용되는 스무딩 유형입니다.
  • smoothing_weight (int): 모든 패널에 적용되는 스무딩 가중치입니다.

class Workspace

실행 세트(run set)를 위한 섹션, 설정, 구성(config)을 포함하는 W&B 워크스페이스를 나타냅니다. Attributes:
  • entity (str): 이 워크스페이스가 저장될 엔터티(일반적으로 사용자 또는 팀 이름)입니다.
  • project (str): 이 워크스페이스가 저장될 프로젝트입니다.
  • name: 워크스페이스의 이름입니다.
  • sections (LList[Section]): 워크스페이스의 섹션이 순서대로 나열된 리스트입니다. 첫 번째 섹션은 워크스페이스 상단에 위치합니다.
  • settings (WorkspaceSettings): 워크스페이스에 대한 설정으로, 일반적으로 UI 상단에서 확인할 수 있습니다.
  • runset_settings (RunsetSettings): 워크스페이스에서 실행들을 포함하는 왼쪽 사이드바(runset)에 대한 설정입니다.
  • auto_generate_panels (bool): 이 프로젝트에서 로깅된 모든 키에 대해 패널을 자동으로 생성할지 여부입니다. 사용 가능한 모든 데이터를 기본값으로 시각화하고 싶다면 권장됩니다. 이 값은 워크스페이스를 생성할 때만 설정할 수 있으며, 이후에는 수정할 수 없습니다.

property auto_generate_panels


property url

W&B 앱의 워크스페이스 URL입니다.

classmethod from_url

from_url(url: str)
URL에서 워크스페이스를 가져옵니다.

메서드 save

save()
현재 워크스페이스를 W&B에 저장합니다. 반환:
  • Workspace: 내부 이름과 ID가 저장된 업데이트된 워크스페이스.

method save_as_new_view

save_as_new_view()
현재 워크스페이스를 새 뷰로 W&B에 저장합니다. 반환값:
  • Workspace: 저장된 내부 이름과 ID가 반영된 업데이트된 워크스페이스입니다.

class WorkspaceSettings

워크스페이스에 대한 설정으로, 일반적으로 UI에서 워크스페이스 상단에 표시됩니다. 이 객체에는 x축, smoothing, 이상치, 패널, 툴팁, 실행, 패널 쿼리 바에 대한 설정이 포함됩니다. 여기에서 적용한 설정은 더 세분화된 Section 및 Panel 설정에 의해 다음 우선순위로 재정의될 수 있습니다: Workspace < Section < Panel Attributes:
  • x_axis (str): X축에 사용할 메트릭 이름.
  • x_min (Optional[float]): X축 최소값.
  • x_max (Optional[float]): X축 최대값.
  • smoothing_type (Literal[‘exponentialTimeWeighted’, ‘exponential’, ‘gaussian’, ‘average’, ‘none’]): 모든 패널에 적용되는 smoothing 유형.
  • smoothing_weight (int): 모든 패널에 적용되는 smoothing 가중치.
  • ignore_outliers (bool): 모든 패널에서 이상치를 무시할지 여부.
  • sort_panels_alphabetically (bool): 모든 섹션의 패널을 알파벳순으로 정렬합니다.
  • group_by_prefix (Literal[“first”, “last”]): 패널을 첫 번째 또는 마지막 prefix 기준으로 그룹화합니다. 기본값은 last입니다.
  • remove_legends_from_panels (bool): 모든 패널에서 범례를 제거합니다.
  • tooltip_number_of_runs (Literal[“default”, “all”, “none”]): 툴팁에 표시할 실행 수.
  • tooltip_color_run_names (bool): 툴팁에서 실행 이름을 runset과 일치하도록 색상으로 표시할지(True) 여부입니다. 기본값은 True입니다.
  • max_runs (int): 패널당 표시할 최대 실행 수(해당 runset의 처음 10개 실행).
  • point_visualization_method (Literal[“line”, “point”, “line_point”]): 점 데이터에 대한 시각화 방법.
  • panel_search_query (str): 패널 검색 바에 사용할 쿼리(정규식일 수 있음).
  • auto_expand_panel_search_results (bool): 패널 검색 결과를 자동으로 확장할지 여부.