基于pytorch的代价敏感决策树模型平衡CICIDS-2017数据集算法代码并用cnn模型训练代码

时间: 2024-01-12 16:05:20 浏览: 40
以下是使用 PyTorch 实现的代价敏感决策树模型平衡 CICIDS-2017 数据集,并使用 CNN 模型训练的代码: ``` import torch import torch.nn as nn import torch.optim as optim import pandas as pd from sklearn.model_selection import train_test_split from sklearn.metrics import classification_report, confusion_matrix from imblearn.datasets import fetch_datasets from imblearn.under_sampling import RandomUnderSampler # 读取数据集 dataset = fetch_datasets()['CICIDS2017'] X = dataset.data y = dataset.target # 平衡数据集 sampler = RandomUnderSampler(random_state=42) X_resampled, y_resampled = sampler.fit_resample(X, y) # 划分训练集和测试集 X_train, X_test, y_train, y_test = train_test_split(X_resampled, y_resampled, test_size=0.2, random_state=42) # 定义 CNN 模型 class CNN(nn.Module): def __init__(self): super(CNN, self).__init__() self.conv = nn.Sequential( nn.Conv2d(1, 16, kernel_size=(3, 3)), nn.ReLU(), nn.MaxPool2d(kernel_size=(2, 2)), nn.Conv2d(16, 32, kernel_size=(3, 3)), nn.ReLU(), nn.MaxPool2d(kernel_size=(2, 2)), nn.Flatten(), nn.Linear(1152, 128), nn.ReLU(), nn.Linear(128, 2) ) def forward(self, x): x = x.unsqueeze(1) x = self.conv(x) return x # 定义代价敏感决策树损失函数 class CostSensitiveDecisionTreeLoss(nn.Module): def __init__(self, cost_matrix): super(CostSensitiveDecisionTreeLoss, self).__init__() self.cost_matrix = cost_matrix def forward(self, input, target): loss = 0.0 for i in range(input.shape[0]): if target[i] == 0: loss += self.cost_matrix[0][1] * input[i][1] else: loss += self.cost_matrix[1][0] * input[i][0] return loss / input.shape[0] # 训练 CNN 模型 model = CNN() optimizer = optim.Adam(model.parameters(), lr=0.001) criterion = nn.CrossEntropyLoss() epochs = 10 for epoch in range(epochs): running_loss = 0.0 for i in range(len(X_train)): x = torch.tensor(X_train[i], dtype=torch.float32).view(1, 1, 28, 28) y = torch.tensor(y_train[i], dtype=torch.long) optimizer.zero_grad() outputs = model(x) loss = criterion(outputs, y) loss.backward() optimizer.step() running_loss += loss.item() print('Epoch [%d], Loss: %.4f' % (epoch+1, running_loss/len(X_train))) # 使用代价敏感决策树损失函数训练 CNN 模型 cost_matrix = torch.tensor([[0, 1], [5, 0]], dtype=torch.float32) criterion = CostSensitiveDecisionTreeLoss(cost_matrix) epochs = 20 for epoch in range(epochs): running_loss = 0.0 for i in range(len(X_train)): x = torch.tensor(X_train[i], dtype=torch.float32).view(1, 1, 28, 28) y = torch.tensor(y_train[i], dtype=torch.long) optimizer.zero_grad() outputs = model(x) loss = criterion(outputs, y) loss.backward() optimizer.step() running_loss += loss.item() print('Epoch [%d], Loss: %.4f' % (epoch+1, running_loss/len(X_train))) # 测试 CNN 模型 y_pred = [] for i in range(len(X_test)): x = torch.tensor(X_test[i], dtype=torch.float32).view(1, 1, 28, 28) output = model(x) _, predicted = torch.max(output.data, 1) y_pred.append(predicted.item()) print(confusion_matrix(y_test, y_pred)) print(classification_report(y_test, y_pred)) ``` 在这个代码中,我们首先使用 `fetch_datasets()` 函数从 imbalanced-learn 库中获取 CICIDS-2017 数据集,并使用 `RandomUnderSampler` 类平衡数据集。然后,我们使用 `train_test_split` 函数划分训练集和测试集,并定义一个 CNN 模型。接着,我们使用 nn.Module 类定义一个代价敏感决策树损失函数,其中包含了一个代价矩阵。这个代价矩阵是一个 2x2 的矩阵,其中第一行表示对真实类别为负例的样本的惩罚,第二行表示对真实类别为正例的样本的惩罚。然后,我们使用 Adam 优化器和交叉熵损失函数训练 CNN 模型,并使用代价敏感决策树损失函数训练 CNN 模型。最后,我们使用训练好的 CNN 模型对测试集进行预测,并使用 `confusion_matrix` 和 `classification_report` 函数打印模型的评估结果。

相关推荐

最新推荐

recommend-type

Pytorch加载部分预训练模型的参数实例

今天小编就为大家分享一篇Pytorch加载部分预训练模型的参数实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

用Pytorch训练CNN(数据集MNIST,使用GPU的方法)

今天小编就为大家分享一篇用Pytorch训练CNN(数据集MNIST,使用GPU的方法),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

PyTorch版YOLOv4训练自己的数据集—基于Google Colab

你可以在上面轻松地跑例如:Keras、Tensorflow、Pytorch等框架;其次是入门相对简单,语法和cmd语句以及linux语句相似。目前colab平台GPU的状态信息如下图: 原创文章 3获赞 2访问量 186 关注
recommend-type

基于pytorch的UNet_demo实现及训练自己的数据集.docx

基于pytorch的UNet分割网络demo实现,及训练自己的数据集。包括对相关报错的分析。收集了几个比较好的前辈的网址。
recommend-type

使用pytorch搭建AlexNet操作(微调预训练模型及手动搭建)

本文介绍了如何在pytorch下搭建AlexNet,使用了两种方法,一种是直接加载预训练模型,并根据自己的需要微调(将最后一层全连接层输出由1000改为10),另一种是手动搭建。 构建模型类的时候需要继承自torch.nn.Module...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用 Python 画一个可以动的爱心

好的,我可以帮助您使用Python来绘制一个动态的爱心。您可以使用turtle库来实现。以下是实现代码: ```python import turtle import math # 设置画布和画笔 canvas = turtle.Screen() canvas.bgcolor("black") pencil = turtle.Turtle() pencil.speed(0) pencil.color("red", "pink") pencil.pensize(3) # 定义爱心函数 def draw_love(heart_size, x_offset=0, y_offset=0):
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。