Metadata-Version: 2.1
Name: phenofect
Version: 1.0.4
Summary: Package for Forecasting and Exploration of Plant Phenology under Climate Change, which has Parameter Examination, Visualization, Clustering and so on... with Phenological & Meteorological Data.
Home-page: https://github.com/SongWon03/PhenoFECT
Author: Songwon Kim
Author-email: kimsongwon10@korea.ac.kr
License: MIT
Classifier: Programming Language :: Python :: 3
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Requires-Python: >=3.6
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: numpy==1.24.4
Requires-Dist: pandas==2.0.3
Requires-Dist: scikit-learn==1.3.2
Requires-Dist: matplotlib==3.7.5
Requires-Dist: seaborn==0.13.2
Requires-Dist: scipy==1.10.1
Requires-Dist: tqdm==4.67.1
Requires-Dist: requests==2.32.3
Requires-Dist: beautifulsoup4==4.12.3

# PhenoFECT: Phenology Forecasting and Exploring under ClimaTe change

## What is PhenoFECT?

**PhenoFECT** is an open-source and open meteorological/phenology data (for Korea & Japan) embedded python package designed to guide the overall analysis procedure for **Budding & Flowering Prediction** applicable to user-target plant. It offers useful functions including, Key Parameter Examination of temperature-based model, Clustering, Visualization, Downloading & Merging Phenological and Meteorological Data... and so on. The Chill-Day model (CDM) refined by PhenoFECT showed the highest prediction accuracy for Korean local areas. The root mean square error (RMSE) for the prediction of flowering event decreased about 1–8 days for three temperate zone angiosperms. Under global warming and climate change, the timing of the phenological events of flowering plants is one of the good **climate change indicator**. PhenoFECT can be utilized to predict the phenological event of diverse orchard and tree species and has an advantage of easy-to-use due to the embedded dataset.  

