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

Add CFS model #199

Open
wants to merge 8 commits into
base: main
Choose a base branch
from
Open

Add CFS model #199

wants to merge 8 commits into from

Conversation

blaylockbk
Copy link
Owner

Adds a Herbie template for the NOAA Climate Forecast System (CFS)

Resolves #198 request.

The CFS model has lots of files associated with it, and thus the inputs for the Herbie template are kind of all over the place.

@blaylockbk blaylockbk marked this pull request as ready for review November 7, 2023 05:27
@MeasureSpace
Copy link

Hello, any plan to merge this PR?

herbie/models/cfs.py Outdated Show resolved Hide resolved
herbie/models/cfs.py Outdated Show resolved Hide resolved
herbie/models/cfs.py Outdated Show resolved Hide resolved
@blaylockbk
Copy link
Owner Author

Thanks for the poke @MeasureSpace. After looking at this again, I remember why I didn't merge it...I am so unfamiliar with the CFS structure and didn't understand the naming convention to make the Herbie template easy to use. It would take some time to come up with a good template that allowed users to download all types of CFS files.

I don't have that time now, but could do two things:

  1. Merge this into the main branch, even though I feel like it's half baked (I added a warning that this CFS is an alpha capability).
  2. Let you just use this branch if it works for you.

@blaylockbk blaylockbk linked an issue Jan 3, 2025 that may be closed by this pull request
@MeasureSpace
Copy link

Hi @blaylockbk, thanks a lot for the quick response. I tested the CFS code, and it works fine for me. Another useful component is the time series data from CFS (see below). Feel free to include it in your code.

class cfs_time_series:
    def template(self):
        self.DESCRIPTION = "Climate Forecast System; Time Series"
        self.DETAILS = {
            "NOMADS product description": "https://www.nco.ncep.noaa.gov/pmb/products/cfs/",
            "Amazon Open Data": "https://registry.opendata.aws/noaa-cfs/",
            "Microsoft Azure": "https://planetarycomputer.microsoft.com/dataset/storage/noaa-cfs",
        }
        # https://www.nco.ncep.noaa.gov/pmb/products/cfs/#DAILY
        self.PRODUCTS = {
            "wnd10m": "10 meter wind",
            "tmp2m": "2 meter temperature",
            "tmin": "Minimum Temperature 2 Meters Above",
            "tmax": "Maximum Temperature 2 Meters Above",
            "q2m": "2 meter specific humidity",
            "tcdcclm": "total cloud cover",
            "prate": "total precipitation rate",
            "weasd": " Water Equivalent of Accumulated Snow Depth",
            "soilt1": "Soil Temperature, 0-0.1 m Below Ground",
            "soilm1": "Soil Moisture Content, 0-0.1 m Below Ground",
            "pressfc": "surface pressure",
            "dswsfc": "shortwave radiation at the surface",
        }

        try:
            self.member
        except NameError:
            print(
                "'member' is not defined. Please set 'member=1` for monthly data for the 6, 12, and 18 UTC cycles, but may be 1, 2, 3, or 4 for the 0 UTC cycle."
            )

        PATH = f"cfs.{self.date:%Y%m%d/%H}/time_grib_{self.member:02d}/{self.product}.{self.member:02d}.{self.date:%Y%m%d%H}.daily.grb2"

        self.SOURCES = {
            "aws": f"https://noaa-cfs-pds.s3.amazonaws.com/{PATH}",
            "nomads": f"https://nomads.ncep.noaa.gov/pub/data/nccf/com/cfs/prod/{PATH}",
            # "azure": f"https://noaacfs.blob.core.windows.net/cfs/{PATH}"
        }

        self.IDX_SUFFIX = [".grb2.idx", ".idx", ".grib.idx"]
        self.LOCALFILE = f"{self.get_remoteFileName}"

Copy link

@MeasureSpace MeasureSpace left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Might want to check the CI failures and include the cfs_time_series model. Otherwise, LGTM.

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

Successfully merging this pull request may close these issues.

Any support for downloading CFSv2 data? Add CFS model
2 participants