Skip to content

Change Point Analysis and Statistical Modelling of Time Series Data - Detecting Changes and Associating causes on Time Series Data

Notifications You must be signed in to change notification settings

tedoaba/Change-Point-Analysis-And-Statistical-Modeling

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

33 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Change Point Analysis and Statistical Modelling of Time Series Data - Detecting Changes and Associating causes on Time Series Data

KAIM Weak 10 Challenge

Project Overview

This project aims to analyze the impact of significant global events on Brent oil prices over the past few decades, focusing on political decisions, regional conflicts, economic sanctions, and OPEC policy changes. By detecting change points in time series data and analyzing the statistical impact of these events, we provide actionable insights for investors, policymakers, and energy companies. The project involves comprehensive data analysis and model building to predict price fluctuations and understand contributing factors.

As part of Birhan Energies, a consultancy dedicated to data-driven insights in the energy sector, this project helps our stakeholders make informed decisions in a volatile market environment.

Task Breakdown

The project is divided into multiple tasks to facilitate a structured approach to data analysis and model development.

Task 1: Define Data Analysis Workflow and Understand the Model

  • Objective: Plan the analysis workflow and ensure a solid understanding of the data and statistical models.
    • Outline the steps involved in analyzing the data.
    • Familiarize with time series models (e.g., ARIMA, GARCH).
    • Identify model inputs, parameters, and limitations.

Task 2: Time Series Analysis and Model Application

  • Objective: Build on foundational knowledge to analyze Brent oil prices.
    • Utilize statistical and econometric models (e.g., VAR, Markov-Switching ARIMA, LSTM) for complex pattern detection.
    • Analyze economic indicators (GDP, inflation, unemployment) and their relationship to oil prices.
    • Explore political, regulatory, and technological factors that influence oil prices.

Task 3: Interactive Dashboard Development

  • Objective: Create a user-friendly dashboard to visualize analysis results.
    • Develop a Flask-based backend and a React frontend for a seamless experience.
    • Present historical trends, forecasts, and correlations with events through interactive visualizations.

Folder Structure

The project uses a modular structure to maintain clean, organized code.

    ├── .github/
    ├── data/
    ├── figures/
    ├── frontend/
    ├── notebooks/
    │   ├── kaim_week_10_eda.ipynb
    │   ├── kaim_week_10_predict.ipynb
    │   ├── kaim_week_10_relation.ipynb
    ├── scripts/
    │   ├── __init__.py
    │   ├── app.py
    │   ├── main.py
    ├── src/
    │     └── __init__.py       
    │     ├── analysis.py
    │     ├── arima_model.py  
    │     └── feature_engineering.py  
    │     ├── model_trainig.py      
    │     └── relation.py    
    │     ├── visualization.py                            
    ├── tests/
    │   ├── __init__.py                  
    │   ├── test_data_loader.py               
    ├── requirements.txt                     
    ├── README.md                           

Installation

To set up the project on your local machine, follow these steps:

  1. Clone the Repository:

    git clone https://github.com/tedoaba/KAIM-W10.git
    cd KAIM-w10
  2. Install Dependencies: Use the following command to install necessary packages:

    python -m venv .week10
    
    source .week10/Scripts/activate
    
    pip install -r requirements.txt
    
  3. Set Up Dashboard (Flask + React):

    • Navigate to the scripts directory and start the Flask server:
      python app.py
    • Navigate to the frontend directory and start the React app:
      npm install
      npm start
  4. Access the Dashboard: Open your browser and go to http://localhost:3000 to interact with the dashboard.

Visualization

The interactive dashboard provides the following visualization features:

  • Historical Trends: Line charts displaying historical Brent oil price trends with highlighted events.

Price Trend

  • Correlation Analysis: Scatter plots showing relationships between Brent oil prices and selected economic indicators (natural gas price, exchange rate, etc.).

Oil Price with Natural Gas

Merged Price

Moving Average

Moving Average

Oil Price with Exchange Rate

Exchange Rate

  • Event Highlights: Interactive elements that allow users to select and highlight specific events on the timeline.

Natural gas vs Oil Price

Event Highlight

US Economic Depresson

Economic Depression

  • Model Future Forcast Results: Interactive elements that allow users to select and highlight future prices on the timeline.

XGBoost

CatBoost

Decision Tree

Random Fores

SARIMA

  • Residual Distribution: Interactive elements that allow users to select and highlight residual distribution on the timeline.

XGBoost

CatBoost

Decision Tree

Random Fores

  • Forecasting and Predictions: Displayed through charts (e.g., Recharts, Chart.js) for understanding future price movements based on selected models.

Dashboard

Contributing

We welcome contributions! To contribute:

  1. Fork the Repository: Create a fork and clone it locally.
  2. Create a Branch:
    git checkout -b feature-name
  3. Make Your Changes: Implement your feature or fix.
  4. Run Tests: Ensure all tests pass before committing.
  5. Push and Submit PR:
    git push origin feature-name
  6. Submit a Pull Request: Describe your changes and submit the pull request for review.

For significant changes, please open an issue first to discuss your ideas.

About

Change Point Analysis and Statistical Modelling of Time Series Data - Detecting Changes and Associating causes on Time Series Data

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published