数学建模套用网上的matlab代码后要如何修改成自己的代码?

数学建模套用网上的matlab代码后要如何修改成自己的代码?,第1张

三次数模国奖路过,曾经单挑过两次国赛(第三次有一个负责编程的同学给予我很大的帮助)。稍微谈谈编程这一块的经验吧,现在临近美赛,时间也不多了。最高票回答适合长时间准备(至少有一个从校内赛到国赛的周期,我就谈谈只剩下一个月不到应该如何准备编程这一块工作吧)。

编程的同学,主要是把建模同学的思想给生产出结果,也就是输出一定的东西,可以是图,可以是表可以是数据等等。当你随便打开一本数模书(比如司守奎老师写的《数学建模算法与应用》这本书),你会被里面的Matlab,lingo等代码吓住,尤其是以前不怎么编程的同学来说更为如此。所以数模三个部分,很多同学会觉得编程非常难以上手。

其实,负责编程的同学,并不是说比谁代码写得长,谁代码写得好,而是应该为建模的同学提供一个结果(只从数模拿奖(功利的角度出发)无论结果的好坏,甚至是否有结果,在比赛即将结束的时刻,都应该给建模队友一个所得过去的“答案”),所以可以在做一些数模问题的时候,用一些较为“傻瓜”的软件,比如SPSS,这个软件可以解决统计学中的很多问题,比如2012年的国赛葡萄酒评价问题,这道题就是使用SPSS的代表。所以说,以其说是会编程,不如说是应该会使用相关软件,让所建模型输出一个不错的结果。还有作图软件Origin,在进行一些简单的作图时候,可以使用Origin而没有必要去使用Matlab进行画图,一般情况下,在问题不太复杂的时候,是没有必要使用Matlab的。还有一款软件叫做Visio,这款软件是画流程图的利器,比如说写完一段程序附上程序框图,或者用系统动力学解决一个问题时画的系统流图,得到的效果都是非常棒的(PS:初次学习建模的同学,无论如何一定要在Matlab上面下一点功夫,即使没有办法掌握,也需要知道如何修改别人的优秀程序,为我所用)。

如果真的想短期学会一个真正需要编程的语言,还是选Matlab吧,虽然在短时间之类,你是无法把这门语言学到精通,但是只要知道Matlab的语法规律,以及一些基本功能,一些基本的工具箱就足够了,这里推荐两本书,一本是《Matlab完全自学一本通》这本书上面基本上包含了可以用得到的功能,至少是基础功能。在数模上面,可以司守奎老师写的《数学建模算法与应用》这本书,一般常用模型的代码都给出来了。还有一个最关键的是,比赛前,多看看别人写的优秀论文。不管是国赛还是美赛,都有着优秀论文集,看看别人写的论文还有别人的代码,争取找到一些灵感。

在比赛的过程中,如果什么地方卡住了,一定不要蒙着头想,应该即使去相关论坛查找一些使用技巧,当然Matlab自身的帮助文档也是挺不错的。

多说一句话,LaTeX是写作排版用的,虽然也是类似于编程语言,不建议编程的人去学习,应该去鼓励写作的同学学习LaTeX,编程的同学应该和建模的同学好好合作,合力把比赛题目拿下。

看到数学建模老司机(国一优秀论文获得者,深圳杯获得者,SAS大赛冠军)的回答了,SPSS在这几年的国赛的赛题(2014,2015,2016)当中确实比较难使用了,问题基本上都是纯物理类问题(2014航天,2015球面天文学,2016受力分析)而且SPSS还有一个非常强大的竞争对手SAS的存在。至少是国赛A题,一般都是需要自己踏踏实实建模,最后使用Matlab实现。但是,A题由于过于考察建模的实力,因此一些非理工科的学生往往望而怯步。

R,Python以及SAS作为数据分析时代的新兴语言,大家可以有空的时候学一学。由于现在有一个SAS数据分析大赛(由汇丰银行赞助,SAS公司主办)搞的还不错,大家可以学一学SAS然后去这个比赛中练一练手。参加过蛮多的比赛,还是发现SAS举办的这个数据分析竞赛(尤其是决赛)给我的参赛体验非常地好。

其实,如果单纯从拿奖的角度来说,某些问题,尤其是国赛B题, 美赛E、F题对于程序要求不高的情况下,可以适当地使用现有的模型理论对具体问题进行分析。但是,从2014年开始每一年国赛A题基本上都很难找到可以直接套用的模型(虽然2016年的系泊系统在知网上面有很多现成的研究结果,但是往往不是太复杂,就是和题目分析的背景有点不太一样),这也是我前面说为什么对于没有经历过理工科训练的学生很容易望而怯步的原因。所以,我觉得如果你想做好A题,在近些年A题越来越需要自己建模,自己使用一定的软件实现的大环境下,建议有一定改编现有程序的能力。

首先,数学建模比赛是一个竞赛活动,旨在锻炼选手的数学建模能力。这个比赛强调的是选手的能力,而非代码本身。因此,卖代码是不道德的行为,也是违反比赛规则的行为。同时,从道义上讲,卖代码等于抄袭,这是不应该被鼓励的行为。

