Octopus
|
This module implements the basic elements defining algorithms. More...
This module implements the basic elements defining algorithms.
An algorithm is composed of algorithmic operations that are repeated in a loop.
Unsurprisingly, those repetitions are called iterations. The way how one keeps track of the iterations is with iteration counters.
Then each iteration is divided into algorithmic steps, and there is one interaction update per algorithmic step. The concept of algorithmic step is necessary to ensure that the couplings are updated at the right iteration, knowing that some systems might execute algorithms with a different number of algorithmic steps and/or have a different granularity.
Data Types | |
interface | algorithm_continues_after_finished |
indicate whether the algorithm should continue executing after finishing, or should set a barrier More... | |
interface | algorithm_finished |
indicate whether the algorithm has finished one time step More... | |
interface | algorithm_init_iteration_counters |
initializes the algorithm and system iteration counters More... | |
type | algorithm_iterator_t |
Iterator to loop over the algorithmic operations of an algorithm. More... | |
type | algorithm_t |
An algorithm is a list of algorithmic operations executed sequentially. More... | |
interface | algorithm_write_output_header |
Write the header for the execution log. More... | |
type | algorithmic_operation_t |
Descriptor of one algorithmic operation. More... | |
Functions/Subroutines | |
subroutine | algorithm_add_operation (this, operation) |
add an algorithmic operation to the list More... | |
logical function | algorithm_do_operation (this, operation) |
try to perform one operation of the algorithm. If successfull return .true. More... | |
subroutine | algorithm_update_elapsed_time (this) |
The elapsed time is used for the output of run time information. More... | |
subroutine | algorithm_rewind (this) |
Reset the algorithm to the first operation. More... | |
subroutine | algorithm_next (this) |
move to the next algorithmic operation More... | |
type(algorithmic_operation_t) function | algorithm_get_current_operation (this) |
return the current algorithmic operation. More... | |
type(algorithmic_operation_t) function | algorithm_iterator_get_next (this) |
Get the next algorithmic operation from the iterator. More... | |
Variables | |
integer, parameter, public | algo_label_len = 50 |
character(len=algo_label_len), parameter, public | skip = 'SKIP' |
Operations that can be used by any algorithm and, therefore, should be implemented by all systems. More... | |
character(len=algo_label_len), parameter, public | update_couplings = 'UPDATE_COUPLINGS' |
character(len=algo_label_len), parameter, public | update_interactions = 'UPDATE_INTERACTIONS' |
character(len=algo_label_len), parameter, public | iteration_done = 'ITERATION_DONE' |
character(len=algo_label_len), parameter, public | rewind_algorithm = 'REWIND_ALGORITHM' |
type(algorithmic_operation_t), parameter, public | op_skip = algorithmic_operation_t(SKIP, 'Skipping algorithmic operation') |
type(algorithmic_operation_t), parameter, public | op_update_couplings = algorithmic_operation_t(UPDATE_COUPLINGS, 'Algorithmic operation - Updating couplings') |
type(algorithmic_operation_t), parameter, public | op_update_interactions = algorithmic_operation_t(UPDATE_INTERACTIONS, 'Algorithmic operation - Updating interactions') |
type(algorithmic_operation_t), parameter, public | op_iteration_done = algorithmic_operation_t(ITERATION_DONE, 'Iteration finished') |
type(algorithmic_operation_t), parameter, public | op_rewind_algorithm = algorithmic_operation_t(REWIND_ALGORITHM, 'Rewind algorithm') |
|
private |
add an algorithmic operation to the list
Definition at line 274 of file algorithm.F90.
|
private |
try to perform one operation of the algorithm. If successfull return .true.
Definition at line 288 of file algorithm.F90.
|
private |
The elapsed time is used for the output of run time information.
Definition at line 302 of file algorithm.F90.
|
private |
Reset the algorithm to the first operation.
Definition at line 315 of file algorithm.F90.
|
private |
move to the next algorithmic operation
Definition at line 332 of file algorithm.F90.
|
private |
return the current algorithmic operation.
Definition at line 345 of file algorithm.F90.
|
private |
Get the next algorithmic operation from the iterator.
This function is necessary to specialize the deferred method of the linked list.
Definition at line 360 of file algorithm.F90.
integer, parameter, public algorithm_oct_m::algo_label_len = 50 |
Definition at line 157 of file algorithm.F90.
character(len=algo_label_len), parameter, public algorithm_oct_m::skip = 'SKIP' |
Operations that can be used by any algorithm and, therefore, should be implemented by all systems.
Definition at line 172 of file algorithm.F90.
character(len=algo_label_len), parameter, public algorithm_oct_m::update_couplings = 'UPDATE_COUPLINGS' |
Definition at line 172 of file algorithm.F90.
character(len=algo_label_len), parameter, public algorithm_oct_m::update_interactions = 'UPDATE_INTERACTIONS' |
Definition at line 172 of file algorithm.F90.
character(len=algo_label_len), parameter, public algorithm_oct_m::iteration_done = 'ITERATION_DONE' |
Definition at line 172 of file algorithm.F90.
character(len=algo_label_len), parameter, public algorithm_oct_m::rewind_algorithm = 'REWIND_ALGORITHM' |
Definition at line 172 of file algorithm.F90.
type(algorithmic_operation_t), parameter, public algorithm_oct_m::op_skip = algorithmic_operation_t(SKIP, 'Skipping algorithmic operation') |
Definition at line 179 of file algorithm.F90.
type(algorithmic_operation_t), parameter, public algorithm_oct_m::op_update_couplings = algorithmic_operation_t(UPDATE_COUPLINGS, 'Algorithmic operation - Updating couplings') |
Definition at line 179 of file algorithm.F90.
type(algorithmic_operation_t), parameter, public algorithm_oct_m::op_update_interactions = algorithmic_operation_t(UPDATE_INTERACTIONS, 'Algorithmic operation - Updating interactions') |
Definition at line 179 of file algorithm.F90.
type(algorithmic_operation_t), parameter, public algorithm_oct_m::op_iteration_done = algorithmic_operation_t(ITERATION_DONE, 'Iteration finished') |
Definition at line 179 of file algorithm.F90.
type(algorithmic_operation_t), parameter, public algorithm_oct_m::op_rewind_algorithm = algorithmic_operation_t(REWIND_ALGORITHM, 'Rewind algorithm') |
Definition at line 179 of file algorithm.F90.