24小时热门版块排行榜    

查看: 4591  |  回复: 3
【奖励】 本帖被评价2次,作者cttsyauchina增加金币 1.2

cttsyauchina

木虫 (小有名气)


[资源] 用matlab来实现分类汇总

用matlab来实现分类汇总最近遇到一个项目,需要处理大量的气象数据,并进行空间分析,而在空间插值处理之前又必须对数据进行剔除、插值、分类汇总等预处理。由于项目中用到大量的寻优算法和微分方程求解的问题,所以我最终选择了Matlab作为编程语言。但是matlab不像c# vb.net等语言,缺乏了一些动态数组、泛型等数据结构,处理分类汇总等问题比较棘手。自己也编制了些小函数,不过总感觉速度不行。所以再次认真地看了看Matlab帮助文档,并结合GOOGlE和BING资料,重新编制了一个分类汇总小程序。为了方便自己查阅并给大家一些参考,特将代码贴到空间中如下:



%%% Subtotal sub
%% load data
if ~exist('mcell','var')==1
    load 'E:\MatLab\CTT\FileIn\mat\mcelldaily.mat'; %get a cell array "mcell".
end


%% create a cell used to save subtotal result
result=cell(size(mcell));
result(:,1:2)=mcell(:,1:2);


%% subtotal process
for i=1:size(mcell,1)
    temp=mcell{i,3};
    cols=[1 2];% the first two colomns used to subtotal
    [b, ~, n]= unique(temp(:,cols),'rows');
    %% Define sdata structure used to save current station data.
    rowNum=size(b,1);
    colNum=size(cols,2)+1;
    sdata=cell(rowNum,colNum);
   
    %% find out the data colomns left excluding the columns of cols
     totalcol=size(temp,2);  %  colomns needed to total  
  
   
    %% subtotal
    for j=1:rowNum
        sdata(j,1:colNum-1)=num2cell(b(j,);
        idx=n==j;
        sdata{j,colNum}=sum(temp(idx,totalcol))./10;
    end
   
    %% assign sdata to result(i,3).
    result{i,3}=sdata;
end


%% clear temporay variable
clear b colNum colleft cols j i m n rowNum sdata temp totalcol idx;

[ Last edited by cttsyauchina on 2012-8-30 at 09:32 ]
回复此楼

» 收录本帖的淘帖专辑推荐

matlab source 工具

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
回帖置顶 ( 共有1个 )

★★★ 三星级,支持鼓励

多谢分享.
"但是matlab不像c# vb.net等语言,缺乏了一些动态数组、泛型等数据结构"
这个不太确切,我觉得matlab是最方便的编程环境了,动态数组matlab本身就是的,甚至都不需要预先定义一个数组,直接利用下标赋值就行.泛型我不大熟悉,不太明白你想要在matlab中实现什么样的效果.
2楼2012-08-31 18:32:48
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通回帖

zzpnlz

木虫 (正式写手)


★★★ 三星级,支持鼓励

看不懂了,楼主应该注释一下,方便我们小白
3楼2012-09-20 17:35:58
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

cttsyauchina

木虫 (小有名气)


内容已删除
4楼2013-01-28 14:49:32
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 cttsyauchina 的主题更新
☆ 无星级 ★ 一星级 ★★★ 三星级 ★★★★★ 五星级
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 211本,11408一志愿中科院277分,曾在中科院自动化所实习 +3 Losir 2026-03-12 4/200 2026-03-16 21:52 by Losir
[考研] 材料专硕326求调剂 +5 墨煜姒莘 2026-03-15 5/250 2026-03-16 21:30 by 木瓜膏
[考研] 318求调剂 +3 Yanyali 2026-03-15 3/150 2026-03-16 16:41 by houyaoxu
[考研] 070303一志愿西北大学学硕310找调剂 +5 d如愿上岸 2026-03-12 8/400 2026-03-16 15:19 by peike
[考研] 311求调剂 +6 冬十三 2026-03-15 6/300 2026-03-16 08:00 by wang_dand
[考研] 材料工程327求调剂 +3 xiaohe12w 2026-03-11 3/150 2026-03-14 20:20 by ms629
[考研] 材料与化工 323 英一+数二+物化,一志愿:哈工大 本人本科双一流 +4 自由的_飞翔 2026-03-13 5/250 2026-03-14 19:39 by hmn_wj
[考研] 330求调剂 +3 ?酱给调剂跪了 2026-03-13 3/150 2026-03-14 10:13 by JourneyLucky
[考研] 材料工程专硕,一志愿中国矿业大学,总分314,求调剂 +5 无懈可击的巨人 2026-03-10 5/250 2026-03-14 00:37 by JourneyLucky
[考研] 招收0805(材料)调剂 +3 18595523086 2026-03-13 3/150 2026-03-14 00:33 by 123%、
[考研] 一志愿湖师大化学289求调剂 +6 XMCMM3.14159 2026-03-10 6/300 2026-03-14 00:28 by JourneyLucky
[考研] 327求调剂 +4 Ffff03 2026-03-10 4/200 2026-03-14 00:17 by JourneyLucky
[考研] 2026考研调剂+本科延边大学+山东大学+生物化学与分子生物学+有项目经验 +3 ccdsscjy 2026-03-10 3/150 2026-03-14 00:12 by JourneyLucky
[考研] 材料与化工(0856)304求B区调剂 +6 邱gl 2026-03-12 7/350 2026-03-13 23:24 by 邱gl
[考研] 四川大学085601材料工程专硕 初试294求调剂 +4 祝我们好在冬天 2026-03-11 4/200 2026-03-13 21:39 by peike
[考研] 求b区学校调剂 +3 周56 2026-03-11 3/150 2026-03-13 16:20 by JourneyLucky
[考研] 考研调剂 +4 芬达46 2026-03-12 4/200 2026-03-13 16:04 by ruiyingmiao
[考研] 材料专硕350 求调剂 +4 王金科 2026-03-12 4/200 2026-03-13 16:02 by ruiyingmiao
[考研] 求调剂 +3 程雨杭 2026-03-12 3/150 2026-03-13 15:06 by JourneyLucky
[考研] 材料301分求调剂 +5 Liyouyumairs 2026-03-12 5/250 2026-03-13 14:42 by JourneyLucky
信息提示
请填处理意见