+ # -------------------
+ input = task.test_input[:32, : task.height * task.width]
+ targets = task.test_policies[:32]
+ output_gpt = gpt(mygpt.BracketedSequence(input), mode=args.oneshot_mode).x
+ output = model(output_gpt)
+ # losses = (-output.log_softmax(-1) * targets + targets.xlogy(targets)).sum(-1)
+ # losses = losses * (input == maze.v_empty)
+ # losses = losses / losses.max()
+ # losses = (output.softmax(-1) - targets).abs().max(-1).values
+ # losses = (losses >= 0.05).float()
+ losses = (
+ (F.one_hot(output.argmax(-1), num_classes=4) * targets).sum(-1) == 0
+ ).float()
+ losses = losses.reshape(-1, args.maze_height, args.maze_width)
+ input = input.reshape(-1, args.maze_height, args.maze_width)
+ maze.save_image(
+ os.path.join(
+ args.result_dir, f"oneshot_{args.oneshot_mode}_{n_epoch:04d}.png"
+ ),
+ mazes=input,
+ score_paths=losses,
+ )
+ # -------------------
+