24小时热门版块排行榜    

查看: 353  |  回复: 0

542950171

金虫 (小有名气)

[求助] matlab求助

下面的一段代码为啥只实现了排序,期待解答
%基于熵的属性离散化方法,参见《一种基于熵的连续属性离散化方法》
function [result,dds]=shang(data)
[m,n]=size(data);
result=zeros(10,5);
for i=1:n
    %%%%%%%%%%%%%%%%%计算划分点
    setpoints=[];
    seqs=[];
    locs=[];
    %%%%%%%%%%%%%%%当出现有相通属性值的样本点时,去掉其余的只保留一个,为后面
    %为后面计算断点做准备
    [seqs,locs]=sort(data(:,i));
    se=seqs;
    for bbs=1:m-1
    if se(bbs)==se(bbs+1)
        qs=bbs+1;
        while se(bbs)==se(qs)
            se(qs)=inf;
        end
    end
    end
    se(find(se==inf))=[];
    newlen=length(se);
    %%%%%%%%%%%%%%%%%
    for j=1:newlen-1       %计算断点的值
        setpoints(j)=(se(j)+se(j+1))/2;
    end
    %%%%%%%%%%%%%%%%%
    nn=length(setpoints);%计算现有内部断点数
    for t1=1:nn+1   %计算各个断点处的卡方统计值
   %%%%%%%%%%计算卡方分布值
    if t1==1
    s1=length(find(-inf     elseif t1==nn+1
    s1=length(find(setpoints(t1-1)<=seqs&seqs     else
    s1=length(find(setpoints(t1-1)<=seqs&seqs     end
    num(t1)=s1;
    P(t1)=s1/m;
    end%接 for t1=1:nn+1
    Hmin(1)=-sum(P.*log2(P));%初始熵值
    k0=length(setpoints);
    H0=Hmin(1);
    Ck=zeros(1,2);%初始化Ck,另Ck(2)=0是为了它能够进入循环while Ck(2)-Ck(1)>=0
    %Ck(2)是合并区间后的值,在while循环中会设置
    %%%%%%%%%%%%%%%%%%循环
    symbol=0;
    while Ck(2)-Ck(1)>=0
    Ck(1)=Ck(2);
    if symbol==1
        setpt(ad)=[];
        setpoints=[];
        setpoints=setpt;
    end
    Q=[];
    H=[];
    num=[];
    setpt=[];
    nn=length(setpoints);%计算现有内部断点数
    setpt=setpoints;
    for c1=1:nn%计算去掉每个断点所得的熵值,找出其中熵差最小的一个作为合并对象
        setpoints=[];
        setpoints=setpt;
        setpoints(c1)=[];
        tt=length(setpoints);
        for t2=1:tt+1   %计算各个断点处的卡方统计值
        %%%%%%%%%%计算卡方分布值
        if t2==1
        s1=length(find(-inf         elseif t2==tt+1
        s1=length(find(setpoints(t2-1)<=seqs&seqs         else
        s1=length(find(setpoints(t2-1)<=seqs&seqs         end
        num(t2)=s1;
        Q(t1)=s1/m;
        end%接 for t1=1:nn+1
        H(c1)=-sum(Q.*log2(Q));%后续计算所得熵值
    end
    symbol=1;
    [Hmin(2),ad]=min(H);
%     Ck(2)=(nn)*Hmin(2)-Hmin(1)*(nn-1);
    Ck(2)=(k0)*Hmin(2)-H0*(nn-1);
   
    Hmin(1)=Hmin(2);
    end
    nt=length(setpt);
    result(1:nt,i)=setpt;
end
pointsnum=[];
    %将各个区间的值离散化
    dds=zeros(m,n);
    for i=1:n
        locd=[];
        locd=result(:,i);
        locd(find(locd==0))=[];
        pointsnum(i)=length(locd)+1;%区间个数
        if length(locd)~=0
        for j=1:pointsnum(i)
            if j==1
                dds(find(-inf             elseif j==pointsnum(i)
                dds(find(locd(j-1)<=data(:,i)&data(:,i)             else
                dds(find(locd(j-1)<=data(:,i)&data(:,i)<=locd(j)),i)=j;
            end
        end
        end
    end
附件中是那篇论文[ 来自科研家族 英乐盒 ]
回复此楼

» 本帖附件资源列表

  • 欢迎监督和反馈:小木虫仅提供交流平台,不对该内容负责。
    本内容由用户自主发布,如果其内容涉及到知识产权问题,其责任在于用户本人,如对版权有异议,请联系邮箱:xiaomuchong@tal.com
  • 附件 1 : 一种基于熵的连续属性离散化算法.pdf
  • 2012-04-19 09:06:28, 159.71 K

» 猜你喜欢

低头要有勇气,抬头要有底气,做人要有志气。吃得苦中苦,方为人上人。
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 542950171 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 341求调剂(一志愿湖南大学070300) +4 番茄头--- 2026-03-22 5/250 2026-03-23 21:59 by fuyu_
[考研] 303求调剂 +4 元夕元 2026-03-20 4/200 2026-03-23 19:00 by macy2011
[考研] 一志愿上海交大生物与医药专硕324分,求调剂 +5 jiajunX 2026-03-22 5/250 2026-03-23 18:07 by YMU施老师
[考研] 一志愿南京理工大学085701资源与环境302分求调剂 +5 葵梓卫队 2026-03-18 7/350 2026-03-23 16:26 by lingjue
[考研] 工科材料085601 279求调剂 +8 困于星晨 2026-03-17 10/500 2026-03-23 13:05 by 醉在风里
[考研] 石河子大学(211、双一流)硕博研究生长期招生公告 +3 李子目 2026-03-22 3/150 2026-03-22 21:01 by 怎么释怀
[考研] 307求调剂 +11 冷笙123 2026-03-17 11/550 2026-03-22 20:16 by edmund7
[考研] 寻找调剂 +4 倔强芒? 2026-03-21 4/200 2026-03-22 16:14 by 木托莫露露
[考研] 303求调剂 +5 安忆灵 2026-03-22 6/300 2026-03-22 12:46 by 素颜倾城1988
[考研] 一志愿华中科技大学071000,求调剂 +4 沿岸有贝壳6 2026-03-21 4/200 2026-03-22 07:21 by ilovexiaobin
[考研] 278求调剂 +9 烟火先于春 2026-03-17 9/450 2026-03-21 17:47 by 学员8dgXkO
[考研] 0703化学297求调剂 +3 Daisy☆ 2026-03-20 3/150 2026-03-21 17:45 by ColorlessPI
[考研] 求调剂,一志愿:南京航空航天大学大学 ,080500材料科学与工程学硕,总分289分 +4 @taotao 2026-03-19 4/200 2026-03-20 22:14 by JourneyLucky
[考研] 材料与化工 322求调剂 +4 然11 2026-03-19 4/200 2026-03-20 22:12 by luoyongfeng
[考研] 求调剂一志愿南京航空航天大学289分 +3 @taotao 2026-03-19 3/150 2026-03-20 21:34 by JourneyLucky
[考研] 295材料求调剂,一志愿武汉理工085601专硕 +5 Charlieyq 2026-03-19 5/250 2026-03-20 20:35 by JourneyLucky
[考研] 一志愿 南京航空航天大学大学 ,080500材料科学与工程学硕 +5 @taotao 2026-03-20 5/250 2026-03-20 20:16 by JourneyLucky
[考研] 求调剂 +3 @taotao 2026-03-20 3/150 2026-03-20 19:35 by JourneyLucky
[考研] 求调剂 +3 eation27 2026-03-20 3/150 2026-03-20 19:32 by JourneyLucky
[考研] 一志愿中国海洋大学,生物学,301分,求调剂 +5 1孙悟空 2026-03-17 6/300 2026-03-19 23:46 by zcl123
信息提示
请填处理意见