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

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

?? d9r10.cpp

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

int ndatat;
double xt[1001], yt[1001], arr[1001], aa, abdevt;

int sgn(double x)
{
	if (x>0)
	{
		return 1;
	}
	else
	{
		if(x<0)
		{
			return -1;
		}
	}
	return 0;
}

double gammln(double xx)
{
	double cof[7];
	cof[1] = 76.18009173;
	cof[2] = -86.50532033;
	cof[3] = 24.01409822;
	cof[4] = -1.231739516;
	cof[5] = 0.00120858003;
	cof[6] = -0.00000536382;
	double ser,x,tmp,stp = 2.50662827465;
	double half = 0.5;
	double one = 1.0;
	double fpf = 5.5;
	int j;
	x = xx - one;
	tmp = x + fpf;
	tmp = (x + half) * log(tmp) - tmp;
	ser = one;
	for (j = 1; j<=6; j++)
	{
		x = x + one;
		ser = ser + cof[j] / x;
	}
	return tmp + log(stp * ser);
}

void gcf(double& gammcf, double a, double x, double gln)
{
	int an,n,itmax = 100;
	double anf,g,ana,eps = 0.0000003;
	gln = gammln(a);
	double gold = 0.0;
	double a1,a0 = 1.0;
	a1 = x;
	double b0 = 0.0;
	double b1 = 1.0;
	double fac = 1.0;
	for (n = 1; n<=itmax; n++)
	{
		an = n;
		ana = an - a;
		a0 = (a1 + a0 * ana) * fac;
		b0 = (b1 + b0 * ana) * fac;
		anf = an * fac;
		a1 = x * a0 + anf * a1;
		b1 = x * b0 + anf * b1;
		if (a1 != 0.0)
		{
			fac = 1.0 / a1;
			g = b1 * fac;
			if (fabs((g - gold) / g) < eps)
			{
				gammcf = exp(-x + a * log(x) - gln) * g;
				return;
			}
			gold = g;
		}
	}
	cout<< "a too large, itmax too small"<<endl;
	gammcf = exp(-x + a * log(x) - gln) * g;
}

void gser(double& gamser, double a, double x, double gln)
{
	int n,itmax = 100;
	double ap,sum,del,eps = 0.0000003;
	gln = gammln(a);
	if (x <= 0.0)
	{
		if (x < 0.0)
		{
			cout<<"pause in gser"<<endl;
			return;
		}
		gamser = 0.0;
		return;
	}
	ap = a;
	sum = 1.0 / a;
	del = sum;
	for (n = 1; n<=itmax; n++)
	{
		ap = ap + 1.0;
		del = del * x / ap;
		sum = sum + del;
		if (fabs(del) < fabs(sum) * eps)
		{
			gamser = sum * exp(-x + a * log(x) - gln);
			return;
		}
	}
	cout<< "a too large, itmax too small";
	gamser = sum * exp(-x + a * log(x) - gln);
}

double gammq(double a, double x)
{
	double gamser,gammcf,gln=0;
	if (x < 0.0 || a <= 0.0)
	{
		cout<< "pause"<<endl;
		exit(1);
	}
	if (x < a + 1.0)
	{
		gser(gamser, a, x, gln);
		return 1.0 - gamser;
	}
	else
	{
		gcf(gammcf, a, x, gln);
		return gammcf;
	}
}

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 fit(double x[], double y[], int ndata, double sig[], int mwt, double& a,
		double& b, double& siga, double& sigb, double& chi2, double& q)
{
	int i;
    double sigdat,t,sxoss,wt,ss,sx = 0.0;
    double sy = 0.0;
    double st2 = 0.0;
    b = 0.0;
    if (mwt != 0)
	{
        ss = 0.0;
        for (i = 1; i<=ndata; i++)
		{
            wt = 1.0 / (sig[i] * sig[i]);
            ss = ss + wt;
            sx = sx + x[i] * wt;
            sy = sy + y[i] * wt;
        }
	}
    else
	{
        for (i = 1; i<=ndata; i++)
		{
            sx = sx + x[i];
            sy = sy + y[i];
        }
        ss = ndata;
    }
    sxoss = sx / ss;
    if (mwt != 0)
	{
        for (i = 1; i<=ndata; i++)
		{
            t = (x[i] - sxoss) / sig[i];
            st2 = st2 + t * t;
            b = b + t * y[i] / sig[i];
        }
	}
    else
	{
        for (i = 1; i<=ndata; i++)
		{
            t = x[i] - sxoss;
            st2 = st2 + t * t;
            b = b + t * y[i];
		}
    }
    b = b / st2;
    a = (sy - sx * b) / ss;
    siga = sqrt((1.0 + sx * sx / (ss * st2)) / ss);
    sigb = sqrt(1.0 / st2);
    chi2 = 0.0;
    if (mwt == 0)
	{
        for (i = 1; i<=ndata; i++)
		{
            chi2 = chi2 + pow((y[i] - a - b * x[i]) , 2);
        }
        q = 1.0;
        sigdat = sqrt(chi2 / (ndata - 2));
        siga = siga * sigdat;
        sigb = sigb * sigdat;
	}
    else
	{
        for (i = 1; i<=ndata; i++)
		{
            chi2 = chi2 + pow(((y[i] - a - b * x[i]) / sig[i]) , 2);
        }
        q = gammq(0.5 * (ndata - 2), 0.5 * chi2);
    }
}

