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

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

?? lsq.cpp

?? orange源碼 數據挖掘技術
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// TODO: CopyRight .. =???

#include <math.h>
#include "lsq.h"
//#include <malloc.h>

void xdisaster() {
}

void lsq::startup(int nvar, bool fit_const) {
/*
!     Allocates dimensions for arrays and initializes to zero
!     The calling program must set nvar = the number of variables, and
!     fit_const = true if a constant is to be included in the model,
!     otherwise fit_const = false
!
	!--------------------------------------------------------------------------*/
	
	int i;
	
	nobs = 0;
	if (fit_const) {
		ncol = nvar + 1;
	} else {
		ncol = nvar;
	}
	
	if (initialized) {
		free(d);
		free(rhs);
		free(r);
		free(tol);
		free(rss);
		free(vorder);
	}
	
	r_dim = ncol * (ncol - 1)/2;
	
	++ncol;
	++r_dim;
	d = (double*)malloc(sizeof(double)*ncol);
	rhs = (double*)malloc(sizeof(double)*ncol);
	tol = (double*)malloc(sizeof(double)*ncol);
	rss = (double*)malloc(sizeof(double)*ncol);
	vorder = (int*)malloc(sizeof(int)*ncol);
	r = (double*)malloc(sizeof(double)*r_dim);
	--ncol;
	--r_dim;
	
	for (i = 0; i <= ncol; ++i) {
		d[i] = zero;
		rhs[i] = zero;
	}
//nt tmpc=0;
	for (i = 0; i <= r_dim; ++i) {
/*		if (i%((ncol+ncol-tmpc)/2 + 1)==0) {
			tmpc++;
			r[i]=0.5;
		}
		else*/
			r[i] = zero;
	}
	sserr = zero;
	
	if (fit_const) {
		for (i = 1; i <= ncol; ++i) {
			vorder[i] = i-1;
		}
	} else { 	
		for (i = 1; i <= ncol; ++i) {
			vorder[i] = i;
		}
	}

	initialized = true;
	tol_set = false;
	rss_set = false;
}

void lsq::includ(double weight, double *xrow, double yelem) {
/*
!     ALGORITHM AS75.1  APPL. STATIST. (1974) VOL.23, NO. 3
!     Calling this routine updates D, R, RHS and SSERR by the
!     inclusion of xrow, yelem with the specified weight.
!     *** WARNING  Array XROW is overwritten.
!     N.B. As this routine will be called many times in most applications,
!          checks have been eliminated.
!
!--------------------------------------------------------------------------
	*/
	int i, k, nextr;
	double w, y, xi, di, wxi, dpi, cbar, sbar, xk;
	
	nobs = nobs + 1;
	w = weight;
	y = yelem;
	rss_set = false;
	nextr = 1;
	for (i = 1; i <= ncol; ++i) {
		//!     Skip unnecessary transformations.   Test on exact zeroes must be
		//!     used or stability can be destroyed.
		
		if (fabs(w) < vsmall)
			return;
		xi = xrow[i];
		if (fabs(xi) < vsmall)
			nextr = nextr + ncol - i;
		else {
			di = d[i];
			wxi = w * xi;
			dpi = di + wxi*xi;
			cbar = di / dpi;
			sbar = wxi / dpi;
			w = cbar * w;
			d[i] = dpi;
			for (k = i+1; k <= ncol; ++k) {
 				xk = xrow[k];
				xrow[k] = xk - xi * r[nextr];
				r[nextr] = cbar * r[nextr] + sbar * xk;
				nextr = nextr + 1;
			}
			xk = y;
			y = xk - xi * rhs[i];
			rhs[i] = cbar * rhs[i] + sbar * xk;
		}
	}
	
	//!     Y * sqrt(W) is now equal to the Brown, Durbin & Evans recursive
	//!     residual.
	
	sserr = sserr + w * y * y;
	
}


void lsq::regcf(double *beta, int nreq, int& ifault) {
/*
!     ALGORITHM AS274  APPL. STATIST. (1992) VOL.41, NO. 2
!     Modified version of AS75.4 to calculate regression coefficients
!     for the first NREQ variables, given an orthogonal reduction from
!     AS75.1.
!
!--------------------------------------------------------------------------
	*/
	int i, j, nextr;
	
	ifault = 0;
	if (nreq < 1 || nreq > ncol) 
		ifault = ifault + 4;
	if (ifault != 0) 
		return;
	
	if (!tol_set) 
		tolset();
	
	for (i = nreq; i >= 1; --i) {
		if (sqrt(d[i]) < tol[i]) {
			beta[i] = zero;
			d[i] = zero;
		} else {
			beta[i] = rhs[i];
			nextr = (i-1) * (ncol+ncol-i)/2 + 1;
			for(j = i+1; j <= nreq; ++j) {
				beta[i] -= r[nextr] * beta[j];
				nextr = nextr + 1;
			}
		}
	}
	
	return;
}




