自学内容网 自学内容网

2014年全国大学生数学建模竞赛D题储药柜的设计(含word论文和源代码资源)

一、部分题目

2014高教社杯全国大学生数学建模竞赛题目

D题 储药柜的设计

储药柜的结构类似于书橱,通常由若干个横向隔板和竖向隔板将储药柜分割成若干个储药槽(如图1所示)。为保证药品分拣的准确率,防止发药错误,一个储药槽内只能摆放同一种药品。药品在储药槽中的排列方式如图2所示。药品从后端放入,从前端取出。一个实际储药柜中药品的摆放情况如图3所示。

为保证药品在储药槽内顺利出入,要求药盒与两侧竖向隔板之间、与上下两层横向隔板之间应留2mm的间隙,同时还要求药盒在储药槽内推送过程中不会出现并排重叠、侧翻或水平旋转。在忽略横向和竖向隔板厚度的情况下,建立数学模型,给出下面几个问题的解决方案。

问题1 药房内的盒装药品种类繁多,药盒尺寸规格差异较大,附件1中给出了一些药盒的规格。请利用附件1的数据,给出竖向隔板间距类型最少的储药柜设计方案,包括类型的数量和每种类型所对应的药盒规格。

问题2 药盒与两侧竖向隔板之间的间隙超出2mm的部分可视为宽度冗余。增加竖向隔板的间距类型数量可以有效地减少宽度冗余,但会增加储药柜的加工成本,同时降低了储药槽的适应能力。设计时希望总宽度冗余尽可能小,同时也希望间距的类型数量尽可能少。仍利用附件1的数据,给出合理的竖向隔板间距类型的数量以及每种类型对应的药品编号。

问题3 考虑补药的便利性,储药柜的宽度不超过2.5m、高度不超过2m,传送装置占用的高度为0.5m,即储药柜的最大允许有效高度为1.5m。药盒与两层横向隔板之间的间隙超出2mm的部分可视为高度冗余,平面冗余=高度冗余×宽度冗余。在问题2计算结果的基础上,确定储药柜横向隔板间距的类型数量,使得储药柜的总平面冗余量尽可能地小,且横向隔板间距的类型数量也尽可能地少。

问题4 附件2给出了每一种药品编号对应的最大日需求量。在储药槽的长度为1.5m、每天仅集中补药一次的情况下,请计算每一种药品需要的储药槽个数。为保证药房储药满足需求,根据问题3中单个储药柜的规格,计算最少需要多少个储药柜。

二、部分论文

请添加图片描述

请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述

三、部分源代码

问题1

% 完整代码 https://github.com/yan-fanyu/CUMCM-Paper-And-SourceCode
load xinghao.txt
N=size(xinghao);
data=zeros(N(1),5);
for i=1:N(1)
   data(i,1)= xinghao(i,1);
   data(i,2)= xinghao(i,2);
   data(i,3)= xinghao(i,3);
   data(i,4)= ceil(sqrt(xinghao(i,2)^2+xinghao(i,3)^2));
   data(i,5)= ceil(sqrt(xinghao(i,1)^2+xinghao(i,3)^2));
end
K_min=min(xinghao(:,3));
K_max=max(xinghao(:,3));
C_min=K_min;
C_K=2*C_min-1;
C_max=C_K-4;

while(C_max<K_max)
    index=[];
    data_temp=[];
    for i=1:N(1)
       if (data(i,3)<=C_max) &&  (data(i,3)>=C_min) 
           index=[index i];
           data_temp=[data_temp;data(i,4:5)];
       end
    end
    DJ=min(min(data_temp()));
          
    if (C_K > DJ)
           C_K=DJ-1;
           C_max=C_K-4;
    else
        index%输出药槽宽度对应的药盒编号
        num=size(index) %输出药槽宽度对应药盒的数量
        C_K %输出药槽宽度
        %计算宽度冗余
        rongyu=0;
        for k=1:num(2)
            if ( (C_K-data(index(k),3))>4 )
                rongyu=rongyu+(C_K-data(index(k),3)-4);
            end
        end
        rongyu
        
        C_min=C_max+1;
        C_K=2*C_min-1;
        if(C_K>56+4)
            C_K=60;
            C_max=56;
            index=[];
            data_temp=[];
               for i=1:N(1)
                   if (data(i,3)<=C_max) &&  (data(i,3)>=C_min) 
                       index=[index i];
                       data_temp=[data_temp;data(i,4:5)];
                   end
               end
               DJ=min(min(data_temp()));
                if (C_K > DJ)
                       C_K=DJ-1;
                       C_max=C_K-4;
                else
                    index%输出药槽宽度对应的药盒编号
                    num=size(index) %输出药槽宽度对应药盒的数量
                    C_K %输出药槽宽度
                     %计算宽度冗余
                     rongyu=0;
                    for k=1:num(2)
                        if ( (C_K-data(index(k),3))>4 )
                            rongyu=rongyu+(C_K-data(index(k),3)-4);
                        end
                    end
                    rongyu
                end
        else
            C_max=C_K-4;
        end
        
    end
 
