forked from LLNL/libROM
-
Notifications
You must be signed in to change notification settings - Fork 0
/
BasisWriter.h
96 lines (80 loc) · 2.37 KB
/
BasisWriter.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
/******************************************************************************
*
* Copyright (c) 2013-2019, Lawrence Livermore National Security, LLC
* and other libROM project developers. See the top-level COPYRIGHT
* file for details.
*
* SPDX-License-Identifier: (Apache-2.0 OR MIT)
*
*****************************************************************************/
// Description: A class that writes basis vectors to a file.
#ifndef included_BasisWriter_h
#define included_BasisWriter_h
#include "Database.h"
#include <string>
namespace CAROM {
class SVDBasisGenerator;
/**
* Class BasisWriter writes the basis vectors created by an SVDBasisGenerator.
*/
class BasisWriter {
public:
/**
* @brief Constructor.
*
* @pre basis_generator != 0
* @pre !base_file_name.empty()
*
* @param[in] basis_generator The generator of the basis vectors to be
* written.
* @param[in] base_file_name The base part of the name of the files
* holding the basis vectors.
* @param[in] db_format Format of the file to read.
* One of the implemented file formats defined in
* Database.
*/
BasisWriter(
SVDBasisGenerator* basis_generator,
const std::string& base_file_name,
Database::formats db_format = Database::HDF5);
/**
* @brief Destructor.
*/
~BasisWriter();
/**
* @brief Write basis vectors generated by d_basis_generator.
*/
void
writeBasis();
private:
/**
* @brief Unimplemented default constructor.
*/
BasisWriter();
/**
* @brief Unimplemented copy constructor.
*/
BasisWriter(
const BasisWriter& other);
/**
* @brief Unimplemented assignment operator.
*/
BasisWriter&
operator = (
const BasisWriter& rhs);
/**
* @brief Basis generator whose basis vectors are being written.
*/
SVDBasisGenerator* d_basis_generator;
/**
* @brief Database to which basis vectors are being written.
*/
Database* d_database;
/**
* @brief Number of time intervals for which basis vectors have been
* written.
*/
int d_num_intervals_written;
};
}
#endif