void lsq::tolset() {
/*
!     ALGORITHM AS274  APPL. STATIST. (1992) VOL.41, NO. 2

  !     Sets up array TOL for testing for zeroes in an orthogonal
  !     reduction formed using AS75.1.
	*/
	int col, row, pos,i;
	double eps, ten = 10.0, total, *work;
	
	work = new double[ncol+1];
	eps = .2220e-7;
	
	/*
	!     Set tol(i) = sum of absolute values in column I of R after
	!     scaling each element by the square root of its row multiplier,
	!     multiplied by EPS.
	*/
	
	for (i = 1; i <= ncol; ++i) {
		work[i] = sqrt(d[i]);
	}
	for(col = 1; col <= ncol; ++col) {
		pos = col - 1;
		total = work[col];
		for(row = 1; row < col; ++row) {
			total = total + fabs(r[pos]) * work[row];
			pos = pos + ncol - row - 1;
		}
		tol[col] = eps * total;
	}
	
	tol_set = true;
	delete[] work;
}



void lsq::sing(bool* lindep, int& ifault) {
/*
!     ALGORITHM AS274  APPL. STATIST. (1992) VOL.41, NO. 2
!     Checks for singularities, reports, and adjusts orthogonal
!     reductions produced by AS75.1.
!--------------------------------------------------------------------------
	*/
	
	double temp, *x, *work, y, weight;
	int col, pos, row, pos2,i,l;
	
	x = new double[ncol+1];
	work = new double[ncol+1];
	
	ifault = 0;

	if(!tol_set)
		tolset();
	
	for (i = 1; i <= ncol; ++i) {
		work[i] = sqrt(d[i]);
	}	
	for( col = 1; col <= ncol; ++col) {
		
	/*
	!     Set elements within R to zero if they are less than tol(col) in
	!     absolute value after being scaled by the square root of their row
	!     multiplier.
		*/
		
		temp = tol[col];
		pos = col - 1;
		for(row = 1; row <= col-1; ++row) {
			if (fabs(r[pos]) * work[row] < temp) 
				r[pos] = zero;
			pos = pos + ncol - row - 1;
		}
		/*
		!     If diagonal element is near zero, set it to zero, set appropriate
		!     element of LINDEP, and use INCLUD to augment the projections in
		!     the lower rows of the orthogonalization.
		*/
//		printf("%f %f\n",work[col],temp);
		lindep[col] = false;
		if (work[col] <= temp) {
			lindep[col] = true;
			ifault = ifault - 1;
			if (col < ncol) {
				pos2 = pos + ncol - col + 1;
				for(l = 1; l <= ncol; ++l) {
					x[l] = zero;
				}
				for(l = col+1; l <= ncol; ++l) {
					x[l] = r[pos+l-col];
				}
				y = rhs[col];
				weight = d[col];
				for(l = pos+1; l <= pos2-1; ++l) {
					r[l] = zero;
				}
				d[col] = zero;
				rhs[col] = zero;
				includ(weight, x, y);
				nobs--;
			}
			else
				sserr = sserr + d[col] * rhs[col]*rhs[col];
		}
	}
	
	delete[] x;
	delete[] work;
	return;
}


void lsq::ss() {
/*
!     ALGORITHM AS274  APPL. STATIST. (1992) VOL.41, NO. 2
!     Calculates partial residual sums of squares from an orthogonal
!     reduction from AS75.1.
!
!--------------------------------------------------------------------------
	*/
	
	int i;
	double total;
	
	total = sserr;
	rss[ncol] = sserr;
	for (i = ncol; i >= 2; --i) {
		total = total + d[i] * rhs[i]*rhs[i];
		rss[i-1] = total;
	}
	rss_set = false;
	return;
}

