sas转java(1)截取子矩阵、unique、获取矩阵的行列数、创建特殊矩阵、求矩阵中的最大最小值、横纵合并矩阵、将矩阵转换为0,1形式、转置求逆

这里java的矩阵运算用的是ujmp包

sas和java的矩阵名一律以m(Means for matrix)表示,

向量一律用v(vector)表示

数值用num表示

结果res(result)表示

1:sas创建行向量,列向量和矩阵

v = {1 2 3 4};行向量

v = {1,2,3,4};列向量

v = {1 2,3 4};矩阵

选择一列或一行/多行或多列

单行列的情况

sas列 res = m[,j];   java列 res = m.selectColumns(Calculation.Ret.NEW, j);

sas行 res = m[i,];   java行 res = m.selectColumns(Calculation.Ret.NEW, i);

多行列的情况,单这里是针对要么行全部/列全部

sas res = m[,mj];  mj是行向量,这样就可以选取多列多行情况一样。

java res=m.selectColumns(Calculation.Ret.NEW, mj.toLongArray()[0]);  将mj转化为数组的行书进行处理。

截取子矩阵,行列都可以设置

lx->left x            ly->left y

rx->right x      ry->right y

sas:  m[lx:rx,ly:ry];

java:  m.subMatrix(Calculation.Ret.NEW, lx, ly, rx, ry)

2:选择矩阵中的distinct值

sas:    res=unique(m);结果以行向量表示

java:   res=m.unique(Calculation.Ret.NEW);结果一列向量表示

3:获取矩阵的行数与列数

sas:       res = nrow(m)             java:res = m.getRowCount();

sas:   res = ncol(m)      java:res = m.getColumnCount();

4:创建几种特殊的矩阵

sas:m*n值全为value的矩阵         m = j(m,n,value);

java:m*n值全为value的矩阵    m = Matrix.factory.ones(m,n).times(value);

对角矩阵

sas:对角线全为1的n维矩阵    m=i(n);

java:对角线全为1的n维矩阵    m=Matrix.factory.eye(n,n); 

空矩阵

sas:这个、、、完全没必要,随便写一个变量即为矩阵、、、

java : res = MatrixFactory.emptyMatrix();

5:矩阵与向量以及向量与向量间一一对应相乘

例如{1 2 3}#{1 2 3}={1 4 9}

{1 2 3, 4 5 6}#{1 2 3}={1 4 9,4 10 18}

sas:  res=v1#v2;   res=m#v; 

java: res=v.times(Calculation.Ret.NEW, true, v1); true是忽略缺失值,缺失值项乘得的结果为0。java暂时只找到向量间一一对应的

6:额。。。这个操作有点难描述

就是一个数和一个矩阵进行比较,数值相同的赋值为1,不同的变为0,也就是数和矩阵间的异或

例如m={1,2,3} var=1;

m=var ---->{1,0,0}

sas:   res=(m=var);这里返回的结果的表现为{1,0}

java:  res=m.euqal(var); 这里返回的结果的表现为{true,false},对返回的矩阵用getValueSum()可以得到double型的所有true的数量

对返回的矩阵用toDoubleMatrix()可以将其转换为1 0的形式

7:求出矩阵中的最大值与最小值

sas:   res=max(m);       res=min(m);

java:  res=m.getMaxValue(); res=m.getMinValue();

 

8:横向合并和纵向合并

m1={1 2 3};
m2={1 2 3};

纵向   1 2 3    横向 1 2 3 1 2 3

     1 2 3

sas:纵向合并   res=m1//m2;      java:纵向合并  m1.appendVertically(m2)
sas:横向合并   rea= m1||m2;        java:横向合并 m1.appendHorizontally(m2)

9:转置求逆

sas:   转置m` 那个点是大键盘一排数字键1左边的点          求逆inv(m)

java: 转置m.transpose()               求逆m.inv()

posted @ 2014-12-03 14:15  暴走的豆浆  阅读(873)  评论(0编辑  收藏  举报