X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fmath%2FMatrix.java;h=87b0ef3ca31de93a49ebc86a339ad90a9f9a0d95;hb=b2f9a8d7bce642ff4011bc6d49e02bb0569fbb11;hp=b6e77ed159212198d55e70751df1554f32208fb1;hpb=797df64fa2a0a30773d0f48f5494d4155e5a8be3;p=jalview.git diff --git a/src/jalview/math/Matrix.java b/src/jalview/math/Matrix.java index b6e77ed..87b0ef3 100755 --- a/src/jalview/math/Matrix.java +++ b/src/jalview/math/Matrix.java @@ -1,19 +1,20 @@ /* - * Jalview - A Sequence Alignment Editor and Viewer (Version 2.7) - * Copyright (C) 2011 J Procter, AM Waterhouse, J Engelhardt, LM Lui, G Barton, M Clamp, S Searle + * Jalview - A Sequence Alignment Editor and Viewer (Version 2.8.1) + * Copyright (C) 2014 The Jalview Authors * * This file is part of Jalview. * * Jalview is free software: you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. - * + * * Jalview is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty * of MERCHANTABILITY or FITNESS FOR A PARTICULAR * PURPOSE. See the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along with Jalview. If not, see . + * The Jalview Authors are detailed in the 'AUTHORS' file. */ package jalview.math; @@ -47,6 +48,12 @@ public class Matrix public double[] e; // off diagonal /** + * maximum number of iterations for tqli + * + */ + int maxIter = 45; // fudge - add 15 iterations, just in case + + /** * Creates a new Matrix object. * * @param value @@ -341,11 +348,11 @@ public class Matrix } } } - + /** * DOCUMENT ME! */ - public void tqli() + public void tqli() throws Exception { int n = rows; @@ -392,10 +399,9 @@ public class Matrix { iter++; - if (iter == 30) + if (iter == maxIter) { - System.err.print("Too many iterations in tqli"); - System.exit(0); // JBPNote - should this really be here ??? + throw new Exception("Too many iterations in tqli ("+maxIter+")"); } else { @@ -595,7 +601,7 @@ public class Matrix /** * DOCUMENT ME! */ - public void tqli2() + public void tqli2() throws Exception { int n = rows; @@ -642,10 +648,9 @@ public class Matrix { iter++; - if (iter == 30) + if (iter == maxIter) { - System.err.print("Too many iterations in tqli"); - System.exit(0); // JBPNote - same as above - not a graceful exit! + throw new Exception ("Too many iterations in tqli2 (max is "+maxIter+")"); } else { @@ -779,7 +784,7 @@ public class Matrix * @param args * DOCUMENT ME! */ - public static void main(String[] args) + public static void main(String[] args) throws Exception { int n = Integer.parseInt(args[0]); double[][] in = new double[n][n];