- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
线性规划c实现
/* *@aim:线性规划,单纯形算法实现 *@note:这里的实现比常规的实现相比,需要更大的存储空间,但灵活性更强,所需要的代码更少 *@date:2015-6-11 *@Author:小花熊 *@Q:1198253149 */ #ifndef __SIMPLEX_H__ #define __SIMPLEX_H__ #includeCArray2D.h #includeCArray.h//单纯型算法所需要的数据结构//@note:使用的规则/* *@1:松弛约束表达式中第k个基本变量的下标是k,非基本变量的下标为m+i,m为基本变量的最大索引 *@2:系数矩阵的行列(m+n,m+n),m为基本变量数目,n非基本变量的数目 */structCSimplex {//记录基本变量的索引CArrayint *basicVariableIndexes;//记录非基本变量得索引CArrayint *nonbasicVariableIndexes;//记录每个松弛约束中的常数,其长度和nonbasicVariableIndexes+basicVariableIndexes相等CArrayfloat *relaxConstants;//松弛约束表达式的矩形阵列 CArray2Dfloat *relaxExpressRestrict;//目标函数,其内容的长度为nonbasicVariableIndexes-size+bacsicVariableIndexes-size//计算目标函数的最大值CArrayfloat *objectFunc;//目标函数中的常数项floatobjectConstant;//CSimplex();CSimplex(intbasicVariableSize,intnonVariableSize); ~CSimplex(); };enumCSimplexType {CSimplexTypeInvalide,//单纯型输入不可行CSimplexTypeNoBound,//单纯型算法所得到的结果是无界的CSimplexTypeOK,//单纯形算法可能得到一个正常的结果 }; //单纯形算法实现 //@request:调用前simple已经是松弛型的 //@return:返回上面的枚举类型中的一种,如果计算成功,则将结果写入到result中CSimplexTypesimplex_algorithm(CSimplex *simplex,float *result); #endif/* *@aim:单纯形算法实现 *@date:2015-6-11 18:59 */ #includesimplex.h #includeassert.h #includestdio.h //标准型转换为松弛型 //注意,函数可能会修改src的内容staticboolsimplex_normal_switch_relax(CSimplex *src,CSimplex *dst); //注意,函数可能会修改simplex的内容,如果初始现行约束不可行返回CSimplexTypeInvalidestaticCSimplexTypeinit_simplex(CSimplex *simple); //构造函数和析构函数CSimplex::CSimplex() {this-basicVariableIndexes=NULL;this-nonbasicVariableIndexes=NULL;this-relaxConstants=NULL;this-relaxExpressRestrict=NULL;this-objectFunc=NULL;this-objectConstant=0.0f; }CSimplex::CSimplex(intbasicVariableSize,intnonVariableSize) {this-basicVariableIndexes=new CArrayint(basicVariableSize);this-nonbasicVariableIndexes=new CArrayint(nonVariableSize);this-objectFunc=new CArrayfloat(basicVariableSize+nonVariableSize);this-relaxExpressRestrict=new CArray2Dfloat(basicVariableSize+n
文档评论(0)