Changes between Version 4 and Version 5 of doc/app/userint
- Timestamp:
- Sep 14, 2010 8:56:09 AM (14 years ago)
Legend:
- Unmodified
- Added
- Removed
- Modified
-
doc/app/userint
v4 v5 1 Programming user-defined code extensions usually requires exact knowledge of the internal structure of PALM. Appropriate explanations in [wiki:chapter_2 chapter 2.0] and the technical documentation are usually not sufficient and must be supplemented by a rigorous study of the model's source code. Programming experiences with {{{FORTRAN95}}} and if necessary experiences with the parallelization tool MPIare absolutely necessary!\\\\1 Programming user-defined code extensions usually requires exact knowledge of the internal structure of PALM. Appropriate explanations in [wiki:chapter_2 chapter 2.0] and the technical documentation are usually not sufficient and must be supplemented by a rigorous study of the model's source code. Programming experiences with {{{FORTRAN95}}} and if necessary experiences with the parallelization tool {{{MPI}}} are absolutely necessary!\\\\ 2 2 Changes of the standard model code by the user should be avoided whenever possible and are reserved to the developer-group of PALM. The corrections, revisions and extensions of the model accomplished by this group are published in the technical/numerical documentation and the accordingly updated source files are accessible to the users (see [wiki:chapter_51 chapter 5.1]).\\\\ 3 3 However, the user frequently may feel the need to make extensions of the model code for his/her own simulations. For this purpose, a set of interfaces is available, which can be used to add user-defined code to the model. This chapter describes the programming of such user-defined code extensions.\\\\ 4 The integration of user-defined code occurs in the form of subroutine calls, which are made at a set of places in the model code, by default. These subroutines have pre-defined names, which must not be changed by the user. Their basic versions are a component of the standard model code and can be found in the source code files {{{user_***.f90}}}. The basic versions accomplish nearly no actions, thus they are pure templates, which can be extended by the user as required. Actions which are already accomplished in these basic versions by default should not be changed. Here is an example of such a basic version (file {{{user_init.f90}}}): 4 The integration of user-defined code occurs in the form of subroutine calls, which are made at a set of places in the model code, by default. These subroutines have pre-defined names, which must not be changed by the user. Their basic versions are a component of the standard model code and can be found in the source code files {{{user_***.f90}}}. The basic versions accomplish nearly no actions, thus they are pure templates, which can be extended by the user as required. Actions which are already accomplished in these basic versions by default should not be changed. Here is an example of such a basic version (file {{{user_init.f90}}}): \\\\ 5 {{{ 6 SUBROUTINE user_init 7 8 !------------------------------------------------------------------------------ 9 ! 10 ! 11 ! Description: 12 ! ----------- 13 ! Execution of user-defined initializing actions 14 !------------------------------------------------------------------------------ 15 ! 16 17 USE control_parameters 18 USE user 19 20 IMPLICIT NONE 21 22 ! 23 !-- Here the user defined initializing actions follow: 24 25 26 END SUBROUTINE user_init 27 }}}