机械优化设计黄金分割法外推法.pdf





《机械优化设计黄金分割法外推法.pdf》由会员分享,可在线阅读,更多相关《机械优化设计黄金分割法外推法.pdf(8页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、1/8 郑州大学 机械优化设计部分程序 1.外推法 2.黄金分割法 3.二次插值法 4.坐标轮换法 5.随机方向法 6.四杆机构优化设计 2/8 1.外推法 源程序:#include#include#define R 0.01 double fun(double x)double m;m=x*x-10*x+36;return m;void main()double h0=R,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;y3=y1;x1=x2;y1=y2;x2=x3;y2=y3;x3=x2
2、+h;y3=fun(x3);while(y3y2)h*=2.0;x1=x2;y1=y2;x2=x3;y2=y3;x3=x2+h;y3=fun(x3);printf(fun(%f)=%f,fun(%f)=%f,fun(%f)=%fn,x1,y1,x2,y2,x3,y3);运行过程及结果:fun(2.560000)=16.953600,fun(5.120000)=11.014400,fun(10.240000)=38.457600 2.黄金分割法 源程序:#include#include#define f(x)x*x*x*x-5*x*x*x+4*x*x-6*x+60 double hj(doubl
3、e*a,double*b,double e,int*n)double x1,x2,s;if(fabs(*b-*a)/(*b)f(x2)*a=x1;else *b=x2;*n=*n+1;s=hj(a,b,e,n);return s;void main()double s,a,b,e,m;int n=0;printf(输入 a,b 值和精度 e 值n);scanf(%lf%lf%lf,&a,&b,&e);s=hj(&a,&b,e,&n);m=(a+b)/2;printf(a=%lf,b=%lf,s=%lf,m=%lf,n=%dn,a,b,s,m,n);3/8 运行过程及结果:输入 a,b 值和精度
4、 e 值-3 5 0.0001 a=3.279466,b=3.279793,s=22.659008,m=3.279629,n=21 3.二次插值法 源程序:#include#include int main(void)double a1,a2,a3,ap,y1,y2,y3,yp,c1,c2,m;double j3;int i,h=1;void finding(double a3);finding(j);a1=j0;a2=j1;a3=j2;m=0.001;double f(double x);y1=f(a1);y2=f(a2);y3=f(a3);for(i=1;1=1;i+)c1=(y3-y1)
5、/(a3-a1);c2=(y2-y1)/(a2-a1)-c1)/(a2-a3);ap=0.5*(a1+a3-c1/c2);yp=f(ap);if(fabs(y2-yp)/y2)0)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;elsea1=ap;y1=yp;double x,y;if(y2y0)h=-h;a2=a0;y2=y0;do a0=a1;a1=a2;y0=y1;y1=y2;a2=a1+h;y2=f(a2);h=2*h;while(y2=1;i+)a2=a1+
6、h;y2=f(a2);if(y2=y1)break;4/8 h=2*h;a0=a1;y0=y1;a1=a2;y1=y2;return;运行过程及结果:a*=5.000000 y*=11.000000 4.坐标轮换法 源程序:#include#include#include float fun1(float x,float a,float b)float y;y=x+a*b;return y;float fun2(float x,float y)float z;z=4*(x-5)*(x-5)+(y-6)*(y-6);return z;main()float d1003,x1003,xx3,ax1
7、003;float a1,a2,a3,h,t,y1,y2,y3,e,a,b,l,fi;int i,k;printf(输入初始点坐标n);scanf(%f%f,&x01,&x02);e=0.000001;l=0.618;x21=x01;x22=x02;k=0;k-;do x01=x21;x02=x22;k+;for(i=1;iy1)h=-h;a3=a1;y3=y1;a1=a2;a2=a3;y1=y2;y2=y3;a3=a2+h;xi1=fun1(xi-11,di1,a3);xi2=fun1(xi-12,di2,a3);y3=fun2(xi1,xi2);do a1=a2;y1=y2;a2=a3;y
8、2=y3;a3=a2+h;xi1=fun1(xi-11,di1,a3);xi2=fun1(xi-12,di2,a3);y3=fun2(xi1,xi2);while(y3a3;)t=a3;a3=a1;a1=t;t=y1;5/8 y3=y1;y1=t;a=a1;b=a3;a1=b-l*(b-a);a2=a+l*(b-a);xi1=fun1(xi-11,di1,a1);xi2=fun1(xi-12,di2,a1);y1=fun2(xi1,xi2);xi1=fun1(xi-11,di1,a2);xi2=fun1(xi-12,di2,a2);y2=fun2(xi1,xi2);if(be;)if(y1=y
9、2)a=a1;a1=a2;y1=y2;a2=a+l*(b-a);xi1=fun1(xi-11,di1,a2);xi2=fun1(xi-12,di2,a2);y2=fun2(xi1,xi2);else b=a2;a2=a1;y2=y1;a1=b-l*(b-a);xi1=fun1(xi-11,di1,a1);xi2=fun1(xi-12,di2,a1);y1=fun2(xi1,xi2);else for(;fabs(b-a)/b)=e|fabs(y2-y1)/y2)=e;)if(y1=y2)a=a1;a1=a2;y1=y2;a2=a+l*(b-a);xi1=fun1(xi-11,di1,a2);x
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 机械 优化 设计 黄金分割 法外推法

限制150内