blob: a608627813225179fcbf3c34b4cccc5df8663d7a (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
|
import torch.nn as nn
import torch.utils.data as tud
import torch
class Model(nn.Module):
def __init__(self, customs: dict, dataloader: tud.DataLoader = None):
"""
:param customs: 自定义参数,内容取自于config.ini文件的[CustomParameters]部分。
:param dataloader: 数据集初始化完成的dataloader。在自定义的预处理方法文件中,可以增加内部变量或者方法,提供给模型。
例如:模型初始化需要数据的维度数量,可通过n_features = dataloader.dataset.train_inputs.shape[-1]获取
或在预处理方法的MyDataset类中,定义self.n_features = self.train_inputs.shape[-1],
通过n_features = dataloader.dataset.n_features获取
"""
super(Model, self).__init__()
def forward(self, x):
"""
:param x: 模型的输入,在本工具中为MyDataset类中__getitem__方法返回的三个变量中的第一个变量。
:return: 模型的输出,可以自定义
"""
return None
def loss(self, x, y_true, epoch: int = None, device: str = "cpu"):
"""
计算loss。注意,计算loss时如采用torch之外的库计算会造成梯度截断,请全部使用torch的方法
:param x: 输入数据
:param y_true: 真实输出数据
:param epoch: 当前是第几个epoch
:param device: 设备,cpu或者cuda
:return: loss值
"""
y_pred = self.forward(x) # 模型的输出
loss = torch.Tensor([1]) # 示例,请修改
loss.backward()
return loss.item()
def detection(self, x, y_true, epoch: int = None, device: str = "cpu"):
"""
检测方法,可以输出异常的分数,也可以输出具体的标签。
如输出异常分数,则后续会根据异常分数自动划分阈值,高于阈值的为异常,自动赋予标签;如输出标签,则直接进行评估。
:param x: 输入数据
:param y_true: 真实输出数据
:param epoch: 当前是第几个epoch
:param device: 设备,cpu或者cuda
:return: score,label。如选择输出异常的分数,则输出score,label为None;如选择输出标签,则输出label,score为None。
score的格式为torch的Tensor格式,尺寸为[batch_size];label的格式为torch的IntTensor格式,尺寸为[batch_size]
"""
y_pred = self.forward(x) # 模型的输出
return None, None
|