forked from yueliu1999/HSAN
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmodel.py
37 lines (27 loc) · 1.15 KB
/
model.py
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
import torch
from opt import args
import torch.nn as nn
import torch.nn.functional as F
class hard_sample_aware_network(nn.Module):
def __init__(self, input_dim, hidden_dim, act, n_num):
super(hard_sample_aware_network, self).__init__()
self.AE1 = nn.Linear(input_dim, hidden_dim)
self.AE2 = nn.Linear(input_dim, hidden_dim)
self.SE1 = nn.Linear(n_num, hidden_dim)
self.SE2 = nn.Linear(n_num, hidden_dim)
self.alpha = nn.Parameter(torch.Tensor(1, ))
self.alpha.data = torch.tensor(0.99999).to(args.device)
self.pos_weight = torch.ones(n_num * 2).to(args.device)
self.pos_neg_weight = torch.ones([n_num * 2, n_num * 2]).to(args.device)
if act == "ident":
self.activate = lambda x: x
if act == "sigmoid":
self.activate = nn.Sigmoid()
def forward(self, x, A):
Z1 = self.activate(self.AE1(x))
Z2 = self.activate(self.AE2(x))
Z1 = F.normalize(Z1, dim=1, p=2)
Z2 = F.normalize(Z2, dim=1, p=2)
E1 = F.normalize(self.SE1(A), dim=1, p=2)
E2 = F.normalize(self.SE2(A), dim=1, p=2)
return Z1, Z2, E1, E2