ARTS 2.5.4 (git: 31ce4f0e)
propmat_field.h
Go to the documentation of this file.
1/* Copyright (C) 2019 Richard Larsson <ric.larsson@gmail.com>
2
3 This program is free software; you can redistribute it and/or modify it
4 under the terms of the GNU General Public License as published by the
5 Free Software Foundation; either version 2, or (at your option) any
6 later version.
7
8 This program is distributed in the hope that it will be useful,
9 but WITHOUT ANY WARRANTY; without even the implied warranty of
10 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 GNU General Public License for more details.
12
13 You should have received a copy of the GNU General Public License
14 along with this program; if not, write to the Free Software
15 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
16 USA. */
17
30#ifndef PROPAGATION_FIELD_HEADER
31#define PROPAGATION_FIELD_HEADER
32
33#include "energylevelmap.h"
34#include "field.h"
35#include "transmissionmatrix.h"
36#include "workspace_ng.h"
37
38class Agenda;
39class Workspace;
40
44
62 FieldOfPropagationMatrix& propmat_field,
63 FieldOfStokesVector& absorption_field,
64 FieldOfStokesVector& additional_source_field,
65 const Index& stokes_dim,
66 const Vector& f_grid,
67 const Vector& p_grid,
68 const Tensor3& z_field,
69 const Tensor3& t_field,
70 const EnergyLevelMap& nlte_field,
71 const Tensor4& vmr_field,
72 const ArrayOfRetrievalQuantity& jacobian_quantities,
73 const Agenda& propmat_clearsky_agenda);
74
82 const FieldOfPropagationMatrix& propmat_field, const Numeric& r = 1.0);
83
113 Workspace& ws,
114 ArrayOfRadiationVector& lvl_rad,
115 ArrayOfRadiationVector& src_rad,
118 const FieldOfPropagationMatrix& propmat_field,
119 const FieldOfStokesVector& absorption_field,
120 const FieldOfStokesVector& additional_source_field,
121 const Vector& f_grid,
122 const Tensor3& t_field,
123 const EnergyLevelMap& nlte_field,
124 const Ppath& ppath,
125 const Agenda& iy_main_agenda,
126 const Agenda& iy_space_agenda,
127 const Agenda& iy_surface_agenda,
128 const Agenda& iy_cloudbox_agenda,
129 const Tensor3& surface_props_data,
130 const Verbosity& verbosity);
132 Workspace& ws,
133 ArrayOfRadiationVector& lvl_rad,
134 ArrayOfRadiationVector& src_rad,
137 const FieldOfPropagationMatrix& propmat_field,
138 const FieldOfStokesVector& absorption_field,
139 const FieldOfStokesVector& additional_source_field,
140 const Vector& f_grid,
141 const Tensor3& t_field,
142 const EnergyLevelMap& nlte_field,
143 const Ppath& ppath,
144 const Agenda& iy_main_agenda,
145 const Agenda& iy_space_agenda,
146 const Agenda& iy_surface_agenda,
147 const Agenda& iy_cloudbox_agenda,
148 const Tensor3& surface_props_data,
149 const Verbosity& verbosity);
150
151#endif // PROPAGATION_FIELD_HEADER
The Agenda class.
Definition: agenda_class.h:69
This can be used to make arrays out of anything.
Definition: array.h:48
Creates a 3D field of a base unit.
Definition: field.h:33
The Tensor3 class.
Definition: matpackIII.h:346
The Tensor4 class.
Definition: matpackIV.h:429
The Vector class.
Definition: matpackI.h:899
Workspace class.
Definition: workspace_ng.h:53
Array< WorkspaceVariable > ws
Workspace variable container.
Definition: workspace_ng.h:56
Class to map energy levels.
This file contains the definition of Field3D.
NUMERIC Numeric
The type to use for all floating point numbers.
Definition: matpack.h:33
INDEX Index
The type to use for all integer numbers and indices.
Definition: matpack.h:39
void field_of_propagation(Workspace &ws, FieldOfPropagationMatrix &propmat_field, FieldOfStokesVector &absorption_field, FieldOfStokesVector &additional_source_field, const Index &stokes_dim, const Vector &f_grid, const Vector &p_grid, const Tensor3 &z_field, const Tensor3 &t_field, const EnergyLevelMap &nlte_field, const Tensor4 &vmr_field, const ArrayOfRetrievalQuantity &jacobian_quantities, const Agenda &propmat_clearsky_agenda)
Creates a field of propagation matrices, absorption vectors, and source vectors.
FieldOfTransmissionMatrix transmat_field_calc_from_propmat_field(const FieldOfPropagationMatrix &propmat_field, const Numeric &r=1.0)
Get a field of transmission matrices from the propagation matrix field.
void emission_from_propmat_field(Workspace &ws, ArrayOfRadiationVector &lvl_rad, ArrayOfRadiationVector &src_rad, ArrayOfTransmissionMatrix &lyr_tra, ArrayOfTransmissionMatrix &tot_tra, const FieldOfPropagationMatrix &propmat_field, const FieldOfStokesVector &absorption_field, const FieldOfStokesVector &additional_source_field, const Vector &f_grid, const Tensor3 &t_field, const EnergyLevelMap &nlte_field, const Ppath &ppath, const Agenda &iy_main_agenda, const Agenda &iy_space_agenda, const Agenda &iy_surface_agenda, const Agenda &iy_cloudbox_agenda, const Tensor3 &surface_props_data, const Verbosity &verbosity)
Computes the radiation and transmission from fields of atmospheric propagation.
The structure to describe a propagation path and releated quantities.
Definition: ppath_struct.h:17
Stuff related to the transmission matrix.
This file contains the Workspace class.