
import torch
import torch.nn as nn
from layer import GraphConv

class GCN(nn.Module):
    def __init__(self,
                 g,
                 in_feats,
                 n_hidden,
                 n_classes,
                 n_layers,
                 activation,
                 dropout):
        super(GCN, self).__init__()
        self.g = g
        self.layers = nn.ModuleList()
        # input layer
        self.layers.append(GraphConv(in_feats, n_hidden, activation=activation,bias=False))
        # hidden layers
        for i in range(n_layers - 1):
            self.layers.append(GraphConv(n_hidden, n_hidden, activation=activation,bias=False))
        # output layer
        self.layers.append(GraphConv(n_hidden, n_classes,bias=False))
        self.dropout = nn.Dropout(p=dropout)
        self.aggre=[]
        # self.prob=GraphConv(n_hidden, n_classes)

    def forward(self, features):
        self.aggre=[]
        h = features
        for i, layer in enumerate(self.layers):
            if i != 0:
                h = self.dropout(h)
            h, aggre = layer(self.g, h)
            self.aggre.append(aggre)

        return h
