请选择 进入手机版 | 继续访问电脑版
爱气象,爱气象家园! 

气象家园

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博登陆

只需一步, 快速开始

搜索
查看: 270|回复: 2

[混合编程] Python处理梁氏克里曼因果关系

[复制链接]

新浪微博达人勋

发表于 2024-9-4 10:43:34 | 显示全部楼层 |阅读模式

登录后查看更多精彩内容~

您需要 登录 才可以下载或查看,没有帐号?立即注册 新浪微博登陆

x
请问在用Python的puleoclim库计算梁氏克里曼因果关系的时候怎么看输出结果的显著检验?输出结果如大图

在输入参数时如果输入qs值,则输出结果不再是图中6个数的数组,会输出前面输入的qs值。
如小图,输入qs=0.005时

大图

大图

小图

小图
密码修改失败请联系微信:mofangbao

新浪微博达人勋

发表于 2024-9-5 23:22:30 | 显示全部楼层
你不放出代码,不知道你算了什么
密码修改失败请联系微信:mofangbao
回复 支持 反对

使用道具 举报

新浪微博达人勋

 楼主| 发表于 2024-9-6 14:33:41 | 显示全部楼层
千与千叶 发表于 2024-9-5 23:22
你不放出代码,不知道你算了什么

第一次运行不设置qs参数
import pyleoclim as pyleo
import pandas as pd
import numpy as np

sici= np.array(pd.read_excel(r"D:\20240904\sici.xlsx",header=None)).mean(1)
pc2= np.array(pd.read_excel(r"D:/20240904/pc2.xlsx",header=None)).mean(1)

a=pyleo.utils.causality.liang_causality(pc2,sici,npt=1,signif_test='isospec',nsim=1000)
print(a)

得到了
{'T21': 0.054141223276783626, 'tau21': 0.031616391240725655, 'Z': 1.7124415896980463, 'dH1_star': -0.6780833946335855, 'dH1_noise': 0.29030021412568885, 'signif_qs': [0.005, 0.025, 0.05, 0.95, 0.975, 0.995], 'T21_noise': array([-0.07295671, -0.04228982, -0.03173436,  0.05648664,  0.07023634,
        0.11941366]), 'tau21_noise': array([-0.04899939, -0.02855708, -0.02101496,  0.03532788,  0.04403452,
        0.07219273])}

第二次运行,设置了qs为0.05,得到了
{'T21': 0.054141223276783626, 'tau21': 0.031616391240725655, 'Z': 1.7124415896980463, 'dH1_star': -0.6780833946335855, 'dH1_noise': 0.29030021412568885, 'signif_qs': [0.05], 'T21_noise': array([-0.02822197]), 'tau21_noise': array([-0.01913916])}

主要输出区别在于得到的'T21_noise'结果数量的变化,这条帖子主要是想请教怎么根据输出结果判断两时间序列是否存在显著因果关系

感谢回复!!!!
密码修改失败请联系微信:mofangbao
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册 新浪微博登陆

本版积分规则

Copyright ©2011-2014 bbs.06climate.com All Rights Reserved.  Powered by Discuz! (京ICP-10201084)

本站信息均由会员发表,不代表气象家园立场,禁止在本站发表与国家法律相抵触言论

快速回复 返回顶部 返回列表