end


问题2

% 完整代码 https://github.com/yan-fanyu/CUMCM-Paper-And-SourceCode
fid=fopen('F:\数学建模\2014\D\index.txt','w');
fclose(fid);

load xinghao.txt
N=size(xinghao);
data=zeros(N(1),5);
data_CK=zeros(N(1),2);%保存每种药品的储药槽宽
for i=1:N(1)
   data(i,1)= xinghao(i,1);
   data(i,2)= xinghao(i,2);
   data(i,3)= xinghao(i,3);
   data(i,4)= ceil(sqrt(xinghao(i,2)^2+xinghao(i,3)^2));%高宽对角线
   data(i,5)= ceil(sqrt(xinghao(i,1)^2+xinghao(i,3)^2));%长宽对角线
end
K_min=min(xinghao(:,3));
K_max=max(xinghao(:,3));

sum_rongyu=0;
C_K=[19 31 39 50 60]
% C_min=(C_K(1)+1)/2;
% C_max=C_K(1)-4;
% index=[];
% for i=1:N(1)
%     if (data(i,3)<=C_max) &&  (data(i,3)>=C_min) 
%         index=[index i];
%     end
% end
% % index%输出药槽宽度对应的药盒编号
% num=size(index) %输出药槽宽度对应药盒的数量
% C_K(1) %输出药槽宽度
% %计算宽度冗余
% rongyu=0;
% for k=1:num(2)
%     if ( (C_K(1)-data(index(k),3))>4 )
%          rongyu=rongyu+(C_K(1)-data(index(k),3));
%      end
% end
% rongyu
% sum_rongyu=sum_rongyu+rongyu;  



num_C=5;
j=1;
while( j<=num_C)
    if(j==1)
        C_min=K_min;
    else
        C_min=C_max+1;
    end
C_max=C_K(j)-4;
    index=[];
    for i=1:N(1)
        if (data(i,3)<=C_max) &&  (data(i,3)>=C_min) 
            index=[index i];
        end
    end
%     index%输出药槽宽度对应的药盒编号
    num=size(index) %输出药槽宽度对应药盒的数量
    C_K(j) %输出药槽宽度
    %计算宽度冗余
    rongyu=0;
    for k=1:num(2)
        if ( (C_K(j)-data(index(k),3))>4 )
             rongyu=rongyu+(C_K(j)-data(index(k),3)-4);
         end
    end
    rongyu
    

    %分裂为2,均分
    temp=floor((C_max-C_min)/2);
    C_min_1=C_min;
C_max_1=C_min_1+temp;
    C_K_1=C_max_1+4;
    C_min_2=C_max_1+1;
C_max_2=C_max;
    C_K_2=C_max_2+4;
    index_1=[];
    for i=1:N(1)
        if (data(i,3)<=C_max_1) &&  (data(i,3)>=C_min_1) 
            index_1=[index_1 i];
        end
    end
%     index_1%输出药槽宽度对应的药盒编号
    num=size(index_1) %输出药槽宽度对应药盒的数量
    C_K_1 %输出药槽宽度
    %计算宽度冗余
    rongyu_1=0;
    for k=1:num(2)
        if ( (C_K_1-data(index_1(k),3))>4 )
             rongyu_1=rongyu_1+(C_K_1-data(index_1(k),3)-4);
         end
    end
    rongyu_1
    index_2=[];
    for i=1:N(1)
        if (data(i,3)<=C_max_2) &&  (data(i,3)>=C_min_2) 
            index_2=[index_2 i];
        end
    end
