#MEPS DATA Hexpend<-read.csv("HealthExpend.csv") #导入数据 # CHECK THE NAMES,DIMENSION IN THE FILE AND LIST THE FRIST names(Hexpend) dim(Hexpend) Hexpend[1:8,] attach(Hexpend) n<-dim(Hexpend)[1] POSEXP<-seq(0,0,length=n) for(i in 1:n){ if(EXPENDIP[i]!=0)POSEXP[i]=1} # ALTERNATIVE - FIT A GENERALIZED LINEAR MODEL; PosExpglm = glm(POSEXP~GENDER,family=binomial(link=logit)) summary(PosExpglm) logLik(PosExpglm) summary(POSEXP) # FULL LOGIT MODEL PosExpglmFull=glm(POSEXP~AGE+GENDER +factor(RACE)+factor(REGION)+factor(EDUC)+factor(PHSTAT)+factor(ANYLIMIT)+factor(INCOME)+factor(insure), family=binomial(link=logit)) summary(PosExpglmFull) logLik(PosExpglmFull) Gender<-as.factor(GENDER) PosExpglmFull=glm(POSEXP~AGE+C(Gender,base=1) +as.factor(RACE)+as.factor(REGION)+as.factor(EDUC)+as.factor(PHSTAT)+as.factor(ANYLIMIT)+as.factor(INCOME)+as.factor(insure), family=binomial(link=logit)) summary(PosExpglmFull)
时间: 2023-07-30 15:09:35 浏览: 203
这段代码是在 R 语言中导入名为 HealthExpend.csv 的数据集,并进行一些数据清洗和统计分析。具体来说,这段代码首先使用 read.csv() 函数导入数据,然后使用 names() 和 dim() 函数查看数据集的变量名和维度,再使用 attach() 函数将数据集附加到工作环境中,方便后续的操作。
接下来,代码使用一个 for 循环,将数据集中 EXPENDIP 变量不为0的观测值对应的 POSEXP 变量赋值为1,其余观测值为0。这样处理后,POSEXP 变量就成为了一个二元变量,表示是否有医疗支出。这个操作是为了方便后续建立的二元 logistic 回归模型。
代码接着使用 glm() 函数建立了一个二元 logistic 回归模型,用于探究性别对医疗支出的影响。这个模型的因变量是 POSEXP,自变量是 GENDER。模型假设因变量服从二项分布,使用对数几率函数(logit)作为连结函数。summary() 函数用于输出模型的结果,包括每个自变量的系数估计、标准误、z 值、p 值等。logLik() 函数用于计算模型的对数似然值。
接下来,代码使用 glm() 函数建立了一个包含多个自变量的二元 logistic 回归模型,用于探究各个因素对医疗支出的影响。这个模型的因变量仍然是 POSEXP,自变量包括 AGE、GENDER、RACE、REGION、EDUC、PHSTAT、ANYLIMIT、INCOME 和 insure。其中,GENDER、RACE、REGION、EDUC、PHSTAT、ANYLIMIT、INCOME 和 insure 都被转换成了因子变量,方便进行回归分析。这个模型同样假设因变量服从二项分布,使用对数几率函数作为连结函数。summary() 函数和 logLik() 函数同样用于输出模型的结果。
阅读全文