问题描述
- 我有一个cell类型的wlf变量,16行4列,每个单元格都是[1000,1]的矩阵,如下图所示
业务含义:代表16个医院的4个业务指标的1000次模拟值(蒙特卡洛模拟)
![](https://file.jishuzhan.net/article/1734530666407661570/e2067be160c8e47f74bd436c0f3c5643.webp)
- 我想要处理成[16,4,1000]的三维矩阵,如下图所示
业务含义:1000次模拟,每次模拟对应的16个医院的4个业务指标的模拟值
![](https://file.jishuzhan.net/article/1734530666407661570/de3c7f26239f17a664450f4e0e6a0391.webp)
实现步骤
- 先用
cell2mat
函数转成矩阵z1
但是所有的数据会堆叠起来,即16个医院,每个医院1000次堆叠了起来
![](https://file.jishuzhan.net/article/1734530666407661570/267d0f6d13d3256b36cf88cd6cd45f33.webp)
- 然后使用
reshape
函数转成三维数组
- reshape的原理是从上到下, 从左往右拆开重组
- 所以为了拆分,需要先把矩阵
z1
转置下变成z2
- 最后改变矩阵的维度,
从上到下,从左往右,数够1000列拆开
![](https://file.jishuzhan.net/article/1734530666407661570/b835c92178346c9f72f7ed0e3c1461dc.webp)
- 最后使用
permute
函数调整三维矩阵的维度顺序
![](https://file.jishuzhan.net/article/1734530666407661570/4a8dd815f5d64e746aa867e90db5c196.webp)
![](https://file.jishuzhan.net/article/1734530666407661570/b4e43b439dfd2364691ffd16b9da6805.webp)
- 代码
matlab
>> load('wlf.mat')
>> z1=cell2mat(wlf);
>> z2=z1';
>> z3=reshape(z2,[4,1000,16]);
>> res=permute(z3,[3,1,2]);