Javaで行列式を計算するプログラムを書いています。
いくつかのサイトを参考にして書いてみたのですが、正しい答えが得られません、、、
Matrixクラスには二重のArrayList型である、matrixがあり、Matrixのインスタンスを生成する時に引数に指定したファイルから行列を読み込みます。(ファイルから正しく読み込むことはできています。)
det()についてですが、自分で確認してみた限りでは、
Java
1buf=m.matrix.get(j).get(i)/m.matrix.get(i).get(i);
この部分の分母が0になってしまうことで、InfinityやNaNになってしまっているということまでは確認できたのですが、これをどう修正すれば正しい計算ができるのかわかりません、、、
元の行列は
2.0 4.0 -2.0 -4.0
-6.0 -12.0 12.0 24.0
4.0 2.0 2.0 -4.0
2.0 -4.0 -2.0 4.0
で、正しい行列式の値は、1344なのですが、今のプログラムではNaNになってしまっています。
Java
1public static void main(String[] args) { 2 3 Matrix m = new Matrix(args[0]); 4 double det = 0; 5 det = m.det(); 6 System.out.println("Det: "+ det); 7 8 try { 9 BufferedWriter writer = new BufferedWriter(new FileWriter(args[1])); 10 writer.write(String.valueOf(det)); 11 writer.close(); 12 }catch(Exception e) { 13 e.printStackTrace(); 14 } 15 }
Java
1double det() { 2 //行列をコピー 3 Matrix m =new Matrix(); 4 for(int i=0;i<matrix.size();i++) { 5 ArrayList<Double> sub = new ArrayList<Double>(); 6 for(int j=0;j<matrix.get(0).size();j++) { 7 sub.add(matrix.get(i).get(j)); 8 } 9 m.matrix.add(sub); 10 } 11 //コピーが正しくされたか確認 12 m.show(); 13 14 double det=1.0; 15 double buf=0; 16 int n= m.matrix.size(); 17 18 for(int i=0;i<n;i++) { 19 for(int j=0;j<n;j++) { 20 if(i<j) { 21 buf=m.matrix.get(j).get(i)/m.matrix.get(i).get(i); 22 for(int k=0;k<n;k++) { 23 m.matrix.get(j).set(k, m.matrix.get(j).get(k)-(m.matrix.get(i).get(k)*buf)); 24 } 25 } 26 } 27 } 28 29 for(int i=0;i<n;i++) { 30 det*=m.matrix.get(i).get(i); 31 } 32 33 return det; 34 }
Java
1void show() { 2 for(int i=0;i<matrix.size();i++) { 3 for(int j=0;j<matrix.get(0).size();j++) { 4 System.out.print(" "+matrix.get(i).get(j)); 5 if(i!=matrix.size()-1) { 6 if(j==matrix.get(0).size()-1) { 7 System.out.println(); 8 } 9 } 10 } 11 if(i==matrix.size()-1) { 12 System.out.println(); 13 } 14 } 15 }
回答2件
あなたの回答
tips
プレビュー