2018-01-02 11:31:02 +00:00
|
|
|
! Copyright 2005-2018 ECMWF.
|
2015-01-28 22:54:42 +00:00
|
|
|
!
|
|
|
|
! This software is licensed under the terms of the Apache Licence Version 2.0
|
|
|
|
! which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
|
|
|
|
!
|
|
|
|
! In applying this licence, ECMWF does not waive the privileges and immunities granted to it by
|
|
|
|
! virtue of its status as an intergovernmental organisation nor does it submit to any jurisdiction.
|
|
|
|
!
|
|
|
|
!
|
2016-07-11 10:27:08 +00:00
|
|
|
!> Module eccodes\n
|
|
|
|
!> This is the \b Fortran90 interface for ecCodes
|
2015-01-28 22:54:42 +00:00
|
|
|
module eccodes
|
|
|
|
|
|
|
|
use grib_api
|
|
|
|
implicit none
|
|
|
|
include "eccodes_constants.h"
|
|
|
|
include "eccodes_visibility.h"
|
|
|
|
|
2015-12-30 18:43:48 +00:00
|
|
|
real(8), parameter,public :: CODES_MISSING_DOUBLE = -1.D+100
|
|
|
|
integer(4), parameter,public :: CODES_MISSING_LONG = 2147483647
|
|
|
|
|
2015-03-27 20:31:08 +00:00
|
|
|
integer, parameter,public :: CODES_PRODUCT_ANY = 0
|
2015-03-04 17:11:18 +00:00
|
|
|
integer, parameter,public :: CODES_PRODUCT_GRIB = 1
|
|
|
|
integer, parameter,public :: CODES_PRODUCT_BUFR = 2
|
|
|
|
|
|
|
|
|
2015-01-28 22:54:42 +00:00
|
|
|
!> Create a new message in memory from an integer or character array containting the coded message.
|
|
|
|
!>
|
2016-07-11 10:27:08 +00:00
|
|
|
!> The message can be accessed through its ID and it will be available\n
|
2015-01-28 22:54:42 +00:00
|
|
|
!> until @ref codes_release is called. A reference to the original coded\n
|
|
|
|
!> message is kept in the new message structure.
|
|
|
|
!>
|
|
|
|
!> In case of error, if the status parameter (optional) is not given, the program will
|
|
|
|
!> exit with an error message.\n Otherwise the error message can be
|
|
|
|
!> gathered with @ref codes_get_error_string.
|
|
|
|
!>
|
|
|
|
!>
|
2016-08-25 15:28:20 +00:00
|
|
|
!> \b Examples: \ref grib_copy_message.f90 "grib_copy_message.f90"
|
2015-01-28 22:54:42 +00:00
|
|
|
!>
|
2016-07-11 10:27:08 +00:00
|
|
|
!> @param id ID of the message loaded in memory
|
2015-01-28 22:54:42 +00:00
|
|
|
!> @param message array containing the coded message
|
|
|
|
!> @param status CODES_SUCCESS if OK, integer value on error
|
|
|
|
interface codes_new_from_message
|
|
|
|
module procedure codes_new_from_message_int4
|
|
|
|
module procedure codes_new_from_message_char
|
|
|
|
end interface codes_new_from_message
|
|
|
|
|
|
|
|
!> Get a value of specified index from an array key.
|
|
|
|
!>
|
2016-07-11 10:27:08 +00:00
|
|
|
!> Given an ID and key name as input a value corresponding to the given index
|
2015-01-28 22:54:42 +00:00
|
|
|
!> is returned. The index is zero based i.e. the first element has
|
|
|
|
!> zero index, the second element index one and so on.
|
|
|
|
!> If the parameter index is an array all the values correspondig to the indexes
|
|
|
|
!> list is returned.
|
2016-07-11 10:27:08 +00:00
|
|
|
!> The ID references to a message loaded in memory.
|
2015-01-28 22:54:42 +00:00
|
|
|
!>
|
|
|
|
!> In case of error, if the status parameter (optional) is not given, the program will
|
|
|
|
!> exit with an error message.\n Otherwise the error message can be
|
|
|
|
!> gathered with @ref codes_get_error_string.
|
|
|
|
!>
|
2015-03-17 15:55:36 +00:00
|
|
|
!> \b Examples: \ref grib_nearest.f90 "grib_nearest.f90"
|
2015-01-28 22:54:42 +00:00
|
|
|
!>
|
|
|
|
!> @see codes_new_from_file, codes_release, codes_get
|
|
|
|
!>
|
2016-07-11 10:27:08 +00:00
|
|
|
!> @param[in] id ID of the message loaded in memory
|
2015-01-28 22:54:42 +00:00
|
|
|
!> @param[in] key key name
|
|
|
|
!> @param[in] index index can be a scalar or array of integer(4)
|
|
|
|
!> @param[out] value value can be a scalar or array of integer(4),real(4),real(8)
|
|
|
|
!> @param[out] status CODES_SUCCESS if OK, integer value on error
|
|
|
|
interface codes_get_element
|
|
|
|
module procedure codes_get_real4_element, &
|
|
|
|
codes_get_real8_element, &
|
|
|
|
codes_get_real4_elements, &
|
|
|
|
codes_get_real8_elements
|
|
|
|
end interface codes_get_element
|
|
|
|
|
|
|
|
!> Find the nearest point/points of a given latitude/longitude point.
|
|
|
|
!>
|
|
|
|
!> The value in the nearest point (or the four nearest points) is returned as well as the
|
|
|
|
!> zero based index (which can be used in @ref codes_get_element)
|
|
|
|
!> and its distance from the given point using the following
|
|
|
|
!> formula radius * acos( sin(lat1)*sin(lat2)+cos(lat1)*cos(lat2)*cos(lon1-lon2) ).
|
|
|
|
!>
|
|
|
|
!> If the is_lsm flag is .true. the input field gribid is considered as
|
|
|
|
!> a land sea mask and the nearest land point is returned.\n
|
|
|
|
!> The nearest land point among the four neighbours is:
|
|
|
|
!> - the nearest point with land sea mask value >= 0.5
|
|
|
|
!> - the nearest without any other condition if all the four have land sea mask value <0.5.
|
|
|
|
!>
|
|
|
|
!> Arrays (real(8)) of latitude/longitude can be provided to find with one call
|
|
|
|
!> the values,indexes and distances for all the lat/lon points listed in the arrays.
|
|
|
|
!>
|
|
|
|
!> If a single latitude/longitude point is provided and outlat,outlon,value,distance,index
|
|
|
|
!> are defined as arrays with four elements the lat/lon coordinates and values, distances
|
|
|
|
!> and indexes of the four nearest points are returned.
|
|
|
|
!>
|
|
|
|
!> In case of error, if the status parameter (optional) is not given, the program will
|
|
|
|
!> exit with an error message.\n Otherwise the error message can be
|
|
|
|
!> gathered with @ref codes_get_error_string.
|
|
|
|
!>
|
2015-03-17 15:55:36 +00:00
|
|
|
!> \b Examples: \ref grib_nearest.f90 "grib_nearest.f90"
|
2015-01-28 22:54:42 +00:00
|
|
|
!>
|
|
|
|
!> @param[in] gribid id of the grib loaded in memory
|
|
|
|
!> @param[in] is_lsm .true. if the nearest land point is required otherwise .false.
|
|
|
|
!> @param[in] inlat latitude of the point in degrees
|
|
|
|
!> @param[in] inlon longitudes of the point in degrees
|
|
|
|
!> @param[out] outlat latitude of the nearest point in degrees
|
|
|
|
!> @param[out] outlon longitude of the nearest point in degrees
|
|
|
|
!> @param[out] distance distance between the given point and its nearest (in km)
|
|
|
|
!> @param[out] index zero based index
|
|
|
|
!> @param[out] value value of the field in the nearest point
|
|
|
|
!> @param[out] status CODES_SUCCESS if OK, integer value on error
|
2015-02-11 16:23:21 +00:00
|
|
|
interface codes_grib_find_nearest
|
|
|
|
module procedure codes_grib_find_nearest_single, &
|
|
|
|
codes_grib_find_nearest_four_single, &
|
|
|
|
codes_grib_find_nearest_multiple
|
|
|
|
end interface codes_grib_find_nearest
|
2015-01-28 22:54:42 +00:00
|
|
|
|
|
|
|
!> Get latitude/longitude and data values.
|
|
|
|
!>
|
|
|
|
!> Latitudes, longitudes, data values arrays are returned.
|
|
|
|
!> They must be properly allocated by the caller and their required
|
|
|
|
!> dimension can be obtained with \ref codes_get_size or by getting (with \ref codes_get)
|
|
|
|
!> the value of the integer key "numberOfPoints".
|
|
|
|
!>
|
|
|
|
!> In case of error, if the status parameter (optional) is not given, the program will
|
|
|
|
!> exit with an error message.\n Otherwise the error message can be
|
|
|
|
!> gathered with @ref codes_get_error_string.
|
|
|
|
!>
|
2016-08-25 18:08:19 +00:00
|
|
|
!> \b Examples: \ref grib_get_data.f90 "grib_get_data.f90"
|
2015-01-28 22:54:42 +00:00
|
|
|
!>
|
|
|
|
!> @param[in] gribid id of the grib loaded in memory
|
|
|
|
!> @param[out] lats latitudes array with dimension "size"
|
|
|
|
!> @param[out] lons longitudes array with dimension "size"
|
|
|
|
!> @param[out] values data values array with dimension "size"
|
2015-02-11 16:23:21 +00:00
|
|
|
interface codes_grib_get_data
|
|
|
|
module procedure codes_grib_get_data_real4, &
|
|
|
|
codes_grib_get_data_real8
|
|
|
|
end interface codes_grib_get_data
|