Last change
on this file since 4163 was
3908,
checked in by idelkadi, 4 years ago
|
Online implementation of the radiative transfer code ECRAD in the LMDZ model.
- Inclusion of the ecrad directory containing the sources of the ECRAD code
- interface routine : radiation_scheme.F90
- Adaptation of compilation scripts :
- compilation under CPP key CPP_ECRAD
- compilation with option "-rad ecard" or "-ecard true"
- The "-rad old/rtm/ecran" build option will need to replace the "-rrtm true" and "-ecrad true" options in the future.
- Runing LMDZ simulations with ecrad, you need :
- logical key iflag_rrtm = 2 in physiq.def
- namelist_ecrad (DefLists?)
- the directory "data" containing the configuration files is temporarily placed in ../libfphylmd/ecrad/
- Compilation and execution are tested in the 1D case. The repository under svn would allow to continue the implementation work: tests, verification of the results, ...
|
File size:
1.2 KB
|
Line | |
---|
1 | /** |
---|
2 | * (C) Copyright 2014- ECMWF. |
---|
3 | * |
---|
4 | * This software is licensed under the terms of the Apache Licence Version 2.0 |
---|
5 | * which can be obtained at http://www.apache.org/licenses/LICENSE-2.0. |
---|
6 | * |
---|
7 | * In applying this licence, ECMWF does not waive the privileges and immunities |
---|
8 | * granted to it by virtue of its status as an intergovernmental organisation |
---|
9 | * nor does it submit to any jurisdiction. |
---|
10 | */ |
---|
11 | |
---|
12 | #ifndef _RAISE_H_ |
---|
13 | #define _RAISE_H_ |
---|
14 | |
---|
15 | /* raise.h */ |
---|
16 | |
---|
17 | #include <stdio.h> |
---|
18 | #include <string.h> |
---|
19 | #include <signal.h> |
---|
20 | #include <unistd.h> |
---|
21 | |
---|
22 | extern void abor1fl_(const char *filename, const int *linenum, |
---|
23 | const char *s, |
---|
24 | int filenamelen, int slen); |
---|
25 | extern void abor1_(const char *s, int slen); |
---|
26 | |
---|
27 | #define ABOR1(txt) { const char *t = (txt); t ? abor1_(t, strlen(t)) : abor1_("",0); } |
---|
28 | |
---|
29 | #define ABOR1FL(txt) { \ |
---|
30 | const char *t = (txt); \ |
---|
31 | int linenum=__LINE__; \ |
---|
32 | t ? abor1fl_(__FILE__, &linenum, t, sizeof(__FILE__)-1, strlen(t)) \ |
---|
33 | : abor1fl_(__FILE__, &linenum, "", sizeof(__FILE__)-1, 0); \ |
---|
34 | _exit(1); /* Should never end up here */ } |
---|
35 | |
---|
36 | #define RAISE(x) { \ |
---|
37 | if ((x) == SIGABRT) { \ |
---|
38 | ABOR1FL("*** Fatal error; aborting (SIGABRT) ..."); \ |
---|
39 | _exit(1); /* Should never end up here */ \ |
---|
40 | } \ |
---|
41 | else raise(x); \ |
---|
42 | } |
---|
43 | |
---|
44 | #endif /* _RAISE_H_ */ |
---|
Note: See
TracBrowser
for help on using the repository browser.