Alien  1.3.0
Developer documentation
Loading...
Searching...
No Matches
MatrixMarketSystemReader.h
1/*
2 * Copyright 2020 IFPEN-CEA
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 *
16 * SPDX-License-Identifier: Apache-2.0
17 */
18
19#pragma once
20
21#include <arccore/base/ArccoreGlobal.h>
22#include <string>
23
24#include <alien/import_export/Reader.h>
25
26namespace Alien
27{
28
29class ALIEN_EXPORT MatrixMarketSystemReader
30{
31 public:
32 MatrixMarketSystemReader() = delete;
33 MatrixMarketSystemReader(MatrixMarketSystemReader const&) = delete;
34 MatrixMarketSystemReader& operator=(MatrixMarketSystemReader const&) = delete;
35
36 explicit MatrixMarketSystemReader(std::string const& filename);
37 ~MatrixMarketSystemReader();
38
39 template <typename MatrixT>
40 void readMatrix(MatrixT& A);
41
42 template <typename VectorT>
43 void readVector(VectorT& rhs);
44
45 private:
46 std::string m_filename;
47};
48
49template <typename MatrixT>
50void MatrixMarketSystemReader::readMatrix(MatrixT& A)
51{
52 std::fstream file_stream(m_filename, std::ios::in);
53
54 if (!file_stream.good()) {
55 throw FatalErrorException(A_FUNCINFO);
56 }
57
58 FStreamReader reader(&file_stream);
59 loadMMMatrixFromReader<MatrixT, FStreamReader>(A, reader);
60}
61
62template <typename VectorT>
63void MatrixMarketSystemReader::readVector(VectorT& rhs)
64{
65 std::fstream file_stream(m_filename, std::ios::in);
66
67 if (!file_stream.good()) {
68 throw FatalErrorException(A_FUNCINFO);
69 }
70
71 FStreamReader reader(&file_stream);
72 loadMMRhsFromReader<VectorT, FStreamReader>(rhs, reader);
73}
74
75} // namespace Alien
-- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature --
Definition BackEnd.h:17