Version 1 (modified by suehring, 14 years ago) (diff) |
---|
Compiling and linking user-defined code
Users can add their own (modified) user-interface to a PALM-run by carrying out the following steps:
- Copy the appropriate default (empty) user-interface files user_***.f90 to a directory of your choice, e.g.:
cd ~/palm/current_version mkdir -p USER_CODE/example cp trunk/SOURCE/user_***.f90 USER_CODE/example
Attention: do not change the filenames!
- Set an additional path in the configuration file .mrun.config to allow mrun to find and include these files:
%add_source_path $base_directory/USER_CODE/$fname
The default configuration file (trunk/SCRIPTS/.mrun.config.default) already includes this setting. - Modify the interface routines according to your needs.
- Start a PALM run by executing
mrun -d example ...
The files user_***.f90 will be automatically compiled within the job and will replace the respective PALM‘s default user-interface routines.
The above method with including $fname in the additional source path allows to use different user-interfaces for different runs at the same time. Just store the respective interface-files in subdirectories USER_CODE/abcd, USER_CODE/cdef, etc. and start mrun with option "-d abcd", "-d cdef", etc.
If the user wants to add additional routines, he/she can a) put them into the default user-interface file user_additional_routines.f90 or b) can create new files in the additional source directory. These files must have names different from the default PALM source code files. In case of b), the user must also copy the default makefile into the additional source directory:
cp trunk/SOURCE/Makefile USER_CODE/example
The makefile must be modified appropriately followinf the "make"-rules in order to allow the new files to be compiled.
The modified user-interface files cannot be pre-compiled by using mbuild!
While programming user-defined code, errors are frequently made. Possible ways of error tracing are described in the next chapter.