Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

EOBS: r95p und rr95p #47

Open
KatharinaBuelow opened this issue Mar 28, 2024 · 5 comments
Open

EOBS: r95p und rr95p #47

KatharinaBuelow opened this issue Mar 28, 2024 · 5 comments

Comments

@KatharinaBuelow
Copy link
Contributor

I calculated all precipitation indices using '-search_query variable_id:rr ' and also R95p for eobs and all went fine, but I can not calculate RR95p.
I used
index_calculation -p EOBS create_scripts -idx RR95p -intake /work/ch0636/eddy/pool/intake-esm_catalogues/EOBS.json -scrpt_dir /scratch/g/g300047/index_calculation -out_dir /work/ch0636/g300047/index_calculation -ofreq sem -submit

and also

index_calculation -p EOBS create_scripts -idx RR95p -intake /work/ch0636/eddy/pool/intake-esm_catalogues/EOBS.json -scrpt_dir /scratch/g/g300047/index_calculation -out_dir /work/ch0636/g300047/index_calculation -ofreq sem -search_query variable_id:rr -submit

Do you have an idea where to look for the mistake?
The log file sends me to xarray ?
...
.... python3.10/site-packages/xarray/core/dataset.py", line 214, in _get_virtual_variable
raise KeyError(key)
KeyError: 'rr'

But it worked for everything else very well ?

@ludwiglierhammer
Copy link
Collaborator

Hi @KatharinaBuelow, the only information I get from this error message is that the variable rr, wherever, does not occur. As far as I could read in the code, you need to to set a xclim function that calculates RRYYp. You can define this function in the __init__ function of this class. See here.

You can find a list of available xclim functions in the documentation

Hopfully this solves your problem. If not, you can send me the entire error message for a more detailed analysis.

Please submit a new PR if you want to make changes to the code.

@KatharinaBuelow
Copy link
Contributor Author

Hi @ludwiglierhammer I could in most cases calculate RR95p for euro-cordex using xcalc-0-11-0, but the results do not look good. (You used: x_calc_0.6.1, where the results look good), it is just a problem that starts with new version xcalc_0.7.1 and higher.
I use xcalc_0-11-0, which produces wrong files for euro cordex : only 1971-2000 in one file and the timesteps do not have a date

There is no xclim funktion which calculates the percentile value, as far as could see.

You wrote this funktion:

class RRYYp(ClimateIndicator):

It is not new.

Perhaps I should try eobs later again.
Perhaps you could have a look, or if you see better then me and see a xclim funktion for the percentile, let me know I could try to add that as a new index.

@ludwiglierhammer
Copy link
Collaborator

I think you should ask the xclim guys about this version issue. I have no knowledge in this percentage area.

Could you send me the entire log file? I may have a look at it.

@KatharinaBuelow
Copy link
Contributor Author

@ludwiglierhammer ich glaube es hat keine priorität, da wir glaube ich RR95p nicht verwenden, aber es fällt einem ja immer wieder auf die Füße, wenn man etwas nicht löst.
Unbenanntes Dokument.pdf
Den orginal log file konnte ich hier nicht anhängen

@ludwiglierhammer
Copy link
Collaborator

@KatharinaBuelow:
Versuch einmal diese Funktion anzupassen:

def _rename_variable_names(self, ds):
    if self.project not in cfjson.keys():
        return ds
    var_names = cfjson[self.project]["variables"]
    units = cfjson[self.project]["units"]
    for dvar in ds.data_vars:
        if dvar in var_names.keys():
            ds = ds.rename({dvar: var_names[dvar]})
            idx = self.var_name.index(dvar)  # new line
            dvar = var_names[dvar]
            self.var_name[idx] = dvar  # new line
        if dvar in units.keys():
            ds[dvar].attrs["units"] = units[dvar]
    return ds

und diesen Codeabschnitt:

self.unlimited_dims = None  # new line
for dim in idx_ds[self.CIname].dims:
    if self.unlimited_dims:  # new ine
        break  # new line    
    for var_name in self.var_name:
        if dim not in self.preproc[var_name].dims:
            self.unlimited_dims = dim
            break

Alles weitere gern in einem neuen PR.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants