Name | zambretti-py JSON |
Version |
0.0.6
JSON |
| download |
home_page | None |
Summary | The Zambretti Algorithm for weather forecasting |
upload_time | 2025-01-16 21:27:08 |
maintainer | None |
docs_url | None |
author | None |
requires_python | >=3.9 |
license | None |
keywords |
forecasting
weather
zambretti
|
VCS |
|
bugtrack_url |
|
requirements |
No requirements were recorded.
|
Travis-CI |
No Travis.
|
coveralls test coverage |
No coveralls.
|
# Zambretti Weather Forecasting in Python
This is a Python implementation of the [Zambretti Weather
Forecaster](https://en.wikipedia.org/wiki/Zambretti_Forecaster)
The code is heavily based on the [Zambretti Algorithm for Weather Forecasting
ESP
example](https://github.com/sassoftware/iot-zambretti-weather-forcasting?tab=readme-ov-file)
Further reading: [Short-Range Local Forecasting with a Digital Barograph using
an Algorithm based on the Zambretti
Forecaster.](https://integritext.net/DrKFS/zambretti.htm)
## Python Package
This repository is available as a package in PyPi: [https://pypi.org/project/zambretti-py/](https://pypi.org/project/zambretti-py/)
## Usage notes
To calculate for forecast, the Zambretti algorithm requires:
- elevation above sea level
- current temperature
- pressure data from the last three hours, or less.
- data points older than three hours will be removed
- the pressure data is expected to be provided as a list of tuples, each
tuple consisting of a datetime.datetime object, and the pressure as float
- optional wind direction, denoting the direction from which the wind is
flowing. This has a minor effect on the forecast and can be omitted.
The result will be a text description of the forecasted weather.
Pressure data must be provided in millibars or hPa (those are equivalent).
Elevation must be provided in meters.
Temperature must be provided in degrees Celsius.
Minimum 6 readings of atmospheric pressure are required. Best results are when
the pressure readings span the last three hours, but the code will run on any timespan.
## Technical notes
This project has no dependencies, uses only functions from the Python Standard
Library. It should run both in Python and MicroPython.
## Examples
### Example usage with provided pressure data:
```
import datetime
from zambretti_py import PressureData, WindDirection, Zambretti
now = datetime.datetime.now()
pressure_data = PressureData(
[
(now - datetime.timedelta(hours=2, minutes=59), 1050.0),
(now - datetime.timedelta(hours=2, minutes=49), 1040.0),
(now - datetime.timedelta(hours=2, minutes=39), 1030.0),
(now - datetime.timedelta(hours=2, minutes=12), 1020.0),
(now - datetime.timedelta(hours=1, minutes=19), 1010.0),
(now - datetime.timedelta(minutes=20), 1000.0),
]
)
zambretti = Zambretti()
forecast = zambretti.forecast(
elevation=90,
temperature=25,
pressure_data=pressure_data,
wind_direction=WindDirection.NORTH,
)
print(forecast)
```
### Example usage with loading pressure data from a CSV file:
If you have the pressure history in a CSV file such as this one:
| state | last_changed |
|----------------|---------------------------|
| 988.6 | 2024-11-19T11:33:32.706Z |
| 988.5 | 2024-11-19T11:34:06.863Z |
| 988.4 | 2024-11-19T11:37:06.887Z |
That file can be loaded into `PressureData` by using a `PressureData.from_csv_file`:
```
from zambretti_py import PressureData, WindDirection, Zambretti
pressure_data = PressureData.from_csv_file(
fname="history.csv",
timestamp_column_position=1,
pressure_column_position=0,
skip_header_rows=1,
strptime_template="%Y-%m-%dT%H:%M:%S.%fZ",
)
zambretti = Zambretti()
forecast = zambretti.forecast(
elevation=75,
temperature=3,
pressure_data=pressure_data,
wind_direction=WindDirection.SOUTH,
)
print(forecast)
```
### Example usage with a CSV file generated in Home Assistant:
When you have a sensor in Home Assistant, you can export its history from the
web interface, the result will be a CSV file with this schema:
| entity_id | state | last_changed |
|--------------|----------------|---------------------------|
| sensor.pressure | 988.6 | 2024-11-19T11:33:32.706Z |
| sensor.pressure | 988.5 | 2024-11-19T11:34:06.863Z |
| sensor.pressure | 988.4 | 2024-11-19T11:37:06.887Z |
That file can be loaded into `PressureData` by using `PressureData.from_home_assistant_csv`:
```
from zambretti_py import PressureData, WindDirection, Zambretti
pressure_data = PressureData.from_home_assistant_csv("history.csv")
zambretti = Zambretti()
forecast = zambretti.forecast(
elevation=75,
temperature=3,
pressure_data=pressure_data,
wind_direction=WindDirection.SOUTH,
)
print(forecast)
```
Raw data
{
"_id": null,
"home_page": null,
"name": "zambretti-py",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.9",
"maintainer_email": null,
"keywords": "forecasting, weather, zambretti",
"author": null,
"author_email": "STFN <stfndev@protonmail.com>",
"download_url": "https://files.pythonhosted.org/packages/28/5a/382fe0be0d44f65987b2d1fbc1c7f1c7c00172ba0438eac3df8a1a8f0b31/zambretti_py-0.0.6.tar.gz",
"platform": null,
"description": "# Zambretti Weather Forecasting in Python\n\nThis is a Python implementation of the [Zambretti Weather\nForecaster](https://en.wikipedia.org/wiki/Zambretti_Forecaster)\n\nThe code is heavily based on the [Zambretti Algorithm for Weather Forecasting\nESP\nexample](https://github.com/sassoftware/iot-zambretti-weather-forcasting?tab=readme-ov-file)\n\nFurther reading: [Short-Range Local Forecasting with a Digital Barograph using\nan Algorithm based on the Zambretti\nForecaster.](https://integritext.net/DrKFS/zambretti.htm)\n\n## Python Package\n\nThis repository is available as a package in PyPi: [https://pypi.org/project/zambretti-py/](https://pypi.org/project/zambretti-py/)\n\n## Usage notes\n\nTo calculate for forecast, the Zambretti algorithm requires:\n- elevation above sea level\n- current temperature\n- pressure data from the last three hours, or less.\n - data points older than three hours will be removed\n - the pressure data is expected to be provided as a list of tuples, each\n tuple consisting of a datetime.datetime object, and the pressure as float\n- optional wind direction, denoting the direction from which the wind is\n flowing. This has a minor effect on the forecast and can be omitted.\n\nThe result will be a text description of the forecasted weather. \n\nPressure data must be provided in millibars or hPa (those are equivalent).\nElevation must be provided in meters.\nTemperature must be provided in degrees Celsius.\n\nMinimum 6 readings of atmospheric pressure are required. Best results are when\nthe pressure readings span the last three hours, but the code will run on any timespan.\n\n## Technical notes\n\nThis project has no dependencies, uses only functions from the Python Standard\nLibrary. It should run both in Python and MicroPython.\n\n## Examples\n\n### Example usage with provided pressure data:\n\n```\nimport datetime\n\nfrom zambretti_py import PressureData, WindDirection, Zambretti\n\nnow = datetime.datetime.now()\npressure_data = PressureData(\n [\n (now - datetime.timedelta(hours=2, minutes=59), 1050.0),\n (now - datetime.timedelta(hours=2, minutes=49), 1040.0),\n (now - datetime.timedelta(hours=2, minutes=39), 1030.0),\n (now - datetime.timedelta(hours=2, minutes=12), 1020.0),\n (now - datetime.timedelta(hours=1, minutes=19), 1010.0),\n (now - datetime.timedelta(minutes=20), 1000.0),\n ]\n)\nzambretti = Zambretti()\n\nforecast = zambretti.forecast(\n elevation=90,\n temperature=25,\n pressure_data=pressure_data,\n wind_direction=WindDirection.NORTH,\n)\nprint(forecast)\n```\n\n### Example usage with loading pressure data from a CSV file:\n\nIf you have the pressure history in a CSV file such as this one:\n\n| state | last_changed |\n|----------------|---------------------------|\n| 988.6 | 2024-11-19T11:33:32.706Z |\n| 988.5 | 2024-11-19T11:34:06.863Z |\n| 988.4 | 2024-11-19T11:37:06.887Z |\n\nThat file can be loaded into `PressureData` by using a `PressureData.from_csv_file`:\n\n\n```\nfrom zambretti_py import PressureData, WindDirection, Zambretti\n\npressure_data = PressureData.from_csv_file(\n fname=\"history.csv\",\n timestamp_column_position=1,\n pressure_column_position=0,\n skip_header_rows=1,\n strptime_template=\"%Y-%m-%dT%H:%M:%S.%fZ\",\n)\n\nzambretti = Zambretti()\n\nforecast = zambretti.forecast(\n elevation=75,\n temperature=3,\n pressure_data=pressure_data,\n wind_direction=WindDirection.SOUTH,\n)\nprint(forecast)\n```\n\n### Example usage with a CSV file generated in Home Assistant:\n\nWhen you have a sensor in Home Assistant, you can export its history from the\nweb interface, the result will be a CSV file with this schema:\n\n| entity_id | state | last_changed |\n|--------------|----------------|---------------------------|\n| sensor.pressure | 988.6 | 2024-11-19T11:33:32.706Z |\n| sensor.pressure | 988.5 | 2024-11-19T11:34:06.863Z |\n| sensor.pressure | 988.4 | 2024-11-19T11:37:06.887Z |\n\nThat file can be loaded into `PressureData` by using `PressureData.from_home_assistant_csv`:\n\n```\nfrom zambretti_py import PressureData, WindDirection, Zambretti\n\npressure_data = PressureData.from_home_assistant_csv(\"history.csv\")\n\nzambretti = Zambretti()\n\nforecast = zambretti.forecast(\n elevation=75,\n temperature=3,\n pressure_data=pressure_data,\n wind_direction=WindDirection.SOUTH,\n)\nprint(forecast)\n```\n",
"bugtrack_url": null,
"license": null,
"summary": "The Zambretti Algorithm for weather forecasting",
"version": "0.0.6",
"project_urls": {
"Homepage": "https://github.com/thestfndev/zambretti-py",
"Issues": "https://github.com/thestfndev/zambretti-py/issues"
},
"split_keywords": [
"forecasting",
" weather",
" zambretti"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "ec409c62cd3f8807ce49b8b70a0999053f67ca741a88788818b1bbc5967f171c",
"md5": "abf60b9573ec810038b4bfdc7bf9db6b",
"sha256": "9e85424a8aa2bf3bcc30883c347c7d9157e365564b36971fd32b87781fc6c3b6"
},
"downloads": -1,
"filename": "zambretti_py-0.0.6-py3-none-any.whl",
"has_sig": false,
"md5_digest": "abf60b9573ec810038b4bfdc7bf9db6b",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.9",
"size": 6269,
"upload_time": "2025-01-16T21:27:06",
"upload_time_iso_8601": "2025-01-16T21:27:06.218577Z",
"url": "https://files.pythonhosted.org/packages/ec/40/9c62cd3f8807ce49b8b70a0999053f67ca741a88788818b1bbc5967f171c/zambretti_py-0.0.6-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "285a382fe0be0d44f65987b2d1fbc1c7f1c7c00172ba0438eac3df8a1a8f0b31",
"md5": "b9b5886f2530f898f54c3e989250b50a",
"sha256": "d8fc70803bb8bc9c07edb04988d73124172205d9ca791f32766358894c65d6d3"
},
"downloads": -1,
"filename": "zambretti_py-0.0.6.tar.gz",
"has_sig": false,
"md5_digest": "b9b5886f2530f898f54c3e989250b50a",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.9",
"size": 7159,
"upload_time": "2025-01-16T21:27:08",
"upload_time_iso_8601": "2025-01-16T21:27:08.060238Z",
"url": "https://files.pythonhosted.org/packages/28/5a/382fe0be0d44f65987b2d1fbc1c7f1c7c00172ba0438eac3df8a1a8f0b31/zambretti_py-0.0.6.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-01-16 21:27:08",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "thestfndev",
"github_project": "zambretti-py",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "zambretti-py"
}