What is **Chill-Day model** and how to apply?  
- [Chilling and forcing model to predict bud-burst of crop and forest species](https://www.sciencedirect.com/science/article/pii/S0168192304000632)
- [Prediction of Blooming Dates of Spring Flowers by Using Digital Temperature Forecasts and Phenology Models](https://www.researchgate.net/publication/263399406_Prediction_of_Blooming_Dates_of_Spring_Flowers_by_Using_Digital_Temperature_Forecasts_and_Phenology_Models) 

## Table of Contents

- [PhenoFECT: Phenology Forecasting and Exploring under ClimaTe change](#phenofect-phenology-forecasting-and-exploring-under-climate-change)
  - [What is PhenoFECT?](#what-is-phenofect)
  - [Table of Contents](#table-of-contents)
  - [How to use PhenoFECT?](#how-to-use-phenofect)
  - [Main Features](#main-features)
  - [Description for Embedded Dataset (**Korea**)](#description-for-embedded-dataset-korea)
  - [Description for Embedded Dataset (**Japan**)](#description-for-embedded-dataset-japan)
  - [Physiological Background for Plant Phenology](#physiological-background-for-plant-phenology)
  - [Where to get it](#where-to-get-it)
  - [Useful Readings \& Links](#useful-readings--links)
  - [Contributing to PhenoFECT](#contributing-to-phenofect)

## How to use PhenoFECT?

[Here](https://wikidocs.net/book/17034) is the detailed user guide of PhenoFECT.  

## Main Features

PhenoFECT is designed to specialize in these areas.
- Contains sufficient [Embedded Data for Korea](#description-for-embedded-dataset) extracted from [**Public Data Portal in Korea**](https://www.data.go.kr/) and [Embedded Data for Japan]() extracted from [**JMA (Japan Meteorological Administration)**](). 
- Easily [download and merge](https://wikidocs.net/272158) various types of phenological and meteorological data into the embedded data set or create your own. [Filter and Preprocess]([https://wikidocs.net/272158](https://wikidocs.net/272259)) data to make it compatible with the package.
- [Predict Bud-burst](https://wikidocs.net/272309) and [Predict Flowering](https://wikidocs.net/272326) simultaneously for multiple regions with Chill-Day Model and Dataset. Highest accuracy for Korean local areas among previously published models.
- Simple application of [Hierarchical Clustering](https://wikidocs.net/272554) based on Chill-Day Model Temperature Time and [2D & 3D t-SNE method](https://wikidocs.net/272554) for future analysis.
- Select best key parameter sets with [Error Heatmap](https://wikidocs.net/272326#details-of-flowering_error_heatmap) and [Error Contourmap](https://wikidocs.net/272326#details-of-flowering_error_contourmap) visualization based on Mean Absolute Error(MAE) & Root Mean Squared Error(RMSE).
- After select the best fit parameter set, [line graph & simple regression](https://wikidocs.net/272345) shows how you select parameters well.
- [Detailed shape of Chill-Day Model graph](https://wikidocs.net/272553#details-of-detailed_chillday_graph) for each location & year and [Merged Chill-Day Model graph](https://wikidocs.net/272750#details-of-chillday_graph_merged) for each Cluster. 
- Contains [information](https://wikidocs.net/272757) about the years of occurrence of El Niño and La Niña in Korea, gives plot [how the prediction error shifts](https://wikidocs.net/272750#prediction-error-shift-under-climate-change) under climate change.  


## Description for Embedded Dataset (**Korea**)

| Data | Division | Description | Period | Reference |
|----:|----:|----:|----:|-----:|
|daily_meteorological_data|Daily|95 locations & 39 variables|1907-2025 (Maximum)|[Public Data Portal in Korea](https://www.data.go.kr/data/15043648/fileData.do)|
|monthly_meteorological_data|Monthly|95 locations & 31 variables| 1907-2025 (Maximum)| [KMA](https://www.data.go.kr/data/15043648/fileData.do)|
|daylen_temperature_data|Daily|95 locations & 4 variables|1907-2025 (Maximum)|[Public Data Portal in Korea](https://www.data.go.kr/data/15043648/fileData.do)|
|OBS_phenology_data|Animal, Plant, Meteorological Phenomena|Main Target (Budding date/Flowering date/Full Bloom date)| 1973-2025 (Observed Once A Year)| [KMA](https://data.kma.go.kr/data/seasonObs/seasonObsDataList.do?pgmNo=648)|
|azalea_phenology_data|Azalea (budding/flowering/full bloom)|Extracted from OBS_phenology_data| 1973-2025 (Observed Once A Year)| [KMA](https://data.kma.go.kr/data/seasonObs/seasonObsDataList.do?pgmNo=648)| 
|cherry_phenology_data|Cherry (budding/flowering/full bloom)|Extracted from OBS_phenology_data| 1973-2025 (Observed Once A Year)| [KMA](https://data.kma.go.kr/data/seasonObs/seasonObsDataList.do?pgmNo=648)|
|forsythia_phenology_data|Forsythia (budding/flowering/full bloom)|Extracted from OBS_phenology_data| 1973-2025 (Observed Once A Year)| [KMA](https://data.kma.go.kr/data/seasonObs/seasonObsDataList.do?pgmNo=648)|
 

All embedded dataset can be downloaded from [this repository](https://github.com/SongWon03/PhenoFECT/tree/main/Embedded_Dataset) or [here](https://drive.google.com/drive/folders/1C1-MjZfz-xxKi8u51Na7rhOPy-hr4DrV). The `daily_meteorological_data` is not in repository's `Embedded_Dataset Folder` due to its capacity. Dataset can also be handled easily using **PhenoFECT package**. 

## Description for Embedded Dataset (**Japan**)

| Data | Division | Description | Period | Reference |
|----:|----:|----:|----:|-----:|
|daily_meteorological_data|Daily|101 locations & 3 variables|1976-2025 (Maximum)|[JMA](https://www.data.jma.go.jp/stats/etrn/index.php?prec_no=&block_no=&year=&month=1&day=&view=)|
|camellia_phenology_data|Camellia (flowering)|102 locations|1953-2020 (Maximum)|[JMA](https://www.data.jma.go.jp/sakura/data/index.html)|
|cherry_phenology_data|Cherry (flowering/full bloom)|102 locations|1953-2024 (Maximum)|[JMA](https://www.data.jma.go.jp/sakura/data/index.html)|
|dandelion_phenology_data|Dandelion (flowering)|102 locations|1953-2020 (Maximum)|[JMA](https://www.data.jma.go.jp/sakura/data/index.html)|
|narcissus_phenology_data|Narcissus (flowering)|102 locations|1953-2021 (Maximum)|[JMA](https://www.data.jma.go.jp/sakura/data/index.html)|
|plumblossom_phenology_data|Plum blossom (flowering)|102 locations|1953-2024 (Maximum)|[JMA](https://www.data.jma.go.jp/sakura/data/index.html)|
|wisteria_phenology_data|Wisteria (flowering)|102 locations|1953-2020 (Maximum)|[JMA](https://www.data.jma.go.jp/sakura/data/index.html)|

All embedded dataset can be downloaded from [this repository](https://github.com/SongWon03/PhenoFECT/tree/main/Embedded_Dataset) or [here](https://drive.google.com/drive/folders/1C1-MjZfz-xxKi8u51Na7rhOPy-hr4DrV).   
**Note**: The Chill-Day model (CDM) is species-specific model. The information about observed species and observation method is in [JMA](https://www.data.jma.go.jp/sakura/data/index.html). 


## Physiological Background for Plant Phenology

After summer, if the nutrition & weather conditions are satisfied, woody plants prepare next year flowering by differentiation to **flower buds**. But to prevent flower bud differentiate to flowers in cold winter condition because of transient warm temperature, flower buds come into **dormancy state** and their flowering control genes maintain bud statement until they get enough cold requirment. 

![Endo-dormancy (Cherry Blossom)](https://github.com/SongWon03/PhenoFECT/blob/main/Imgs/cherry_endo_dormancy.jpg)

In the Phenology Model, we call the cold requirement as '*Chill-requirement(Cr)*'. If the woody plant get enough cold, dormancy releases. From this time, plant needs Heat to differentiate into flowers. After the heat accumulated same amount to Cr, the Budding event happens. We call that as **Bud burst**. Last, the amount of heat accumulation flower bud differentiate into flower, **flowering**, is called as '*Heat-requirement(Hr)*'.

![Flowering (Cherry Blossom)](https://github.com/SongWon03/PhenoFECT/blob/main/Imgs/cherry_flowering.jpg)

- Dormancy initiation: The Day when minimum temperature reaches to 5-7℃. (Depends on species)
- Dormancy release: The first Day when Chill accumulation is lower than Chill-requirement. 
- Bud burst: Observed Day when 20% of total flower buds in Woody plant get into bud burst.
- Flowering: Observed Day when 3 flowers are observed in a branch. 
- Detailed definition and observation rules are [**guidelines**](https://data.kma.go.kr/data/publication/publicationGlList.do) of KMA(Korea Meteorological Administration).


## Where to get it

The source code is currently hosted on GitHub at:
[https://github.com/SongWon03/PhenoFECT](https://github.com/SongWon03/PhenoFECT)

Installers for the latest released version are available at the [Python Package Index (PyPI)](https://pypi.org/project/pyCDM4F/)

```python
# PyPI

pip install phenofect
```  

## Useful Readings & Links

- [KMA (Korea Meteorological Administration)](https://data.kma.go.kr/)
- [JMA (Japan Meteorological Administration)](https://www.data.jma.go.jp/stats/etrn/index.php?prec_no=&block_no=&year=&month=1&day=&view=)
- [Public Data Portal in Korea](https://www.data.go.kr/)
- [Chilling and forcing model to predict bud-burst of crop and forest species](https://www.sciencedirect.com/science/article/abs/pii/S0168192304000632)
- [Predicting Cherry Flowering Date Using a Plant Phonology Model](https://www.researchgate.net/publication/263643081_Predicting_Cherry_Flowering_Date_Using_a_Plant_Phonology_Model)


## Contributing to PhenoFECT

All questions, bug reports, bug fixes, enhancements, requests, and ideas are welcome.

Feel free to send an email. 
- **kimsongwon10@korea.ac.kr**
