중요한 통계 방법으로 카이제곱 검정은 범주형 변수 간의 관계를 테스트하는 데 널리 사용되는 방법 중 하나입니다. Python에서 SciPy 라이브러리는 카이제곱 테스트를 수행하기 위한 카이제곱 함수를 제공합니다. 이 글에서는 독자들이 카이제곱 검정을 더 잘 이해하고 적용할 수 있도록 카이제곱 검정의 원리, 사용법 및 구현 예를 소개합니다.
1. 카이제곱 검정의 원리
카이제곱 검정의 핵심 아이디어는 실제 관측값과 이론값의 차이를 비교하는 것입니다. 두 변수 사이에는 관계가 있습니다. 카이제곱 검정은 다양한 차원의 데이터를 다르게 분석합니다. 이 글에서는 주로 2차원 카이제곱 검정의 원리를 소개합니다.
2차원 테이블의 경우 카이제곱 검정은 먼저 두 변수 사이에 관계가 없다고 가정하고, 그 가정에 따라 기대값 E를 계산한 후, 실제 변수를 기준으로 카이제곱 값을 계산합니다. 관측값 O와 기대값 E를 구하고, 테이블을 조회하거나 계산하여 최종적으로 카이제곱 값을 계산한다. 가설이 참인지 확인하기 위해 유의성 검정을 실시한다.
구체적인 계산식은 다음과 같습니다.
Chi-square value χ²=(O-E)²/E
이 중 O는 실제 관측값이고 E는 기대값입니다.
카이제곱 값이 더 크면 두 변수 간의 관계가 더 유의미하고 가설이 기각되고, 카이제곱 값이 더 작으면 관계가 덜 유의미하여 가설이 채택됩니다.
2. 카이제곱 검정 사용
- 데이터 준비
카이제곱 검정을 수행하기 전에 데이터를 준비해야 합니다. 일반적으로 데이터는 실제 관측값 O와 기대값 E를 모두 포함하는 2차원 테이블 형태로 다음과 같이 존재합니다.
类别A 类别B
Variable 1 70 30
Variable 2 40 60
그 중 70은 변수 1과 범주 A의 교차점 수.
- 데이터를 기반으로 카이제곱 값 계산
Python의 SciPy 라이브러리를 사용하여 카이제곱 값과 해당 p-값을 쉽게 계산할 수 있습니다. 코드는 다음과 같습니다.
from scipy.stats import chisquare import numpy as np obs = np.array([[70, 30], [40, 60]]) #实际观测值 exp = np.array([[50, 50], [50, 50]]) #期望值 stat, pval = chisquare(obs.ravel(), f_exp=exp.ravel()) print(stat, pval)
그 중 chisquare 함수는 카이제곱 값과 해당 p 값을 계산하는 데 사용되며, obs와 exp는 각각 실제 관측값과 기대값을 나타내며, ravel() 함수는 2차원 배열을 1차원 배열로 변환하고 f_exp 매개변수는 예상 값을 지정합니다. None으로 설정된 경우 예상 값으로 obs.sum()/4를 사용합니다.
- 가설 검정
카이제곱 값과 p-값을 구한 후에는 가설이 참인지 판단해야 합니다. 일반적으로 유의 수준 α는 0.05로 설정됩니다. p 값이 α보다 작거나 같으면 귀무 가설이 기각되어 두 변수 사이에 관계가 있음을 나타내며 그렇지 않으면 귀무 가설이 채택됩니다. 아무 관계도 없습니다.
코드는 다음과 같습니다.
alpha = 0.05 if pval <= alpha: print("Reject null hypothesis, variables are related.") else: print("Accept null hypothesis, variables are independent.")
3. 구현 예
다음은 카이제곱 검정의 사용법을 보여주는 간단한 예입니다. 사용자의 로그인 시간이 웹사이트 탐색 시간에 영향을 미치는지 테스트하기 위해 전자상거래 웹사이트에서 A/B 테스트를 수행한다고 가정해 보겠습니다. 데이터는 다음과 같습니다.
浏览时长<10s 浏览时长>=10s
Login A 1000 2000
Login B 1500 2500
먼저 기대값 E를 계산해야 합니다. 에 따르면 데이터 계산으로 얻은 기대값은 다음과 같습니다.
浏览时长<10s 浏览时长>=10s
Login A 1200 1800
Login B 1300 1900
계산 및 가설 검정을 위해 Python 코드를 다음과 같이 사용합니다.
obs = np.array([[1000, 2000], [1500, 2500]]) #实际观测值 exp = np.array([[1200, 1800], [1300, 1900]]) #期望值 stat, pval = chisquare(obs.ravel(), f_exp=exp.ravel()) print(stat, pval) alpha = 0.05 if pval <= alpha: print("Reject null hypothesis, variables are related.") else: print("Accept null hypothesis, variables are independent.")
최종 결과는 귀무가설을 기각하여 사용자 로그인 방법이 탐색 시간에 영향을 미친다는 것입니다.
4. 요약
카이제곱 검정은 두 변수 사이에 관계가 있는지 확인할 수 있는 범주형 변수 간의 관계에 대해 일반적으로 사용되는 테스트 방법입니다. Python에서는 SciPy 라이브러리에서 제공하는 카이제곱 함수를 사용하여 카이제곱 테스트를 쉽게 수행할 수 있습니다. 이 글의 소개를 통해 독자들은 카이제곱 검정을 더 잘 이해하고 활용할 수 있으며, 데이터의 통계적 분석이 더욱 표준화되고 과학화될 수 있습니다.
위 내용은 Python에서 통계 분석을 위해 카이제곱 테스트를 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

