运用STATSMODELS库函数最小二回归t检验等

本文介绍了如何利用Python的STATSMODELS库进行最小二乘回归分析,并详细阐述了如何执行t检验以评估回归系数的显著性。通过对数据集的应用,展示了相关统计模型的构建步骤和结果解释。
摘要由CSDN通过智能技术生成
import xlrd
from scipy.optimize import leastsq
from scipy.stats import ttest_rel
import xlwt
from sklearn.metrics import r2_score
import numpy as np
import statsmodels.api as sm

def data_reader():
    path="C:/Users/Administrator/Desktop/mn/择时选股2.xlsx"
    work=xlrd.open_workbook(path)
    sheet1=work.sheet_by_name("Sheet1")
    sheet2=work.sheet_by_name("SMBHML")

    person_id=[]
    person_name=[]
    time=[]
    rpt=[]
    rft=[]
    rmt=[]
    time_s=[]
    rpt_s = []
    rft_s = []
    rmt_s = []


    id_1 = sheet1.cell_value(1, 0)
    person_id.append(id_1)
    person_name.append(sheet1.cell_value(1,1))
    #print(sheet1.cell_value(1,12)[0:6])
    time_s.append(sheet1.cell_value(1,12)[0:6])
    rpt_s.append(sheet1.cell_value(1,3))
    rft_s.append(sheet1.cell_value(1, 4))
    rmt_s.append(sheet1.cell_value(1, 5))

    for i in range(sheet1.nrows-2):
        if id_1==sheet1.cell_value(2+i,0):
            time_s.append(sheet1.cell_value(2+i, 12)[0:6])
            rpt_s.append(sheet1.cell_value(2+i, 3))
            rft_s.append(sheet1.cell_value(2+i, 4))
            rmt_s.append(sheet1.cell_value(2+i, 5))
        else:
            time.append(time_s)
            rpt.append(rpt_s)
            rft.append(rft_s)
            rmt.append(rmt_s)
            id_1=sheet1.cell_value(2+i,0)
            person_id.append(id_1)
            person_name.append(sheet1.cell_value(2+i,1))

            time_s=[]
            rpt_s = []
            rft_s = []
            rmt_s = []
            time_s.append(sheet1.cell_value(2+i, 12)[0:6])
            rpt_s.append(sheet1.cell_value(2+i, 3))
            rft_s.append(sheet1.cell_value(2+i, 4))
            rmt_s.append(sheet1.cell_value(2+i, 5))

    time.append(time_s)
    rpt.append(rpt_s)
    rft.append(rft_s)
    rmt.append(rmt_s)

    #print(len(time),len(rpt),len(person_name),len(person_id))
    #print(time[0],rpt[0],rft[0],rmt[0])

    time2=[]
    smb=[]
    hml=[]

    for i in range(sheet2.nrows-1):
        time2.append(str(int(sheet2.cell_value(i+1,0))))
        smb.append(sheet2.cell_value(i+1,1))
        hml.append(sheet2.cell_value(i+1,2))
    #print(time2,smb,hml)

    return time,rpt,rft,rmt,time2,smb,hml,person_id,person_name

time,rpt,rft,rmt,time2,smb,hml,person_id,person_name=data_reader()


def tm_model(rpt_s,rft_s,rmt_s):
    rpt_s=np.asfarray(rpt_s)
    rft_s=np.asfarray(rft_s)
    rmt_s=np.asfarray(rmt_s)
    sig=0

    nsmaple=len(rpt_s)
    model=np.column_stack((np.ones(nsmaple),(rmt_s-rft_s),(rmt_s-rft_s)**2))
    #beta=[0,0,0]
    y=rpt_s-rft_s+sig*np.random.normal(size=nsmaple)
    res=sm.OLS(y,model).fit()
    #print(res.summary())
    #print(res.params,res.rsquared,res.tvalues,res.pvalues)
    alpha,beta1,beta2=res.params
    r2=res.rsquared
    t1,t2,t3=res.tv
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值