+ # -------------------
+ input, targets = next(task.policy_batches(split="test"))
+ output_gpt = gpt(mygpt.BracketedSequence(input), with_readout=False).x
+ output = model(output_gpt)
+ losses = (-output.log_softmax(-1) * targets + targets.xlogy(targets)).sum(-1)
+ losses = losses / losses.max()
+ print(f"{input.size()=} {losses.size()=} {losses.min()=} {losses.max()=}")
+ losses = losses * (input == 0)
+ 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_{n_epoch:04d}.png"),
+ mazes=input,
+ score_paths=losses,
+ )
+ # -------------------
+