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

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

?? d9r2.cpp

?? 這個是常用的數值算法用VC編寫的。相信對大家有用哦。
?? CPP
字號:
#include "iostream.h"
#include "math.h"
#include "stdlib.h"

double ran1(long& idum)
{
    int j,iff=-1;
	static long ix1,ix2,ix3;
	static double r[98];
    long m1 = 259200; long m2 = 134456; long m3 = 243000;
	long ia1 = 7141; long ia2 = 8121; long ia3 = 4561;
	long ic1 = 54773; long ic2 = 28411; long ic3 = 51349;
	double rm1 = 0.0000038580247; double rm2 = 0.0000074373773;    
    if (idum < 0 || iff == 0)
	{
        iff = 1;
        ix1 = (ic1 - idum) % m1;
        ix1 = (ia1 * ix1 + ic1) % m1;
        ix2 = ix1 % m2;
        ix1 = (ia1 * ix1 + ic1) % m1;
        ix3 = ix1 % m3;
        for (j = 1; j<=97; j++)
		{
            ix1 = (ia1 * ix1 + ic1) % m1;
            ix2 = (ia2 * ix2 + ic2) % m2;
            r[j] = (double(ix1) + double(ix2) * rm2) * rm1;
        }
        idum = 1;
    }
    ix1 = (ia1 * ix1 + ic1) % m1;
    ix2 = (ia2 * ix2 + ic2) % m2;
    ix3 = (ia3 * ix3 + ic3) % m3;
    j = 1 + int((97 * ix3) / m3);
    if (j > 97 || j < 1)
	{
		cout<<"abnormal exit in ran1"<<endl;
		exit(1);
	}
	double temp=r[j];
    r[j] = (double(ix1) + double(ix2) * rm2) * rm1;
	return temp;
}

double gasdev(long& idum)
{
    static int iset;
	static double gset;
	double v1,v2,r,fac;
    if (iset == 0)
	{
		do
		{
			v1 = 2.0 * ran1(idum) - 1.0;
			v2 = 2.0 * ran1(idum) - 1.0;
			r = v1 * v1 + v2 * v2;
		}while (r >= 1.0 || r == 0);
		fac = sqrt(-2.0 * log(r) / r);
		gset = v1 * fac;
		iset = 1;
		return v2 * fac;
	}
    else
	{
		iset = 0;
		return gset;
    }
}

void covsrt(double covar[], int ncvm, int ma, int lista[], int mfit)
{
	int i,j;
	double swap;
	for (j = 1; j<=ma - 1; j++)
	{
		for (i = j + 1; i<=ma; i++)
		{
			covar[(i-1)*ma+j] = 0.0;
		}
    }
    for (i = 1; i<=mfit - 1; i++)
	{
        for (j = i + 1; j<=mfit; j++)
		{
            if (lista[j] > lista[i])
			{
                covar[(lista[j]-1)*ma+lista[i]] = covar[(i-1)*ma+j];
			}
            else
			{
               covar[(lista[i]-1)*ma+lista[j]] = covar[(i-1)*ma+j];
            }
        }
    }
    swap = covar[1];;
    for (j = 1; j<=ma; j++)
	{
        covar[j] = covar[(j-1)*ma+j];
        covar[(j-1)*ma+j] = 0.0;
    }
    covar[(lista[1]-1)*ma+lista[1]] = swap;
    for (j = 2; j<=mfit; j++)
	{
        covar[(lista[j]-1)*ma+lista[j]] = covar[j];
    }
    for (j = 2; j<=ma; j++)
	{
        for (i = 1; i<=j - 1; i++)
		{
            covar[(i-1)*ma+j] = covar[(j-1)*ma+i];
		}
	}
}

