在MATLAB中进行为期3天的滚动相关性计算

如何解决在MATLAB中进行为期3天的滚动相关性计算

| 我需要计算3天的相关性。下面给出了一个样本矩阵。我的问题是ID可能并非每天都存在于Universe中。例如,AAPL可能始终在Universe中,但是公司-ccl可能仅在我的Universe中存在2天。我将感谢矢量解决方案。由于相关矩阵的大小可能会有所不同,因此我可能必须在这里使用structs /
accumarray
等。
% col1 = TradingDates,col2 = companyID_asInts,col3 = VALUE_forCorrelation

rawdata = [ ...

    734614 1 0.5; 
    734614 2 0.4; 
    734614 3 0.1; 

    734615 1 0.6; 
    734615 2 0.4; 
    734615 3 0.2; 
    734615 4 0.5; 
    734615 5 0.12;

    734618 1 0.11; 
    734618 2 0.9; 
    734618 3 0.2; 
    734618 4 0.1; 
    734618 5 0.33;
    734618 6 0.55; 

    734619 2 0.11; 
    734619 3 0.45; 
    734619 4 0.1; 
    734619 5 0.6; 
    734619 6 0.5;

    734620 5 0.1; 
    734620 6 0.3] ; 
\\三天关联\':
% 734614 & 734615 corr is ignored as this is a 3-day corr

% 734618_corr = corrcoef(IDs 1,2,3 values are used. ID 4,5,6 is ignored) -> 3X3 matrix

% 734619_corr = corrcoef(IDs 2,3,4,5 values are used. ID 1,6 is ignored) -> 3X4 matrix

% 734620_corr = corrcoef(IDs 5,6 values are used. ID 1,4 is ignored) -> 3X2 matrix
实际数据涵盖了1995-2011年间的Russel1000宇宙,并拥有超过410万行。所需的相关性为20天。     

解决方法

        我不会在这里尝试获得向量化的解决方案:MATLAB JIT编译器意味着循环在最新版本的MATLAB上通常可以同样快。 您的矩阵看起来很像一个稀疏矩阵:将其转换为该形式是否有帮助,以便您可以使用数组索引?仅当第三列中的数据永远不能为0时,这才可能起作用,否则,您将必须保留当前的显式列表并使用如下所示的内容:
dates = unique(rawdata(:,1));
num_comps = max(rawdata(:,2));

for d = 1:length(dates) - 2;
    days = dates(d:d + 2);

    companies = true(1,num_comps);
    for curr_day = days\'
        c = false(1,num_comps);
        c(rawdata(rawdata(:,1) == curr_day,2)) = true;
        companies = companies & c;
    end
    companies = find(companies);

    data = zeros(3,length(companies));
    for curr_day = 1:3
        for company = 1:length(companies)
            data(curr_day,company) = ...
                rawdata(rawdata(:,1) == days(curr_day) & ...
                        rawdata(:,2) == companies(company),3);
        end
    end

    corrcoef(data)
end
    

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?