void lsq::cov(int nreq, double& var, double *covmat, int dimcov, double *sterr, int& ifault) {
/*
!     ALGORITHM AS274  APPL. STATIST. (1992) VOL.41, NO. 2
!     Calculate covariance matrix for regression coefficients for the
!     first nreq variables, from an orthogonal reduction produced from
!     AS75.1.
	*/
	
	int dim_rinv, pos, row, start, pos2, col, pos1, k;
	double total;
	double *rinv;
	
	//!     Check that dimension of array covmat is adequate.
	
	if (dimcov < nreq*(nreq+1)/2) {
		ifault = 1;
		return;
	}

	if (!rss_set)
		ss();

	
	//!     Check for small or zero multipliers on the diagonal.
	
	ifault = 0;
	for (row = 1;row<= nreq; ++row) {
		if (fabs(d[row]) < vsmall) 
			ifault = -row;
	}
	if (ifault != 0) 
		return;
	
	//!     Calculate estimate of the residual variance.
	
	if (nobs > nreq) 
		var = rss[nreq] / (nobs - nreq);
	else {
		ifault = 2;
		return;
	}
	
	dim_rinv = nreq*(nreq-1)/2;

	rinv = (double *)malloc(sizeof(double)*(dim_rinv+1));	

	inv(nreq, rinv);
	pos = 1;
	start = 1;
	for(row = 1; row <= nreq; ++row) {
		pos2 = start;
		for(col = row; col <= nreq; ++col) {
			pos1 = start + col - row;
			if (row == col) 
				total = one / d[col];
			else
				total = rinv[pos1-1] / d[col];
			
			for(k = col+1; k <= nreq; ++k) {
				total = total + rinv[pos1] * rinv[pos2] / d[k];
				pos1 = pos1 + 1;
				pos2 = pos2 + 1;
			}
			covmat[pos] = total * var;
			if (row == col)
				sterr[row] = sqrt(covmat[pos]);
			pos = pos + 1;
		}
		start = start + nreq - row;
	}
	free(rinv);
	return;
}