void gaussj(double a[], int n, int ma,double b[])
{
	int i,j,k,l,ll,irow,icol;
	double big,pivinv,dum;
    int ipiv[51], indxr[51], indxc[51];
    for (j=1;j<=n;j++)
	{
        ipiv[j]=0;
    }
    for (i=1;i<=n;i++)
	{
        big=0.0;
        for (j=1;j<=n;j++)
		{
            if(ipiv[j]!=1)
			{
                for(k=1;k<=n;k++)
				{
					if(ipiv[k]==0)
					{
						if(fabs(a[(j-1)*ma+k])>=big)
						{
							big=fabs(a[(j-1)*ma+k]);
							irow=j;
							icol=k;
						}
						else if(ipiv[k]>1)
						{
							cout<<"singular matrix";
						}
					}
                }
            }
        }
        ipiv[icol]=ipiv[icol]+1;
        if(irow!=icol)
		{
            for(l=1;l<=n;l++)
			{
                dum=(a[(irow-1)*ma+l]);
                a[(irow-1)*ma+l]=a[(icol-1)*ma+l];
                a[(icol-1)*ma+l]=dum;
            }
            dum=b[irow];
            b[irow]=b[icol];
            b[icol]=dum;
		}
        indxr[i]=irow;
        indxc[i]=icol;
        if(a[(icol-1)*ma+icol]==0.0)
		{
			cout<< "singular matrix.";
		}
        pivinv=1.0/(a[(icol-1)*ma+icol]);
        a[(icol-1)*ma+icol]=1.0;
        for(l=1;l<=n;l++)
		{
            a[(icol-1)*ma+l]=a[(icol-1)*ma+l]*pivinv;
        }
        b[icol]=b[icol]*pivinv;
        for(ll=1;ll<=n;ll++)
        {
            if(ll!=icol)
			{
                dum=a[(ll-1)*ma+icol];
                a[(ll-1)*ma+icol]=0.0;
                for(l=1;l<=n;l++)
				{
                    a[(ll-1)*ma+l]=a[(ll-1)*ma+l]-a[(icol-1)*ma+l]*dum;
                }
                b[ll]=b[ll]-b[icol]*dum;
            }
        }
	}	
    for(l=n;l>=1;l--)
	{
        if(indxr[l]!=indxc[l])
		{
            for(k=1;k<=n;k++)
			{
                dum=a[(k-1)*ma+indxr[l]];
                a[(k-1)*ma+indxr[l]]=a[(k-1)*ma+indxc[l]];
                a[(k-1)*ma+indxr[l]]=dum;
            }
        }
    }
}

void funcs(double x, double afunc[], int ma)
{
	int i;
    afunc[1] = 1.0;
    for (i = 2; i<=ma; i++)
	{
        afunc[i] = x * afunc[i - 1];
    }
}

