Java開發者的Python快速進修指南:掌握T檢驗

来源:https://www.cnblogs.com/guoxiaoyu/p/18049281
-Advertisement-
Play Games

獨立樣本T檢驗適用於比較兩組獨立樣本的均值差異,而配對T檢驗則適用於比較同一組樣本在不同條件下的均值差異。在Python中,我們可以利用scipy庫進行T檢驗的實現和結果判斷。通過比較P值與顯著性水平,我們可以判斷兩組樣本均值是否存在顯著差異。T值的大小也對判斷兩組樣本均值差異的統計學意義起著重要作... ...


前言

T檢驗是一種用於比較兩個獨立樣本均值差異的統計方法。它通過計算T值和P值來判斷樣本之間是否存在顯著性差異。通常情況下,我們會有兩組數據,例如一組實驗組和一組對照組。

T檢驗的原假設是兩組樣本的均值相等,備假設是兩組樣本的均值不相等。T檢驗會計算一個T值,表示兩組樣本均值之間的差異。同時,還會計算一個P值,用來判斷這個差異是否顯著。

如果P值小於顯著性水平(通常設定為0.05),我們就可以拒絕原假設,認為兩組樣本的均值存在顯著差異。反之,如果P值大於顯著性水平,我們接受原假設,認為兩組樣本的均值沒有顯著差異。

T檢驗有不同的類型,最常見的是獨立樣本T檢驗和配對T檢驗。獨立樣本T檢驗用於比較兩組獨立樣本的均值差異,而配對T檢驗用於比較同一組樣本在不同條件下的均值差異。

我們將繼續採用Python編程語言進行實現,這次我們會利用到scipy庫。scipy庫是一個基於Python的開源科學計算庫,它構建在NumPy庫的基礎之上,擴展了更多數學函數和演算法,涵蓋了優化、插值、統計、信號處理、圖像處理、常微分方程求解等廣泛的功能。

接下來,讓我們對這兩種場景進行簡要討論,以便更好地理解它們的特點和應用條件。

獨立樣本

我們先來看下獨立雙樣本,舉個例子:假設我們有兩組學生,一組接受了數學輔導班,另一組沒有接受輔導。我們想要比較兩組學生在數學考試成績上是否有顯著差異。

案例背景:

  • 組1(輔導班): 10名學生,他們的數學考試成績為 [85, 88, 90, 92, 95, 78, 80, 84, 88, 86]。
  • 組2(非輔導班): 10名學生,他們的數學考試成績為 [75, 78, 80, 82, 85, 68, 70, 74, 78, 76]。

我們將實現一個簡單獨立樣本T檢驗來比較這兩組學生的平均數學考試成績是否有顯著差異。

Python代碼實現:

import scipy.stats as stats

# 組1(輔導班)的數學考試成績
group1_scores = [85, 88, 90, 92, 95, 78, 80, 84, 88, 86]

# 組2(非輔導班)的數學考試成績
group2_scores = [75, 78, 80, 82, 85, 68, 70, 74, 78, 76]

# 執行獨立樣本T檢驗
t_statistic, p_value = stats.ttest_ind(group1_scores, group2_scores)

# 輸出T值和P值
print("T值:", t_statistic)
print("P值:", p_value)

# 判斷顯著性水平
alpha = 0.05
if p_value < alpha:
    print("在顯著性水平為0.05下,拒絕原假設,即兩組學生的數學考試成績存在顯著差異。")
else:
    print("在顯著性水平為0.05下,接受原假設,即兩組學生的數學考試成績沒有顯著差異。")

這裡將計算組1(接受輔導班)和組2(未接受輔導班)學生的數學考試成績的獨立樣本T檢驗,輸出T值和P值,並根據顯著性水平0.05判斷是否拒絕原假設。

運行結果:在顯著性水平為0.05下,拒絕原假設,即兩組學生的數學考試成績存在顯著差異

看來補習輔導班還是有道理的,孩子苦啊~~

配對T檢驗

接下來,讓我們繼續探討配對T檢驗的情況。在這種情況下,我們需要關註的是樣本數據並沒有發生變化,即我們在比較的是同一個樣本在不同條件下的表現。假設我們有一組學生在學習前和學習後的數學成績數據,我們想要確定他們的成績在學習前後是否有顯著差異。這時可以使用配對T檢驗進行分析。

