使用JAMA包求伪逆

JAMA全称为Java矩阵包,这是一个基础的线性代数运算的jar包,官网最后更新时间是2012年11月

官网地址:http://math.nist.gov/javanumerics/jama/

JAMA最新jar包下载:http://math.nist.gov/javanumerics/jama/Jama-1.0.3.jar

官方文档中说明这个包可以调用inverse方法求伪逆或逆矩阵,但实际上并不能求伪逆,inverse方法在求伪逆的时候依然调用LU分解函数,事实上伪逆通常应该做QR分解或SVD分解

好在JAMA提供了SVD分解的函数,可以通过调用SVD函数来实现求伪逆,下面是一个简单的代码

import Jama.Matrix;
import Jama.SingularValueDecomposition;

public class Test {
	public static void main(String[] args) {
		System.out.println("HelloWorld");
		
		double[][] array = { { 2., 2. }, { 1., 1. } };
		System.out.println(array.length);
		Matrix A = new Matrix(array);
		SingularValueDecomposition svd =A.svd();
		Matrix S = svd.getS();
		Matrix V = svd.getV().transpose();
		Matrix U = svd.getU();
		//将S中非0元素取倒数
		Matrix sinv = UnaryNotZeroElement(S);
		Matrix inv = V.times(sinv).times(U.transpose());
		inv.print(8, 8);

	}
	
	//将矩阵中非0元素取倒数
	private static Matrix UnaryNotZeroElement(Matrix x) {
		double[][] array=x.getArray();
		for(int i=0;i<array.length;i++){
			for(int j=0;j<array[i].length;j++){
				if(array[i][j]!=0){
					array[i][j]=1.0/array[i][j];
				}
			}
		}
		return new Matrix(array);
	}

}


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值