%     index_1%输出药槽宽度对应的药盒编号
    num=size(index_2) %输出药槽宽度对应药盒的数量
    C_K_2 %输出药槽宽度
    %计算宽度冗余
    rongyu_2=0;
    for k=1:num(2)
        if ( (C_K_2-data(index_2(k),3))>4 )
             rongyu_2=rongyu_2+(C_K_2-data(index_2(k),3)-4);
         end
    end
    rongyu_2
    
    %计算总冗余
    sum_rongyu=0;
    num_CC=size(C_K);
    for p=1:num_CC(2)
        if(p==1)
            C_min_S=K_min;
        else
            C_min_S=C_max_S+1;
        end
        C_max_S=C_K(p)-4;
        index=[];
        for i=1:N(1)
            if (data(i,3)<=C_max_S) &&  (data(i,3)>=C_min_S) 
                index=[index i];
            end
        end
    %     index%输出药槽宽度对应的药盒编号
        num=size(index) %输出药槽宽度对应药盒的数量
        C_K(p) %输出药槽宽度
        %计算宽度冗余
        rongyu_t=0;
        for k=1:num(2)
            if ( (C_K(p)-data(index(k),3))>4 )
                 rongyu_t=rongyu_t+(C_K(p)-data(index(k),3)-4);
             end
        end
        sum_rongyu=sum_rongyu+rongyu_t;%总冗余
    end
    
    dec_rongyu=rongyu-(rongyu_1+rongyu_2);
    if (dec_rongyu/sum_rongyu)>0.07%冗余降低超过10%,保持分裂
        C_K=[C_K(1:j-1) C_K_1 C_K(j:num_C)]
        num_C=num_C+1;
        j=j-1;
        if(j>=1)
            C_max=C_K(j)-4;
        end
    end
    j=j+1;
end


%分裂完成,计算总冗余
sum_rongyu=0;
num_C=size(C_K);
for j=1:num_C(2)
    if(j==1)
        C_min=K_min;
    else
        C_min=C_max+1;
    end
C_max=C_K(j)-4;
    index=[];
    for i=1:N(1)
        if (data(i,3)<=C_max) &&  (data(i,3)>=C_min) 
            index=[index i];
        end
    end
%     index%输出药槽宽度对应的药盒编号
    num=size(index) %输出药槽宽度对应药盒的数量
    C_K(j) %输出药槽宽度
    fid=fopen('F:\数学建模\2014\D\index.txt','a');
    fprintf(fid,'%d  ',index);
    fprintf(fid,'\n');
    fclose(fid);
    %计算宽度冗余
    rongyu=0;
    for k=1:num(2)
        if ( (C_K(j)-data(index(k),3))>4 )
             rongyu=rongyu+(C_K(j)-data(index(k),3)-4);
         end
    end
    rongyu
    sum_rongyu=sum_rongyu+rongyu;
    
    %保存每种药品的储药槽宽
    for k=1:num(2)
        data_CK(index(k),1)=C_K(j);
        
    end
    
end
sum_rongyu
save data_CK;%保存每种药品的储药槽宽



问题3

% 完整代码 https://github.com/yan-fanyu/CUMCM-Paper-And-SourceCode
load xinghao.txt
load data_CK
N=size(xinghao);
data=zeros(N(1),5);
for i=1:N(1)
   data(i,1)= xinghao(i,1);
   data(i,2)= xinghao(i,2);
   data(i,3)= xinghao(i,3);
   data(i,4)= ceil(sqrt(xinghao(i,2)^2+xinghao(i,3)^2));%高宽对角线
   data(i,5)= ceil(sqrt(xinghao(i,1)^2+xinghao(i,2)^2));%长高对角线
end
Kg_min=min(xinghao(:,2));
Kg_max=max(xinghao(:,2));

sum_rongyu=0;
C_G=[53 72 104 129];

num_C=4;
j=1;
while( j<=num_C)
    if(j==1)
        Cg_min=Kg_min;
    else
        Cg_min=Cg_max+1;
    end
Cg_max=C_G(j)-4;
    index=[];
    for i=1:N(1)
        if (data(i,2)<=Cg_max) &&  (data(i,2)>=Cg_min) 
            index=[index i];
        end
    end
