ARTS
2.4.0(git:4fb77825)
|
#include "arts_api.h"
#include "agenda_class.h"
#include "arts.h"
#include "auto_md.h"
#include "auto_version.h"
#include "global_data.h"
#include "interactive_workspace.h"
#include "parameters.h"
#include "parser.h"
#include "workspace_ng.h"
Go to the source code of this file.
Functions | |
Index | get_wsv_id (const char *) |
Get index of WSV. More... | |
void | copy_output_and_input (ArrayOfIndex &output, ArrayOfIndex &input, unsigned long n_args_out, const long *args_out, unsigned long n_args_in, const long *args_in) |
void | include_path_push (const char *path) |
Add include path. More... | |
void | include_path_pop () |
Remove last include path. More... | |
void | data_path_push (const char *path) |
Add data path. More... | |
void | data_path_pop () |
Remove last data path. More... | |
void | initialize () |
Initalize ARTS runtime. More... | |
void | finalize () |
Finalize ARTS runtime. More... | |
const char * | get_error () |
Get most recent error. More... | |
void | set_basename (const char *name) |
Set the ARTS basename. More... | |
Agenda * | parse_agenda (const char *filename) |
Parse Controlfile. More... | |
Agenda * | create_agenda (const char *name) |
Create Agenda. More... | |
void | agenda_insert_set (InteractiveWorkspace *workspace, Agenda *a, long id, long group_id) |
Insert a set method into an agenda. More... | |
void | agenda_insert_callback (Agenda *a, void(*f)(InteractiveWorkspace *)) |
Insert callback into agenda. More... | |
void | agenda_add_method (Agenda *a, const long id, unsigned long n_output_args, const long *output_args, unsigned long n_input_args, const long *input_args) |
void | agenda_append (Agenda *dst, const Agenda *src) |
Append agendas. More... | |
void | agenda_clear (Agenda *a) |
Clear Agenda. More... | |
const char * | execute_agenda (InteractiveWorkspace *workspace, const Agenda *a) |
Execute Agenda. More... | |
void | destroy_agenda (Agenda *a) |
Destroy Agenda. More... | |
InteractiveWorkspace * | create_workspace (const Index verbosity, const Index agenda_verbosity) |
Create new workspace. More... | |
void | destroy_workspace (InteractiveWorkspace *workspace) |
Destroy given workspace. More... | |
unsigned long | get_number_of_groups () |
Return number of WSV groups. More... | |
const char * | get_group_name (int i) |
Get pointer to name of given group. More... | |
unsigned long | get_number_of_methods () |
Return number of WSMs. More... | |
MethodStruct | get_method (Index i) |
Return MethodStruct describing method with index i. More... | |
const char * | get_method_in (Index i, Index j) |
const char * | get_method_g_in (Index i, Index j) |
Get name of generic input argument. More... | |
const char * | get_method_g_in_default (Index i, Index j) |
Get default value of generic input argument. More... | |
const char * | get_method_out (Index i, Index j) |
const char * | get_method_g_out (Index i, Index j) |
Get name value of generic output argument. More... | |
const char * | execute_workspace_method (InteractiveWorkspace *workspace, long id, unsigned long n_args_out, const long *args_out, unsigned long n_args_in, const long *args_in) |
Execute workspace method. More... | |
const char * | method_print_doc (long id) |
Print method documentation. More... | |
long | lookup_workspace_variable (const char *s) |
Lookup workspace variable by name. More... | |
unsigned long | get_number_of_variables () |
Number of defined WSVs. More... | |
VariableStruct | get_variable (Index i) |
Get WSV by index. More... | |
VariableValueStruct | get_variable_value (InteractiveWorkspace *workspace, Index id, Index group_id) |
Get value WSV in given workspace. More... | |
void * | get_variable_data_pointer (InteractiveWorkspace *workspace, Index id) |
Get data pointer to the WSV variable. More... | |
CovarianceMatrixBlockStruct | get_covariance_matrix_block (CovarianceMatrix *m, long block_index, bool inverse) |
Return block of covariance matrix. More... | |
const char * | set_variable_value (InteractiveWorkspace *workspace, long id, long group_id, VariableValueStruct value) |
Sets the value of a WSV in a given workspace. More... | |
long | add_variable (InteractiveWorkspace *workspace, long group_id, const char *name) |
Add variable of given type to workspace. More... | |
DLL_PUBLIC void | erase_variable (InteractiveWorkspace *workspace, long id, long group_id) |
Erase variable from workspace. More... | |
DLL_PUBLIC VersionStruct | get_version () |
Get ARTS Version. More... | |
Variables | |
Parameters | parameters |
Holds the command line parameters. More... | |
Verbosity | verbosity_at_launch |
The global message verbosity settings: More... | |
String | out_basename |
The basename for the report file and for all other output files. More... | |
std::string | string_buffer |
long add_variable | ( | InteractiveWorkspace * | workspace, |
long | group_id, | ||
const char * | name | ||
) |
Add variable of given type to workspace.
This adds and initializes a variable in the current workspace and also adds a new entry to the global wsv_data array and updates WsvMap.
workspace | The pointer to the InteractiveWorkspace object where to create the object. |
group_id | The index of the group of the variable |
name | Pointer to a null-terminated string containing the name of the variable. If nullptr, a name will be auto-generated. |
Definition at line 637 of file arts_api.cc.
References InteractiveWorkspace::add_variable().
void agenda_add_method | ( | Agenda * | a, |
const long | id, | ||
unsigned long | n_output_args, | ||
const long * | output_args, | ||
unsigned long | n_input_args, | ||
const long * | input_args | ||
) |
Definition at line 157 of file arts_api.cc.
References copy_output_and_input(), and Agenda::push_back().
Append agendas.
Appends the methods in agenda src to agenda dst. This can be used to emulate include statements in agenda definitions.
dst | The agenda to append the methods to |
src | The agenda whose methods to append to src |
Definition at line 171 of file arts_api.cc.
References methods(), Agenda::Methods(), and Agenda::push_back().
void agenda_clear | ( | Agenda * | a | ) |
Clear Agenda.
Resets a given agenda to be emtpy.
a | Pointer to agenda object. |
Definition at line 178 of file arts_api.cc.
void agenda_insert_callback | ( | Agenda * | a, |
void(*)(InteractiveWorkspace *) | f | ||
) |
Insert callback into agenda.
Inserts callback to the given function object into the agenda.
Definition at line 149 of file arts_api.cc.
References InteractiveWorkspace::add_callback(), global_data::md_data, and Agenda::push_back().
void agenda_insert_set | ( | InteractiveWorkspace * | ws, |
Agenda * | a, | ||
long | id, | ||
long | group_id | ||
) |
Insert a set method into an agenda.
This inserts a set method into the given agenda which sets the a workspace variable given by its ID to to the value it currently has in the given workspace.
Pointer | to the workspace |
Pointer | to the agenda |
Pointer | to the callback function object |
Language | type of the callback. |
Definition at line 94 of file arts_api.cc.
References global_data::MdMap, Agenda::push_back(), and global_data::wsv_group_names.
void copy_output_and_input | ( | ArrayOfIndex & | output, |
ArrayOfIndex & | input, | ||
unsigned long | n_args_out, | ||
const long * | args_out, | ||
unsigned long | n_args_in, | ||
const long * | args_in | ||
) |
Definition at line 30 of file arts_api.cc.
Referenced by agenda_add_method(), and execute_workspace_method().
Agenda* create_agenda | ( | const char * | name | ) |
Create Agenda.
Creates an empyt agenda.
[in] | name | Name of the agenda |
Definition at line 88 of file arts_api.cc.
References Agenda::set_name().
InteractiveWorkspace* create_workspace | ( | const Index | verbosity = 1 , |
const Index | agenda_verbosity = 0 |
||
) |
Create new workspace.
Definition at line 191 of file arts_api.cc.
References ARTS::Var::verbosity().
void data_path_pop | ( | ) |
Remove last data path.
Remove the most recently added data path. Will result in an exception if the data path is empty.
Definition at line 58 of file arts_api.cc.
References Parameters::datapath, and parameters.
void data_path_push | ( | const char * | path | ) |
Add data path.
Adds a given path to the ARTS data path.
[in] | path | Pointer to cstring containing the path to add to the data path. |
Definition at line 56 of file arts_api.cc.
References Parameters::datapath, and parameters.
void destroy_agenda | ( | Agenda * | a | ) |
void destroy_workspace | ( | InteractiveWorkspace * | workspace | ) |
Destroy given workspace.
Definition at line 196 of file arts_api.cc.
DLL_PUBLIC void erase_variable | ( | InteractiveWorkspace * | workspace, |
long | id, | ||
long | group_id | ||
) |
Erase variable from workspace.
This variable removes a variable from the workspace and the global wsv_data and WsvMap. This is likely to invalidate indices of existing variables so it should be used with care.
workspace | Pointer to the InteractiveWorkspace object owning the variable |
id | The index of the variable |
group_id | The index of the group of the variable |
Definition at line 644 of file arts_api.cc.
References InteractiveWorkspace::erase_variable().
const char* execute_agenda | ( | InteractiveWorkspace * | workspace, |
const Agenda * | a | ||
) |
Execute Agenda.
Executes the given agenda on a given workspace.
workspace | Pointer of the InteractiveWorkspace object to execute the agenda on. |
a | Pointer to the agenda to execute. |
Definition at line 180 of file arts_api.cc.
References InteractiveWorkspace::execute_agenda(), and Agenda::set_main_agenda().
const char* execute_workspace_method | ( | InteractiveWorkspace * | workspace, |
long | id, | ||
unsigned long | n_args_out, | ||
const long * | args_out, | ||
unsigned long | n_args_in, | ||
const long * | args_in | ||
) |
Execute workspace method.
Execute workspace method with given index. Input arguments are passed using pointers to two arrays holding the indices of the input arguments and the output arguments, respectively. The length of the input (output) arguments must of course match the number of non-generic and generic input (output) arguments.
i | The index of the WSM |
args_out | Pointer to the array holding the indices of the output WSVs. |
args_in | Pointer to the array holding the indices of the input WSVs. |
Definition at line 262 of file arts_api.cc.
References copy_output_and_input(), and InteractiveWorkspace::execute_workspace_method().
void finalize | ( | ) |
CovarianceMatrixBlockStruct get_covariance_matrix_block | ( | CovarianceMatrix * | m, |
long | block_index, | ||
bool | inverse | ||
) |
Return block of covariance matrix.
m | Pointer to covariance matrix from which to return the block. |
block_index | Index of the block to return. |
inverse | Whether the block should be returned from the list of inverse blocks or not. |
Definition at line 467 of file arts_api.cc.
References Block::dense, CovarianceMatrix::get_blocks(), MatrixView::get_c_array(), Sparse::get_column_index_pointer(), Block::get_column_range(), Block::get_dense(), Sparse::get_element_pointer(), Range::get_extent(), Block::get_indices(), CovarianceMatrix::get_inverse_blocks(), Block::get_matrix_type(), Block::get_row_range(), Sparse::get_row_start_pointer(), Block::get_sparse(), Range::get_start(), CovarianceMatrixBlockStruct::indices, and Sparse::nnz().
const char* get_error | ( | ) |
Get most recent error.
Definition at line 66 of file arts_api.cc.
References string_buffer.
const char* get_group_name | ( | int | i | ) |
Get pointer to name of given group.
Definition at line 204 of file arts_api.cc.
References global_data::wsv_group_names.
MethodStruct get_method | ( | Index | i | ) |
Return MethodStruct describing method with index i.
Definition at line 211 of file arts_api.cc.
References global_data::md_data.
Get name of generic input argument.
[in] | i | The index of the WSM |
[in] | The | index of the generic input arguments |
Definition at line 246 of file arts_api.cc.
References global_data::md_data.
Get default value of generic input argument.
[in] | i | The index of the WSM |
[in] | j | The index of the generic input argument |
Definition at line 250 of file arts_api.cc.
References global_data::md_data.
Get name value of generic output argument.
[in] | i | The index of the WSM |
[in] | j | The index of the generic output argument |
Definition at line 258 of file arts_api.cc.
References global_data::md_data.
Definition at line 242 of file arts_api.cc.
References global_data::md_data.
Definition at line 254 of file arts_api.cc.
References global_data::md_data.
unsigned long get_number_of_groups | ( | ) |
Return number of WSV groups.
Definition at line 202 of file arts_api.cc.
References global_data::wsv_group_names.
unsigned long get_number_of_methods | ( | ) |
unsigned long get_number_of_variables | ( | ) |
VariableStruct get_variable | ( | Index | i | ) |
Get WSV by index.
The | index of the WSV |
Definition at line 295 of file arts_api.cc.
References WsvRecord::Description(), WsvRecord::Group(), WsvRecord::Name(), and Workspace::wsv_data.
void* get_variable_data_pointer | ( | InteractiveWorkspace * | workspace, |
Index | id | ||
) |
Get data pointer to the WSV variable.
Initalize uninitialized WSV variable
workspace | Pointer to a InteractiveWorkspace object. |
id | Index of the workspace variable. |
Definition at line 463 of file arts_api.cc.
VariableValueStruct get_variable_value | ( | InteractiveWorkspace * | workspace, |
Index | id, | ||
Index | group_id | ||
) |
Get value WSV in given workspace.
workspace | Pointer to a InteractiveWorkspace object. |
id | Index of the workspace variable. |
group_id | Index of the group the variable belongs to. |
Definition at line 300 of file arts_api.cc.
References ConstVectorView::empty(), ConstMatrixView::empty(), ConstTensor3View::empty(), ConstTensor4View::empty(), ConstTensor5View::empty(), ConstTensor6View::empty(), ConstTensor7View::empty(), VectorView::get_c_array(), MatrixView::get_c_array(), Tensor3View::get_c_array(), Tensor4View::get_c_array(), Tensor5View::get_c_array(), Tensor6View::get_c_array(), Tensor7View::get_c_array(), Sparse::get_column_index_pointer(), Sparse::get_element_pointer(), Sparse::get_row_start_pointer(), InteractiveWorkspace::is_initialized(), ConstTensor4View::nbooks(), ConstTensor5View::nbooks(), ConstTensor6View::nbooks(), ConstTensor7View::nbooks(), ConstMatrixView::ncols(), Sparse::ncols(), ConstTensor3View::ncols(), ConstTensor4View::ncols(), ConstTensor5View::ncols(), ConstTensor6View::ncols(), ConstTensor7View::ncols(), ConstVectorView::nelem(), ConstTensor7View::nlibraries(), Sparse::nnz(), ConstTensor3View::npages(), ConstTensor4View::npages(), ConstTensor5View::npages(), ConstTensor6View::npages(), ConstTensor7View::npages(), ConstMatrixView::nrows(), Sparse::nrows(), ConstTensor3View::nrows(), ConstTensor4View::nrows(), ConstTensor5View::nrows(), ConstTensor6View::nrows(), ConstTensor7View::nrows(), ConstTensor5View::nshelves(), ConstTensor6View::nshelves(), ConstTensor7View::nshelves(), ConstTensor6View::nvitrines(), ConstTensor7View::nvitrines(), and global_data::wsv_group_names.
DLL_PUBLIC VersionStruct get_version | ( | ) |
Get ARTS Version.
This function returns the ARTS version number as a double precision floating point number.
Definition at line 649 of file arts_api.cc.
References ARTS_FULL_VERSION, VersionStruct::major, VersionStruct::minor, and VersionStruct::revision.
Index get_wsv_id | ( | const char * | name | ) |
Get index of WSV.
Returns the index the Workspace of the given WSV.
Convenience function which can be called from within the debugger because it takes a plain char pointer instead of a String object as input.
[in] | name | WSV name |
Definition at line 5771 of file workspace.cc.
void include_path_pop | ( | ) |
Remove last include path.
Remove the most recently added include path. Will result in an exception if the include path is empty.
Definition at line 54 of file arts_api.cc.
References Parameters::includepath, and parameters.
void include_path_push | ( | const char * | path | ) |
Add include path.
Pushes a given path to the back of the include path.
[in] | path | Pointer to cstring containing the path to add to the include path. |
Definition at line 50 of file arts_api.cc.
References Parameters::includepath, and parameters.
void initialize | ( | ) |
Initalize ARTS runtime.
This function must be called before any other function to initialize the ARTS C API otherwise bad things will probably happen.
Definition at line 60 of file arts_api.cc.
References InteractiveWorkspace::initialize().
long lookup_workspace_variable | ( | const char * | s | ) |
Lookup workspace variable by name.
s | Pointer to c string holding the name of the variable. |
Definition at line 285 of file arts_api.cc.
References Zeeman::end(), and Workspace::WsvMap.
const char* method_print_doc | ( | long | id | ) |
Print method documentation.
This prints the documentation of the method as it is found for example in the HTML browser to the stream buffer and returns a pointer to it.
id | The id of the method. |
Definition at line 274 of file arts_api.cc.
References global_data::md_data, and string_buffer.
Agenda* parse_agenda | ( | const char * | filename | ) |
Parse Controlfile.
Parses a controlfile into an Agenda and returns a handle to to this agenda, which can be executed on a workspace using execute_agenda(...).
Note that parsing the same controlfile twice fails if this controlfile creates new WSVs.
{in] | filename The path to the controlfile relative to the ARTS search path. |
Definition at line 73 of file arts_api.cc.
References ArtsParser::parse_tasklist(), Agenda::set_main_agenda(), Agenda::set_name(), and verbosity_at_launch.
void set_basename | ( | const char * | name | ) |
Set the ARTS basename.
The basename is a global variable that is used in some cases by some WSMs for example to store or read data.
Definition at line 68 of file arts_api.cc.
References out_basename.
const char* set_variable_value | ( | InteractiveWorkspace * | workspace, |
long | id, | ||
long | group_id, | ||
VariableValueStruct | value | ||
) |
Sets the value of a WSV in a given workspace.
This method can be used to set the value of an ARTS WSV from external data. Currently supported data types are:
For Index and Numeric the data pointer of the VariableValueStruct is assumed to point to the value to set the WSV to. For variables of type String the data pointer is interpreted as pointer to a c_str. For ArrayOfString the data pointer is assumed to point to an array of pointers to c_str. For Vectors and Matrix data is assumed to point an array of double with c-style memory layout and size given by the corresponding values in the dimension field of VariableValueStruct.
workspace | Pointer to a InteractiveWorkspace object. |
id | Index of the workspace variable. |
group_id | Index of the group the variable belongs to. |
Definition at line 512 of file arts_api.cc.
References InteractiveWorkspace::initialize_variable(), VariableValueStruct::ptr, InteractiveWorkspace::set_agenda_variable(), and global_data::wsv_group_names.
|
extern |
The basename for the report file and for all other output files.
The files will have names like <basename>.rep (for the report file).
Definition at line 42 of file messages.cc.
Referenced by arts_exit(), arts_exit_with_error_message(), filename_ascii(), filename_xml(), filename_xml_with_index(), main(), nca_filename(), nca_filename_with_index(), and set_basename().
|
extern |
Holds the command line parameters.
Definition at line 41 of file parameters.cc.
Referenced by add_basedir(), data_path_pop(), data_path_push(), find_xml_file(), find_xml_file_existence(), get_parameters(), include_path_pop(), include_path_push(), main(), open_input_file(), option_methods(), option_workspacevariables(), ArtsParser::parse_agenda(), and xsec_continuum_tag().
std::string string_buffer |
Definition at line 22 of file arts_api.cc.
Referenced by InteractiveWorkspace::execute_workspace_method(), get_error(), and method_print_doc().
|
extern |
The global message verbosity settings:
Definition at line 34 of file messages.cc.
Referenced by main(), parse_agenda(), set_reporting_level(), and verbosityInit().