Plotly-밀도 플롯 및 오차 막대 플롯 표시
이 장에서는 distplot, 밀도 플롯 및 오차 막대 플롯에 대해 자세히 이해합니다. distplot에 대해 배우는 것으로 시작하겠습니다.
Distplots
distplot 그림 팩토리는 히스토그램, 커널 밀도 추정 또는 정규 곡선 및 러그 플롯과 같은 숫자 데이터의 통계적 표현 조합을 표시합니다.
distplot은 다음 세 가지 구성 요소의 전체 또는 임의의 조합으로 구성 될 수 있습니다.
- histogram
- 곡선 : (a) 커널 밀도 추정 또는 (b) 정규 곡선
- 러그 플롯
그만큼 figure_factory 모듈은 create_distplot() hist_data라는 필수 매개 변수가 필요한 함수입니다.
다음 코드는 히스토그램, kde 플롯 및 러그 플롯으로 구성된 기본 distplot을 생성합니다.
x = np.random.randn(1000)
hist_data = [x]
group_labels = ['distplot']
fig = ff.create_distplot(hist_data, group_labels)
iplot(fig)
위에서 언급 한 코드의 출력은 다음과 같습니다.
밀도 플롯
밀도 플롯은 데이터에서 추정 된 히스토그램의 평활화 된 연속 버전입니다. 가장 일반적인 추정 형태는 다음과 같습니다.kernel density estimation (KDE). 이 방법에서는 모든 개별 데이터 포인트에 연속 곡선 (커널)이 그려지고 이러한 모든 곡선이 함께 추가되어 단일 부드러운 밀도 추정이 이루어집니다.
그만큼 create_2d_density() 모듈의 기능 plotly.figure_factory._2d_density 2D 밀도 플롯에 대한 Figure 객체를 반환합니다.
다음 코드는 히스토그램 데이터에 대한 2D 밀도 플롯을 생성하는 데 사용됩니다.
t = np.linspace(-1, 1.2, 2000)
x = (t**3) + (0.3 * np.random.randn(2000))
y = (t**6) + (0.3 * np.random.randn(2000))
fig = ff.create_2d_density( x, y)
iplot(fig)
아래는 위에 주어진 코드의 출력입니다.
오차 막대 플롯
오차 막대는 데이터의 오차 또는 불확실성을 그래픽으로 표현한 것으로 올바른 해석을 지원합니다. 과학적 목적으로 오류보고는 주어진 데이터를 이해하는 데 중요합니다.
오차 막대는 측정 값 또는 계산 된 값 집합의 신뢰도 또는 정밀도를 보여주기 때문에 문제 해결 자에게 유용합니다.
대부분의 오차 막대는 데이터 세트의 범위와 표준 편차를 나타냅니다. 데이터가 평균값 주위에 어떻게 분산되어 있는지 시각화하는 데 도움이 될 수 있습니다. 막대 그래프, 선 그래프, 산점도 등과 같은 다양한 플롯에서 오차 막대를 생성 할 수 있습니다.
그만큼 go.Scatter() 기능은 error_x 과 error_y 오차 막대가 생성되는 방식을 제어하는 속성.
visible (boolean) −이 오차 막대 세트를 표시할지 여부를 결정합니다.
유형 속성에 가능한 값이 있습니다. "percent"|"constant"|"sqrt"|"data”. 오차 막대를 생성하는 데 사용되는 규칙을 설정합니다. "백분율"인 경우 막대 길이는 기본 데이터의 백분율에 해당합니다. 이 비율을 '값'으로 설정합니다. "sqrt"인 경우 막대 길이는 기본 데이터의 제곱에 해당합니다. "data"인 경우 막대 길이는 데이터 세트 'array'로 설정됩니다.
symmetric속성은 true 또는 false 일 수 있습니다. 따라서 오차 막대의 길이는 양방향으로 동일하거나 그렇지 않습니다 (수직 막대의 경우 위 / 아래, 수평 막대의 경우 왼쪽 / 오른쪽).
array− 각 오차 막대의 길이에 해당하는 데이터를 설정합니다. 값은 기본 데이터를 기준으로 표시됩니다.
arrayminus − 수직 (수평) 막대의 경우 하단 (왼쪽) 방향의 각 오차 막대의 길이에 해당하는 데이터를 설정합니다. 값은 기본 데이터를 기준으로 플롯됩니다.
다음 코드는 산점도에 대칭 오차 막대를 표시합니다-
trace = go.Scatter(
x = [0, 1, 2], y = [6, 10, 2],
error_y = dict(
type = 'data', # value of error bar given in data coordinates
array = [1, 2, 3], visible = True)
)
data = [trace]
layout = go.Layout(title = 'Symmetric Error Bar')
fig = go.Figure(data = data, layout = layout)
iplot(fig)
아래는 위에서 언급 한 코드의 출력입니다.
비대칭 오류 플롯은 다음 스크립트에 의해 렌더링됩니다-
trace = go.Scatter(
x = [1, 2, 3, 4],
y =[ 2, 1, 3, 4],
error_y = dict(
type = 'data',
symmetric = False,
array = [0.1, 0.2, 0.1, 0.1],
arrayminus = [0.2, 0.4, 1, 0.2]
)
)
data = [trace]
layout = go.Layout(title = 'Asymmetric Error Bar')
fig = go.Figure(data = data, layout = layout)
iplot(fig)
동일한 출력은 다음과 같습니다.