FV3-JEDI
LinVarChaNMCBal.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"
17 #include "oops/util/Printable.h"
18 
19 namespace fv3jedi {
20 
21 // -------------------------------------------------------------------------------------------------
22 
23 class LinVarChaNMCBal: public util::Printable {
24  public:
25  static const std::string classname() {return "fv3jedi::LinVarChaNMCBal";}
26  explicit LinVarChaNMCBal(const State &, const State &, const Geometry &,
27  const eckit::Configuration &);
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::LinVarChaNMCBal
Definition: LinVarChaNMCBal.h:23
fv3jedi::LinVarChaNMCBal::multiplyAD
void multiplyAD(const Increment &, Increment &) const
Definition: LinVarChaNMCBal.cc:63
fv3jedi::LinVarChaNMCBal::multiplyInverseAD
void multiplyInverseAD(const Increment &, Increment &) const
Definition: LinVarChaNMCBal.cc:71
fv3jedi::F90lvc_NMC
int F90lvc_NMC
Definition: LinVarChaNMCBal.interface.h:11
LinVarChaNMCBal.interface.h
Geometry.h
fv3jedi::LinVarChaNMCBal::classname
static const std::string classname()
Definition: LinVarChaNMCBal.h:25
fv3jedi::LinVarChaNMCBal::LinVarChaNMCBal
LinVarChaNMCBal(const State &, const State &, const Geometry &, const eckit::Configuration &)
Definition: LinVarChaNMCBal.cc:28
fv3jedi::LinVarChaNMCBal::print
void print(std::ostream &) const override
Definition: LinVarChaNMCBal.cc:79
fv3jedi::Geometry
Geometry handles geometry for FV3JEDI model.
Definition: Geometry.h:41
fv3jedi::LinVarChaNMCBal::multiply
void multiply(const Increment &, Increment &) const
Definition: LinVarChaNMCBal.cc:47
fv3jedi::Increment
Definition: Increment.h:52
fv3jedi::State
Definition: State.h:45
fv3jedi::LinVarChaNMCBal::~LinVarChaNMCBal
~LinVarChaNMCBal()
Definition: LinVarChaNMCBal.cc:40
fv3jedi
Configuration files should be formatted as e.g.
Definition: ErrorCovariance.cc:20
fv3jedi::LinVarChaNMCBal::geom_
std::shared_ptr< const Geometry > geom_
Definition: LinVarChaNMCBal.h:35
fv3jedi::LinVarChaNMCBal::multiplyInverse
void multiplyInverse(const Increment &, Increment &) const
Definition: LinVarChaNMCBal.cc:55
fv3jedi::LinVarChaNMCBal::keyFtnConfig_
F90lvc_NMC keyFtnConfig_
Definition: LinVarChaNMCBal.h:36