亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ch4.h

?? 數值處理算法程序
?? H
?? 第 1 頁 / 共 2 頁
字號:
     }
  if (m<=0)
    { printf("fail\n"); return(-1);}
  for (i=0; i<=m; i++)
    { ar[i]=ar[i]/p; ai[i]=ai[i]/p;}
  for (i=0; i<=m/2; i++)
    { w=ar[i]; ar[i]=ar[m-i]; ar[m-i]=w;
      w=ai[i]; ai[i]=ai[m-i]; ai[m-i]=w;
    }
  k=m; is=0; w=1.0;
  jt=1;
  while (jt==1)
    { pq=sqrt(ar[k]*ar[k]+ai[k]*ai[k]);
	while (pq<1.0e-12)
        { xr[k-1]=0.0; xi[k-1]=0.0; k=k-1;
          if (k==1)
            { p=ar[0]*ar[0]+ai[0]*ai[0];
              xr[0]=-w*(ar[0]*ar[1]+ai[0]*ai[1])/p;
              xi[0]=w*(ar[1]*ai[0]-ar[0]*ai[1])/p;
              return(1);
            }
          pq=sqrt(ar[k]*ar[k]+ai[k]*ai[k]);
        }
	q=log(pq); q=q/(1.0*k); q=exp(q);
      p=q; w=w*p;
      for (i=1; i<=k; i++)
        { ar[i]=ar[i]/q; ai[i]=ai[i]/q; q=q*p;}
      x=0.0001; x1=x; y=0.2; y1=y; dx=1.0;
      g=1.0e+37; 
      l40:
      u=ar[0]; v=ai[0];
      for (i=1; i<=k; i++)
        { p=u*x1; q=v*y1;
          pq=(u+v)*(x1+y1);
          u=p-q+ar[i]; v=pq-p-q+ai[i];
        }
      g1=u*u+v*v;
      if (g1>=g)
        { if (is!=0)
            { it=1;
              csrtg65(&x,&y,&x1,&y1,&dx,&dy,&dd,&dc,
		    &c,&k,&is,&it);
              if (it==0) goto l40;
            }
          else
            { csrtg60(&t,&x,&y,&x1,&y1,&dx,&dy,&p,&q,&k,&it);
              if (t>=1.0e-03) goto l40;
              if (g>1.0e-18)
                { it=0;
                  csrtg65(&x,&y,&x1,&y1,&dx,&dy,&dd,&dc,
			&c,&k,&is,&it);
                  if (it==0) goto l40;
                }
            }
          csrtg90(xr,xi,ar,ai,&x,&y,&p,&w,&k);
        }
      else
        { g=g1; x=x1; y=y1; is=0;
          if (g<=1.0e-22)
	      csrtg90(xr,xi,ar,ai,&x,&y,&p,&w,&k);
          else
            { u1=k*ar[0]; v1=ai[0];
              for (i=2; i<=k; i++)
                { p=u1*x; q=v1*y; pq=(u1+v1)*(x+y);
                  u1=p-q+(k-i+1)*ar[i-1];
                  v1=pq-p-q+(k-i+1)*ai[i-1];
                }
              p=u1*u1+v1*v1;
              if (p<=1.0e-20)
                { it=0;
                  csrtg65(&x,&y,&x1,&y1,&dx,&dy,&dd,&dc,
                      &c,&k,&is,&it);
                  if (it==0) goto l40;
                  csrtg90(xr,xi,ar,ai,&x,&y,&p,&w,&k);
                }
              else
                { dx=(u*u1+v*v1)/p;
                  dy=(u1*v-v1*u)/p;
                  t=1.0+4.0/k;
                  csrtg60(&t,&x,&y,&x1,&y1,&dx,&dy,&p,&q,
                      &k,&it);
                  if (t>=1.0e-03) goto l40;
                  if (g>1.0e-18)
                    { it=0;
                      csrtg65(&x,&y,&x1,&y1,&dx,&dy,&dd,&dc,
                          &c,&k,&is,&it);
                      if (it==0) goto l40;
                    }
                  csrtg90(xr,xi,ar,ai,&x,&y,&p,&w,&k);
                }
            }
        }
      if (k==1) jt=0;
      else jt=1;
    }
  return(1);
}
/////////////////////////////////////////////////////////////
int dsnse(int n,double eps,double x[],int js,
		  double (*dsnsef)(double x[],double y[],int n))//求非線性組一組實根的梯度法
{ //extern double dsnsef();
  int l,j;
  double f,d,s,*y;
  y=(double *)malloc(n*sizeof(double));
  l=js;
  f=dsnsef(x,y,n);
  while (f>=eps)
    { l=l-1;
      if (l==0) { free(y); return(js);}
      d=0.0;
      for (j=0; j<=n-1; j++) d=d+y[j]*y[j];
      if (d+1.0==1.0) { free(y); return(-1);}
      s=f/d;
      for (j=0; j<=n-1; j++) x[j]=x[j]-s*y[j];
      f=dsnsef(x,y,n);
    }
  free(y); return(js-l);
}
/////////////////////////////////////////////////////////////
int dnetn(int n,double eps,double t,double h,double x[],int k,
		  void (*dnetnf)(double x[],double y[],int n))//求非線性方程一組實根的擬牛頓法
{ 
	//extern void dnetnf();
    //extern int agaus();
    int i,j,l;
    double am,z,beta,d,*y,*a,*b;
    y=(double*)malloc(n*sizeof(double));
    a=(double*)malloc(n*n*sizeof(double));
    b=(double*)malloc(n*sizeof(double));
    l=k; am=1.0+eps;
    while (am>=eps)
      { dnetnf(x,b,n);
        am=0.0;
        for (i=0; i<=n-1; i++)
          { z=fabs(b[i]);
            if (z>am) am=z;
          }
        if (am>=eps)
          { l=l-1;
            if (l==0)
              { free(y); free(b); free(a);
                printf("fail\n"); return(0);
              }
            for (j=0; j<=n-1; j++)
              { z=x[j]; x[j]=x[j]+h;
                dnetnf(x,y,n);
                for (i=0; i<=n-1; i++) a[i*n+j]=y[i];
                x[j]=z;
              }
            if (agaus(a,b,n)==0)
              { free(y); free(a); free(b); return(-1);}
            beta=1.0;
            for (i=0; i<=n-1; i++) beta=beta-b[i];
            if (fabs(beta)+1.0==1.0)
              { free(y); free(a); free(b);
                printf("fail\n"); return(-2);
              }
            d=h/beta;
            for (i=0; i<=n-1; i++) x[i]=x[i]-d*b[i];
            h=t*h;
          }
      }
    free(y); free(a); free(b);
    return(k-l);
}
/////////////////////////////////////////////////////////////
int dngin(int m,int n,double eps1,double eps2,double x[],int ka,
		  void (*dnginf)(int m,int n,double x[],double d[]),
		  void (*dngins)(int m,int n,double x[2],double* p))//求非線性方程組最小二乘解的廣義逆法
{ 
	//extern void dnginf();
    //extern void dngins();
    //extern int agmiv();
    int i,j,k,l,kk,jt;
    double y[10],b[10],alpha,z,h2,y1,y2,y3,y0,h1;
    double *p,*d,*pp,*dx,*u,*v,*w;
    p=(double*)malloc(m*n*sizeof(double));
    d=(double*)malloc(m*sizeof(double));
    pp=(double*)malloc(n*m*sizeof(double));
    dx=(double*)malloc(n*sizeof(double));
    u=(double*)malloc(m*m*sizeof(double));
    v=(double*)malloc(n*n*sizeof(double));
    w=(double*)malloc(ka*sizeof(double));
    l=60; alpha=1.0;
    while (l>0)
      { dnginf(m,n,x,d);
        dngins(m,n,x,p);
        jt=agmiv(p,m,n,d,dx,pp,eps2,u,v,ka);
        if (jt<0)
          { free(p); free(d); free(pp); free(w);
            free(dx); free(u); free(v); return(jt);
          }
        j=0; jt=1; h2=0.0;
        while (jt==1)
          { jt=0;
            if (j<=2) z=alpha+0.01*j;
            else z=h2;
            for (i=0; i<=n-1; i++) w[i]=x[i]-z*dx[i];
            dnginf(m,n,w,d);
            y1=0.0;
            for (i=0; i<=m-1; i++) y1=y1+d[i]*d[i];
            for (i=0; i<=n-1; i++)
              w[i]=x[i]-(z+0.00001)*dx[i];
            dnginf(m,n,w,d);
            y2=0.0;
            for (i=0; i<=m-1; i++) y2=y2+d[i]*d[i];
            y0=(y2-y1)/0.00001;
            if (fabs(y0)>1.0e-10)
              { h1=y0; h2=z;
                if (j==0) { y[0]=h1; b[0]=h2;}
                else
                  { y[j]=h1; kk=0; k=0;
                    while ((kk==0)&&(k<=j-1))
                        { y3=h2-b[k];
                          if (fabs(y3)+1.0==1.0) kk=1;
                          else h2=(h1-y[k])/y3;
                          k=k+1;
                        }
                    b[j]=h2;
                    if (kk!=0) b[j]=1.0e+35;
                    h2=0.0;
                    for (k=j-1; k>=0; k--)
                      h2=-y[k]/(b[k+1]+h2);
                    h2=h2+b[0];
                  }
                j=j+1;
                if (j<=7) jt=1;
                else z=h2;
              }
          }
        alpha=z; y1=0.0; y2=0.0;
        for (i=0; i<=n-1; i++)
          { dx[i]=-alpha*dx[i];
            x[i]=x[i]+dx[i];
            y1=y1+fabs(dx[i]);
            y2=y2+fabs(x[i]);
          }
        if (y1<eps1*y2)
          { free(p); free(pp); free(d); free(w);
            free(dx); free(u); free(v); return(1);
          }
        l=l-1;
      }
    free(p); free(pp); free(d); free(dx);
    free(u); free(v); free(w); return(0);
}
/////////////////////////////////////////////////////////////
void dmtcl(double* x,double b,int m,double eps,
		   double (*dmtclf)(double x))//求非線性方程一個實根的蒙特卡洛法
{ //extern double mrnd1();
  //  extern double dmtclf();
    int k;
    double xx,a,r,y,x1,y1;
    a=b; k=1; r=1.0; xx=*x; y=dmtclf(xx);
    while (a>=eps)
      { x1=mrnd1(&r); x1=-a+2.0*a*x1;
        x1=xx+x1; y1=dmtclf(x1);
        k=k+1;
        if (fabs(y1)>=fabs(y))
          { if (k>m) { k=1; a=a/2.0; }}
        else
          { k=1; xx=x1; y=y1;
            if (fabs(y)<eps)
              { *x=xx; return; }
          }
      }
    *x=xx; return;
}
/////////////////////////////////////////////////////////////
void dcmtc(double* x,double* y,double b,int m,double eps,
		   double (*dcmtcf)(double x,double y))//求實函數或復函數方程一個復根的蒙特卡洛法
{ //extern double mrnd1();
    //extern double dcmtcf();
    int k;
    double xx,yy,a,r,z,x1,y1,z1;
    a=b; k=1; r=1.0; xx=*x; yy=*y;
    z=dcmtcf(xx,yy);
    while (a>=eps)
      { x1=-a+2.0*a*mrnd1(&r); x1=xx+x1; 
        y1=-a+2.0*a*mrnd1(&r); y1=yy+y1;
        z1=dcmtcf(x1,y1);
        k=k+1;
        if (z1>=z)
          { if (k>m) { k=1; a=a/2.0; }}
        else
          { k=1; xx=x1; yy=y1;  z=z1;
            if (z<eps)
              { *x=xx; *y=yy; return; }
          }
      }
    *x=xx; *y=yy; return;
}
/////////////////////////////////////////////////////////////
void dnmtc(double x[],int n,double b,int m,double eps,
		   double (*dnmtcf)(double x[],int n))//求非線性方程組一組實根的蒙特卡洛法
{ 
	//extern double mrnd1();
    //extern double dnmtcf();
    int k,i;
    double a,r,*y,z,z1;
    y=(double*)malloc(n*sizeof(double));
    a=b; k=1; r=1.0; z=dnmtcf(x,n);
    while (a>=eps)
      { for (i=0; i<=n-1; i++)
          y[i]=-a+2.0*a*mrnd1(&r)+x[i];
        z1=dnmtcf(y,n);
        k=k+1;
        if (z1>=z)
          { if (k>m) { k=1; a=a/2.0; }}
        else
          { k=1; 
            for (i=0; i<=n-1; i++) x[i]=y[i];
            z=z1;
            if (z<eps)  return;
          }
	}
    return;
}
#endif
/////////////////////////////////////////////////////////////
//用戶自編函數定義參考:
/*double dnmtcf(double x[],int n)
{
	double f,f1,f2,f3;
    n=n;
    f1=3.0*x[0]+x[1]+2.0*x[2]*x[2]-3.0;
    f2=-3.0*x[0]+5.0*x[1]*x[1]+2.0*x[0]*x[2]-1.0;
    f3=25.0*x[0]*x[1]+20.0*x[2]+12.0;
    f=sqrt(f1*f1+f2*f2+f3*f3);
    return(f);
}
double datknf(double x)
{
	double y;
    y=6.0-x*x;
    return(y);
}
double dpqrtf(double x)
{ 
	double y;
    y=x*x*(x-1.0)-1.0;
    return(y);
}
double ddhrtf(double x)
{ 
	double z;
    z=(((((x-5.0)*x+3.0)*x+1.0)*x-7.0)*x+7.0)*x-20.0;
    return(z);
}
void dnewtf(double x,double y[])
{ 
	y[0]=x*x*(x-1.0)-1.0;
    y[1]=3.0*x*x-2.0*x;
    return;
}
double dsnsef(double x[],double y[],int n)
{
	double z,f1,f2,f3,df1,df2,df3;
    n=n;
    f1=x[0]-5.0*x[1]*x[1]+7.0*x[2]*x[2]+12.0;
    f2=3.0*x[0]*x[1]+x[0]*x[2]-11.0*x[0];
    f3=2.0*x[1]*x[2]+40.0*x[0];
    z=f1*f1+f2*f2+f3*f3;
    df1=1.0; df2=3.0*x[1]+x[2]-11.0; df3=40.0;
    y[0]=2.0*(f1*df1+f2*df2+f3*df3);
    df1=10.0*x[1]; df2=3.0*x[0]; df3=2.0*x[2];
    y[1]=2.0*(f1*df1+f2*df2+f3*df3);
    df1=14.0*x[2]; df2=x[0]; df3=2.0*x[1];
    y[2]=2.0*(f1*df1+f2*df2+f3*df3);
    return(z);
}
void dnetnf(double x[],double y[],int n)
{ 
	y[0]=x[0]*x[0]+x[1]*x[1]+x[2]*x[2]-1.0;
    y[1]=2.0*x[0]*x[0]+x[1]*x[1]-4.0*x[2];
    y[2]=3.0*x[0]*x[0]-4.0*x[1]+x[2]*x[2];
    n=n;
    return;
}
double dcmtcf(double x,double y)
{ 
	double u,v,z;
    u=x*x-y*y+x-y-2.0;
    v=2.0*x*y+x+y+2.0;
    z=sqrt(u*u+v*v);
    return(z);
}
double mrnd1(double* r)//From CH13 mrnd1.c
{ 
	int m;
    double s,u,v,p;
    s=65536.0; u=2053.0; v=13849.0;
    m=(int)(*r/s); *r=*r-m*s;
    *r=u*(*r)+v; m=(int)(*r/s);
    *r=*r-m*s; p=*r/s;
    return(p);
}
double dmtclf(double x)
{
	double y;
    y=exp(-x*x*x)-sin(x)/cos(x)+800.0;
    return(y);
}

void dnginf(int m,int n,double x[],double d[])
{ 
	m=m; n=n;
    d[0]=x[0]*x[0]+10.0*x[0]*x[1]+4.0*x[1]*x[1]+0.7401006;
    d[1]=x[0]*x[0]-3.0*x[0]*x[1]+2.0*x[1]*x[1]-1.0201228;
    return;
}

void dngins(int m,int n,double x[2],double* p)
{ m=m; n=n;
    p[0]=2.0*x[0]+7.0*x[1];
    p[1]=7.0*x[0]+6.0*x[1];
    p[2]=2.0*x[0]-2.0*x[1];
    p[3]=-2.0*x[0]+2.0*x[1];
    p[4]=1.0;
    p[5]=1.0;
    return;
}
*/
/////////////////////////////////////////////////////////////

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一二三专区| 亚洲国产一区二区视频| 国产精品国产三级国产aⅴ无密码| 中文字幕不卡一区| 亚洲女爱视频在线| 免费成人在线影院| 国产91精品精华液一区二区三区 | 99精品桃花视频在线观看| 在线视频一区二区免费| 欧美蜜桃一区二区三区| 久久亚洲影视婷婷| 亚洲国产精品久久人人爱| 国产乱人伦偷精品视频免下载| 91日韩在线专区| 精品日产卡一卡二卡麻豆| 亚洲精品一卡二卡| 国产成人精品免费视频网站| 在线电影院国产精品| 中文字幕一区二区5566日韩| 精品一区二区三区香蕉蜜桃| 色94色欧美sute亚洲线路二 | 日产国产欧美视频一区精品| 不卡视频一二三| 成人综合在线网站| 中文字幕乱码日本亚洲一区二区| 久久精品国内一区二区三区| 欧美日韩国产高清一区二区三区 | 国产精品美女久久久久av爽李琼 | 亚洲国产视频一区| 欧美日韩一区不卡| 日韩av电影免费观看高清完整版在线观看 | 国产在线视视频有精品| 91麻豆精品国产自产在线观看一区| 亚洲一区二区三区美女| 久久久久久久综合狠狠综合| 另类小说一区二区三区| 精品久久人人做人人爰| 狠狠色狠狠色综合系列| 国产精品丝袜久久久久久app| 不卡一卡二卡三乱码免费网站| 最新国产精品久久精品| 99国产精品久久久久久久久久| 一区二区三区不卡视频| 337p粉嫩大胆色噜噜噜噜亚洲| 色综合久久88色综合天天6| 久久免费精品国产久精品久久久久| 美国av一区二区| 亚洲午夜免费电影| 亚洲精品免费电影| 精品国产免费一区二区三区香蕉| 偷窥国产亚洲免费视频| 国产精品自拍三区| 欧美国产97人人爽人人喊| 粉嫩欧美一区二区三区高清影视| 2023国产精品视频| 成人性生交大片免费看在线播放 | 免费观看91视频大全| 久久久精品黄色| 欧美中文字幕亚洲一区二区va在线| 亚洲成av人片一区二区| 亚洲欧美影音先锋| 欧美国产激情一区二区三区蜜月 | 欧美三级午夜理伦三级中视频| www.亚洲人| 日本韩国欧美在线| 91国产免费看| 欧美一区二区福利视频| 欧美精品日韩综合在线| 日韩精品中午字幕| 9191国产精品| 欧美精品一区二区在线观看| 欧美日韩一二区| 久久婷婷成人综合色| 日韩理论片网站| 日本成人在线网站| 国产99久久久精品| 欧美无砖砖区免费| 中文乱码免费一区二区| 日韩福利视频导航| 亚洲成人av福利| 中文字幕视频一区二区三区久| 亚洲.国产.中文慕字在线| av电影天堂一区二区在线| 国产精品人成在线观看免费| 亚洲一区二区三区四区在线观看| 亚洲一区二区三区四区五区黄 | 精品一区二区免费视频| 国产99久久精品| 欧美喷水一区二区| 日韩欧美的一区二区| 亚洲欧美日韩国产成人精品影院| 亚洲色图色小说| 久久精品国产成人一区二区三区 | 婷婷综合五月天| 国产成人免费视频网站| 91麻豆精品秘密| 一本色道久久综合亚洲91| 91精品国产色综合久久不卡蜜臀| 日韩精品一区二区在线| 中文字幕亚洲欧美在线不卡| 性久久久久久久久| 高清不卡在线观看av| 91精品国产一区二区| 国产高清一区日本| 欧美精品一区二区蜜臀亚洲| 国产一区二区日韩精品| 国产午夜三级一区二区三| 经典一区二区三区| 日韩欧美一二三四区| 麻豆精品国产91久久久久久| 日韩欧美黄色影院| 国产成人综合在线播放| 国产女主播一区| 日本精品一区二区三区高清| 亚洲国产一区在线观看| 国产日本一区二区| 91精品国产欧美日韩| 91久久人澡人人添人人爽欧美| 日韩成人一区二区| 日韩综合在线视频| 一区二区三区不卡视频在线观看| 日韩欧美专区在线| 欧美亚洲综合久久| 精品视频123区在线观看| 91亚洲精品久久久蜜桃| 成人午夜激情视频| 亚洲日穴在线视频| 欧美一区二区久久| 欧美日韩国产片| 在线播放一区二区三区| 欧美日韩中文一区| 欧洲精品在线观看| 欧美图片一区二区三区| 7777精品伊人久久久大香线蕉完整版 | 不卡在线观看av| 成人午夜精品一区二区三区| 国产电影一区在线| 裸体在线国模精品偷拍| 六月丁香婷婷色狠狠久久| 毛片不卡一区二区| 国产综合色在线视频区| 国产成人自拍网| 色婷婷激情综合| 911精品国产一区二区在线| 欧美一区二区精美| 日韩亚洲电影在线| 久久久不卡网国产精品二区| 欧美国产丝袜视频| 亚洲国产精品欧美一二99| 轻轻草成人在线| 一本色道**综合亚洲精品蜜桃冫 | 日韩欧美一区在线| 亚洲国产精品99久久久久久久久| 国产精品免费网站在线观看| 1000部国产精品成人观看| 欧美一级国产精品| 欧美日韩激情一区二区| 色综合天天性综合| 成人av资源在线| 99视频超级精品| 一本大道久久a久久综合婷婷 | 中文av一区特黄| 国产亲近乱来精品视频| 国产亚洲短视频| 久久久久久免费毛片精品| 欧美日韩综合不卡| 欧美日韩激情在线| 日韩一区二区免费视频| 精品国产伦一区二区三区观看体验| 777欧美精品| 久久久久国产精品麻豆ai换脸| 久久久久久久网| 亚洲欧美乱综合| 一区二区三区欧美激情| 舔着乳尖日韩一区| 裸体健美xxxx欧美裸体表演| 亚洲图片欧美色图| 最新国产成人在线观看| 日韩主播视频在线| 国产成人综合在线观看| 91极品美女在线| 91精品国产综合久久久久久| 久久久青草青青国产亚洲免观| 亚洲欧美日韩国产中文在线| 青青草91视频| 成人午夜视频免费看| 国产成人免费网站| 国产成人在线影院 | 午夜精品一区二区三区免费视频| 精品一区二区在线观看| 欧美中文字幕一区二区三区| 国产精品三级在线观看| 国产在线精品一区二区夜色| 欧美日本在线看| 亚洲欧美视频在线观看| 国产成人在线电影| 337p粉嫩大胆噜噜噜噜噜91av| 亚洲成精国产精品女| 91论坛在线播放| 亚洲欧美日韩在线|