"ECCODES ERROR : concept: no match for paramId=201031" when using flex_extract to prepare era5

It was my first run of Flex_extract using the the provided case “Control_EA5”, and the routine always stopped by:

ECCODES ERROR : concept: no match for paramId=201031
ECCODES ERROR : concept: input handle edition=2, centre=ecmf
ECCODES ERROR : concept: input handle dataset=era
ECCODES ERROR : Please check the Parameter Database ‘Parameter Database
Traceback (most recent call last):
File “/home/flsun/workdisk/flexpart-wrf/flex_extract/Run/…/Source/Python/submit.py”, line 268, in
main()
File “/home/flsun/workdisk/flexpart-wrf/flex_extract/Run/…/Source/Python/submit.py”, line 109, in main
prepare_flexpart(ppid, c)
File “/home/flsun/workdisk/flexpart-wrf/flex_extract/Source/Python/Mods/prepare_flexpart.py”, line 169, in prepare_flexpart
flexpart.create(inputfiles, c)
File “/home/flsun/workdisk/flexpart-wrf/flex_extract/Source/Python/Classes/EcFlexpart.py”, line 1655, in create
codes_set(gid, ‘paramId’, 201031)
File “/home/flsun/miniforge3/envs/flexwrfoutput/lib/python3.11/site-packages/gribapi/gribapi.py”, line 2123, in grib_set
grib_set_long(msgid, key, value)
File “/home/flsun/miniforge3/envs/flexwrfoutput/lib/python3.11/site-packages/gribapi/gribapi.py”, line 989, in grib_set_long
GRIB_CHECK(lib.grib_set_long(h, key.encode(ENC), value))
File “/home/flsun/miniforge3/envs/flexwrfoutput/lib/python3.11/site-packages/gribapi/gribapi.py”, line 226, in GRIB_CHECK
errors.raise_grib_error(errid)
File “/home/flsun/miniforge3/envs/flexwrfoutput/lib/python3.11/site-packages/gribapi/errors.py”, line 381, in raise_grib_error
raise ERROR_MAPerrid
gribapi.errors.ConceptNoMatchError: Concept no match

The ID 201031 is for specific cloud water content, whose grib edition 2 info has a message “This representation is for ECMWF internal use only and should not be used operationally” . I have no idea of this, only a public account.

Hi,
the parameters available from ERA5 are:

Thanks
Michela

Thank you Michela,
Perhaps it’s the usage problem of flex_extract. The error occurred at the following codes that try to get scwc by summing CLWC and CIWC and write it to a grib2 file.

elif paramId == 246 or paramId == 247: # CLWC, CIWC
    # sum cloud liquid water and ice
       if scwc is None:
               scwc = codes_get_values(gid)
       else:
               scwc += codes_get_values(gid)
               codes_set_values(gid, scwc)
               codes_set(gid, 'paramId', 201031)
               codes_write(gid, fdict['22'])
               scwc = None

I’ll try it and update later.

The EcCodes has definition files of local concepts for both ecmf and era5. In this case, the ecmf def file has the “201031” block while era5 has not. My practice is to copy ecmf definition to era5’s, which solves the problem for the moment.

The file is:

…/eccodes/definitions/grib2/localConcepts/ecmf/paramId.def

I copied the definition block to file:

…/eccodes/definitions/grib2/localConcepts/era/paramId.def

Please report if you can run FLEXPART using data retrieved with flex_extract. For me here, it always stopped with errors like ‘no wind fields’

no, there should be an era folder in the path, along with others like 'ecmf ', ‘cnmc’ etc. How did you install eccodes?

You can try a newer version (current 2.38), the 2.7.3 is quite aged, probably has no era def.

Is the new version of eccodes compatible with flexpart 10.4 and are there any additional libraries needed to install eccodes version 2.38?

Did you ultimately solve this issue (as a public user)? It seems that ECMWF and ERA use different code indices, and directly substituting them might lead to retrieval issues. I only copied the block related to 201030 from ECMWF into ERA, reinstalled eccodes using CMAKE, but still encountered the same issue as you. Could it be that flex_extract can no longer access ERA5 as a public user?