%     index%输出药槽宽度对应的药盒编号
    num=size(index) %输出药槽宽度对应药盒的数量
    C_G(j) %输出药槽高度
    %计算平面冗余
    rongyu=0;
    for k=1:num(2)
        if ( (C_G(j)-data(index(k),2))>4 ) && ( (data_CK(index(k),1)-data(index(k),3))>4 )
             rongyu=rongyu+(C_G(j)-data(index(k),2)-4)*(data_CK(index(k),1)-data(index(k),3)-4);
         end
    end
    rongyu
    

    %分裂为2,均分
    temp=floor((Cg_max-Cg_min)/2);
    Cg_min_1=Cg_min;
Cg_max_1=Cg_min_1+temp;
    C_G_1=Cg_max_1+4;
    Cg_min_2=Cg_max_1+1;
Cg_max_2=Cg_max;
    C_G_2=Cg_max_2+4;
    index_1=[];
    for i=1:N(1)
        if (data(i,2)<=Cg_max_1) &&  (data(i,2)>=Cg_min_1) 
            index_1=[index_1 i];
        end
    end
%     index_1%输出药槽宽度对应的药盒编号
    num=size(index_1) %输出药槽宽度对应药盒的数量
    C_G_1 %输出药槽宽度
    %计算平面冗余
    rongyu_1=0;
    for k=1:num(2)
        if ( (C_G_1-data(index_1(k),2))>4 ) && ( (data_CK(index_1(k),1)-data(index_1(k),3))>4 )
             rongyu_1=rongyu_1+(C_G_1-data(index_1(k),2)-4)*(data_CK(index_1(k),1)-data(index_1(k),3)-4);
         end
    end
    rongyu_1
    index_2=[];
    for i=1:N(1)
        if (data(i,2)<=Cg_max_2) &&  (data(i,2)>=Cg_min_2) 
            index_2=[index_2 i];
        end
    end
%     index_1%输出药槽宽度对应的药盒编号
    num=size(index_2) %输出药槽宽度对应药盒的数量
    C_G_2 %输出药槽高度
    %计算平面冗余
    rongyu_2=0;
    for k=1:num(2)
        if ( (C_G_2-data(index_2(k),2))>4 )&& ( (data_CK(index_2(k),1)-data(index_2(k),3))>4 )
             rongyu_2=rongyu_2+(C_G_2-data(index_2(k),2)-4)*(data_CK(index_2(k),1)-data(index_2(k),3)-4);
         end
    end
    rongyu_2
    
    %计算总冗余
    sum_rongyu=0;
    num_CC=size(C_G);
    for p=1:num_CC(2)
        if(p==1)
            Cg_min_S=Kg_min;
        else
            Cg_min_S=Cg_max_S+1;
        end
        Cg_max_S=C_G(p)-4;
        index=[];
        for i=1:N(1)
            if (data(i,2)<=Cg_max_S) &&  (data(i,2)>=Cg_min_S) 
                index=[index i];
            end
        end
    %     index%输出药槽宽度对应的药盒编号
        num=size(index) %输出药槽宽度对应药盒的数量
        C_G(p) %输出药槽宽度
        %计算平面冗余
        rongyu_t=0;
        for k=1:num(2)
            if ( (C_G(p)-data(index(k),2))>4 )&& ( (data_CK(index(k),1)-data(index(k),3))>4 )
                 rongyu_t=rongyu_t+(C_G(p)-data(index(k),2)-4)*(data_CK(index(k),1)-data(index(k),3)-4);
             end
        end
        sum_rongyu=sum_rongyu+rongyu_t;%总冗余
    end
    
    dec_rongyu=rongyu-(rongyu_1+rongyu_2);
    if (dec_rongyu/sum_rongyu)>0.04%冗余降低超过10%,保持分裂
        C_G=[C_G(1:j-1) C_G_1 C_G(j:num_C)]
        num_C=num_C+1;
        j=j-1;
        if(j>=1)
            Cg_max=C_G(j)-4;
        end
    end
    j=j+1;
end


%分裂完成,计算总冗余
sum_rongyu=0;
num_C=size(C_G);
for j=1:num_C(2)
    if(j==1)
        Cg_min=Kg_min;
    else
        Cg_min=Cg_max+1;
    end