void lfit(double x[], double y[], double sig[], int ndata, double a[],int ma,
		  int lista[], int mfit, double covar[], int ncvm, double& chisq)
{
	int i,j,k,kk,ihit;
	double ym,sig2i,wt,sum;
    double beta[51], afunc[51];
    kk = mfit + 1;
    for (j = 1; j<=ma; j++)
	{
        ihit = 0;
        for (k = 1; k<=mfit; k++)
		{
            if (lista[k] == j)
			{
				ihit = ihit + 1;
			}
        }
        if (ihit == 0)
		{
            lista[kk] = j;
            kk = kk + 1;
		}
        else
		{
			if (ihit > 1)
			{
				cout<<" improper set in lista"<<endl;
			}
        }
    }
    if (kk != (ma + 1))
	{
		cout<<" improper set in lista"<<endl;
	}
    for (j = 1; j<=mfit; j++)
	{
        for (k = 1; k<=mfit; k++)
		{
            covar[(j-1)*ma+k] = 0.0;
        }
        beta[j] = 0.0;
    }
    for (i = 1; i<=ndata; i++)
	{
        funcs(x[i], afunc, ma);
        ym = y[i];
        if (mfit < ma)
		{
            for (j = mfit + 1; j<=ma; j++)
			{
                ym = ym - a[lista[j]] * afunc[lista[j]];
            }
        }
        sig2i = 1.0 / (sig[i] * sig[i]);
        for (j = 1; j<=mfit; j++)
		{
            wt = afunc[lista[j]] * sig2i;
            for (k = 1; k<=j; k++)
			{
                covar[(j-1)*ma+k] = covar[(j-1)*ma+k] + wt * afunc[lista[k]];
			}
            beta[j] = beta[j] + ym * wt;
        }
    }
    if (mfit > 1)
	{
        for (j = 2; j<=mfit; j++)
		{
            for (k = 1; k<=j - 1; k++)
			{
                covar[(k-1)*ma+j] = covar[(j-1)*ma+k];
            }
        }
    }
    gaussj(covar, mfit,ma,beta);
    for (j = 1; j<=mfit; j++)
	{
        a[lista[j]] = beta[j];
    }
    chisq = 0.0;
    for (i = 1; i<=ndata; i++)
	{
        funcs(x[i], afunc, ma);
        sum = 0.0;
        for (j = 1; j<=ma; j++)
		{
            sum = sum + a[j] * afunc[j];
        }
        chisq = chisq + ((y[i] - sum) / sig[i]) * ((y[i] - sum) / sig[i]);
    }
    covsrt(covar, ncvm, ma, lista, mfit);
}

