X-Git-Url: https://fleuret.org/cgi-bin/gitweb/gitweb.cgi?a=blobdiff_plain;f=mygpt.py;h=0b63ac800ccccc96f014c0b5c149476814698820;hb=280f38363e34e202d38e6f7c00288329ab067a81;hp=df6eab6076c713d4004fb9a412b4e92d31108c39;hpb=c4eb660976808b873f32fe873819c4988aaf2ea5;p=beaver.git diff --git a/mygpt.py b/mygpt.py index df6eab6..0b63ac8 100755 --- a/mygpt.py +++ b/mygpt.py @@ -197,7 +197,6 @@ class MyGPT(nn.Module): dropout=0.0, len_max=1e5, ): - super().__init__() assert dim_model % nb_heads == 0 @@ -247,18 +246,28 @@ class MyGPT(nn.Module): m.bias.zero_() m.weight.fill_(1.0) - def forward(self, bs): + def forward(self, bs, mode="standard"): bs.x = F.pad(bs.x, (1, -1)) bs = self.embedding(bs) - bs = self.trunk(bs) - bs = self.readout(bs) + if mode == "standard": + bs = self.trunk(bs) + bs = self.readout(bs) + elif mode == "head": + bs = self.trunk(bs) + elif mode == "deep": + r = [] + for l in self.trunk: + bs = l(bs) + r += [bs.slice()] + bs = BracketedSequence(torch.cat(r, -1)) + else: + raise ValueError return bs ###################################################################### if __name__ == "__main__": - print("Basic check.") vocabulary_size = 10