Cg_max=C_G(j)-4;
    index=[];
    for i=1:N(1)
        if (data(i,2)<=Cg_max) &&  (data(i,2)>=Cg_min) 
            index=[index i];
        end
    end
%     index%输出药槽宽度对应的药盒编号
    num=size(index) %输出药槽宽度对应药盒的数量
    C_G(j) %输出药槽宽度
    %计算宽度冗余
    rongyu=0;
    for k=1:num(2)
        if ( (C_G(j)-data(index(k),2))>4 )&& ( (data_CK(index(k),1)-data(index(k),3))>4 )
             rongyu=rongyu+(C_G(j)-data(index(k),2)-4)*(data_CK(index(k),1)-data(index(k),3)-4);
         end
    end
    rongyu
    sum_rongyu=sum_rongyu+rongyu;
    %保存每种药品的储药槽高
    for k=1:num(2)
        data_CG(index(k),1)=C_G(j);
        
    end
end
sum_rongyu
save data_CG;%保存每种药品的储药槽宽




问题4

% 完整代码 https://github.com/yan-fanyu/CUMCM-Paper-And-SourceCode
load xinghao.txt
load data_CK%每种药的储药槽宽 12类
load data_CG%每种药的储药槽高 13类

N=size(xinghao);
data=zeros(N(1),5);
C_number=zeros(N(1),1);
num_Yaogui=1;
% *******************************
for i=1:N(1)
   data(i,1)= xinghao(i,1);%data(i,2)= xinghao(i,2);%data(i,3)= xinghao(i,3);%data(i,4)= ceil(sqrt(xinghao(i,2)^2+xinghao(i,3)^2));%高宽对角线
   data(i,5)= ceil(sqrt(xinghao(i,1)^2+xinghao(i,3)^2));%长宽对角线
end

load liang.txt
for i=1:N(1)
   n=floor(1500/data(i,1));%C_number(i)=ceil(liang(i)/n);%每种药品的药槽数量
end

%需求量大的药优先摆放,同一种药的药槽放在一起(同一行相邻摆放),同样高的药槽放在同一行
sum_CK=zeros(N(1),1);
for i=1:N(1)
    sum_CK(i)=data_CK(i)*C_number(i);%编号i的药的药槽总宽
end
index_already=[];
i=1;
num_already=0;
CG_all=0;%计算药槽高度累加
CG_sum=0;%计算所有药槽累计的总高度
while( num_already<N(1) )%从最小编号的药开始(编号越小需求量越大)
   index_sameline=[];   
   index_sameline=[index_sameline i];
   sum_long=0;
   num_line=1;
   if sum_CK(i)<2500%储药柜宽度为2500mm
       sum_long=sum_CK(i);
       CG_temp=data_CG(i);
       data_CG(i)=0;
       for j=2:N(1)
           if CG_temp==data_CG(j);%寻找相同槽高的最小编号的药(最小编号的药需求量最大)
              sum_long=sum_long+sum_CK(j);
              if sum_long<=2500%储药柜宽度为2500mm
                  index_sameline=[index_sameline j];
                  num_line=num_line+1;%这一行增加一种药
                  data_CG(j)=0;%清除为0,不参与下一次摆放
              else
                  sum_long=sum_long-sum_CK(j);
              end
           end
       end    
   end
   index_sameline %输出一行药的编号
   CG_temp%输出一行的高度
   index_already=[index_already index_sameline];
   num_already=size(index_already);
   data_CG(i)=0;%清除为0,不参与下一次摆放;
   k=1;
   while(k<num_already(2))
       for k=1:num_already(2)      
           if i==index_already(k)
               i=i+1;
               break;
           end
       end
   end
   
   CG_sum=CG_sum+CG_temp;
   CG_all=CG_all+CG_temp;
   if CG_all>1500%储药柜有效高度为1500mm
       CG_all=CG_temp;
       num_Yaogui=num_Yaogui+1;
   end
   if CG_all==1500
       CG_all=0;
       num_Yaogui=num_Yaogui+1;
   end

end
CG_sum%输出药槽摆放后的总高度
num_Yaogui%输出储药柜数量



四、完整word版论文和源代码

Word论文和源代码


原文地址:https://blog.csdn.net/qq_35500719/article/details/140589645

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!