void main()
{
    //program d9r2
    //driver for routine lfit
    int i,j,npt = 100;
    double chisq,spread = 0.1;
    int mfit,nterm = 3;
    double x[101], y[101], sig[101], a[4], covar[10];
	int lista[4];
    long idum = -911;
    for (i = 1; i<=npt; i++)
	{
        x[i] = 0.1 * i;
        y[i] = nterm;
        for (j = nterm - 1; j>=1; j--)
		{
            y[i] = j + y[i] * x[i];
        }
        y[i] = y[i] + spread * gasdev(idum);
        sig[i] = spread;
    }
    mfit = nterm;
    for (i = 1; i<=mfit; i++)
	{
        lista[i] = i;
    }
    lfit(x, y, sig, npt, a, nterm, lista, mfit, covar, nterm, chisq);
    cout<<"Parameter               Uncertainty"<<endl;
	cout.setf(ios::scientific|ios::left);
	cout.precision(4);
    for (i = 1; i<=nterm; i++)
	{
        cout<<"a("<<i<<")= ";
		cout.width(18);
		cout<<a[i];
		cout.width(18);
        cout<<sqrt(covar[(i-1)*nterm+i]);
		cout<<endl;
    }
    cout<<endl;
    cout<<"Chi-squared =  "<<chisq<<endl;
    cout<<endl;
    cout<<"Full covariance matrix"<<endl;
    for (i = 1; i<=nterm; i++)
	{
        for (j = 1; j<=nterm; j++)
		{
			cout.width(18);
            cout<<covar[(i-1)*nterm+j];
        }
		cout<<endl;
    }
    //now test the lista feature
    for (i = 1; i<=nterm; i++)
	{
        lista[i] = nterm + 1 - i;
    }
    lfit(x, y, sig, npt, a, nterm, lista, mfit, covar, nterm, chisq);
    cout<<endl;
    cout<<"Parameter               Uncertainty"<<endl;
    for (i = 1; i<=nterm; i++)
	{
        cout<<"a("<<i<<")= ";
		cout.width(18);
		cout<<a[i];
		cout.width(18);
		cout<<sqrt(covar[(i-1)*nterm+i])<<endl;
    }
    cout<<endl;
    cout<<"Chi-squared =  "<<chisq<<endl;
    cout<<endl;
    cout<<"Full covariance matrix"<<endl;
    for (i = 1; i<=nterm; i++)
	{
        for (j = 1; j<=nterm; j++)
		{
			cout.width(18);
            cout<<covar[(i-1)*nterm+j];
        }
		cout<<endl;
    }
    //now check results of restricting fit parameters
    int ii = 1;
	int aaa;
    for (i = 1; i<=nterm; i++)
	{
        aaa = i - int(i / 2) * 2;
        if (aaa == 1)
		{
            lista[ii] = i;
            ii = ii + 1;
        }
    }
    mfit = ii - 1;
    lfit(x, y, sig, npt, a, nterm, lista, mfit, covar, nterm, chisq);
    cout<<endl;
    cout<<"Parameter               Uncertainty"<<endl;
    for (i = 1; i<=nterm; i++)
	{
        cout<<"a("<<i<<")= ";
		cout.width(18);
		cout<<a[i];
		cout.width(18);
		cout<<sqrt(covar[(i-1)*nterm+i])<<endl;
    }
    cout<<endl;
    cout<<"Chi-squared =  "<<chisq<<endl;
    cout<<endl;
    cout<<"Full covariance matrix"<<endl;
    for (i = 1; i<=nterm; i++)
	{
        for (j = 1; j<=nterm; j++)
		{
			cout.width(18);
            cout<<covar[(i-1)*nterm+j];
        }
		cout<<endl;
    }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
综合久久久久久久| 色乱码一区二区三区88| 欧美精品一区二区三区视频 | 欧美另类变人与禽xxxxx| 尤物在线观看一区| 欧美日韩综合色| 六月丁香婷婷色狠狠久久| 欧美成人a视频| 成人福利电影精品一区二区在线观看| 国产精品久久久久一区二区三区 | 国产精品亚洲专一区二区三区| xvideos.蜜桃一区二区| 成人午夜看片网址| 亚洲免费资源在线播放| 777午夜精品免费视频| 韩日欧美一区二区三区| 综合色中文字幕| 7777精品伊人久久久大香线蕉完整版| 久久精品久久久精品美女| 欧美国产日韩精品免费观看| 91电影在线观看| 国产自产v一区二区三区c| 日韩美女视频19| 日韩一区二区三| 99免费精品视频| 蜜臀99久久精品久久久久久软件| 国产婷婷色一区二区三区四区| 日本韩国欧美一区二区三区| 美女看a上一区| 亚洲毛片av在线| 久久亚洲影视婷婷| 欧美日韩国产美女| www.99精品| 激情综合网最新| 亚洲v精品v日韩v欧美v专区| 中文字幕精品综合| 日韩一区二区在线免费观看| 91网上在线视频| 国产毛片一区二区| 视频在线在亚洲| 亚洲欧美日本韩国| 欧美极品另类videosde| 日韩午夜激情免费电影| 欧美曰成人黄网| 丁香天五香天堂综合| 免费在线一区观看| 亚洲二区视频在线| 亚洲男女一区二区三区| 日本一区二区综合亚洲| 日韩欧美一区二区在线视频| 日本黄色一区二区| aaa国产一区| 成人av在线看| 国产精品18久久久久久vr| 国产91精品一区二区| 日韩av一区二区三区四区| 亚洲一区二区欧美| 亚洲欧洲www| 中文字幕在线一区免费| 国产欧美日韩另类一区| 日韩精品一区二区三区在线播放 | 人人狠狠综合久久亚洲| 亚洲激情五月婷婷| 国产精品高潮呻吟| 日本一区二区三区免费乱视频 | 欧美日本一道本| 色综合天天天天做夜夜夜夜做| 国产精品一区二区你懂的| 紧缚奴在线一区二区三区| 久久av中文字幕片| 韩国av一区二区三区在线观看| 美女在线观看视频一区二区| 爽好多水快深点欧美视频| 亚洲国产成人tv| 日韩综合小视频| 秋霞成人午夜伦在线观看| 蜜臀91精品一区二区三区| 男女视频一区二区| 久久国产精品99久久人人澡| 精久久久久久久久久久| 激情欧美一区二区| 国产成人精品一区二区三区四区| 国产精品伊人色| 成人美女在线视频| 色妹子一区二区| 欧美精品久久99久久在免费线| 欧美丰满一区二区免费视频| 欧美一区二区三区免费| 欧美电影免费观看高清完整版在| 精品久久久久一区二区国产| 国产拍揄自揄精品视频麻豆| 国产精品成人一区二区艾草| 亚洲一区二区免费视频| 日韩和欧美一区二区三区| 另类综合日韩欧美亚洲| 国产乱子伦视频一区二区三区| 成人三级伦理片| 在线亚洲免费视频| 欧美挠脚心视频网站| 欧美电影免费提供在线观看| 国产精品色眯眯| 夜夜亚洲天天久久| 久久99精品国产麻豆不卡| 国产成人在线视频网站| 色综合久久中文字幕| 欧美一区二区精品在线| 中文成人综合网| 午夜影院在线观看欧美| 国产成人午夜电影网| 在线视频一区二区三| 日韩欧美国产综合| 日韩理论片中文av| 人人狠狠综合久久亚洲| 成人毛片老司机大片| 4438x成人网最大色成网站| 久久久久国色av免费看影院| 亚洲综合网站在线观看| 激情丁香综合五月| 91麻豆swag| 久久久久高清精品| 亚洲h动漫在线| av男人天堂一区| 国产精品久久三区| 午夜一区二区三区视频| 懂色av中文一区二区三区 | 92国产精品观看| 欧美大片在线观看一区| 亚洲日本在线看| 国产中文字幕精品| 欧美日韩中文字幕一区| 欧美国产精品一区| 免费精品视频最新在线| 91老师国产黑色丝袜在线| 久久影院午夜论| 日本视频在线一区| 在线观看视频91| 国产精品久久久99| 国产麻豆视频精品| 欧美一区二区三区四区久久| 亚洲天堂久久久久久久| 国产91丝袜在线观看| 欧美xxxxx裸体时装秀| 亚洲bt欧美bt精品| 欧美自拍丝袜亚洲| 亚洲日本电影在线| 国产成人日日夜夜| 久久久久久亚洲综合| 美女脱光内衣内裤视频久久网站| 在线观看不卡一区| 亚洲蜜桃精久久久久久久| 成人精品国产一区二区4080| 久久一夜天堂av一区二区三区| 日韩 欧美一区二区三区| 欧美日韩一级黄| 亚洲国产精品久久久男人的天堂| 日本道色综合久久| 亚洲视频一区在线| 99re8在线精品视频免费播放| 欧美国产乱子伦 | 久久99久久久久| 91麻豆精品久久久久蜜臀| 亚洲第一会所有码转帖| 欧美午夜电影在线播放| 一区二区三区不卡在线观看 | 亚洲国产成人在线| 国产精品主播直播| 国产农村妇女毛片精品久久麻豆 | av福利精品导航| 综合色中文字幕| 色婷婷狠狠综合| 亚洲成av人片一区二区| 欧美日韩日日夜夜| 麻豆精品国产传媒mv男同| 精品国产成人系列| 国产高清一区日本| 天天色天天操综合| 日韩欧美一区二区免费| 国产精品一区二区你懂的| 日本一区二区三区久久久久久久久不| 国产精品亚洲一区二区三区在线| 国产视频一区在线播放| 99久久精品久久久久久清纯| 亚洲精品伦理在线| 在线播放中文字幕一区| 日本在线不卡视频| 久久久久99精品国产片| 97se亚洲国产综合自在线| 一区二区高清在线| 欧美一级精品大片| 国产福利一区在线| 亚洲欧美一区二区久久| 欧美另类久久久品| 国产精品一二三四区| 亚洲女性喷水在线观看一区| 欧美午夜不卡视频| 激情五月婷婷综合网| 亚洲视频图片小说| 日韩限制级电影在线观看| 成人国产亚洲欧美成人综合网| 亚洲一区二区三区四区中文字幕|