纵向数据是流行病学研究中最常见的资料类型之一,常见于队列研究、定群研究等研究设计中。这些研究设计中暴露因素或健康结局指标均具有随时间变化而变化的特点,为探索暴露因素与健康结局间的关系,往往需对研究对象进行随访或重复测量。针对同一研究对象的多次测量,研究结果间通常存在相关关系,若不满足独立性的条件,不适用一般线性模型或广义线性模型,且当观测值存在缺失时,重复测量方差分析也不适用。因此,广义估计方程(generalized estimating equations,GEE)和混合线性模型(mixed linear model,MLM)被广泛应用于纵向数据的统计分析。目前,主流的统计分析软件如SAS、SPSS和R等均能实现GEE和MLM的建模分析[1-3]。Python作为一款开源免费软件,因其强大的大数据处理第三方库(Pandas、Numpy、Scipy等)、内存优化系统和丰富的应用场景(爬虫等),可方便快速地实现数据的获取、清洗、管理和分析,显著缩短数据分析时间[4-5],近年来越来越受到国内科研工作者的欢迎。随着我国医疗系统信息化建设的快速推进,医疗大数据的智能化统计分析是必然的发展趋势[6]。运用Python软件实现流行病学研究中的统计分析,目前尚不多见。本研究以Python 3.8.5中的statsmodels库为例,通过研究实例介绍GEE和MLM在Python软件中的实现方法。同时,采用R 4.0.5软件中的geepack包和lmerTest包构建GEE与MLM模型[7],作为本次Python结果的对照,验证Python输出结果是否正确。
1 资料与方法
1.1 资料来源
为研究某地区大气颗粒物PM2.5对肺功能的影响,收集该地区连续十日的日均PM2.5浓度、温湿度和研究对象的肺功能数据。其中,PM2.5浓度、温湿度数据分别来自武汉市生态环境保护局(http://hbj.wuhan.gov.cn/)和湖北省气象局(http://hb.cma.gov.cn/),均采用Python爬虫收集。
采用方便抽样方法抽取研究对象,使用第1秒用力呼气容积(forced expiratory volume in one second,FEV1)作为肺功能评估指标,使用肺功能测试仪于每日7:30 AM由研究对象自测,测量10日后通过软件将数据读入计算机。以某位研究对象(20岁)为例,显示十天连续测量数据,详见表1。
-
表格1 连续10日颗粒物、气象及研究对象数据资料
Table1.Data of particulate matter, meteorology and research objects in over consecutive days
注:BMI:体质量指数;FEV1:第1秒用力呼气容积(forced expiratory volume in one second)
1.2 模型构建
本研究通过控制研究对象年龄、BMI和大气温湿度,评价PM2.5对研究对象肺功能的影响,以PM2.5单污染物滞后2天的暴露模型为例展示GEE与MLM在Python软件中的实现。
1.2.1 GEE模型构建
GEE模型是Liang 和 Zeger于1986年在拟似然的基础上对广义线性模型的推广,旨在分析纵向数据中因素对总体平均水平的影响[8-10]。本研究以FEV1为因变量,记为Yij,表示有i个研究对象(1,…,n),每个研究对象有j个观察值(1,…,p),协变量记为Xij。构建如下模型:
(1)为链接函数。
建立Yij与Xij间的函数关系,链接函数的选择主要有以下几种形式:①因变量服从正态分布,链接函数选择identify;②因变量服从二项分布,链接函数选择logit;③因变量服从泊松分布,链接函数选择log;④因变量服从负二项分布,链接函数选择negativebinomial。
(2)Var(Yij) = v(μij)·φ,建立Yij的方差与均值间的函数关系。
(3)Ri(α)是Yij的作业相关矩阵,表示因变量各次的重复测量值间的相关性大小,作业相关矩阵包括以下几种形式:①可交换,又称等相关,即任意两次不同时间的观测值间相关是相等的;②相邻相关,即只有相邻时间的两次测量值之间具有相关性;③自相关,即相关与间隔次数有关,相隔次数越长,相关关系越小;④不确定型相关,即相关矩阵非对角线上的元素均不等;⑤独立,即因变量之间不相关。
根据Liang和Zeger的定义,构建如下 GEE模型:
Vi是Yi的协方差矩阵,根据给定的α和φ的估计值,通过迭代重复加权,采用最小二乘法,求解上述方程,最后得出β的一致性估计。
1.2.2 MLM模型构建
MLM是一般线性模型(Y = Xβ + ε)的拓展[11-12],其保留了传统线性模型中的残差需满足正态性的假定,而对独立性与方差齐性不做要求[13],引入随机效应部分Zγ,可表达为:Y = Xβ + Zγ + ε,Y表示因变量测量值的向量,X为固定效应设计矩阵,β为固定效应参数向量,Z为随机效应设计矩阵,γ为随机效应参数向量,服从均值向量为0、方差/协方差矩阵为G的正态分布,表示为γ~N(0,G),随机效应主要有以下三种[14-15]:①随机回归系数带来的随机效应;②随机截距带来的随机效应;③随机回归系数和随机截距带来的随机效应。ε为随机误差向量,服从均值向量为0、方差/协方差矩阵为R的正态分布,即ε~N(0,R)。
1.3 模型验证
采用R 4.0.5软件的geepack包、lmerTest包分别构建GEE与MLM模型,作为参照,验证Python输出结果是否正确。
2 结果
2.1 GEE建模及参数估计结果
本研究因变量FEV1为定量连续数据,服从正态分布,故链接函数选择identify,根据以上定义,可构建如下GEE模型:
β0为截距,β1、β2、β3、β4、β5为各协变量的回归系数,CORR表示作业相关矩阵,ε表示残差项,相关代码见框1,GEE参数估计结果如表2所示。
-
框图1 广义估计方程代码呈现
Box1.GEE codes in Python and R
-
表格2 广义估计方程参数估计结果
Table2.Results of GEE parameter estimation
2.2 MLM建模及参数估计结果
根据MLM定义,可构建如下MLM模型:
FEV1 = β0 + β1 PM2.5 + β2 Age + β3 BMI +β4 Temperature + β5 Humidity + Ζγ + ε
β0为总截距,β1、β2、β3、β4、β5为各协变量的回归系数,ε为残差项,Zγ是随机效应,对应研究对象的个体差异带来的随机截距。相关代码见框2,MLM参数估计结果如表3所示。
-
框图2 混合线性模型代码呈现
Box2.MLM codes in Python and R
-
表格3 混合线性模型参数估计结果
Table3.Results of MLM parameter estimation
根据模型中自变量的检验结果可知,PM2.5是肺功能降低的危险因素,PM2.5每升高1μg/m3,研究对象2天后的FEV1减少8 mL(P<0.05)。GEE模型中,Python与R输出的检验统计量分别为z和χ2,同一自变量参数检验结果与P值基本一致;MLM模型中,Python与R输出的检验统计量分别为z和t,同一自变量参数检验结果与P值基本一致,表示Python输出结果基本可信。
3 讨论
本文结合流行病学中的研究实例,简要介绍了GEE和MLM在Python中的具体操作,拓展了纵向数据分析的实现方法。尽管纵向数据在Python与R软件中的实现代码有些许不同,但输出的参数和P值检验结果基本一致,反映Python输出结果可信。在不同的软件中,相同的方法模型输出的统计量有所差异,这是开发人员的统计检验倾向导致的。鉴于Z统计量值的平方等于Wald χ2统计量的值,因此Wald χ2检验是等价于Z检验的[16];在大样本(n>50)的情况下,t检验与Z检验结果也是近似的[17],所以软件输出参数统计量的不同不影响参数检验结果。
Python在数据分析方面存在诸多优点,其完善的作图功能以及丰富的数据分析库、机器学习库的发展,越来越符合大数据背景下的数据分析要求。例如,陈伟等使用Python相似度分析与标签云分析方法进行文本数据分析,拓展了大数据审计的研究方向[18];杨俊秀等采用Python的matplotlib库、numpy库和scikit-learn库完成了数据的可视化、整理与分析,显著提高了高频电子线路实验数据的处理分析效率[5]。但Python也存在着不足之处,其用作数据分析工具的时间较短,更多的数据分析方法程序有待进一步开发及完善。本研究使用的statsmodels库目前可实现简单线性模型、广义线性模型、GEE、MLM等大部分模型的建模。随着statsmodels库的进一步开发,相信未来statsmodels库可满足更多的建模需求。
综上,将Python用于环境流行病学,在实现数据获取、处理与分析的过程中,统一了语言环境,避免了数据在不同平台间的转换,提高了数据分析的效率。使用Python软件可灵活实现 GEE和MLM的统计建模,在实际研究中有一定参考价值。
1.周婷, 兰蓝, 邱建青, 等. GEE、GLMM和MLM分析卫生重复测量资料的效果比较[J]. 现代预防医学, 2017, 44(16): 2881-2885, 2899. [Zhou T, Lan L, Qiu JQ, et al. Effect comparison of GEE, GLMM, and MLM in analyzing repeated measures of health-related field[J].Modern Preventive Medicine, 2017, 44(16): 2881-2885, 2899.] DOI: CNKI:SUN:XDYF.0.2017-16-001.
2.陈樱, 黄碧芬, 郑建清, 等. 基于SAS软件的混合效应模型实现重复测量数据的Meta分析[J]. 中国循证医学杂志, 2019, 19(8): 998-1005. [Chen Y, Huang BF, Zheng JQ, et al. Meta-analysis of repeated measurement data based on mixed effects model of SAS software[J]. Chinese Journal of Evidence-Based Medicine, 2019, 19(8): 998-1005.] DOI: 10.7507/1672-2531.201902004.
3.特维斯克. 实用流行病学纵向数据分析方法(第2版)[M]. 北京: 人民卫生出版社, 2016. [Twisk. Applied longgitu-dinal data analysis for epidemiology (Version 2)[M]. Beijing: People's Medical Publishing House, 2016.]
4.平凯珂, 陈平雁. Python与R语言联合应用的实现[J]. 中国卫生统计, 2017, 34(2): 358-360. [Ping KK, Chen PY. Realization of joint application of Python and R language[J]. Chinese Journal of Health Statistics, 2017, 34(2): 358-360.] http://med.wanfangdata.com.cn/Paper/Detail?id=PeriodicalPaper_zgwstj201702054.
5.杨俊秀, 赵文来, 姚青, 等.高频电子线路实验数据的Python处理分析[J]. 实验技术与管理, 2021, 38(10): 227-231, 240. [Yang JX, Zhao WL, Yao Q, et al. Experimental data processing and analysis of high frequency electronic circuit by Python[J]. Experimental Technology and Management, 2021, 38(10): 227-231, 240.] DOI: 10.16791/j.cnki.sjg.2021.10.041.
6.周江杰, 王胜锋, 李立明. Python爬虫技术在信息流行病学中的应用[J]. 中华流行病学杂志, 2020, 41(6): 952-956. [Zhou JJ, Wang SF, Li LM. Application of Python web crawler technology in infodemiology[J]. Chinese Journal of Epidemiology, 2020, 41(6): 952-956.] DOI: 10.3760/cma.j.cn112338-20190901-00643.
7.朱雪宁. R语言: 从数据思维到数据实战[M]. 北京: 中国人民大学出版社, 2018. [Zhu XN. Playing with R: data thinking to practice[M]. Beijing: China Renmin University Press, 2018.]
8.朱玉, 王静, 何倩. 广义估计方程在SPSS统计软件中的实现[J]. 中国卫生统计, 2011, 28(2): 199-201. [Zhu Y, Wang J, He Q. Implementation of generalized estimating equation in SPSS statistical software[J]. Chinese Journal of Health Statistics, 2011, 28(2): 199-201.] DOI: 10.3969/j.issn.1002-3674.2011.02.031.
9.Zeger SL, Liang KY, Albert PS. Models for longitudinal data: a generalized estimating equation ap-proach[J]. Biometrics, 1988, 44(4): 1049-1060. DOI: 10.2307/2531734.
10.李洪艳, 谭珊, 高晓, 等. 基于广义估计方程的婴儿超重的影响因素分析[J]. 中国卫生统计, 2016, 33(2): 222-225, 230. [Li HY, Tan S, Gao X, et al. A study about the influence factors of infant overweight based on generalized estimating equation[J]. Chinese Journal of Health Statistics, 2016, 33(2): 222-225, 230.] DOI: CNKI:SUN:ZGWT.0.2016-02-011.
11.陈博文, 赵培信, 唐新蓉, 等. 线性混合效应模型的有效稳健经验似然推断[J]. 应用数学, 2020, 33(4): 886-893. [Chen BW, Zhao PX, Tang XR, et al. Efficient and robust empirical likelihood inference for linear mixed effects models[J]. Mathematica Applicata, 2020, 33(4): 886-893.]DOI: 10.13642/j.cnki.42-1184/o1.2020.04.008.
12.高莹, 沈玉, 周慧婵, 等. 个体PM2.5暴露与老年人肺功能关系[J]. 环境卫生学杂志, 2019, 9(5): 482-488. [Gao Y, Shen Y, Zhou HC, et al. Relationship between individual PM2.5 exposure and lung function in the el-derly[J]. Journal of Environmental Hygiene, 2019, 9(5): 482-488.] DOI: 10.13421/j.cnki.hjwsxzz.2019.05.014.
13.杨珉, 李晓松. 医学和公共卫生研究常用多水平统计模型[M]. 北京: 北京大学医学出版社, 2007. [Yang M, Li XS. Multilevel statistical models commonly used in medical and public health research[M]. Beijing: Peking University Medical Press, 2007.]
14.庄东辰,茆诗松. 混合系数线性模型的参数估计[J]. 应用概率统计, 1996, (1): 81-87. [Zhuang DC, Mao SS. Pa-rameter estimation of mixed coefficient linear model[J]. Chinese Journal of Applied Probability and Statistics, 1996, (1): 81-87.] DOI: CNKI:SUN:YYGN.0.1996-01-011.
15.余松林. 混合线性模型的应用[J]. 中国医院统计, 2006, 13(1): 70-75. [Yu SL. Application of mixed linear mod-el[J].Chinese Journal of Hospital Statistics, 2006, 13(1): 70-75.]DOI: 10.3969/j.issn.1006-5253.2006.01.030.
16.Wallis, Sean. z-squared: the origin and application of χ2[J]. Journal of Quantitative Linguistics, 2013, 20(4): 350-378. DOI: 10.1080/09296174.2013.830554.
17.智冬晓, 许晓娟, 张皓博. z检验与t检验方法的比较[J]. 统计与决策, 2014, (20): 31-34. [Zhi DX, Xu XJ, Zhang HB. Comparison of Z-test and t-test[J]. Statistics and Decision, 2014, (20): 31-34.] DOI: 10.13546/j.cnki.tjyjc.2014.20.007.
18.陈伟,勾东升,徐发亮.基于文本数据分析的大数据审计方法研究[J].中国注册会计师, 2018, (11): 80-84. [Chen W, Gou DS, Xu FL. Research on big data audit method on basis of text data analysis[J]. The Chinese Certified Public Accountant, 2018, (11): 80-84.] DOI: 10.16292/j.cnki.issn1009-6345.2018.11.016.