内点惩罚函数法子程.doc

上传人:pu****.1 文档编号:544475347 上传时间:2024-02-19 格式:DOC 页数:3 大小:22KB
返回 下载 相关 举报
内点惩罚函数法子程.doc_第1页
第1页 / 共3页
内点惩罚函数法子程.doc_第2页
第2页 / 共3页
内点惩罚函数法子程.doc_第3页
第3页 / 共3页
亲,该文档总共3页,全部预览完了,如果喜欢就下载吧!
资源描述

《内点惩罚函数法子程.doc》由会员分享,可在线阅读,更多相关《内点惩罚函数法子程.doc(3页珍藏版)》请在金锄头文库上搜索。

1、#include hjfgf.c#include stdlib.hvoid gradient(double x,double g,int n)int i;double af,f1,f2,dltx=0.000001;for(i=0;in;i+)gi=0;f1=objf(x);for(i=0;in;i+)af=*(x+i); *(x+i)=af+dltx; f2=objf(x); gi=(f2-f1)/dltx; *(x+i)=af;double oneoptim(double x0,double s,double h0,double epsg,int n,double x)double *a,*

2、b,ff;a=(double *)malloc(n*sizeof (double );b=(double *)malloc(n*sizeof (double );jtf(x0,h0,s,n,a,b);ff=gold(a,b,epsg,n,x);free(a);free(b);return(ff);double dfpopt(double xx,double h0,double eps,double epsg,int n)int i,j,k;double ae,zcc;double *s,*x,*ay2,*df2,*zd2,*zc2,*zh2;s=(double *)malloc(n*sizeo

3、f (double );x=(double *)malloc(n*sizeof (double );for(i=0;i2;i+)ayi=(double*)malloc(n*sizeof(double); dfi=(double*)malloc(n*sizeof(double); zdi=(double*)malloc(n*sizeof(double); zci=(double*)malloc(n*sizeof(double); zhi=(double*)malloc(n*n*sizeof(double);for(i=0;in;i+)*(ay0+i)=xxi;L1: k=0; for (i=0;

4、in;i+) for (j=0;jn;j+) *(zh0+i*n+j)=0; if(i=j) *(zh0+i*n+j)=1; for(i=0;in;i+)*(x+i)=*(ay0+i); *(ay1+i)=*(ay0+i);gradient(x,df0,n);for(i=0;in;i+)*(s+i)=0; *(df1+i)=*(df0+i); for(j=0;jn;j+) *(s+i)=*(s+i)-(*(zh0+i*n+j)*(*(df0+j);L2:oneoptim(x,s,h0,epsg,n,ay0);for(i=0;in;i+) *(x+i)=*(ay0+i);gradient(x,d

5、f0,n);ae=0;for(i=0;in;i+) ae=ae+(*(df0+i)*(*(df0+i);if(ae=eps) for(i=0;in;i+) *(xx+i)=*(x+i); free(s); free(x); for(i=0;i2;i+) free(ayi); free(dfi); free(zdi); free(zci); free(zhi); return(objf(xx); if(k=n) goto L1; zcc=0; for(i=0;in;i+) *(zd0+i)=*(ay0+i)-(*(ay1+i); *(zd1+i)=*(df0+i)-(*(df1+i); *(df

6、1+i)=*(df0+i); zcc=zcc+(*(zd0+i)*(*(zd1+i); for(i=0;in;i+) for(j=0;jn;j+) *(zh1+i*n+j)=*(zd0+i)*(*(zd0+j)/zcc; for(i=0;in;i+) *(zc0+i)=0; for(j=0;jn;j+) *(zc0+i)=*(zc0+i)+(*(zd1+j)*(*(zh0+j*n+i); zcc=0; for(i=0;in;i+) zcc=zcc+(*(zc0+i)*(*(zd1+i); for(i=0;in;i+) *(zc0+i)=0; *(zc1+i)=0; for (j=0;jn;j+) *(zc0+i)=*(zc0+i)+(*(zh0+i*n+j)*(*(zd1+j); *(zc1+i)=*(zc1+i)+(*(zh1+j)*(*(zh0+j*n+i); for(i=0;in;i+) for(j=0;jn;j+) *(zh0+i*n+j)=*(zh0+i*n+j)+(*(zh1+i*n+j)-(*(zc0+i)*(*(zc1+j)/zcc; for(i=0;in;i+) *(s+i)=0; for(j=0;jn;j+) *(s+i)=*(s+i)-(*(zh0+i*n+j)*(*(df0+j); k=k+1; goto L2;

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 生活休闲 > 社会民生

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号