FV3-JEDI
LinVarChaC2A.h
Go to the documentation of this file.
1 /*
2  * (C) Copyright 2017-2020 UCAR.
3  *
4  * This software is licensed under the terms of the Apache Licence Version 2.0
5  * which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
6  */
7 
8 #pragma once
9 
10 #include <memory>
11 #include <ostream>
12 #include <string>
13 
14 #include "eckit/config/Configuration.h"
16 #include "LinVarChaC2A.interface.h"
17 #include "oops/util/Printable.h"
18 
19 namespace fv3jedi {
20 
21 // -------------------------------------------------------------------------------------------------
22 
23 class LinVarChaC2A: public util::Printable {
24  public:
25  static const std::string classname() {return "fv3jedi::LinVarChaC2A";}
26  explicit LinVarChaC2A(const State &, const State &,
27  const Geometry &, const eckit::Configuration &);
28  ~LinVarChaC2A();
29  void multiply(const Increment &, Increment &) const;
30  void multiplyInverse(const Increment &, Increment &) const;
31  void multiplyAD(const Increment &, Increment &) const;
32  void multiplyInverseAD(const Increment &, Increment &) const;
33 
34  private:
35  std::shared_ptr<const Geometry> geom_;
37  void print(std::ostream &) const override;
38 };
39 
40 // -------------------------------------------------------------------------------------------------
41 
42 } // namespace fv3jedi
fv3jedi::LinVarChaC2A::geom_
std::shared_ptr< const Geometry > geom_
Definition: LinVarChaC2A.h:35
fv3jedi::LinVarChaC2A::multiplyInverseAD
void multiplyInverseAD(const Increment &, Increment &) const
Definition: LinVarChaC2A.cc:71
fv3jedi::LinVarChaC2A::classname
static const std::string classname()
Definition: LinVarChaC2A.h:25
Geometry.h
fv3jedi::LinVarChaC2A::LinVarChaC2A
LinVarChaC2A(const State &, const State &, const Geometry &, const eckit::Configuration &)
Definition: LinVarChaC2A.cc:28
fv3jedi::F90lvc_C2A
int F90lvc_C2A
Definition: LinVarChaC2A.interface.h:11
fv3jedi::LinVarChaC2A::multiplyInverse
void multiplyInverse(const Increment &, Increment &) const
Definition: LinVarChaC2A.cc:55
fv3jedi::LinVarChaC2A::~LinVarChaC2A
~LinVarChaC2A()
Definition: LinVarChaC2A.cc:40
fv3jedi::LinVarChaC2A::print
void print(std::ostream &) const override
Definition: LinVarChaC2A.cc:79
fv3jedi::LinVarChaC2A
Definition: LinVarChaC2A.h:23
fv3jedi::Geometry
Geometry handles geometry for FV3JEDI model.
Definition: Geometry.h:41
fv3jedi::LinVarChaC2A::multiply
void multiply(const Increment &, Increment &) const
Definition: LinVarChaC2A.cc:47
fv3jedi::Increment
Definition: Increment.h:52
fv3jedi::State
Definition: State.h:45
LinVarChaC2A.interface.h
fv3jedi
Configuration files should be formatted as e.g.
Definition: ErrorCovariance.cc:20
fv3jedi::LinVarChaC2A::keyFtnConfig_
F90lvc_C2A keyFtnConfig_
Definition: LinVarChaC2A.h:36
fv3jedi::LinVarChaC2A::multiplyAD
void multiplyAD(const Increment &, Increment &) const
Definition: LinVarChaC2A.cc:63