Skip to content

This repository contains a comprehensive project on detecting network intrusions using various machine learning models. It includes data preprocessing, exploratory data analysis, feature selection, model training, and evaluation. The goal is to build robust classifiers to identify potential network threats accurately.

License

Notifications You must be signed in to change notification settings

FouadHellal/Network-Intrusion-Detection-with-Machine-Learning

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Network Intrusion Detection with Machine Learning

This repository contains a comprehensive project focused on detecting network intrusions using various machine learning models. The project includes data preprocessing, exploratory data analysis, feature selection, model training, and evaluation to build robust classifiers for identifying potential network threats accurately.

Table of Contents

Project Overview

The objective of this project is to develop machine learning models capable of detecting network intrusions. The steps involved in the project are:

  1. Data Loading and Initial Inspection
  2. Exploratory Data Analysis (EDA)
  3. Data Preprocessing
  4. Feature Selection
  5. Model Training and Evaluation
  6. Model Optimization
  7. Performance Comparison

Dataset

The dataset used in this project is divided into training and testing sets:

  • Train_data.csv: Contains the training data.
  • Test_data.csv: Contains the testing data.

Both files are located in the Dataset directory.

Requirements

The project requires the following Python libraries:

  • numpy
  • pandas
  • seaborn
  • matplotlib
  • warnings
  • optuna
  • scikit-learn
  • lightgbm
  • catboost
  • xgboost
  • tabulate

Installation

To install the required libraries, you can use the following command:

pip install numpy pandas seaborn matplotlib optuna scikit-learn lightgbm catboost xgboost tabulate

Usage

To run the project, follow these steps:

Clone the repository:

git clone https://github.com/FouadHellal/network-intrusion-detection.git

Navigate to the project directory:

cd network-intrusion-detection

Run the Python script:

python intrusion_detection.py

Models and Optimization

The project includes the following machine learning models:

  • K-Nearest Neighbors (KNN)
  • Logistic Regression
  • Decision Tree
  • Random Forest
  • Gradient Boosting
  • XGBoost
  • LightGBM
  • AdaBoost
  • CatBoost
  • Naive Bayes
  • Voting Classifier
  • Support Vector Machine (SVM)
  • Hyperparameter optimization is performed using Optuna for models like KNN, Decision Tree, Random Forest, and SVM.

Results

The results of the models are summarized in a tabular format, showing both train and test accuracies. The confusion matrix of the best model (XGBoost) is also displayed to visualize the classification performance.

Contributing

Contributions are welcome! Please follow these steps:

  1. Fork the repository.
  2. Create a new branch.
  3. Make your changes and commit them.
  4. Push your changes to your fork.
  5. Submit a pull request.

License

This project is licensed under the MIT License.

About

This repository contains a comprehensive project on detecting network intrusions using various machine learning models. It includes data preprocessing, exploratory data analysis, feature selection, model training, and evaluation. The goal is to build robust classifiers to identify potential network threats accurately.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages