Diana
0.8.3
|
00001 /* ----------------------------------------------------------------------------- 00002 * Diana process modelling, simulation and analysis software 00003 * Copyright (c) 2005, Michael Krasnyk 00004 * All rights reserved. 00005 00006 * This file is a part of Diana process modelling, simulation and analysis software 00007 * 00008 * Diana is free software; you can redistribute it and/or modify it 00009 * under the terms of the GNU General Public License as published 00010 * by the Free Software Foundation (see accompanying file LICENSE) 00011 * ----------------------------------------------------------------------------- 00012 * $Id$ 00013 * ----------------------------------------------------------------------------- 00014 * Description: 00015 */ 00016 00017 #ifndef DIANA_LSQR_SOLVER_HPP 00018 #define DIANA_LSQR_SOLVER_HPP 00019 00020 #include <vector> 00021 #include <Basic/DianaSparseArray.hpp> 00022 #include "IDianaLinearAlgebraSolver.hpp" 00023 00024 namespace Diana { 00025 00032 class DianaLSQRSolver : virtual public IDianaLinearAlgebraSolver { 00033 public: 00034 DianaLSQRSolver(); 00035 virtual ~DianaLSQRSolver(); 00036 00037 DianaLSQRSolver(const DianaSparseArray& spar) 00038 throw (Common::Error::ECapeUnknown, Common::Error::ECapeBadArgument, 00039 Common::Error::ECapeOutOfBounds, Common::Error::ECapeSolvingError, 00040 Common::Error::ECapeNoMemory); 00041 00042 DianaLSQRSolver& operator=(const DianaSparseArray& spar) 00043 throw (Common::Error::ECapeUnknown, Common::Error::ECapeBadArgument, 00044 Common::Error::ECapeOutOfBounds, Common::Error::ECapeSolvingError, 00045 Common::Error::ECapeNoMemory); 00046 00047 void solve(const Common::Types::CapeArrayDouble& rhs, 00048 Common::Types::CapeArrayDouble& sol, 00049 Common::Types::CapeBoolean transpose=false) 00050 throw (Common::Error::ECapeUnknown, Common::Error::ECapeBadArgument, 00051 Common::Error::ECapeOutOfBounds, Common::Error::ECapeSolvingError, 00052 Common::Error::ECapeNoMemory); 00053 00054 void solve(int n, const double* rhs, double* sol, 00055 Common::Types::CapeBoolean transpose=false) 00056 throw (Common::Error::ECapeUnknown, Common::Error::ECapeBadArgument, 00057 Common::Error::ECapeOutOfBounds, Common::Error::ECapeSolvingError, 00058 Common::Error::ECapeNoMemory); 00059 00060 void mulvec(const Common::Types::CapeArrayDouble& vec, 00061 Common::Types::CapeArrayDouble& res, 00062 Common::Types::CapeBoolean transpose=false) 00063 throw (Common::Error::ECapeUnknown, Common::Error::ECapeBadArgument, 00064 Common::Error::ECapeOutOfBounds, Common::Error::ECapeSolvingError, 00065 Common::Error::ECapeNoMemory); 00066 00067 void mulvec(int nvec, const double* vec, int nres, double* res, 00068 Common::Types::CapeBoolean transpose=false) 00069 throw (Common::Error::ECapeUnknown, Common::Error::ECapeBadArgument, 00070 Common::Error::ECapeOutOfBounds, Common::Error::ECapeSolvingError, 00071 Common::Error::ECapeNoMemory); 00072 private: 00073 void init_matrix(const DianaSparseArray& spar) 00074 throw (Common::Error::ECapeUnknown, Common::Error::ECapeBadArgument, 00075 Common::Error::ECapeOutOfBounds, Common::Error::ECapeSolvingError, 00076 Common::Error::ECapeNoMemory); 00077 00078 double norm2(int n, const double* vec); 00079 00080 private: 00081 DianaSparseArray::crc_type crc32sa; 00082 00083 long nRows; 00084 long nCols; 00085 long nNonZeros; 00086 std::vector<long> irow; 00087 std::vector<long> jcol; 00088 std::vector<double> aval; 00089 Common::Types::CapeDouble dblUround; 00090 }; 00091 }; 00092 00093 #endif // DIANA_LSQR_SOLVER_HPP