- 1、本文档共8页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
《机械优化设计》上机源程序与结果—
第 PAGE 8 页 共 NUMPAGES 8 页
《机械优化设计》上机源程序与结果
4
程序一:外推法
源程序:
#includestdio.h
#includemath.h
#define B 0.001
double fun(double x)
{ double min;
min=x*x-10*x+36;
return min;
}
void main()
{
double h0=B,y1,y2,y3,x1,x2,x3,h;
x1=0;h=h0;x2=h;
y1=fun(x1);y2=fun(x2);
if(y2y1)
{h=-h;
x3=x1; x1=x2; x2=x3;
y3=y1; y1=y2; y2=y3;
}
x3=x2+h;y3=fun(x3);
while(y3y2)
{h*=1.5;
x1=x2; x2=x3; x3=x2+h;
y1=y2; y2=y3; y3=fun(x3);
}
printf(fun(%f)=%f,\nfun(%f)=%f,\nfun(%f)=%f\n,x1,y1,x2,y2,x3,y3);
}
运行过程及结果:
fun(2.954784)=15.182909,
fun(4.432676)=11.321857,
fun(6.649513)=13.720895
程序二:黄金分割法
源程序:
#includestdio.h
#includemath.h
#define f(x) x*x-10*x+36
double gi(double *a,double *b,double e,int *n)
{
double x1,x2,min;
if(fabs((*b-*a)/(*b))=e)
min=f((*b+*a)/2);
else
{
x1=*b-0.618*(*b-*a);
x2=*a+0.618*(*b-*a);
if(f(x1)f(x2))
*a=x1;
else
*b=x2;
*n=*n+1;
min=gi(a,b,e,n);
}
return min;
}
void main()
{
double min,a,b,e,m;
int n=0;
printf(输入有哪些信誉好的足球投注网站区间a,b值和精度e\n);
scanf(%lf %lf %lf,a,b,e);
min=gi(a,b,e,n);
m=(a+b)/2;
printf(a=%lf,b=%lf,min=%lf,m=%lf,n=%d\n,a,b,min,m,n);
}
Press any key to continue
运行过程及结果:
a*=5.000000
y*=11.000000
程序三:二次插值法
源程序:
#includestdio.h
#includemath.h
float f(float x)
{ float min;
min=x*x-10*x+36;
return min;
}
void main()
{float e=0.001,c1,c2,ap,yp,a,y;
float h0=0.03,h=h0,a1=0,a2=h,y1,y2,a3,y3;
y1=f(a1);
y2=f(a2);
if(y2y1)
{
h=-h;a3=a1;y3=y1;
a1=a2;y1=y2;a2=a3;y2=y3;
}
a3=a2+h;y3=f(a3);
while(y3y2)
{
h=2*h;
a1=a2;y1=y2;a2=a3;y2=y3;
a3=a2+h;y3=f(a3);
}
printf(f(%f)=%f\nf(%f)=%f\nf(%f)=%f,a1,y1,a2,y2,a3,y3);
y1=f(a1);
y2=f(a2);
y3=f(a3);
c1=(y3-y1)/(a3-a1);
c2=((y2-y1)/(a2-a1)-c1)/(a2-a3);
ap=0.5*(a1+a3-c1/c2);
yp=f(ap);
while(abs((y2-yp)/y2)=e)
{if((ap-a2)*h0){if(y2=yp){a1=a2;y1=y2;a2=ap;y2=yp;}
else{a3=ap;y3=yp;}}
else{if(y2=yp){a3=a2;y3=y2;a2=ap;y2=yp;}
else{a1=ap;y1=yp;}}
}
if(y2yp)
您可能关注的文档
- 煤矿开工建筑至联合试运转已改.docx
- 城镇带建设领学综述.doc
- 干挂石材施工工艺解析剖析.docx
- ADAMS-View函数与ADAMS-Solver函数的类型与建立.docx
- 生态建设情况综述.docx
- 获取的应用程序路径操作XML等.docx
- 农村宅基地登记管理问题.doc
- 免渡河林业局党群众路线教育实践活动基层党组织专题组织生活会的方案.doc
- 2017年度一级消防工程师综合能力精选提分题十二.doc
- 邢台职业的技术学院.doc
- DB32T3444 健康企业评估规范.pdf
- DBJ25-82-2000 甘肃省聚苯板外保温墙体设计与施工规程 甘肃省地方标准.pdf
- DB32T-核与辐射突发事件卫生应急处置技术规范 第3部分:现场流行病学调查及编制说明.pdf
- DB44T1430-2014 冷冻水产品流通冷链管理技术规范.pdf
- TCASME-监控系统安装与维护规范.pdf
- TCSAE-汽车远程升级(OTA)信息安全测试规范.pdf
- TJSSAE-智能网联汽车开放道路测试管理要求及编制说明.pdf
- TEERT-挥发性有机物污染治理设施工况自动监控技术规范.pdf
- TCASME-三跨连续节段梁悬浇施工技术规范.pdf
- DB36T-行政执法案卷评查规范编制说明.pdf
文档评论(0)