void sort(int n, double ra[])
{
    int i,j,l,ir;
	double rra;
	l = int(n / 2) + 1;
    ir = n;
    do
	{
        if (l > 1)
		{
            l = l - 1;
            rra = ra[l];
		}
        else
		{
            rra = ra[ir];
            ra[ir] = ra[1];
            ir = ir - 1;
            if (ir == 1)
			{
              ra[1] = rra;
              return;
            }
        }
        i = l;
        j = l + l;
        while (j <= ir)
		{
            if (j < ir)
			{
                if (ra[j] < ra[j + 1])
				{
					j+=1;
				}
            }
            if (rra < ra[j])
			{
                ra[i] = ra[j];
                i = j;
                j += j;
			}
            else
			{
                j = ir + 1;
            }
        }
        ra[i] = rra;
    }while(1);
}

double rofunc(double b)
{
    int n1,j;
	double nml,nmh;
	double d;
	n1 = ndatat + 1;
    nml = (double)n1 / 2;
    nmh = n1 - nml;
    for (j = 1; j<=ndatat; j++)
	{
        arr[j] = yt[j] - b * xt[j];
    }
    sort(ndatat, arr);
    aa = 0.5 * (arr[(int)nml] + arr[(int)nmh]);
    double sum = 0.0;
    abdevt = 0.0;
    for (j = 1; j<=ndatat; j++)
	{
        d = yt[j] - (b * xt[j] + aa);
        abdevt = abdevt + fabs(d);
        sum = sum + xt[j] * sgn(d);
    }
    return sum;
}

void medfit(double x[], double y[], int ndata, double& a, double& b, double& abdev)
{
	int j;
    double bb,del,chisq,f,sx = 0.0;
    double sigb,b1,b2,f1,f2,sy = 0.0;
    double sxy = 0.0;
    double sxx = 0.0;
    for (j = 1; j<=ndata; j++)
	{
        xt[j] = x[j];
        yt[j] = y[j];
        sx = sx + x[j];
        sy = sy + y[j];
        sxy = sxy + x[j] * y[j];
        sxx = sxx + x[j] * x[j];
    }
    ndatat = ndata;
    del = ndata * sxx - sx * sx;
    aa = (sxx * sy - sx * sxy) / del;
    bb = (ndata * sxy - sx * sy) / del;
    chisq = 0.0;
    for (j = 1; j<=ndata; j++)
	{
        chisq = chisq + pow((y[j] - (aa + bb * x[j])) , 2);
    }
    sigb = sqrt(chisq / del);
    b1 = bb;
    f1 = rofunc(b1);
    b2 = bb + fabs(3 * sigb) * sgn(f1);
    f2 = rofunc(b2);
    while (f1 * f2 > 0.0)
	{
        bb = 2.0 * b2 - b1;
        b1 = b2;
        f1 = f2;
        b2 = bb;
        f2 = rofunc(b2);
	}
    sigb = 0.01 * sigb;
    while (fabs(b2 - b1) > sigb)
	{
        bb = 0.5 * (b1 + b2);
        if (bb == b1 || bb == b2)
		{
			break;
		}
        f = rofunc(bb);
        if (f * f1 >= 0.0)
		{
            f1 = f;
            b1 = bb;
		}
        else
		{
            f2 = f;
            b2 = bb;
        }
    }
    a = aa;
    b = bb;
    abdev = abdevt / ndata;
}

