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

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

?? matrix.java

?? wecome to sumathi computer centre is the centre for
?? JAVA
字號:
/*  * @(#)Matrix.java	1.3	20/9/96 Akio Utsugi */import java.lang.Math;import java.util.Random;/** * Matrix is a class for matrix objects with basic linear calculation methods. * @version 1.2 17 Sep 1996 * @author <a href="http://www.aist.go.jp/NIBH/~b0616/"> Akio Utsugi </a> */public class Matrix{    final static double small = 1e-8;        int row, col;    double value[][];/** * Construct a square matrix object. * @param n size */    public Matrix(int n)    {	this(n, n);    }    /** * Construct a rectangle matrix object. * @param row number of row * @param col number of column */    public Matrix(int row, int col)    {	int i, j;		this.row = row;	this.col = col;	value = new double[row][col];	for(i=0; i<row; i++){	    for(j=0; j<col; j++){		value[i][j] = 0;	    }	}	    }/* * Creation of special matrices */    /** * Make an identity matrix. * @param n size */    static public Matrix identity(int n)    {	int i;		Matrix ret = new Matrix(n);	for(i=0; i<n; i++){	    ret.value[i][i] = 1;	}	return ret;    }/**     * Make a standard Gaussian random Matrix. * @param row number of row * @param col number of column * @param seed random seed */    static public Matrix random(int row, int col, int seed)    {	int i, j;		Random rnd = new Random(seed);	Matrix ret = new Matrix(row, col);	for(i=0; i<row; i++){	    for(j=0; j<col; j++){		ret.value[i][j] = rnd.nextGaussian();	    }	}	return ret;    }/** * Same as random(row, col, 1). */       static public Matrix random(int row, int col)    {	return random(row, col, 1);    }    /** * Copy the matrix. */    public Matrix copy()    {	int i, j;		Matrix ret = new Matrix(row, col);	for(i=0; i<row; i++){	    for(j=0; j<col; j++){		ret.value[i][j] = value[i][j];	    }	}		return ret;    }/* * Basic Matrix Calculations *//** * Transpose: X'. */    public Matrix transpose()    {        int i, j;                Matrix ret = new Matrix(col, row);        for(i=0; i< row; i++){            for(j=0; j< col; j++){                ret.value[j][i] = value[i][j];            }        }        return ret;    }    /** * Linear conversion: a*X + b*Y. */    public Matrix linearConv(double a, double b, Matrix Y)    {	int i, j;		int Y_row = Y.row;	int Y_col = Y.col;		if(row == Y_row && col == Y_col){	    Matrix ret = new Matrix(row, col);	    	    for(i=0; i < row; i++){		for(j=0; j < col; j++){		    ret.value[i][j] = a*value[i][j] + b*Y.value[i][j];		}	    }	    return ret;	}	else{	    return null;	}    }            /** * Update by Linear conversion: X = a*X + b*Y. */    public void updateLinearConv(double a, double b, Matrix Y)    {	int i, j;		int Y_row = Y.row;	int Y_col = Y.col;		for(i=0; i < row; i++){	   for(j=0; j < col; j++){	       value[i][j] = a*value[i][j] + b*Y.value[i][j];	   }	}    }    /** * Scalar product: aX. */    public Matrix multipliedBy(double a)    {	int i, j;		Matrix ret = new Matrix(row, col);	for(i=0; i< row; i++){	    for(j=0; j< col; j++){		ret.value[i][j] = a*value[i][j];	    }	}	return ret;    }/** * Matrix multiplication: X*Y. */    public Matrix multipliedBy(Matrix Y)    {	int i, j, k;	double s;		int Y_row = Y.row, Y_col = Y.col;		if(col != Y_row){	    return null;	}		Matrix ret = new Matrix(row, Y_col);		for(i=0; i< row; i++){	    for(j=0; j<Y_col; j++){		s = 0;		for(k=0; k<col; k++){		    s += value[i][k] * Y.value[k][j];		}		ret.value[i][j] = s;	    }	}		return ret;    }    /** * Matrix division: X\Y. */    public Matrix dividedBy(Matrix Y)    {	return this.dividedBy(Y, 2*col-1);    }/** * Matrix division with bandwidth: X\Y.  */    public Matrix dividedBy(Matrix Y, int bw)    {    	Matrix L, U, ret;	int n, m, i, j, k;	double w, s, pp;		L = this.copy();	U = Y.copy();		m = L.row;	n = U.col;	bw = bw/2 + 1;		for(k = 0; k < m; k++){	    pp=L.value[k][k];	    	    if(Math.abs(pp)< small){		return null;	    }	    w = 1/pp;	    	    for(j = k+1; j < k+bw && j < m ; j++){		s = w*L.value[k][j];		L.value[k][j] = s;		for(i = k+1; i < k+bw+1 && i < m; i++){		    s = L.value[i][j] - L.value[i][k]*L.value[k][j];		    L.value[i][j] = s;		}	    }	    for(j = 0; j < n; j++){		s=w*U.value[k][j];		U.value[k][j] = s;		for(i = k+1; i < k+bw && i < m; i++){		    s=U.value[i][j] - L.value[i][k] * U.value[k][j];		    U.value[i][j] = s;		}	    }	}		ret = new Matrix(m, n);		for(i = m; --i>=0;){	    for(j = 0; j < n; j++){		w=U.value[i][j];				for(k = i+1; i < k+bw && k < m; k++){		    w -= L.value[i][k] * ret.value[k][j];		}		ret.value[i][j] = w;	    }		}		return ret;    }/* * Special purpose calculations *//** * Cross squared Euclidean distance Matrix: Z_{ij} = ||X_i - Y_j||^2  */    public Matrix crossSqDistance(Matrix Y)    {	Matrix ret;	int i, j, k;	double s, d;	int Y_row = Y.row, Y_col = Y.col;		if(col != Y_col){	    return null;	}		ret = new Matrix(row, Y_row);		for(i=0; i<row; i++){	    for(j=0; j<Y_row; j++){		s = 0;		for(k=0; k<col; k++){		    d = value[i][k] - Y.value[j][k];		    s += d*d;		}		ret.value[i][j] = s;	    }	}		return ret;    }    /** * Update by exponential : exp(X_{ij}) */    public void updateExp()    {	int i, j;		for(i=0; i<row; i++){	    for(j=0; j<col; j++){		value[i][j] = Math.exp(value[i][j]);	    }	}    }    /** * Make a horizontal-summation vector. */    public Matrix horizontalSum()    {	int i, j;	double s;		Matrix ret = new Matrix(row, 1);		for(i=0; i<row; i++){	    s = 0;	    for(j=0; j<col; j++){		s += value[i][j];	    }	    ret.value[i][0] = s;	}	return ret;    }/** * Make a vertical-summation vector. */    public Matrix verticalSum()    {	int i, j;	double s;		Matrix ret = new Matrix(1, col);		for(j=0; j<col; j++){	    s = 0;	    for(i=0; i<row; i++){		s += value[i][j];	    }	    ret.value[0][j] = s;	}	return ret;    }/** * Summation of all entries. */        public double sumEntries()    {        int i, j;        double s = 0;                for(i=0; i<row; i++){            for(j=0; j<col; j++){                s += value[i][j];            }        }        return s;    }   /** * Summation of squared entries. */     public double sumSqrEntries()    {        int i, j;        double s = 0;                        for(i=0; i<row; i++){            for(j=0; j<col; j++){                s += value[i][j]*value[i][j];            }        }        return s;    }/** * Multiply entries. */   public Matrix mulipliedEntriesWith(Matrix Y)   {       Matrix ret;       int i, j;       ret = new Matrix(row, col);       for(i=0; i<row; i++){	   for(j=0; j<col; j++){	       ret.value[i][j] = value[i][j]*Y.value[i][j];	   }       }       return ret;    }                  /**  * X_{ij} = X_{ij}/v_{j}. */    public void updateDivideByRowVector(Matrix vec)    {	int i, j;		for(j=0; j<col; j++){	    for(i=0; i<row; i++){		value[i][j] = value[i][j]/vec.value[0][j];	    }	}    }/** * If the matrix is a row or column vector, make a diagonal matrix from it. * Otherwise extract its diagonal as a row vector. */    public Matrix diagonal()    {	Matrix ret;	int i, n;	if(row == 1){	    ret = new Matrix(col, col);	    for(i=0; i< col; i++){		ret.value[i][i] = value[0][i];	    }	}	else if(col == 1){	    ret = new Matrix(row, row);	    for(i=0; i< row; i++){		ret.value[i][i] = value[i][0];	    }	}	else{	    n = Math.min(row, col);	    ret = new Matrix(1, n);	    for(i=0; i< n; i++){		ret.value[0][i] = value[i][i];	    }	}	return ret;    }/** * Make a row vector including the eigenvalues of the matrix. * @param eps allowable absolute value of off-diagonal entries * @lmax maximum number of repeat */    public Matrix eigenvalues(double eps, int lmax)    {	int n;	int i, j, im = 0, jm = 0, ll;	double pmax, pii, pjj, pij, d, tn;	double a, b, p1, p2, q1, q2, dd;	Matrix px, qx, lmd;	px = this.copy();	n = px.row;	qx = Matrix.identity(n);	ll=0;	do{	    pmax = Math.abs(px.value[0][1]);	    ll++;	    for(i=0; i<n-1; i++){		for(j=i+1; j<n; j++){		    if(pmax<= Math.abs(px.value[i][j])){			pmax= Math.abs(px.value[i][j]);			im=i;			jm=j;		    		    }		}	    }	    if(pmax<=eps)	break;	    pii=px.value[im][im];	    pjj=px.value[jm][jm];	    pij=px.value[im][jm];	    d=pii-pjj;	    dd=d*d+4.*pij*pij;	    tn=2.*pij/(d+Math.sqrt(dd)*(d > 0 ? 1 : -1));	    a=1./Math.sqrt(1.+tn*tn);	    b=a*tn;	    for(i=0; i<n; i++){		p1=px.value[i][im];		p2=px.value[i][jm];		px.value[i][im] = p1*a+p2*b;		px.value[i][jm] =  -p1*b+p2*a;		q1=qx.value[i][im];		q2=qx.value[i][jm];		qx.value[i][im] = q1*a+q2*b;		qx.value[i][jm] = -q1*b+q2*a;	    	    }	    for(i=0; i<n; i++){		p1=px.value[im][i];		p2=px.value[jm][i];		px.value[im][i] = p1*a+p2*b;		px.value[jm][i] = -p1*b+p2*a;	    	    }	}while(ll<lmax);	lmd = px.diagonal();	return lmd;    }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区在线观看免费| 国产亚洲综合在线| 欧美精品九九99久久| 91首页免费视频| 99久久亚洲一区二区三区青草| 国产乱妇无码大片在线观看| 国产一区二区三区av电影 | 成人免费av资源| 国产精品996| 粉嫩在线一区二区三区视频| 国产a级毛片一区| www.一区二区| 91福利在线看| 欧美精品v国产精品v日韩精品| 欧美日韩国产综合久久 | 日韩美女主播在线视频一区二区三区| 在线综合+亚洲+欧美中文字幕| 精品视频在线免费看| 欧美三级日韩三级国产三级| 538prom精品视频线放| 精品美女一区二区| 精品处破学生在线二十三| 久久精品亚洲精品国产欧美kt∨| 欧美国产激情二区三区| 欧美高清在线视频| 亚洲综合丝袜美腿| 日本伊人午夜精品| 国产一区二区三区四区五区入口 | 韩国av一区二区三区四区| 国产精品一级二级三级| av资源站一区| 欧美日韩精品二区第二页| 精品av久久707| 日韩伦理av电影| 日本亚洲免费观看| 成人a免费在线看| 欧美久久久久久久久中文字幕| 久久综合九色综合97婷婷| 亚洲婷婷综合色高清在线| 97久久精品人人爽人人爽蜜臀| 亚洲精品乱码久久久久久日本蜜臀| 国产一区视频网站| 日韩一区二区在线免费观看| 国产精品中文有码| 欧美狂野另类xxxxoooo| 亚洲男帅同性gay1069| 亚洲地区一二三色| 久久久久久夜精品精品免费| 国产精品77777竹菊影视小说| 老司机精品视频线观看86| 亚洲精品一线二线三线无人区| 精品国产欧美一区二区| 国产精品视频你懂的| 日韩中文字幕区一区有砖一区| 成人午夜视频福利| 日韩三级中文字幕| 亚洲成人激情自拍| 在线免费观看成人短视频| 久久久电影一区二区三区| 夜夜精品浪潮av一区二区三区| 国产精品亚洲成人| 精品国产免费一区二区三区四区 | 337p粉嫩大胆噜噜噜噜噜91av| 亚洲自拍偷拍麻豆| 国产成人精品在线看| 精品日韩欧美一区二区| 视频一区视频二区中文| 色综合久久精品| 亚洲欧洲成人av每日更新| 国产成人啪午夜精品网站男同| 91麻豆精品国产91久久久更新时间 | 97se狠狠狠综合亚洲狠狠| 精品国产三级电影在线观看| 日本女优在线视频一区二区| 欧美在线观看一二区| ...xxx性欧美| 久久品道一品道久久精品| 日韩视频一区二区| 美女一区二区三区在线观看| 91精品国产入口| 免费成人av在线| 精品国产免费一区二区三区四区| 蜜乳av一区二区三区| 欧美电影免费观看高清完整版在线| 日韩在线卡一卡二| 精品蜜桃在线看| 成人午夜私人影院| 亚洲人成7777| 欧美日韩电影一区| 免费成人深夜小野草| 久久久久久久久99精品| 粉嫩av一区二区三区| 成人免费在线视频观看| 欧洲精品一区二区三区在线观看| 亚洲五码中文字幕| 欧美一区二区三区影视| 国产在线精品不卡| 国产精品麻豆一区二区| 欧美最新大片在线看| 美腿丝袜亚洲一区| 日本一区二区三区免费乱视频 | 日韩成人dvd| 正在播放一区二区| 国产一区二区三区观看| 欧美激情一区二区三区四区 | 在线亚洲一区二区| 日韩黄色一级片| 久久蜜桃一区二区| 色素色在线综合| 精品一区二区在线视频| 日本一区二区三区高清不卡| 色综合久久中文字幕| 日韩和欧美一区二区| 欧美国产激情二区三区| 欧美日韩一区成人| 风流少妇一区二区| 亚洲一线二线三线久久久| 精品欧美一区二区久久| 色呦呦网站一区| 国产一区二区不卡在线| 亚洲综合一二区| 日韩精品亚洲一区二区三区免费| 久久久久久久久99精品| 欧美日韩精品系列| 99re这里只有精品首页| 久久er精品视频| 一区二区三区精品在线| 国产午夜精品一区二区三区嫩草 | 蜜桃视频一区二区三区在线观看| 中文字幕乱码日本亚洲一区二区| 在线观看中文字幕不卡| 国产精品123区| 蜜臀久久99精品久久久久久9| 中文字幕在线免费不卡| 欧美精品一区二区久久婷婷| 欧美午夜免费电影| 色婷婷综合久久久中文一区二区| 国产一区视频在线看| 麻豆免费看一区二区三区| 亚洲一区二区在线免费看| ...av二区三区久久精品| 国产视频一区在线播放| 欧美一级免费大片| 欧美片网站yy| 精品视频1区2区3区| 色狠狠一区二区| 91免费精品国自产拍在线不卡| 国产成人福利片| 国产成人av电影在线| 国产毛片精品视频| 国产在线播放一区| 精品综合久久久久久8888| 欧美日韩国产在线播放网站| 国产精品久久久久影视| 国产精品久久看| 国产精品久久午夜夜伦鲁鲁| 欧美国产禁国产网站cc| 中文字幕第一区第二区| 自拍偷拍国产精品| 亚洲精品午夜久久久| 亚洲午夜久久久久久久久电影网| 一区二区三区精品在线观看| 亚洲二区视频在线| 日日夜夜精品免费视频| 青青草精品视频| 国产一区二区不卡| 成人高清视频在线| 91网站在线播放| 欧美色倩网站大全免费| 在线成人免费视频| 精品不卡在线视频| 国产精品欧美极品| 亚洲图片欧美视频| 美女精品一区二区| 成人深夜福利app| 91久久精品一区二区| 欧美日韩亚洲综合| 精品少妇一区二区三区| 日本一区二区三级电影在线观看 | 日本大胆欧美人术艺术动态 | 欧美日韩成人激情| 在线不卡免费欧美| 精品美女在线播放| 国产精品久久久久久久久快鸭| 一区二区三区在线播| 日本sm残虐另类| 99久久国产综合精品女不卡| 色婷婷综合久久久久中文| 91精品国产色综合久久ai换脸| 久久久精品国产免费观看同学| 中文字幕制服丝袜一区二区三区| 亚洲六月丁香色婷婷综合久久| 日本不卡123| 日韩视频免费直播| 国产精品福利影院| 久久精品国产99久久6| 一本色道亚洲精品aⅴ| 日韩欧美国产午夜精品| 亚洲欧洲中文日韩久久av乱码| 蜜桃视频一区二区|