其次,如果你需要在数学建模比赛中使用代码,建议你自己编写或者请专业人士编写。通过自己编写代码,可以提高对模型的理解,也可以更好地展示自己的实力。另外,数学建模比赛强调的是选手的数学建模能力,而非编码能力。因此,如果你的代码不太完美,也不必过于担心。

综上所述,卖代码是不道德的行为,也是违反比赛规则的行为。如果需要使用代码,建议自己编写或者请专业人士编写,并不要将重点放在代码上,而是要更加注重数学建模能力。

这道题目里面是不是欠缺几个条件:煤机生产费用应该是一个固定成本加一个可变成本吧,要是这样的话,我就假设固定成本是100每次,可变成本是10元/台。

10和100这两个数是乱写的,你自己改啊

!x是每次生产的台数,y是每次库存的台数;

x1=y2+40;

x2+y2=y3+60;

y3+x3=80;

min=10(x1+x2+x3)+100(c1+c2+c3)+4(y1+y2+y3);

!c是确定每次是否生产,lingo默认0/0等于0,如果x非零c等于1,如果x=0,c等于0;

c1=x1/x1;

c2=x2/x2;

c3=x3/x3;

@bin(c1);

@bin(c2);

@bin(c3);

其实我觉得bin的约束要不要可以自己看,我觉得加上可能保险点,但是去掉的话是个线性规划,这个看自己

不会参与查重。

这里先介绍代码的降重方法,这是很多人容易忽略的,数学建模竞赛还会对大家在附录提交的代码进行一个查重。

方法一:给代码加上自己的注释

大家比赛时肯定会参考很多现成的代码,但是这就有了重复率的风险。在大家照搬其他人代码后,可以按照自己的理解对代码进行一个自己的注释,可以对代码的逻辑,数值传递,甚至是一些现有函数的功能进行注释这样就可以有效的降低代码的重复率。

方法二:改变代码的变量名称

大家可以选择改变代码中的变量名称来降低重复率,在文本中搜索时可以用(Ctrl+F)做到一键替换、可以将变量的名称改为全称或者简称,从而进行简单有效的降重。

方法三:利用公式编辑器

大家在降低重复率时可以选择用公式编辑器将重复率高的部分全部换为公式,或者插入文本框。这是最简单快捷的,但是作者对这种行为并不提倡,希望大家可以用自己的想法写出自己的文章。

方法四:做成表格

将自己的数据或者其他的罗列换成表格形式,可以有限避免查重。

  1设每天加工x公斤A1,y公斤A2,则

  model:

  max=24x+16y;

  50>x/3+y/4;!牛奶总量50桶的限制;

  480>x/312+y/48;!加工时间480小时上限的限制;

  100>x;!设备每天最多加工100公斤A1;

  end

  运行结果:

  Global optimal solution found

  Objective value: 3360000

  Total solver iterations: 2

  Variable Value Reduced Cost

  X 6000000 0000000

  Y 1200000 0000000

  Row Slack or Surplus Dual Price

  1 3360000 1000000

  2 0000000 -4800000

  3 0000000 -2000000

  4 4000000 0000000

  2应作这项投资,因为这时的实际获利是3360/50>38;

  假设若投资,每天最多购买z桶牛奶,很显然这时与第一份相比,仅仅多了成本而已。

  代码:

  model:

  max=24x+16y-38z;

  x/3+y/4=z;

  50>x/3+y/4;!牛奶总量50桶的限制;

  480>x/312+y/48;!加工时间480小时上限的限制;

  100>x;!设备每天最多加工100公斤A1;

  end

  运行结果:

  Global optimal solution found

  Objective value: 1460000

  Total solver iterations: 2

  Variable Value Reduced Cost

  X 6000000 0000000

  Y 1200000 0000000

  Z 5000000 0000000

  Row Slack or Surplus Dual Price

  1 1460000 1000000

  2 0000000 3800000

  3 0000000 -1000000

  4 0000000 -2000000

  5 4000000 0000000

  3若用临时工人以增加劳动时间,设付给临时工人的工资最多是每小时a元。

  代码:

  model:

  max=a;

  24x+16y-38z-at>0;

  x/3+y/4=z;

  50>x/3+y/4;!牛奶总量50桶的限制;

  t=x/312+y/48;

  480>x/312+y/48;!加工时间480小时上限的限制;

  100>x;!设备每天最多加工100公斤A1;

  end

  运行结果:

  Local optimal solution found

  Objective value: 3250000

  Extended solver steps: 5

  Total solver iterations: 148

  Variable Value Reduced Cost

  A 3250000 0000000

  X 0000000 04166667E-02

  Y 2000000 0000000

  Z 5000000 0000000

  T 4000000 0000000

  Row Slack or Surplus Dual Price

  1 3250000 1000000

  2 0000000 -02500000E-02

  3 0000000 09500000E-01

  4 0000000 0000000

  5 0000000 -08125000E-02

  6 8000000 0000000

  7 1000000 0000000

欢迎分享,转载请注明来源:浪漫分享网

原文地址:https://hunlipic.com/langman/3199771.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-08-12
下一篇2023-08-12

发表评论

登录后才能评论

评论列表(0条)

    保存