void lsq::inv(int nreq, double *rinv) {
	
/*
!     ALGORITHM AS274  APPL. STATIST. (1992) VOL.41, NO. 2
!     Invert first nreq rows and columns of Cholesky factorization
!     produced by AS 75.1.
!
!--------------------------------------------------------------------------
	*/
	
	int pos, row, col, start, k, pos1, pos2;
	double total;
	
	//!     Invert R ignoring row multipliers, from the bottom up.
	
	pos = nreq * (nreq-1)/2;
	for (row = nreq-1; row >=  1; row--) {
		start = (row-1) * (ncol+ncol-row)/2 + 1;
		for (col = nreq; col >= row+1; col--) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产真实精品久久二三区| 国产精品视频第一区| 天天做天天摸天天爽国产一区 | 在线不卡免费欧美| 午夜视频一区在线观看| 精品视频一区二区三区免费| 夜夜夜精品看看| 欧美精品自拍偷拍| 麻豆专区一区二区三区四区五区| 欧美变态凌虐bdsm| 国产一区二区导航在线播放| 中文字幕欧美三区| 在线视频综合导航| 久久成人综合网| 日本一区二区在线不卡| 色综合久久综合网欧美综合网 | 亚洲一区在线视频| 欧美二区乱c少妇| 精品写真视频在线观看| 欧美国产日韩a欧美在线观看| 国产99久久久精品| 亚洲精品欧美综合四区| 欧美一区中文字幕| 成年人午夜久久久| 午夜日韩在线观看| 久久久久99精品一区| 色综合久久久久久久| 麻豆精品久久精品色综合| 国产精品你懂的在线欣赏| 欧美日韩亚洲综合一区二区三区| 精品一区二区三区欧美| 亚洲欧美在线观看| 日韩欧美电影一二三| av网站一区二区三区| 日韩va亚洲va欧美va久久| 欧美国产精品一区二区| 538在线一区二区精品国产| 丁香婷婷综合网| 日韩激情在线观看| 亚洲欧洲性图库| 欧美电影免费提供在线观看| 91丝袜美腿高跟国产极品老师| 久久精品国产一区二区| 亚洲综合男人的天堂| 国产亚洲视频系列| 欧美一区二区性放荡片| 91麻豆国产福利在线观看| 精品一区二区三区蜜桃| 亚洲大片免费看| 欧美激情一区三区| 欧美大肚乱孕交hd孕妇| 欧美日韩视频一区二区| 国产精品123区| 麻豆视频一区二区| 日韩激情一二三区| 亚洲激情在线播放| 国产精品乱人伦| 久久久www成人免费无遮挡大片| 69成人精品免费视频| 在线一区二区三区做爰视频网站| 国产91富婆露脸刺激对白 | 久久福利视频一区二区| 亚洲丶国产丶欧美一区二区三区| 国产精品久久久久影院| 久久伊人中文字幕| 久久亚洲精华国产精华液 | 91福利精品第一导航| www.亚洲免费av| 国产精品亚洲成人| 激情深爱一区二区| 精品一区二区三区免费| 久久成人免费网站| 久久99精品国产91久久来源| 理论片日本一区| 日本成人在线电影网| 蜜桃传媒麻豆第一区在线观看| 天天亚洲美女在线视频| 日本特黄久久久高潮| 蜜臀av国产精品久久久久| 日韩1区2区日韩1区2区| 秋霞影院一区二区| 毛片一区二区三区| 国产精品自拍三区| 风间由美中文字幕在线看视频国产欧美| 精品一区二区三区香蕉蜜桃| 国产呦萝稀缺另类资源| 国产大陆精品国产| 成人av资源网站| 99久久99久久综合| 欧美三日本三级三级在线播放| 欧美日韩三级视频| 精品精品国产高清一毛片一天堂| 精品国产自在久精品国产| 欧美国产乱子伦 | 欧美日韩高清影院| 国产麻豆视频一区二区| 国产精品99精品久久免费| 国产成人99久久亚洲综合精品| 成人精品国产一区二区4080| 成人高清视频在线观看| 色天天综合色天天久久| 91精品久久久久久久99蜜桃 | 国产乱色国产精品免费视频| 国产精品小仙女| 一本大道久久精品懂色aⅴ| 欧美日韩国产在线观看| 精品sm在线观看| 一色桃子久久精品亚洲| 午夜精品久久久久久不卡8050| 看电影不卡的网站| 白白色 亚洲乱淫| 欧美日韩一区二区三区四区| 欧美mv日韩mv国产网站app| 国产精品乱码一区二区三区软件 | 亚洲免费av高清| 天堂av在线一区| 国产福利一区二区三区视频在线| 91在线小视频| 日韩欧美第一区| 亚洲乱码国产乱码精品精小说| 日本在线不卡视频| 成年人国产精品| 日韩三级.com| ●精品国产综合乱码久久久久| 亚洲成年人影院| 成人午夜在线免费| 欧美成人在线直播| 一区二区三区日韩欧美| 国产一区二区视频在线| 欧美欧美欧美欧美| 亚洲欧美综合另类在线卡通| 美女一区二区三区| 在线观看视频一区| 国产精品天美传媒沈樵| 久久精品国产精品亚洲红杏| 91久久线看在观草草青青| 久久久久9999亚洲精品| 日本亚洲一区二区| 欧美羞羞免费网站| 国产精品成人一区二区三区夜夜夜| 天天综合天天做天天综合| 91丨九色porny丨蝌蚪| 日本一区二区三区在线不卡| 另类调教123区| 欧美久久久一区| 亚洲一区二区三区中文字幕| 99久久综合国产精品| 久久久91精品国产一区二区三区| 丝袜诱惑制服诱惑色一区在线观看| 成人av电影在线| 国产亚洲精久久久久久| 九一久久久久久| 欧美一区二区播放| 日韩高清不卡一区二区| 欧美久久一二区| 亚洲成人在线观看视频| 在线观看视频一区二区| 亚洲美女免费视频| av不卡免费电影| 国产精品高清亚洲| av电影天堂一区二区在线| 国产精品毛片久久久久久| 丁香五精品蜜臀久久久久99网站| 久久综合九色综合欧美亚洲| 久久精品国产亚洲aⅴ| 日韩一级大片在线| 蜜桃av一区二区在线观看| 欧美老人xxxx18| 日韩成人dvd| 欧美成人一区二区三区| 免费观看一级特黄欧美大片| 欧美一区三区四区| 毛片av一区二区| 精品99久久久久久| 精品亚洲porn| 欧美激情一区二区三区蜜桃视频| 国产精品亚洲视频| 中文字幕在线不卡一区二区三区 | 欧美日韩一区三区| 天使萌一区二区三区免费观看| 91麻豆精品国产91久久久久| 午夜av一区二区三区| 日韩欧美综合在线| 国产成人精品影视| ...av二区三区久久精品| 日本黄色一区二区| 亚洲国产美女搞黄色| 欧美一区二区二区| 风流少妇一区二区| 樱桃国产成人精品视频| 欧美日韩国产一级| 国产自产2019最新不卡| 欧美经典一区二区三区| 91免费观看视频| 亚洲第一福利视频在线| 欧美成人免费网站| 成人午夜电影小说| 亚洲一区二区三区中文字幕| 日韩一级成人av| hitomi一区二区三区精品|