void main()
{
    //program d9r10
    //driver for routine medfit
    int i,npt = 100;
    double a,b,siga,sigb,chi2,q,abdev,spread = 0.1;
    double x[101], y[101], sig[101];
    long idum = -1984;
    for (i = 1; i<=npt; i++)
	{
        x[i] = 0.1 * i;
        y[i] = -2.0 * x[i] + 1.0 + spread * gasdev(idum);
        sig[i] = spread;
    }
    int mwt = 1;
    fit(x, y, npt, sig, mwt, a, b, siga, sigb, chi2, q);
	cout.setf(ios::fixed|ios::left);
	cout.precision(4);
    cout<<"According to routine fit the result is:"<<endl;
    cout<<endl;
    cout<<"a = ";
	cout.width(12);
	cout<<a;
	cout<<"Uncertainty: ";
	cout.width(12);
    cout<<siga<<endl;
	cout<<endl;
    cout<<"b = ";
	cout.width(12);
	cout<<b;
	cout<<"Uncertainty: ";
    cout<<sigb<<endl;
    cout<<endl;
    cout<<"Chi-squared: ";
	cout.width(12);
	cout<<chi2<<" for   ";
	cout.width(5);
	cout<<npt<<"points";
    cout<<endl;cout<<endl;
    cout<<"Goodness-of-fit: ";
	cout.width(12);
	cout<<q;
    cout<<endl;cout<<endl;
    cout<<"According to routine medfit the result is:";
    cout<<endl;cout<<endl;
    medfit(x, y, npt, a, b, abdev);
    cout<<"a = ";
	cout.width(12);
	cout<<a;
    cout<<"b = ";
	cout.width(12);
	cout<<b;
    cout<<endl;cout<<endl;
    cout<<"Absolute deviation (per data point): ";
	cout.width(12);
	cout<<abdev;
    cout<<endl;cout<<endl;
    cout<<"(note: Gaussian spread is  ";
	cout<<spread;
	cout<<")";
	cout<<endl;cout<<endl;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲免费资源在线播放| av高清不卡在线| 亚洲国产精品自拍| 亚洲欧洲国产专区| 亚洲国产成人一区二区三区| 精品欧美乱码久久久久久 | 99国产精品视频免费观看| 国产精品亚洲人在线观看| 日韩成人一级片| 奇米影视在线99精品| 日本中文在线一区| 麻豆一区二区99久久久久| 麻豆精品在线播放| 国产黄色成人av| 成人av在线观| 岛国一区二区三区| 97精品久久久午夜一区二区三区| 成人黄色在线视频| 91成人免费网站| 欧美日韩mp4| 亚洲精品在线网站| 国产精品美女久久久久高潮| 亚洲乱码精品一二三四区日韩在线| 亚洲视频你懂的| 日日嗨av一区二区三区四区| 韩国中文字幕2020精品| 成人午夜在线免费| 欧美亚洲动漫制服丝袜| 日韩三级在线观看| 日韩美女视频一区| 奇米影视一区二区三区| youjizz久久| 日韩视频免费直播| 亚洲私人影院在线观看| 日本aⅴ精品一区二区三区 | 国产清纯白嫩初高生在线观看91 | 久久久国产一区二区三区四区小说 | 欧美老人xxxx18| 日本亚洲免费观看| 理论电影国产精品| 不卡的电影网站| 欧美日韩高清影院| 国产精品天天摸av网| 日韩国产欧美在线视频| 99re成人在线| 2014亚洲片线观看视频免费| 中文字幕亚洲精品在线观看 | 欧美体内she精视频| 久久蜜桃香蕉精品一区二区三区| 国产精品福利一区二区三区| 久久精品国产亚洲一区二区三区| 99久久免费精品| 欧美一区二区三区色| 亚洲精品乱码久久久久久黑人 | 国产欧美一区二区在线观看| 亚洲成人在线网站| 成人国产精品视频| 久久久蜜桃精品| 视频一区中文字幕国产| 欧洲精品在线观看| 亚洲人成在线观看一区二区| 国产乱妇无码大片在线观看| 在线不卡a资源高清| 一区二区在线看| 91在线视频在线| 国产精品第13页| 高清免费成人av| 欧美经典三级视频一区二区三区| 国模娜娜一区二区三区| 久久精品久久综合| 欧美高清dvd| 一区二区三区四区乱视频| 欧美年轻男男videosbes| 色呦呦网站一区| 国产精品色婷婷久久58| 国产成人午夜精品影院观看视频| 国产精品18久久久| 久久综合久久鬼色中文字| 久久99精品一区二区三区| 精品国内二区三区| 久久9热精品视频| 久久综合九色综合97_久久久| 日韩国产精品久久久| 色天天综合久久久久综合片| 最新国产の精品合集bt伙计| www.亚洲在线| 亚洲宅男天堂在线观看无病毒| 成人国产精品免费| 亚洲激情综合网| 欧美日韩亚洲高清一区二区| 麻豆91免费观看| 国产亚洲欧美日韩日本| 成人av免费在线| 一区二区三区精密机械公司| 欧美疯狂性受xxxxx喷水图片| 欧美aaa在线| 中文一区二区完整视频在线观看| av电影在线观看一区| 亚洲成人在线观看视频| 日韩一区二区在线观看视频 | 国产成人午夜高潮毛片| 国产精品网曝门| 欧美日韩一区不卡| 国产综合久久久久影院| 国产精品毛片无遮挡高清| 欧美日韩电影一区| 国产不卡在线视频| 亚洲午夜影视影院在线观看| 精品久久久久久无| 99精品偷自拍| 九九在线精品视频| 亚洲在线成人精品| 国产视频一区在线播放| 欧日韩精品视频| 成人高清视频在线| 日本成人在线电影网| 欧美高清在线一区| 日韩亚洲欧美综合| 一本久道中文字幕精品亚洲嫩| 久久不见久久见免费视频7| 亚洲欧美成aⅴ人在线观看| 精品福利在线导航| 欧美日韩五月天| aaa亚洲精品| 国产激情一区二区三区| 日韩av电影免费观看高清完整版| 国产日产欧美精品一区二区三区| 欧美另类z0zxhd电影| 99国产一区二区三精品乱码| 韩国欧美国产一区| 日产国产高清一区二区三区| 亚洲免费观看高清完整版在线 | 久久精品国产亚洲一区二区三区 | 欧美一级艳片视频免费观看| 91亚洲精华国产精华精华液| 狠狠色丁香婷婷综合久久片| 日韩在线a电影| 亚洲综合小说图片| 亚洲欧美日韩一区| 中文字幕综合网| 中文一区一区三区高中清不卡| 久久久精品人体av艺术| 日韩精品专区在线| 欧美成va人片在线观看| 制服丝袜日韩国产| 欧美精品电影在线播放| 欧美三级日本三级少妇99| 91福利国产精品| 欧美中文字幕一区二区三区| 色综合网色综合| 91国产免费观看| 欧美三级午夜理伦三级中视频| 91久久精品国产91性色tv| 91亚洲精品一区二区乱码| 99国产精品久久久久久久久久 | 欧美日韩一区二区三区四区五区 | 成人听书哪个软件好| 国产激情视频一区二区在线观看| 国产一区二区三区综合| 国产成人精品影视| 成人激情小说乱人伦| 99精品国产视频| 欧美三日本三级三级在线播放| 欧美午夜影院一区| 欧美亚男人的天堂| 8x8x8国产精品| 久久久国产一区二区三区四区小说| 久久久美女毛片| 亚洲婷婷国产精品电影人久久| 一区二区在线免费| 日韩精品电影在线| 国产麻豆精品一区二区| 成人av在线资源| 欧美日韩一区二区三区四区| 欧美xfplay| 亚洲欧洲精品天堂一级| 日韩精品成人一区二区在线| 精品综合免费视频观看| 北条麻妃一区二区三区| 欧美日韩国产综合视频在线观看 | 不卡在线观看av| 欧美群妇大交群的观看方式| 久久婷婷国产综合精品青草| 国产精品国产自产拍在线| 午夜精品福利久久久| 国产很黄免费观看久久| 欧美日韩亚洲国产综合| 欧美韩国一区二区| 日韩av电影免费观看高清完整版在线观看 | 免费在线观看日韩欧美| 成人国产精品免费观看动漫| 91精品综合久久久久久| 国产精品午夜春色av| 奇米在线7777在线精品| 99国产精品久久久久久久久久 | 亚洲图片自拍偷拍| 丁香婷婷深情五月亚洲| 91精品久久久久久久99蜜桃| 国产精品久久久久久久裸模| 日韩激情一区二区|