Project: DECENTRALIZED MANUFACTURING MANAGEMENT BASED ON FEDERATED LEARNING WITH STACKING ENSEMBLE

1. Overview
   This project evaluates the performance of various Federated Learning (FL) algorithms and ensemble models using an industrial time-series dataset.

2. File Structure
   After unzipping, your project folder should have the following structure:

my_submission/
├── fl_algo_compare.py # Code for comparing FL algorithms
├── centralized_model_compare.py # Code for comparing centralized models
├── fl_stacking_compare.py # Code for FL with stacking models
├── federated_dataset.py # Dataset loading utility
├── pre-processing.ipynb # Data preprocessing steps and notes
├── processed/ # Dataset (.npy files)
├── requirements.txt # Package dependencies
└── README.md

3. Environment Setup & Dependencies
   This project was tested with Python 3.12.

Create and Activate a Virtual Environment

Bash

# Create venv with Python 3.12 (Windows)

py -3.12 -m venv my_env
.\my_env\Scripts\activate
Install Required Packages

Bash

pip install -r requirements.txt
(Optional) wandb Login

Bash

pip install wandb
wandb login
Results are also saved locally in the final_industrial_results folder, so logging in is not mandatory.

4. Dataset
   This project uses the 'Partial discharge data for preventing electrical fire accidents in industrial facilities' dataset from AI Hub.

Dataset Link: https://www.aihub.or.kr/aihubdata/data/view.do?currMenu=115&topMenu=100&dataSetSn=71682

The data preprocessing steps are detailed in the pre-processing.ipynb file.

5. Running Experiments
   Each script is designed for a specific experiment. Use the following commands to run them.

5-1. FL Algorithm Comparison (fl_algo_compare.py)
This script compares different FL algorithms, such as FedAvg, FedProx, and FedYogi.

Bash

python fl_algo_compare.py --algo fedavg
python fl_algo_compare.py --algo fedprox --param 0.01
python fl_algo_compare.py --algo fedyogi --param 0.005

5-2. Centralized Model Comparison (centralized_model_compare.py)
This script compares classic machine learning models in a centralized setting.

Bash

python centralized_model_compare.py --model catboost
python centralized_model_compare.py --model xgboost

5-3. FL + Stacking Model Comparison (fl_stacking_compare.py)
This script trains a FedProx model and then compares various stacking models on its output.

Bash

python fl_stacking_compare.py --stacking_model xgboost
python fl_stacking_compare.py --stacking_model lightgbm