在這個案例中,首先,我們需要創建示例數據,接下來,我們將使用stats.ttest_rel函數執行配對T檢驗,並輸出結果:

import numpy as np
from scipy import stats

# 創建示例數據,學習前和學習後的成績
before_scores = np.array([70, 75, 80, 65, 72])
after_scores = np.array([75, 80, 85, 70, 78])

# 執行配對T檢驗
t_statistic, p_value = stats.ttest_rel(before_scores, after_scores)

# 輸出T統計量和P值
print("T統計量:", t_statistic)
print("P值:", p_value)

# 判斷顯著性水平
if p_value < 0.05:
    print("學習前後成績存在顯著差異")
else:
    print("學習前後成績沒有顯著差異")

運行以上代碼,我們可以得到配對T檢驗的結果,包括T統計量和P值。根據P值與顯著性水平的比較,我們可以判斷學習前後成績是否存在顯著差異。

運行結果:學習前後成績存在顯著差異

經過一番討論,我們一直在對P值進行驗證,那麼這與T檢驗有什麼關聯呢?讓我們探究一下它們之間的聯繫。

我們通過計算T值來判斷兩組樣本均值是否有顯著差異。如果計算得到的T值較大,意味著兩組樣本的均值差異較大,反之則差異較小。一般來說,T值大於1.96或小於-1.96時,即絕對值大於1.96時,我們可以認為兩組樣本均值之間存在顯著差異,P值也會小於0.05。因此,T值的大小也會幫助我們判斷兩組樣本均值之間的差異是否具有統計學意義。

總結

獨立樣本T檢驗適用於比較兩組獨立樣本的均值差異,而配對T檢驗則適用於比較同一組樣本在不同條件下的均值差異。在Python中,我們可以利用scipy庫進行T檢驗的實現和結果判斷。通過比較P值與顯著性水平,我們可以判斷兩組樣本均值是否存在顯著差異。T值的大小也對判斷兩組樣本均值差異的統計學意義起著重要作用。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Linux入門(五) 本篇文章主要講述下文件處理相關的命令 1: 顯示許可權 ls -lh 總用量 36K drwxrwxr-x 5 zh zh 4.0K 2月 28 16:47 app -rw-rw-r-- 1 zh zh 530 2月 22 18:25 build.gradle drwxrwxr- ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 開始之前 Composition API 可以說是Vue3的最大特點,那麼為什麼要推出Composition Api,解決了什麼問題? 通常使用Vue2開發的項目,普遍會存在以下問題: 代碼的可讀性隨著組件變大而變差 每一種代碼復用的方式 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 一、Object.defineProperty 定義:Object.defineProperty() 方法會直接在一個對象上定義一個新屬性,或者修改一個對象的現有屬性,並返回此對象 為什麼能實現響應式 通過defineProperty 兩 ...
  • SpringBoot底層預設使用logback日誌框架。 切換使用Log4j2日誌框架。 pom.xml配置 <!-- web場景啟動器 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-b ...
  • 在微服務架構或者分散式系統中,客戶端如何捕捉服務端的異常?這裡說的客戶端指調用方、服務端指被調用方,它們通常運行在不同的進程之中,這些進程可能運行在同一臺伺服器,也可能運行在不同的伺服器,甚至不同的數據機房;其使用的技術棧可能相同,也可能存在很大的差異。 ...
  • 什麼是訂單履約系統? 訂單履約系統用來管理從接收客戶訂單到將商品送達客戶手中的全過程。 它連接了上游交易(客戶在銷售平臺下單環)和下游倉儲配送(如庫存管理、物流配送),確保信息流順暢、操作協同,提升整個供應鏈的效率和響應速度。 系統定位 訂單履約系統的目標是讓訂單處理更快、更清晰,提高客戶體驗。 履 ...
  • Spring Boot允許外部化項目配置,以便您可以在不同的環境中使用相同的應用程式代碼。您可以使用各種外部配置源,包括Java屬性文件、YAML文件、環境變數和命令行參數。 屬性值可以通過使用@Value註釋直接註入到bean中,通過Spring的環境抽象進行訪問,或者通過@Configurati ...
  • druid-spring-boot-3-starter目前最新版本是1.2.20,雖然適配了SpringBoot3,但缺少自動裝配的配置文件,會導致載入時報載入驅動異常。 <dependency> <groupId>com.alibaba</groupId> <artifactId>druid-sp ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...