Arraysinpython, 특히 비밀 복구를위한 ArecrucialInscientificcomputing.1) theaRearedFornumericalOperations, DataAnalysis 및 MachinELearning.2) Numpy'SimplementationIncensuressuressurations thanpythonlists.3) arraysenablequick

Pyenv, Venv 및 Anaconda를 사용하여 다양한 Python 버전을 관리 할 수 있습니다. 1) PYENV를 사용하여 여러 Python 버전을 관리합니다. Pyenv를 설치하고 글로벌 및 로컬 버전을 설정하십시오. 2) VENV를 사용하여 프로젝트 종속성을 분리하기 위해 가상 환경을 만듭니다. 3) Anaconda를 사용하여 데이터 과학 프로젝트에서 Python 버전을 관리하십시오. 4) 시스템 수준의 작업을 위해 시스템 파이썬을 유지하십시오. 이러한 도구와 전략을 통해 다양한 버전의 Python을 효과적으로 관리하여 프로젝트의 원활한 실행을 보장 할 수 있습니다.

Numpyarrayshaveseveraladvantagesstandardpythonarrays : 1) thearemuchfasterduetoc 기반 간증, 2) thearemorememory-refficient, 특히 withlargedatasets 및 3) wepferoptizedformationsformationstaticaloperations, 만들기, 만들기

어레이의 균질성이 성능에 미치는 영향은 이중입니다. 1) 균질성은 컴파일러가 메모리 액세스를 최적화하고 성능을 향상시킬 수 있습니다. 2) 그러나 유형 다양성을 제한하여 비 효율성으로 이어질 수 있습니다. 요컨대, 올바른 데이터 구조를 선택하는 것이 중요합니다.

tocraftexecutablepythonscripts, 다음과 같은 비스트 프랙티스를 따르십시오 : 1) 1) addashebangline (#!/usr/bin/envpython3) tomakethescriptexecutable.2) setpermissionswithchmod xyour_script.py.3) organtionewithlarstringanduseifname == "__"

numpyarraysarebetterfornumericaloperations 및 multi-dimensionaldata, mumemer-efficientArrays

numpyarraysarebetterforheavynumericalcomputing, whilearraymoduleisiMoresuily-sportainedprojectswithsimpledatatypes.1) numpyarraysofferversatively 및 formanceforgedatasets 및 complexoperations.2) Thearraymoduleisweighit 및 ep

ctypesallowscreatingandmanipulatingC-stylearraysinPython.1)UsectypestointerfacewithClibrariesforperformance.2)CreateC-stylearraysfornumericalcomputations.3)PassarraystoCfunctionsforefficientoperations.However,becautiousofmemorymanagement,performanceo


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기
