{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0cca943d-e629-41b2-a410-cb763c6bfc0c",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "====== Running Experiment: NM0_H256 ======\n",
      "Hyperparameters: {'n_in': 3, 'n_out': 1, 'n_rnn': 256, 'N_NM': 0, 'decay': 0.95, 'activation': 'tanh', 'keepW0': True, 'use_bias': False, 'learning_rate': 0.0001, 'seed': 123, 'clip': 1.0, 'grad_value_clip': 0.1, 'l1_h': 0, 'l2_h': 0, 'l1_weight': 0, 'l2_weight': 0, 'l2_nmVelo': 0, 'use_spatial_weights': False, 'spatial_ell': 0.2, 'spatial_scale': 1.0, 'use_modulated_readout': False, 'use_nm_decoder_loss': False, 'nm_decoder_loss_weight': 0, 'nm_init_scale': 0, 'experiment_name': 'NM0_H256'}\n",
      "Saving results to: Hopf_experiments_new/NM0_H256_20250514-071137\n",
      "Using device: cpu\n",
      "\n",
      "Main Model (Model_nm_CombinedFeatures, H=256, NM=0) params: 66560\n",
      "\n",
      "Skipping Surrogate Model creation as N_NM is 0.\n",
      "\n",
      "\n",
      "--- Train Phase 1: Stationary (5000 steps) ---\n",
      "Settings: SpatialW=False, ModReadout=False, NMDecodeLoss=False\n",
      "Loss calculated from T_settle=50. Total SEQ_LEN=150\n",
      "P1 S [1/5000], Loss:0.0267, RegLoss:0.0000, T:0.1s\n",
      "P1 S [10/5000], Loss:0.0168, RegLoss:0.0000, T:1.9s\n",
      "P1 S [20/5000], Loss:0.0166, RegLoss:0.0000, T:1.5s\n",
      "P1 S [30/5000], Loss:0.0238, RegLoss:0.0000, T:1.5s\n",
      "P1 S [40/5000], Loss:0.0258, RegLoss:0.0000, T:1.5s\n",
      "P1 S [50/5000], Loss:0.0167, RegLoss:0.0000, T:1.6s\n",
      "P1 S [60/5000], Loss:0.0241, RegLoss:0.0000, T:1.6s\n",
      "P1 S [70/5000], Loss:0.0153, RegLoss:0.0000, T:1.5s\n",
      "P1 S [80/5000], Loss:0.0240, RegLoss:0.0000, T:1.6s\n",
      "P1 S [90/5000], Loss:0.0206, RegLoss:0.0000, T:1.5s\n",
      "P1 S [100/5000], Loss:0.0289, RegLoss:0.0000, T:1.6s\n",
      "P1 S [110/5000], Loss:0.0190, RegLoss:0.0000, T:1.5s\n",
      "P1 S [120/5000], Loss:0.0214, RegLoss:0.0000, T:1.6s\n",
      "P1 S [130/5000], Loss:0.0178, RegLoss:0.0000, T:1.5s\n",
      "P1 S [140/5000], Loss:0.0189, RegLoss:0.0000, T:1.6s\n",
      "P1 S [150/5000], Loss:0.0150, RegLoss:0.0000, T:1.5s\n",
      "P1 S [160/5000], Loss:0.0207, RegLoss:0.0000, T:1.6s\n",
      "P1 S [170/5000], Loss:0.0245, RegLoss:0.0000, T:1.5s\n",
      "P1 S [180/5000], Loss:0.0229, RegLoss:0.0000, T:1.5s\n",
      "P1 S [190/5000], Loss:0.0268, RegLoss:0.0000, T:1.6s\n",
      "P1 S [200/5000], Loss:0.0212, RegLoss:0.0000, T:1.6s\n",
      "P1 S [210/5000], Loss:0.0261, RegLoss:0.0000, T:1.6s\n",
      "P1 S [220/5000], Loss:0.0131, RegLoss:0.0000, T:1.6s\n",
      "P1 S [230/5000], Loss:0.0142, RegLoss:0.0000, T:1.5s\n",
      "P1 S [240/5000], Loss:0.0184, RegLoss:0.0000, T:1.5s\n",
      "P1 S [250/5000], Loss:0.0220, RegLoss:0.0000, T:1.6s\n",
      "P1 S [260/5000], Loss:0.0230, RegLoss:0.0000, T:1.5s\n",
      "P1 S [270/5000], Loss:0.0164, RegLoss:0.0000, T:1.6s\n",
      "P1 S [280/5000], Loss:0.0159, RegLoss:0.0000, T:1.5s\n",
      "P1 S [290/5000], Loss:0.0195, RegLoss:0.0000, T:1.6s\n",
      "P1 S [300/5000], Loss:0.0217, RegLoss:0.0000, T:1.6s\n",
      "P1 S [310/5000], Loss:0.0176, RegLoss:0.0000, T:1.6s\n",
      "P1 S [320/5000], Loss:0.0298, RegLoss:0.0000, T:1.5s\n",
      "P1 S [330/5000], Loss:0.0269, RegLoss:0.0000, T:1.6s\n",
      "P1 S [340/5000], Loss:0.0176, RegLoss:0.0000, T:1.5s\n",
      "P1 S [350/5000], Loss:0.0188, RegLoss:0.0000, T:1.7s\n",
      "P1 S [360/5000], Loss:0.0190, RegLoss:0.0000, T:1.5s\n",
      "P1 S [370/5000], Loss:0.0149, RegLoss:0.0000, T:1.6s\n",
      "P1 S [380/5000], Loss:0.0177, RegLoss:0.0000, T:1.5s\n",
      "P1 S [390/5000], Loss:0.0173, RegLoss:0.0000, T:1.6s\n",
      "P1 S [400/5000], Loss:0.0240, RegLoss:0.0000, T:1.5s\n",
      "P1 S [410/5000], Loss:0.0188, RegLoss:0.0000, T:1.6s\n",
      "P1 S [420/5000], Loss:0.0197, RegLoss:0.0000, T:1.6s\n",
      "P1 S [430/5000], Loss:0.0189, RegLoss:0.0000, T:1.5s\n",
      "P1 S [440/5000], Loss:0.0164, RegLoss:0.0000, T:1.6s\n",
      "P1 S [450/5000], Loss:0.0301, RegLoss:0.0000, T:1.5s\n",
      "P1 S [460/5000], Loss:0.0169, RegLoss:0.0000, T:1.6s\n",
      "P1 S [470/5000], Loss:0.0250, RegLoss:0.0000, T:1.5s\n",
      "P1 S [480/5000], Loss:0.0232, RegLoss:0.0000, T:1.6s\n",
      "P1 S [490/5000], Loss:0.0227, RegLoss:0.0000, T:1.6s\n",
      "P1 S [500/5000], Loss:0.0193, RegLoss:0.0000, T:1.5s\n",
      "P1 S [510/5000], Loss:0.0133, RegLoss:0.0000, T:2.0s\n",
      "P1 S [520/5000], Loss:0.0156, RegLoss:0.0000, T:1.5s\n",
      "P1 S [530/5000], Loss:0.0195, RegLoss:0.0000, T:1.6s\n",
      "P1 S [540/5000], Loss:0.0232, RegLoss:0.0000, T:1.5s\n",
      "P1 S [550/5000], Loss:0.0175, RegLoss:0.0000, T:1.6s\n",
      "P1 S [560/5000], Loss:0.0236, RegLoss:0.0000, T:1.6s\n",
      "P1 S [570/5000], Loss:0.0246, RegLoss:0.0000, T:1.5s\n",
      "P1 S [580/5000], Loss:0.0174, RegLoss:0.0000, T:1.6s\n",
      "P1 S [590/5000], Loss:0.0156, RegLoss:0.0000, T:1.5s\n",
      "P1 S [600/5000], Loss:0.0297, RegLoss:0.0000, T:1.6s\n",
      "P1 S [610/5000], Loss:0.0216, RegLoss:0.0000, T:1.7s\n",
      "P1 S [620/5000], Loss:0.0166, RegLoss:0.0000, T:1.6s\n",
      "P1 S [630/5000], Loss:0.0200, RegLoss:0.0000, T:1.5s\n",
      "P1 S [640/5000], Loss:0.0185, RegLoss:0.0000, T:1.6s\n",
      "P1 S [650/5000], Loss:0.0231, RegLoss:0.0000, T:1.5s\n",
      "P1 S [660/5000], Loss:0.0214, RegLoss:0.0000, T:1.5s\n",
      "P1 S [670/5000], Loss:0.0117, RegLoss:0.0000, T:1.6s\n",
      "P1 S [680/5000], Loss:0.0186, RegLoss:0.0000, T:1.6s\n",
      "P1 S [690/5000], Loss:0.0201, RegLoss:0.0000, T:1.5s\n",
      "P1 S [700/5000], Loss:0.0209, RegLoss:0.0000, T:1.5s\n",
      "P1 S [710/5000], Loss:0.0207, RegLoss:0.0000, T:1.6s\n",
      "P1 S [720/5000], Loss:0.0204, RegLoss:0.0000, T:1.6s\n",
      "P1 S [730/5000], Loss:0.0208, RegLoss:0.0000, T:1.5s\n",
      "P1 S [740/5000], Loss:0.0174, RegLoss:0.0000, T:1.6s\n",
      "P1 S [750/5000], Loss:0.0226, RegLoss:0.0000, T:1.6s\n",
      "P1 S [760/5000], Loss:0.0214, RegLoss:0.0000, T:1.6s\n",
      "P1 S [770/5000], Loss:0.0219, RegLoss:0.0000, T:1.6s\n",
      "P1 S [780/5000], Loss:0.0147, RegLoss:0.0000, T:1.6s\n",
      "P1 S [790/5000], Loss:0.0211, RegLoss:0.0000, T:1.6s\n",
      "P1 S [800/5000], Loss:0.0218, RegLoss:0.0000, T:1.6s\n",
      "P1 S [810/5000], Loss:0.0155, RegLoss:0.0000, T:1.5s\n",
      "P1 S [820/5000], Loss:0.0242, RegLoss:0.0000, T:1.6s\n",
      "P1 S [830/5000], Loss:0.0158, RegLoss:0.0000, T:1.6s\n",
      "P1 S [840/5000], Loss:0.0239, RegLoss:0.0000, T:1.5s\n",
      "P1 S [850/5000], Loss:0.0224, RegLoss:0.0000, T:1.6s\n",
      "P1 S [860/5000], Loss:0.0153, RegLoss:0.0000, T:1.6s\n",
      "P1 S [870/5000], Loss:0.0203, RegLoss:0.0000, T:1.6s\n",
      "P1 S [880/5000], Loss:0.0145, RegLoss:0.0000, T:1.6s\n",
      "P1 S [890/5000], Loss:0.0149, RegLoss:0.0000, T:1.5s\n",
      "P1 S [900/5000], Loss:0.0222, RegLoss:0.0000, T:1.6s\n",
      "P1 S [910/5000], Loss:0.0216, RegLoss:0.0000, T:1.6s\n",
      "P1 S [920/5000], Loss:0.0220, RegLoss:0.0000, T:1.5s\n",
      "P1 S [930/5000], Loss:0.0155, RegLoss:0.0000, T:1.6s\n",
      "P1 S [940/5000], Loss:0.0189, RegLoss:0.0000, T:1.6s\n",
      "P1 S [950/5000], Loss:0.0165, RegLoss:0.0000, T:1.5s\n",
      "P1 S [960/5000], Loss:0.0252, RegLoss:0.0000, T:1.6s\n",
      "P1 S [970/5000], Loss:0.0171, RegLoss:0.0000, T:1.6s\n",
      "P1 S [980/5000], Loss:0.0222, RegLoss:0.0000, T:1.6s\n",
      "P1 S [990/5000], Loss:0.0178, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1000/5000], Loss:0.0222, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1010/5000], Loss:0.0158, RegLoss:0.0000, T:2.0s\n",
      "P1 S [1020/5000], Loss:0.0213, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1030/5000], Loss:0.0126, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1040/5000], Loss:0.0173, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1050/5000], Loss:0.0207, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1060/5000], Loss:0.0182, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1070/5000], Loss:0.0165, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1080/5000], Loss:0.0138, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1090/5000], Loss:0.0193, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1100/5000], Loss:0.0228, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1110/5000], Loss:0.0161, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1120/5000], Loss:0.0210, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1130/5000], Loss:0.0146, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1140/5000], Loss:0.0190, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1150/5000], Loss:0.0177, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1160/5000], Loss:0.0126, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1170/5000], Loss:0.0156, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1180/5000], Loss:0.0246, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1190/5000], Loss:0.0201, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1200/5000], Loss:0.0173, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1210/5000], Loss:0.0245, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1220/5000], Loss:0.0279, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1230/5000], Loss:0.0180, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1240/5000], Loss:0.0164, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1250/5000], Loss:0.0199, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1260/5000], Loss:0.0267, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1270/5000], Loss:0.0097, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1280/5000], Loss:0.0227, RegLoss:0.0000, T:1.7s\n",
      "P1 S [1290/5000], Loss:0.0201, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1300/5000], Loss:0.0215, RegLoss:0.0000, T:1.7s\n",
      "P1 S [1310/5000], Loss:0.0160, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1320/5000], Loss:0.0141, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1330/5000], Loss:0.0196, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1340/5000], Loss:0.0173, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1350/5000], Loss:0.0214, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1360/5000], Loss:0.0174, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1370/5000], Loss:0.0104, RegLoss:0.0000, T:1.8s\n",
      "P1 S [1380/5000], Loss:0.0195, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1390/5000], Loss:0.0088, RegLoss:0.0000, T:1.7s\n",
      "P1 S [1400/5000], Loss:0.0161, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1410/5000], Loss:0.0200, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1420/5000], Loss:0.0162, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1430/5000], Loss:0.0169, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1440/5000], Loss:0.0210, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1450/5000], Loss:0.0191, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1460/5000], Loss:0.0169, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1470/5000], Loss:0.0170, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1480/5000], Loss:0.0182, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1490/5000], Loss:0.0167, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1500/5000], Loss:0.0142, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1510/5000], Loss:0.0175, RegLoss:0.0000, T:2.1s\n",
      "P1 S [1520/5000], Loss:0.0187, RegLoss:0.0000, T:1.8s\n",
      "P1 S [1530/5000], Loss:0.0164, RegLoss:0.0000, T:2.0s\n",
      "P1 S [1540/5000], Loss:0.0110, RegLoss:0.0000, T:1.9s\n",
      "P1 S [1550/5000], Loss:0.0162, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1560/5000], Loss:0.0200, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1570/5000], Loss:0.0144, RegLoss:0.0000, T:1.7s\n",
      "P1 S [1580/5000], Loss:0.0203, RegLoss:0.0000, T:1.7s\n",
      "P1 S [1590/5000], Loss:0.0160, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1600/5000], Loss:0.0180, RegLoss:0.0000, T:1.7s\n",
      "P1 S [1610/5000], Loss:0.0205, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1620/5000], Loss:0.0209, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1630/5000], Loss:0.0164, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1640/5000], Loss:0.0242, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1650/5000], Loss:0.0159, RegLoss:0.0000, T:1.7s\n",
      "P1 S [1660/5000], Loss:0.0173, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1670/5000], Loss:0.0122, RegLoss:0.0000, T:1.7s\n",
      "P1 S [1680/5000], Loss:0.0239, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1690/5000], Loss:0.0210, RegLoss:0.0000, T:1.7s\n",
      "P1 S [1700/5000], Loss:0.0171, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1710/5000], Loss:0.0220, RegLoss:0.0000, T:1.8s\n",
      "P1 S [1720/5000], Loss:0.0090, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1730/5000], Loss:0.0137, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1740/5000], Loss:0.0172, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1750/5000], Loss:0.0163, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1760/5000], Loss:0.0192, RegLoss:0.0000, T:1.7s\n",
      "P1 S [1770/5000], Loss:0.0136, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1780/5000], Loss:0.0174, RegLoss:0.0000, T:1.7s\n",
      "P1 S [1790/5000], Loss:0.0197, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1800/5000], Loss:0.0105, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1810/5000], Loss:0.0208, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1820/5000], Loss:0.0169, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1830/5000], Loss:0.0133, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1840/5000], Loss:0.0126, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1850/5000], Loss:0.0186, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1860/5000], Loss:0.0239, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1870/5000], Loss:0.0186, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1880/5000], Loss:0.0226, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1890/5000], Loss:0.0223, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1900/5000], Loss:0.0196, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1910/5000], Loss:0.0193, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1920/5000], Loss:0.0166, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1930/5000], Loss:0.0211, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1940/5000], Loss:0.0176, RegLoss:0.0000, T:1.7s\n",
      "P1 S [1950/5000], Loss:0.0175, RegLoss:0.0000, T:1.5s\n",
      "P1 S [1960/5000], Loss:0.0186, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1970/5000], Loss:0.0207, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1980/5000], Loss:0.0195, RegLoss:0.0000, T:1.7s\n",
      "P1 S [1990/5000], Loss:0.0200, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2000/5000], Loss:0.0253, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2010/5000], Loss:0.0152, RegLoss:0.0000, T:2.1s\n",
      "P1 S [2020/5000], Loss:0.0161, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2030/5000], Loss:0.0165, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2040/5000], Loss:0.0223, RegLoss:0.0000, T:1.8s\n",
      "P1 S [2050/5000], Loss:0.0182, RegLoss:0.0000, T:1.5s\n",
      "P1 S [2060/5000], Loss:0.0174, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2070/5000], Loss:0.0206, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2080/5000], Loss:0.0140, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2090/5000], Loss:0.0235, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2100/5000], Loss:0.0150, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2110/5000], Loss:0.0223, RegLoss:0.0000, T:1.5s\n",
      "P1 S [2120/5000], Loss:0.0194, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2130/5000], Loss:0.0186, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2140/5000], Loss:0.0225, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2150/5000], Loss:0.0182, RegLoss:0.0000, T:1.5s\n",
      "P1 S [2160/5000], Loss:0.0230, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2170/5000], Loss:0.0267, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2180/5000], Loss:0.0143, RegLoss:0.0000, T:1.7s\n",
      "P1 S [2190/5000], Loss:0.0203, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2200/5000], Loss:0.0155, RegLoss:0.0000, T:1.5s\n",
      "P1 S [2210/5000], Loss:0.0150, RegLoss:0.0000, T:1.7s\n",
      "P1 S [2220/5000], Loss:0.0206, RegLoss:0.0000, T:1.5s\n",
      "P1 S [2230/5000], Loss:0.0170, RegLoss:0.0000, T:1.7s\n",
      "P1 S [2240/5000], Loss:0.0193, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2250/5000], Loss:0.0164, RegLoss:0.0000, T:1.5s\n",
      "P1 S [2260/5000], Loss:0.0157, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2270/5000], Loss:0.0153, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2280/5000], Loss:0.0180, RegLoss:0.0000, T:1.5s\n",
      "P1 S [2290/5000], Loss:0.0207, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2300/5000], Loss:0.0169, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2310/5000], Loss:0.0197, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2320/5000], Loss:0.0182, RegLoss:0.0000, T:1.5s\n",
      "P1 S [2330/5000], Loss:0.0189, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2340/5000], Loss:0.0213, RegLoss:0.0000, T:1.5s\n",
      "P1 S [2350/5000], Loss:0.0163, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2360/5000], Loss:0.0169, RegLoss:0.0000, T:1.5s\n",
      "P1 S [2370/5000], Loss:0.0254, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2380/5000], Loss:0.0186, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2390/5000], Loss:0.0202, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2400/5000], Loss:0.0172, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2410/5000], Loss:0.0181, RegLoss:0.0000, T:1.5s\n",
      "P1 S [2420/5000], Loss:0.0151, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2430/5000], Loss:0.0152, RegLoss:0.0000, T:1.5s\n",
      "P1 S [2440/5000], Loss:0.0208, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2450/5000], Loss:0.0143, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2460/5000], Loss:0.0201, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2470/5000], Loss:0.0232, RegLoss:0.0000, T:1.7s\n",
      "P1 S [2480/5000], Loss:0.0160, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2490/5000], Loss:0.0216, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2500/5000], Loss:0.0134, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2510/5000], Loss:0.0122, RegLoss:0.0000, T:2.0s\n",
      "P1 S [2520/5000], Loss:0.0145, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2530/5000], Loss:0.0162, RegLoss:0.0000, T:1.5s\n",
      "P1 S [2540/5000], Loss:0.0121, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2550/5000], Loss:0.0177, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2560/5000], Loss:0.0097, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2570/5000], Loss:0.0169, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2580/5000], Loss:0.0230, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2590/5000], Loss:0.0194, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2600/5000], Loss:0.0152, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2610/5000], Loss:0.0104, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2620/5000], Loss:0.0167, RegLoss:0.0000, T:1.9s\n",
      "P1 S [2630/5000], Loss:0.0139, RegLoss:0.0000, T:1.7s\n",
      "P1 S [2640/5000], Loss:0.0180, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2650/5000], Loss:0.0177, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2660/5000], Loss:0.0173, RegLoss:0.0000, T:1.5s\n",
      "P1 S [2670/5000], Loss:0.0111, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2680/5000], Loss:0.0170, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2690/5000], Loss:0.0142, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2700/5000], Loss:0.0181, RegLoss:0.0000, T:1.5s\n",
      "P1 S [2710/5000], Loss:0.0136, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2720/5000], Loss:0.0169, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2730/5000], Loss:0.0165, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2740/5000], Loss:0.0151, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2750/5000], Loss:0.0185, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2760/5000], Loss:0.0162, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2770/5000], Loss:0.0129, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2780/5000], Loss:0.0184, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2790/5000], Loss:0.0123, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2800/5000], Loss:0.0228, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2810/5000], Loss:0.0187, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2820/5000], Loss:0.0170, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2830/5000], Loss:0.0114, RegLoss:0.0000, T:1.7s\n",
      "P1 S [2840/5000], Loss:0.0127, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2850/5000], Loss:0.0113, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2860/5000], Loss:0.0147, RegLoss:0.0000, T:1.7s\n",
      "P1 S [2870/5000], Loss:0.0167, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2880/5000], Loss:0.0202, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2890/5000], Loss:0.0130, RegLoss:0.0000, T:1.5s\n",
      "P1 S [2900/5000], Loss:0.0140, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2910/5000], Loss:0.0151, RegLoss:0.0000, T:1.5s\n",
      "P1 S [2920/5000], Loss:0.0175, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2930/5000], Loss:0.0121, RegLoss:0.0000, T:1.5s\n",
      "P1 S [2940/5000], Loss:0.0116, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2950/5000], Loss:0.0154, RegLoss:0.0000, T:1.5s\n",
      "P1 S [2960/5000], Loss:0.0139, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2970/5000], Loss:0.0126, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2980/5000], Loss:0.0107, RegLoss:0.0000, T:1.5s\n",
      "P1 S [2990/5000], Loss:0.0135, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3000/5000], Loss:0.0192, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3010/5000], Loss:0.0152, RegLoss:0.0000, T:2.0s\n",
      "P1 S [3020/5000], Loss:0.0161, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3030/5000], Loss:0.0127, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3040/5000], Loss:0.0158, RegLoss:0.0000, T:1.7s\n",
      "P1 S [3050/5000], Loss:0.0167, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3060/5000], Loss:0.0117, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3070/5000], Loss:0.0186, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3080/5000], Loss:0.0118, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3090/5000], Loss:0.0107, RegLoss:0.0000, T:1.7s\n",
      "P1 S [3100/5000], Loss:0.0155, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3110/5000], Loss:0.0091, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3120/5000], Loss:0.0183, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3130/5000], Loss:0.0101, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3140/5000], Loss:0.0129, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3150/5000], Loss:0.0151, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3160/5000], Loss:0.0166, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3170/5000], Loss:0.0086, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3180/5000], Loss:0.0091, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3190/5000], Loss:0.0151, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3200/5000], Loss:0.0120, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3210/5000], Loss:0.0132, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3220/5000], Loss:0.0117, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3230/5000], Loss:0.0125, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3240/5000], Loss:0.0115, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3250/5000], Loss:0.0119, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3260/5000], Loss:0.0148, RegLoss:0.0000, T:1.7s\n",
      "P1 S [3270/5000], Loss:0.0141, RegLoss:0.0000, T:1.7s\n",
      "P1 S [3280/5000], Loss:0.0129, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3290/5000], Loss:0.0125, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3300/5000], Loss:0.0101, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3310/5000], Loss:0.0167, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3320/5000], Loss:0.0121, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3330/5000], Loss:0.0118, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3340/5000], Loss:0.0114, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3350/5000], Loss:0.0131, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3360/5000], Loss:0.0141, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3370/5000], Loss:0.0112, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3380/5000], Loss:0.0136, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3390/5000], Loss:0.0107, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3400/5000], Loss:0.0120, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3410/5000], Loss:0.0118, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3420/5000], Loss:0.0111, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3430/5000], Loss:0.0106, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3440/5000], Loss:0.0088, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3450/5000], Loss:0.0140, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3460/5000], Loss:0.0118, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3470/5000], Loss:0.0144, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3480/5000], Loss:0.0136, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3490/5000], Loss:0.0129, RegLoss:0.0000, T:1.7s\n",
      "P1 S [3500/5000], Loss:0.0106, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3510/5000], Loss:0.0153, RegLoss:0.0000, T:2.1s\n",
      "P1 S [3520/5000], Loss:0.0105, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3530/5000], Loss:0.0121, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3540/5000], Loss:0.0123, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3550/5000], Loss:0.0112, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3560/5000], Loss:0.0109, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3570/5000], Loss:0.0136, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3580/5000], Loss:0.0093, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3590/5000], Loss:0.0125, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3600/5000], Loss:0.0095, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3610/5000], Loss:0.0108, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3620/5000], Loss:0.0132, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3630/5000], Loss:0.0139, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3640/5000], Loss:0.0130, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3650/5000], Loss:0.0117, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3660/5000], Loss:0.0105, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3670/5000], Loss:0.0090, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3680/5000], Loss:0.0084, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3690/5000], Loss:0.0084, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3700/5000], Loss:0.0068, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3710/5000], Loss:0.0100, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3720/5000], Loss:0.0130, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3730/5000], Loss:0.0078, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3740/5000], Loss:0.0104, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3750/5000], Loss:0.0112, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3760/5000], Loss:0.0078, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3770/5000], Loss:0.0092, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3780/5000], Loss:0.0068, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3790/5000], Loss:0.0109, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3800/5000], Loss:0.0110, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3810/5000], Loss:0.0094, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3820/5000], Loss:0.0120, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3830/5000], Loss:0.0095, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3840/5000], Loss:0.0070, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3850/5000], Loss:0.0104, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3860/5000], Loss:0.0093, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3870/5000], Loss:0.0102, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3880/5000], Loss:0.0095, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3890/5000], Loss:0.0043, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3900/5000], Loss:0.0066, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3910/5000], Loss:0.0075, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3920/5000], Loss:0.0074, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3930/5000], Loss:0.0095, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3940/5000], Loss:0.0079, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3950/5000], Loss:0.0074, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3960/5000], Loss:0.0071, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3970/5000], Loss:0.0084, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3980/5000], Loss:0.0064, RegLoss:0.0000, T:1.5s\n",
      "P1 S [3990/5000], Loss:0.0085, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4000/5000], Loss:0.0068, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4010/5000], Loss:0.0076, RegLoss:0.0000, T:2.0s\n",
      "P1 S [4020/5000], Loss:0.0103, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4030/5000], Loss:0.0088, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4040/5000], Loss:0.0049, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4050/5000], Loss:0.0080, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4060/5000], Loss:0.0069, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4070/5000], Loss:0.0080, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4080/5000], Loss:0.0070, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4090/5000], Loss:0.0070, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4100/5000], Loss:0.0081, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4110/5000], Loss:0.0070, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4120/5000], Loss:0.0078, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4130/5000], Loss:0.0100, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4140/5000], Loss:0.0078, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4150/5000], Loss:0.0058, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4160/5000], Loss:0.0064, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4170/5000], Loss:0.0049, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4180/5000], Loss:0.0087, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4190/5000], Loss:0.0075, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4200/5000], Loss:0.0070, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4210/5000], Loss:0.0041, RegLoss:0.0000, T:1.7s\n",
      "P1 S [4220/5000], Loss:0.0053, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4230/5000], Loss:0.0065, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4240/5000], Loss:0.0049, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4250/5000], Loss:0.0075, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4260/5000], Loss:0.0062, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4270/5000], Loss:0.0055, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4280/5000], Loss:0.0063, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4290/5000], Loss:0.0068, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4300/5000], Loss:0.0082, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4310/5000], Loss:0.0045, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4320/5000], Loss:0.0066, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4330/5000], Loss:0.0070, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4340/5000], Loss:0.0077, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4350/5000], Loss:0.0043, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4360/5000], Loss:0.0040, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4370/5000], Loss:0.0047, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4380/5000], Loss:0.0083, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4390/5000], Loss:0.0056, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4400/5000], Loss:0.0060, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4410/5000], Loss:0.0046, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4420/5000], Loss:0.0074, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4430/5000], Loss:0.0051, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4440/5000], Loss:0.0043, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4450/5000], Loss:0.0045, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4460/5000], Loss:0.0060, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4470/5000], Loss:0.0034, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4480/5000], Loss:0.0082, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4490/5000], Loss:0.0051, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4500/5000], Loss:0.0048, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4510/5000], Loss:0.0071, RegLoss:0.0000, T:2.0s\n",
      "P1 S [4520/5000], Loss:0.0061, RegLoss:0.0000, T:1.7s\n",
      "P1 S [4530/5000], Loss:0.0067, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4540/5000], Loss:0.0044, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4550/5000], Loss:0.0054, RegLoss:0.0000, T:1.7s\n",
      "P1 S [4560/5000], Loss:0.0054, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4570/5000], Loss:0.0043, RegLoss:0.0000, T:1.7s\n",
      "P1 S [4580/5000], Loss:0.0049, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4590/5000], Loss:0.0034, RegLoss:0.0000, T:1.7s\n",
      "P1 S [4600/5000], Loss:0.0059, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4610/5000], Loss:0.0059, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4620/5000], Loss:0.0057, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4630/5000], Loss:0.0047, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4640/5000], Loss:0.0043, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4650/5000], Loss:0.0039, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4660/5000], Loss:0.0039, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4670/5000], Loss:0.0036, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4680/5000], Loss:0.0035, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4690/5000], Loss:0.0044, RegLoss:0.0000, T:1.7s\n",
      "P1 S [4700/5000], Loss:0.0066, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4710/5000], Loss:0.0049, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4720/5000], Loss:0.0040, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4730/5000], Loss:0.0044, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4740/5000], Loss:0.0043, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4750/5000], Loss:0.0035, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4760/5000], Loss:0.0038, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4770/5000], Loss:0.0033, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4780/5000], Loss:0.0048, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4790/5000], Loss:0.0033, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4800/5000], Loss:0.0040, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4810/5000], Loss:0.0037, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4820/5000], Loss:0.0034, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4830/5000], Loss:0.0041, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4840/5000], Loss:0.0036, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4850/5000], Loss:0.0044, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4860/5000], Loss:0.0025, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4870/5000], Loss:0.0024, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4880/5000], Loss:0.0042, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4890/5000], Loss:0.0022, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4900/5000], Loss:0.0027, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4910/5000], Loss:0.0027, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4920/5000], Loss:0.0039, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4930/5000], Loss:0.0032, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4940/5000], Loss:0.0029, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4950/5000], Loss:0.0026, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4960/5000], Loss:0.0030, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4970/5000], Loss:0.0038, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4980/5000], Loss:0.0035, RegLoss:0.0000, T:1.5s\n",
      "P1 S [4990/5000], Loss:0.0026, RegLoss:0.0000, T:1.6s\n",
      "P1 S [5000/5000], Loss:0.0032, RegLoss:0.0000, T:1.5s\n",
      "Phase 1 training complete.\n",
      "\n",
      "Phase 2 LR: 5e-05\n",
      "\n",
      "--- Train Phase 2: Curriculum (1000 steps) ---\n",
      "Settings: SpatialW=False, ModReadout=False, NMDecodeLoss=False\n",
      "Loss calculated from T_settle=50. Total SEQ_LEN=150\n",
      "P2 S [1/1000], Loss:0.0025, RegLoss:0.0000, T:0.1s\n",
      "P2 S [10/1000], Loss:0.0030, RegLoss:0.0000, T:1.9s\n",
      "P2 S [20/1000], Loss:0.0030, RegLoss:0.0000, T:1.6s\n",
      "P2 S [30/1000], Loss:0.0032, RegLoss:0.0000, T:1.6s\n",
      "P2 S [40/1000], Loss:0.0034, RegLoss:0.0000, T:1.5s\n",
      "P2 S [50/1000], Loss:0.0030, RegLoss:0.0000, T:1.6s\n",
      "P2 S [60/1000], Loss:0.0041, RegLoss:0.0000, T:1.5s\n",
      "P2 S [70/1000], Loss:0.0030, RegLoss:0.0000, T:1.6s\n",
      "P2 S [80/1000], Loss:0.0023, RegLoss:0.0000, T:1.6s\n",
      "P2 S [90/1000], Loss:0.0050, RegLoss:0.0000, T:1.5s\n",
      "P2 S [100/1000], Loss:0.0039, RegLoss:0.0000, T:2.0s\n",
      "P2 S [110/1000], Loss:0.0039, RegLoss:0.0000, T:1.5s\n",
      "P2 S [120/1000], Loss:0.0039, RegLoss:0.0000, T:1.6s\n",
      "P2 S [130/1000], Loss:0.0048, RegLoss:0.0000, T:1.6s\n",
      "P2 S [140/1000], Loss:0.0045, RegLoss:0.0000, T:1.5s\n",
      "P2 S [150/1000], Loss:0.0035, RegLoss:0.0000, T:1.6s\n",
      "P2 S [160/1000], Loss:0.0037, RegLoss:0.0000, T:1.7s\n",
      "P2 S [170/1000], Loss:0.0020, RegLoss:0.0000, T:1.7s\n",
      "P2 S [180/1000], Loss:0.0054, RegLoss:0.0000, T:1.6s\n",
      "P2 S [190/1000], Loss:0.0042, RegLoss:0.0000, T:1.6s\n",
      "P2 S [200/1000], Loss:0.0033, RegLoss:0.0000, T:1.5s\n",
      "P2 S [210/1000], Loss:0.0036, RegLoss:0.0000, T:1.6s\n",
      "P2 S [220/1000], Loss:0.0043, RegLoss:0.0000, T:1.6s\n",
      "P2 S [230/1000], Loss:0.0035, RegLoss:0.0000, T:1.6s\n",
      "P2 S [240/1000], Loss:0.0043, RegLoss:0.0000, T:1.5s\n",
      "P2 S [250/1000], Loss:0.0050, RegLoss:0.0000, T:1.6s\n",
      "P2 S [260/1000], Loss:0.0038, RegLoss:0.0000, T:1.5s\n",
      "P2 S [270/1000], Loss:0.0048, RegLoss:0.0000, T:1.6s\n",
      "P2 S [280/1000], Loss:0.0039, RegLoss:0.0000, T:1.6s\n",
      "P2 S [290/1000], Loss:0.0046, RegLoss:0.0000, T:1.6s\n",
      "P2 S [300/1000], Loss:0.0057, RegLoss:0.0000, T:1.5s\n",
      "P2 S [310/1000], Loss:0.0042, RegLoss:0.0000, T:1.6s\n",
      "P2 S [320/1000], Loss:0.0040, RegLoss:0.0000, T:1.6s\n",
      "P2 S [330/1000], Loss:0.0038, RegLoss:0.0000, T:1.6s\n",
      "P2 S [340/1000], Loss:0.0049, RegLoss:0.0000, T:1.5s\n",
      "P2 S [350/1000], Loss:0.0052, RegLoss:0.0000, T:1.6s\n",
      "P2 S [360/1000], Loss:0.0035, RegLoss:0.0000, T:1.6s\n",
      "P2 S [370/1000], Loss:0.0054, RegLoss:0.0000, T:1.5s\n",
      "P2 S [380/1000], Loss:0.0052, RegLoss:0.0000, T:1.6s\n",
      "P2 S [390/1000], Loss:0.0026, RegLoss:0.0000, T:1.6s\n",
      "P2 S [400/1000], Loss:0.0044, RegLoss:0.0000, T:1.6s\n",
      "P2 S [410/1000], Loss:0.0042, RegLoss:0.0000, T:1.6s\n",
      "P2 S [420/1000], Loss:0.0047, RegLoss:0.0000, T:1.6s\n",
      "P2 S [430/1000], Loss:0.0048, RegLoss:0.0000, T:1.6s\n",
      "P2 S [440/1000], Loss:0.0030, RegLoss:0.0000, T:1.6s\n",
      "P2 S [450/1000], Loss:0.0041, RegLoss:0.0000, T:1.6s\n",
      "P2 S [460/1000], Loss:0.0044, RegLoss:0.0000, T:1.6s\n",
      "P2 S [470/1000], Loss:0.0046, RegLoss:0.0000, T:1.6s\n",
      "P2 S [480/1000], Loss:0.0041, RegLoss:0.0000, T:1.6s\n",
      "P2 S [490/1000], Loss:0.0033, RegLoss:0.0000, T:1.6s\n",
      "P2 S [500/1000], Loss:0.0033, RegLoss:0.0000, T:1.5s\n",
      "P2 S [510/1000], Loss:0.0045, RegLoss:0.0000, T:2.0s\n",
      "P2 S [520/1000], Loss:0.0057, RegLoss:0.0000, T:1.6s\n",
      "P2 S [530/1000], Loss:0.0056, RegLoss:0.0000, T:1.6s\n",
      "P2 S [540/1000], Loss:0.0032, RegLoss:0.0000, T:1.5s\n",
      "P2 S [550/1000], Loss:0.0036, RegLoss:0.0000, T:1.6s\n",
      "P2 S [560/1000], Loss:0.0025, RegLoss:0.0000, T:1.6s\n",
      "P2 S [570/1000], Loss:0.0033, RegLoss:0.0000, T:1.5s\n",
      "P2 S [580/1000], Loss:0.0031, RegLoss:0.0000, T:1.6s\n",
      "P2 S [590/1000], Loss:0.0037, RegLoss:0.0000, T:1.5s\n",
      "P2 S [600/1000], Loss:0.0024, RegLoss:0.0000, T:1.6s\n",
      "P2 S [610/1000], Loss:0.0037, RegLoss:0.0000, T:1.6s\n",
      "P2 S [620/1000], Loss:0.0049, RegLoss:0.0000, T:1.5s\n",
      "P2 S [630/1000], Loss:0.0033, RegLoss:0.0000, T:1.6s\n",
      "P2 S [640/1000], Loss:0.0041, RegLoss:0.0000, T:1.6s\n",
      "P2 S [650/1000], Loss:0.0026, RegLoss:0.0000, T:1.6s\n",
      "P2 S [660/1000], Loss:0.0043, RegLoss:0.0000, T:1.6s\n",
      "P2 S [670/1000], Loss:0.0036, RegLoss:0.0000, T:1.6s\n",
      "P2 S [680/1000], Loss:0.0031, RegLoss:0.0000, T:1.6s\n",
      "P2 S [690/1000], Loss:0.0035, RegLoss:0.0000, T:1.6s\n",
      "P2 S [700/1000], Loss:0.0046, RegLoss:0.0000, T:1.7s\n",
      "P2 S [710/1000], Loss:0.0048, RegLoss:0.0000, T:1.6s\n",
      "P2 S [720/1000], Loss:0.0040, RegLoss:0.0000, T:1.6s\n",
      "P2 S [730/1000], Loss:0.0056, RegLoss:0.0000, T:1.6s\n",
      "P2 S [740/1000], Loss:0.0032, RegLoss:0.0000, T:1.6s\n",
      "P2 S [750/1000], Loss:0.0042, RegLoss:0.0000, T:1.6s\n",
      "P2 S [760/1000], Loss:0.0031, RegLoss:0.0000, T:1.6s\n",
      "P2 S [770/1000], Loss:0.0034, RegLoss:0.0000, T:1.5s\n",
      "P2 S [780/1000], Loss:0.0032, RegLoss:0.0000, T:1.6s\n",
      "P2 S [790/1000], Loss:0.0032, RegLoss:0.0000, T:1.5s\n",
      "P2 S [800/1000], Loss:0.0044, RegLoss:0.0000, T:1.6s\n",
      "P2 S [810/1000], Loss:0.0052, RegLoss:0.0000, T:1.6s\n",
      "P2 S [820/1000], Loss:0.0036, RegLoss:0.0000, T:1.5s\n",
      "P2 S [830/1000], Loss:0.0032, RegLoss:0.0000, T:1.6s\n",
      "P2 S [840/1000], Loss:0.0032, RegLoss:0.0000, T:1.5s\n",
      "P2 S [850/1000], Loss:0.0050, RegLoss:0.0000, T:1.6s\n",
      "P2 S [860/1000], Loss:0.0049, RegLoss:0.0000, T:1.6s\n",
      "P2 S [870/1000], Loss:0.0032, RegLoss:0.0000, T:1.6s\n",
      "P2 S [880/1000], Loss:0.0030, RegLoss:0.0000, T:1.5s\n",
      "P2 S [890/1000], Loss:0.0035, RegLoss:0.0000, T:1.6s\n",
      "P2 S [900/1000], Loss:0.0032, RegLoss:0.0000, T:1.6s\n",
      "P2 S [910/1000], Loss:0.0033, RegLoss:0.0000, T:1.5s\n",
      "P2 S [920/1000], Loss:0.0041, RegLoss:0.0000, T:1.6s\n",
      "P2 S [930/1000], Loss:0.0043, RegLoss:0.0000, T:1.5s\n",
      "P2 S [940/1000], Loss:0.0057, RegLoss:0.0000, T:1.6s\n",
      "P2 S [950/1000], Loss:0.0027, RegLoss:0.0000, T:1.6s\n",
      "P2 S [960/1000], Loss:0.0048, RegLoss:0.0000, T:1.5s\n",
      "P2 S [970/1000], Loss:0.0054, RegLoss:0.0000, T:1.6s\n",
      "P2 S [980/1000], Loss:0.0038, RegLoss:0.0000, T:1.5s\n",
      "P2 S [990/1000], Loss:0.0035, RegLoss:0.0000, T:2.0s\n",
      "P2 S [1000/1000], Loss:0.0033, RegLoss:0.0000, T:1.6s\n",
      "Phase 2 training complete.\n",
      "Logs saved to Hopf_experiments_new/NM0_H256_20250514-071137/logs/NM0_H256_logs.pkl\n",
      "Model parameters saved to Hopf_experiments_new/NM0_H256_20250514-071137/models/NM0_H256_model_state_dict.pth\n",
      "\n",
      "--- Generating Final Plots ---\n",
      "Final plots saved to Hopf_experiments_new/NM0_H256_20250514-071137/plots\n",
      "Training movie frames saved to Hopf_experiments_new/NM0_H256_20250514-071137/training_movie_for_NM0_H256\n",
      "====== Experiment NM0_H256 Complete ======\n",
      "\n",
      "\n",
      "====== Running Experiment: NM0_H128 ======\n",
      "Hyperparameters: {'n_in': 3, 'n_out': 1, 'n_rnn': 128, 'N_NM': 0, 'decay': 0.95, 'activation': 'tanh', 'keepW0': True, 'use_bias': False, 'learning_rate': 0.0001, 'seed': 123, 'clip': 1.0, 'grad_value_clip': 0.1, 'l1_h': 0, 'l2_h': 0, 'l1_weight': 0, 'l2_weight': 0, 'l2_nmVelo': 0, 'use_spatial_weights': False, 'spatial_ell': 0.2, 'spatial_scale': 1.0, 'use_modulated_readout': False, 'use_nm_decoder_loss': False, 'nm_decoder_loss_weight': 0, 'nm_init_scale': 0, 'experiment_name': 'NM0_H128'}\n",
      "Saving results to: Hopf_experiments_new/NM0_H128_20250514-072733\n",
      "Using device: cpu\n",
      "\n",
      "Main Model (Model_nm_CombinedFeatures, H=128, NM=0) params: 16896\n",
      "\n",
      "Skipping Surrogate Model creation as N_NM is 0.\n",
      "\n",
      "\n",
      "--- Train Phase 1: Stationary (5000 steps) ---\n",
      "Settings: SpatialW=False, ModReadout=False, NMDecodeLoss=False\n",
      "Loss calculated from T_settle=50. Total SEQ_LEN=150\n",
      "P1 S [1/5000], Loss:0.0486, RegLoss:0.0000, T:0.1s\n",
      "P1 S [10/5000], Loss:0.0173, RegLoss:0.0000, T:1.5s\n",
      "P1 S [20/5000], Loss:0.0149, RegLoss:0.0000, T:1.2s\n",
      "P1 S [30/5000], Loss:0.0183, RegLoss:0.0000, T:1.2s\n",
      "P1 S [40/5000], Loss:0.0167, RegLoss:0.0000, T:1.1s\n",
      "P1 S [50/5000], Loss:0.0220, RegLoss:0.0000, T:1.2s\n",
      "P1 S [60/5000], Loss:0.0212, RegLoss:0.0000, T:1.1s\n",
      "P1 S [70/5000], Loss:0.0148, RegLoss:0.0000, T:1.2s\n",
      "P1 S [80/5000], Loss:0.0232, RegLoss:0.0000, T:1.2s\n",
      "P1 S [90/5000], Loss:0.0247, RegLoss:0.0000, T:1.1s\n",
      "P1 S [100/5000], Loss:0.0197, RegLoss:0.0000, T:1.2s\n",
      "P1 S [110/5000], Loss:0.0151, RegLoss:0.0000, T:1.2s\n",
      "P1 S [120/5000], Loss:0.0212, RegLoss:0.0000, T:1.1s\n",
      "P1 S [130/5000], Loss:0.0257, RegLoss:0.0000, T:1.2s\n",
      "P1 S [140/5000], Loss:0.0187, RegLoss:0.0000, T:1.2s\n",
      "P1 S [150/5000], Loss:0.0151, RegLoss:0.0000, T:1.1s\n",
      "P1 S [160/5000], Loss:0.0129, RegLoss:0.0000, T:1.2s\n",
      "P1 S [170/5000], Loss:0.0233, RegLoss:0.0000, T:1.1s\n",
      "P1 S [180/5000], Loss:0.0231, RegLoss:0.0000, T:1.2s\n",
      "P1 S [190/5000], Loss:0.0262, RegLoss:0.0000, T:1.3s\n",
      "P1 S [200/5000], Loss:0.0198, RegLoss:0.0000, T:1.2s\n",
      "P1 S [210/5000], Loss:0.0213, RegLoss:0.0000, T:1.2s\n",
      "P1 S [220/5000], Loss:0.0138, RegLoss:0.0000, T:1.2s\n",
      "P1 S [230/5000], Loss:0.0179, RegLoss:0.0000, T:1.2s\n",
      "P1 S [240/5000], Loss:0.0205, RegLoss:0.0000, T:1.2s\n",
      "P1 S [250/5000], Loss:0.0233, RegLoss:0.0000, T:1.2s\n",
      "P1 S [260/5000], Loss:0.0200, RegLoss:0.0000, T:1.1s\n",
      "P1 S [270/5000], Loss:0.0144, RegLoss:0.0000, T:1.2s\n",
      "P1 S [280/5000], Loss:0.0241, RegLoss:0.0000, T:1.2s\n",
      "P1 S [290/5000], Loss:0.0268, RegLoss:0.0000, T:1.2s\n",
      "P1 S [300/5000], Loss:0.0154, RegLoss:0.0000, T:1.2s\n",
      "P1 S [310/5000], Loss:0.0141, RegLoss:0.0000, T:1.2s\n",
      "P1 S [320/5000], Loss:0.0223, RegLoss:0.0000, T:1.2s\n",
      "P1 S [330/5000], Loss:0.0233, RegLoss:0.0000, T:1.1s\n",
      "P1 S [340/5000], Loss:0.0235, RegLoss:0.0000, T:1.2s\n",
      "P1 S [350/5000], Loss:0.0181, RegLoss:0.0000, T:1.2s\n",
      "P1 S [360/5000], Loss:0.0177, RegLoss:0.0000, T:1.1s\n",
      "P1 S [370/5000], Loss:0.0147, RegLoss:0.0000, T:1.2s\n",
      "P1 S [380/5000], Loss:0.0210, RegLoss:0.0000, T:1.2s\n",
      "P1 S [390/5000], Loss:0.0177, RegLoss:0.0000, T:1.4s\n",
      "P1 S [400/5000], Loss:0.0192, RegLoss:0.0000, T:1.2s\n",
      "P1 S [410/5000], Loss:0.0219, RegLoss:0.0000, T:1.2s\n",
      "P1 S [420/5000], Loss:0.0215, RegLoss:0.0000, T:1.1s\n",
      "P1 S [430/5000], Loss:0.0232, RegLoss:0.0000, T:1.2s\n",
      "P1 S [440/5000], Loss:0.0259, RegLoss:0.0000, T:1.2s\n",
      "P1 S [450/5000], Loss:0.0200, RegLoss:0.0000, T:1.1s\n",
      "P1 S [460/5000], Loss:0.0165, RegLoss:0.0000, T:1.2s\n",
      "P1 S [470/5000], Loss:0.0235, RegLoss:0.0000, T:1.2s\n",
      "P1 S [480/5000], Loss:0.0197, RegLoss:0.0000, T:1.1s\n",
      "P1 S [490/5000], Loss:0.0242, RegLoss:0.0000, T:1.2s\n",
      "P1 S [500/5000], Loss:0.0220, RegLoss:0.0000, T:1.2s\n",
      "P1 S [510/5000], Loss:0.0163, RegLoss:0.0000, T:1.5s\n",
      "P1 S [520/5000], Loss:0.0250, RegLoss:0.0000, T:1.2s\n",
      "P1 S [530/5000], Loss:0.0231, RegLoss:0.0000, T:1.2s\n",
      "P1 S [540/5000], Loss:0.0169, RegLoss:0.0000, T:1.1s\n",
      "P1 S [550/5000], Loss:0.0192, RegLoss:0.0000, T:1.2s\n",
      "P1 S [560/5000], Loss:0.0203, RegLoss:0.0000, T:1.2s\n",
      "P1 S [570/5000], Loss:0.0162, RegLoss:0.0000, T:1.2s\n",
      "P1 S [580/5000], Loss:0.0188, RegLoss:0.0000, T:1.1s\n",
      "P1 S [590/5000], Loss:0.0202, RegLoss:0.0000, T:1.2s\n",
      "P1 S [600/5000], Loss:0.0148, RegLoss:0.0000, T:1.1s\n",
      "P1 S [610/5000], Loss:0.0252, RegLoss:0.0000, T:1.2s\n",
      "P1 S [620/5000], Loss:0.0191, RegLoss:0.0000, T:1.2s\n",
      "P1 S [630/5000], Loss:0.0210, RegLoss:0.0000, T:1.1s\n",
      "P1 S [640/5000], Loss:0.0220, RegLoss:0.0000, T:1.2s\n",
      "P1 S [650/5000], Loss:0.0220, RegLoss:0.0000, T:1.2s\n",
      "P1 S [660/5000], Loss:0.0260, RegLoss:0.0000, T:1.1s\n",
      "P1 S [670/5000], Loss:0.0242, RegLoss:0.0000, T:1.2s\n",
      "P1 S [680/5000], Loss:0.0178, RegLoss:0.0000, T:1.2s\n",
      "P1 S [690/5000], Loss:0.0268, RegLoss:0.0000, T:1.2s\n",
      "P1 S [700/5000], Loss:0.0194, RegLoss:0.0000, T:1.3s\n",
      "P1 S [710/5000], Loss:0.0134, RegLoss:0.0000, T:1.2s\n",
      "P1 S [720/5000], Loss:0.0219, RegLoss:0.0000, T:1.2s\n",
      "P1 S [730/5000], Loss:0.0223, RegLoss:0.0000, T:1.1s\n",
      "P1 S [740/5000], Loss:0.0224, RegLoss:0.0000, T:1.2s\n",
      "P1 S [750/5000], Loss:0.0175, RegLoss:0.0000, T:1.2s\n",
      "P1 S [760/5000], Loss:0.0192, RegLoss:0.0000, T:1.2s\n",
      "P1 S [770/5000], Loss:0.0246, RegLoss:0.0000, T:1.1s\n",
      "P1 S [780/5000], Loss:0.0180, RegLoss:0.0000, T:1.2s\n",
      "P1 S [790/5000], Loss:0.0256, RegLoss:0.0000, T:1.2s\n",
      "P1 S [800/5000], Loss:0.0154, RegLoss:0.0000, T:1.2s\n",
      "P1 S [810/5000], Loss:0.0135, RegLoss:0.0000, T:1.1s\n",
      "P1 S [820/5000], Loss:0.0185, RegLoss:0.0000, T:1.1s\n",
      "P1 S [830/5000], Loss:0.0217, RegLoss:0.0000, T:1.2s\n",
      "P1 S [840/5000], Loss:0.0228, RegLoss:0.0000, T:1.2s\n",
      "P1 S [850/5000], Loss:0.0194, RegLoss:0.0000, T:1.2s\n",
      "P1 S [860/5000], Loss:0.0231, RegLoss:0.0000, T:1.1s\n",
      "P1 S [870/5000], Loss:0.0234, RegLoss:0.0000, T:1.2s\n",
      "P1 S [880/5000], Loss:0.0244, RegLoss:0.0000, T:1.2s\n",
      "P1 S [890/5000], Loss:0.0250, RegLoss:0.0000, T:1.2s\n",
      "P1 S [900/5000], Loss:0.0175, RegLoss:0.0000, T:1.2s\n",
      "P1 S [910/5000], Loss:0.0196, RegLoss:0.0000, T:1.1s\n",
      "P1 S [920/5000], Loss:0.0178, RegLoss:0.0000, T:1.2s\n",
      "P1 S [930/5000], Loss:0.0183, RegLoss:0.0000, T:1.2s\n",
      "P1 S [940/5000], Loss:0.0238, RegLoss:0.0000, T:1.1s\n",
      "P1 S [950/5000], Loss:0.0204, RegLoss:0.0000, T:1.2s\n",
      "P1 S [960/5000], Loss:0.0163, RegLoss:0.0000, T:1.2s\n",
      "P1 S [970/5000], Loss:0.0165, RegLoss:0.0000, T:1.1s\n",
      "P1 S [980/5000], Loss:0.0210, RegLoss:0.0000, T:1.2s\n",
      "P1 S [990/5000], Loss:0.0158, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1000/5000], Loss:0.0212, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1010/5000], Loss:0.0191, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1020/5000], Loss:0.0276, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1030/5000], Loss:0.0142, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1040/5000], Loss:0.0145, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1050/5000], Loss:0.0143, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1060/5000], Loss:0.0212, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1070/5000], Loss:0.0248, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1080/5000], Loss:0.0253, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1090/5000], Loss:0.0223, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1100/5000], Loss:0.0211, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1110/5000], Loss:0.0287, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1120/5000], Loss:0.0214, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1130/5000], Loss:0.0182, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1140/5000], Loss:0.0290, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1150/5000], Loss:0.0197, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1160/5000], Loss:0.0200, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1170/5000], Loss:0.0273, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1180/5000], Loss:0.0172, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1190/5000], Loss:0.0194, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1200/5000], Loss:0.0210, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1210/5000], Loss:0.0139, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1220/5000], Loss:0.0242, RegLoss:0.0000, T:1.3s\n",
      "P1 S [1230/5000], Loss:0.0205, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1240/5000], Loss:0.0206, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1250/5000], Loss:0.0209, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1260/5000], Loss:0.0218, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1270/5000], Loss:0.0244, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1280/5000], Loss:0.0190, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1290/5000], Loss:0.0109, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1300/5000], Loss:0.0174, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1310/5000], Loss:0.0141, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1320/5000], Loss:0.0176, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1330/5000], Loss:0.0209, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1340/5000], Loss:0.0179, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1350/5000], Loss:0.0252, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1360/5000], Loss:0.0175, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1370/5000], Loss:0.0140, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1380/5000], Loss:0.0168, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1390/5000], Loss:0.0204, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1400/5000], Loss:0.0131, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1410/5000], Loss:0.0248, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1420/5000], Loss:0.0223, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1430/5000], Loss:0.0185, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1440/5000], Loss:0.0185, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1450/5000], Loss:0.0203, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1460/5000], Loss:0.0211, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1470/5000], Loss:0.0262, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1480/5000], Loss:0.0210, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1490/5000], Loss:0.0218, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1500/5000], Loss:0.0232, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1510/5000], Loss:0.0218, RegLoss:0.0000, T:1.6s\n",
      "P1 S [1520/5000], Loss:0.0159, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1530/5000], Loss:0.0265, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1540/5000], Loss:0.0173, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1550/5000], Loss:0.0308, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1560/5000], Loss:0.0206, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1570/5000], Loss:0.0144, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1580/5000], Loss:0.0269, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1590/5000], Loss:0.0164, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1600/5000], Loss:0.0115, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1610/5000], Loss:0.0239, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1620/5000], Loss:0.0185, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1630/5000], Loss:0.0201, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1640/5000], Loss:0.0159, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1650/5000], Loss:0.0220, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1660/5000], Loss:0.0183, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1670/5000], Loss:0.0252, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1680/5000], Loss:0.0216, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1690/5000], Loss:0.0282, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1700/5000], Loss:0.0174, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1710/5000], Loss:0.0220, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1720/5000], Loss:0.0145, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1730/5000], Loss:0.0269, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1740/5000], Loss:0.0214, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1750/5000], Loss:0.0241, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1760/5000], Loss:0.0251, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1770/5000], Loss:0.0180, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1780/5000], Loss:0.0242, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1790/5000], Loss:0.0152, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1800/5000], Loss:0.0187, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1810/5000], Loss:0.0199, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1820/5000], Loss:0.0245, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1830/5000], Loss:0.0163, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1840/5000], Loss:0.0228, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1850/5000], Loss:0.0199, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1860/5000], Loss:0.0198, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1870/5000], Loss:0.0143, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1880/5000], Loss:0.0188, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1890/5000], Loss:0.0181, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1900/5000], Loss:0.0270, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1910/5000], Loss:0.0243, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1920/5000], Loss:0.0188, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1930/5000], Loss:0.0128, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1940/5000], Loss:0.0267, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1950/5000], Loss:0.0170, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1960/5000], Loss:0.0191, RegLoss:0.0000, T:1.2s\n",
      "P1 S [1970/5000], Loss:0.0200, RegLoss:0.0000, T:1.1s\n",
      "P1 S [1980/5000], Loss:0.0159, RegLoss:0.0000, T:1.3s\n",
      "P1 S [1990/5000], Loss:0.0160, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2000/5000], Loss:0.0188, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2010/5000], Loss:0.0196, RegLoss:0.0000, T:1.8s\n",
      "P1 S [2020/5000], Loss:0.0226, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2030/5000], Loss:0.0169, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2040/5000], Loss:0.0164, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2050/5000], Loss:0.0152, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2060/5000], Loss:0.0173, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2070/5000], Loss:0.0164, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2080/5000], Loss:0.0246, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2090/5000], Loss:0.0197, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2100/5000], Loss:0.0269, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2110/5000], Loss:0.0149, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2120/5000], Loss:0.0151, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2130/5000], Loss:0.0162, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2140/5000], Loss:0.0148, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2150/5000], Loss:0.0187, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2160/5000], Loss:0.0184, RegLoss:0.0000, T:1.3s\n",
      "P1 S [2170/5000], Loss:0.0144, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2180/5000], Loss:0.0184, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2190/5000], Loss:0.0134, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2200/5000], Loss:0.0195, RegLoss:0.0000, T:1.3s\n",
      "P1 S [2210/5000], Loss:0.0248, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2220/5000], Loss:0.0177, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2230/5000], Loss:0.0178, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2240/5000], Loss:0.0126, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2250/5000], Loss:0.0145, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2260/5000], Loss:0.0183, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2270/5000], Loss:0.0138, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2280/5000], Loss:0.0188, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2290/5000], Loss:0.0274, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2300/5000], Loss:0.0174, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2310/5000], Loss:0.0161, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2320/5000], Loss:0.0173, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2330/5000], Loss:0.0184, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2340/5000], Loss:0.0143, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2350/5000], Loss:0.0236, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2360/5000], Loss:0.0234, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2370/5000], Loss:0.0247, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2380/5000], Loss:0.0168, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2390/5000], Loss:0.0186, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2400/5000], Loss:0.0274, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2410/5000], Loss:0.0206, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2420/5000], Loss:0.0145, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2430/5000], Loss:0.0196, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2440/5000], Loss:0.0151, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2450/5000], Loss:0.0193, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2460/5000], Loss:0.0213, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2470/5000], Loss:0.0108, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2480/5000], Loss:0.0219, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2490/5000], Loss:0.0177, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2500/5000], Loss:0.0172, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2510/5000], Loss:0.0167, RegLoss:0.0000, T:1.6s\n",
      "P1 S [2520/5000], Loss:0.0258, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2530/5000], Loss:0.0186, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2540/5000], Loss:0.0169, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2550/5000], Loss:0.0190, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2560/5000], Loss:0.0160, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2570/5000], Loss:0.0229, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2580/5000], Loss:0.0160, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2590/5000], Loss:0.0229, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2600/5000], Loss:0.0168, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2610/5000], Loss:0.0190, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2620/5000], Loss:0.0131, RegLoss:0.0000, T:1.4s\n",
      "P1 S [2630/5000], Loss:0.0273, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2640/5000], Loss:0.0165, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2650/5000], Loss:0.0129, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2660/5000], Loss:0.0165, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2670/5000], Loss:0.0168, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2680/5000], Loss:0.0194, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2690/5000], Loss:0.0198, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2700/5000], Loss:0.0146, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2710/5000], Loss:0.0183, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2720/5000], Loss:0.0192, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2730/5000], Loss:0.0147, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2740/5000], Loss:0.0174, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2750/5000], Loss:0.0179, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2760/5000], Loss:0.0225, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2770/5000], Loss:0.0199, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2780/5000], Loss:0.0194, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2790/5000], Loss:0.0151, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2800/5000], Loss:0.0189, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2810/5000], Loss:0.0201, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2820/5000], Loss:0.0157, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2830/5000], Loss:0.0200, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2840/5000], Loss:0.0158, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2850/5000], Loss:0.0203, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2860/5000], Loss:0.0212, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2870/5000], Loss:0.0138, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2880/5000], Loss:0.0183, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2890/5000], Loss:0.0179, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2900/5000], Loss:0.0146, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2910/5000], Loss:0.0160, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2920/5000], Loss:0.0235, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2930/5000], Loss:0.0166, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2940/5000], Loss:0.0161, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2950/5000], Loss:0.0162, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2960/5000], Loss:0.0160, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2970/5000], Loss:0.0180, RegLoss:0.0000, T:1.2s\n",
      "P1 S [2980/5000], Loss:0.0221, RegLoss:0.0000, T:1.1s\n",
      "P1 S [2990/5000], Loss:0.0217, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3000/5000], Loss:0.0167, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3010/5000], Loss:0.0168, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3020/5000], Loss:0.0150, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3030/5000], Loss:0.0130, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3040/5000], Loss:0.0251, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3050/5000], Loss:0.0142, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3060/5000], Loss:0.0125, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3070/5000], Loss:0.0131, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3080/5000], Loss:0.0278, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3090/5000], Loss:0.0170, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3100/5000], Loss:0.0189, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3110/5000], Loss:0.0142, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3120/5000], Loss:0.0194, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3130/5000], Loss:0.0141, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3140/5000], Loss:0.0180, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3150/5000], Loss:0.0186, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3160/5000], Loss:0.0234, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3170/5000], Loss:0.0170, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3180/5000], Loss:0.0173, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3190/5000], Loss:0.0174, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3200/5000], Loss:0.0166, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3210/5000], Loss:0.0138, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3220/5000], Loss:0.0146, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3230/5000], Loss:0.0226, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3240/5000], Loss:0.0212, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3250/5000], Loss:0.0174, RegLoss:0.0000, T:1.3s\n",
      "P1 S [3260/5000], Loss:0.0160, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3270/5000], Loss:0.0145, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3280/5000], Loss:0.0133, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3290/5000], Loss:0.0177, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3300/5000], Loss:0.0144, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3310/5000], Loss:0.0147, RegLoss:0.0000, T:1.3s\n",
      "P1 S [3320/5000], Loss:0.0067, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3330/5000], Loss:0.0234, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3340/5000], Loss:0.0159, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3350/5000], Loss:0.0158, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3360/5000], Loss:0.0159, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3370/5000], Loss:0.0184, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3380/5000], Loss:0.0193, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3390/5000], Loss:0.0193, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3400/5000], Loss:0.0179, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3410/5000], Loss:0.0227, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3420/5000], Loss:0.0126, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3430/5000], Loss:0.0162, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3440/5000], Loss:0.0200, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3450/5000], Loss:0.0180, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3460/5000], Loss:0.0182, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3470/5000], Loss:0.0169, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3480/5000], Loss:0.0214, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3490/5000], Loss:0.0101, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3500/5000], Loss:0.0193, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3510/5000], Loss:0.0120, RegLoss:0.0000, T:1.6s\n",
      "P1 S [3520/5000], Loss:0.0157, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3530/5000], Loss:0.0164, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3540/5000], Loss:0.0235, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3550/5000], Loss:0.0136, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3560/5000], Loss:0.0200, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3570/5000], Loss:0.0189, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3580/5000], Loss:0.0108, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3590/5000], Loss:0.0144, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3600/5000], Loss:0.0183, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3610/5000], Loss:0.0231, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3620/5000], Loss:0.0289, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3630/5000], Loss:0.0170, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3640/5000], Loss:0.0169, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3650/5000], Loss:0.0143, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3660/5000], Loss:0.0170, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3670/5000], Loss:0.0173, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3680/5000], Loss:0.0172, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3690/5000], Loss:0.0194, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3700/5000], Loss:0.0147, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3710/5000], Loss:0.0216, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3720/5000], Loss:0.0198, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3730/5000], Loss:0.0245, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3740/5000], Loss:0.0212, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3750/5000], Loss:0.0213, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3760/5000], Loss:0.0196, RegLoss:0.0000, T:1.3s\n",
      "P1 S [3770/5000], Loss:0.0178, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3780/5000], Loss:0.0174, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3790/5000], Loss:0.0114, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3800/5000], Loss:0.0171, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3810/5000], Loss:0.0148, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3820/5000], Loss:0.0201, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3830/5000], Loss:0.0151, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3840/5000], Loss:0.0236, RegLoss:0.0000, T:1.3s\n",
      "P1 S [3850/5000], Loss:0.0165, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3860/5000], Loss:0.0125, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3870/5000], Loss:0.0237, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3880/5000], Loss:0.0169, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3890/5000], Loss:0.0164, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3900/5000], Loss:0.0176, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3910/5000], Loss:0.0175, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3920/5000], Loss:0.0156, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3930/5000], Loss:0.0233, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3940/5000], Loss:0.0175, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3950/5000], Loss:0.0135, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3960/5000], Loss:0.0158, RegLoss:0.0000, T:1.1s\n",
      "P1 S [3970/5000], Loss:0.0167, RegLoss:0.0000, T:1.2s\n",
      "P1 S [3980/5000], Loss:0.0217, RegLoss:0.0000, T:1.3s\n",
      "P1 S [3990/5000], Loss:0.0159, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4000/5000], Loss:0.0135, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4010/5000], Loss:0.0164, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4020/5000], Loss:0.0105, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4030/5000], Loss:0.0253, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4040/5000], Loss:0.0155, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4050/5000], Loss:0.0176, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4060/5000], Loss:0.0188, RegLoss:0.0000, T:1.3s\n",
      "P1 S [4070/5000], Loss:0.0183, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4080/5000], Loss:0.0172, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4090/5000], Loss:0.0091, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4100/5000], Loss:0.0151, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4110/5000], Loss:0.0149, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4120/5000], Loss:0.0205, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4130/5000], Loss:0.0202, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4140/5000], Loss:0.0205, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4150/5000], Loss:0.0229, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4160/5000], Loss:0.0193, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4170/5000], Loss:0.0164, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4180/5000], Loss:0.0227, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4190/5000], Loss:0.0153, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4200/5000], Loss:0.0116, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4210/5000], Loss:0.0195, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4220/5000], Loss:0.0180, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4230/5000], Loss:0.0182, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4240/5000], Loss:0.0172, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4250/5000], Loss:0.0148, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4260/5000], Loss:0.0133, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4270/5000], Loss:0.0185, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4280/5000], Loss:0.0210, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4290/5000], Loss:0.0177, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4300/5000], Loss:0.0198, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4310/5000], Loss:0.0108, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4320/5000], Loss:0.0190, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4330/5000], Loss:0.0190, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4340/5000], Loss:0.0178, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4350/5000], Loss:0.0196, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4360/5000], Loss:0.0107, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4370/5000], Loss:0.0164, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4380/5000], Loss:0.0190, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4390/5000], Loss:0.0140, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4400/5000], Loss:0.0200, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4410/5000], Loss:0.0177, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4420/5000], Loss:0.0159, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4430/5000], Loss:0.0249, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4440/5000], Loss:0.0177, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4450/5000], Loss:0.0211, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4460/5000], Loss:0.0279, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4470/5000], Loss:0.0172, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4480/5000], Loss:0.0147, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4490/5000], Loss:0.0115, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4500/5000], Loss:0.0180, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4510/5000], Loss:0.0191, RegLoss:0.0000, T:1.6s\n",
      "P1 S [4520/5000], Loss:0.0183, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4530/5000], Loss:0.0073, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4540/5000], Loss:0.0155, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4550/5000], Loss:0.0131, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4560/5000], Loss:0.0150, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4570/5000], Loss:0.0160, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4580/5000], Loss:0.0260, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4590/5000], Loss:0.0199, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4600/5000], Loss:0.0186, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4610/5000], Loss:0.0154, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4620/5000], Loss:0.0158, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4630/5000], Loss:0.0229, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4640/5000], Loss:0.0145, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4650/5000], Loss:0.0215, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4660/5000], Loss:0.0181, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4670/5000], Loss:0.0165, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4680/5000], Loss:0.0173, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4690/5000], Loss:0.0188, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4700/5000], Loss:0.0196, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4710/5000], Loss:0.0183, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4720/5000], Loss:0.0231, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4730/5000], Loss:0.0198, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4740/5000], Loss:0.0150, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4750/5000], Loss:0.0195, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4760/5000], Loss:0.0138, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4770/5000], Loss:0.0234, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4780/5000], Loss:0.0130, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4790/5000], Loss:0.0157, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4800/5000], Loss:0.0197, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4810/5000], Loss:0.0200, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4820/5000], Loss:0.0113, RegLoss:0.0000, T:1.3s\n",
      "P1 S [4830/5000], Loss:0.0096, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4840/5000], Loss:0.0167, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4850/5000], Loss:0.0209, RegLoss:0.0000, T:1.4s\n",
      "P1 S [4860/5000], Loss:0.0174, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4870/5000], Loss:0.0155, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4880/5000], Loss:0.0167, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4890/5000], Loss:0.0158, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4900/5000], Loss:0.0181, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4910/5000], Loss:0.0181, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4920/5000], Loss:0.0135, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4930/5000], Loss:0.0158, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4940/5000], Loss:0.0207, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4950/5000], Loss:0.0223, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4960/5000], Loss:0.0097, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4970/5000], Loss:0.0155, RegLoss:0.0000, T:1.1s\n",
      "P1 S [4980/5000], Loss:0.0179, RegLoss:0.0000, T:1.2s\n",
      "P1 S [4990/5000], Loss:0.0135, RegLoss:0.0000, T:1.2s\n",
      "P1 S [5000/5000], Loss:0.0207, RegLoss:0.0000, T:1.1s\n",
      "Phase 1 training complete.\n",
      "\n",
      "Phase 2 LR: 5e-05\n",
      "\n",
      "--- Train Phase 2: Curriculum (1000 steps) ---\n",
      "Settings: SpatialW=False, ModReadout=False, NMDecodeLoss=False\n",
      "Loss calculated from T_settle=50. Total SEQ_LEN=150\n",
      "P2 S [1/1000], Loss:0.0178, RegLoss:0.0000, T:0.1s\n",
      "P2 S [10/1000], Loss:0.0232, RegLoss:0.0000, T:1.5s\n",
      "P2 S [20/1000], Loss:0.0158, RegLoss:0.0000, T:1.1s\n",
      "P2 S [30/1000], Loss:0.0151, RegLoss:0.0000, T:1.2s\n",
      "P2 S [40/1000], Loss:0.0147, RegLoss:0.0000, T:1.2s\n",
      "P2 S [50/1000], Loss:0.0165, RegLoss:0.0000, T:1.3s\n",
      "P2 S [60/1000], Loss:0.0185, RegLoss:0.0000, T:1.1s\n",
      "P2 S [70/1000], Loss:0.0179, RegLoss:0.0000, T:1.2s\n",
      "P2 S [80/1000], Loss:0.0203, RegLoss:0.0000, T:1.1s\n",
      "P2 S [90/1000], Loss:0.0158, RegLoss:0.0000, T:1.2s\n",
      "P2 S [100/1000], Loss:0.0170, RegLoss:0.0000, T:1.2s\n",
      "P2 S [110/1000], Loss:0.0228, RegLoss:0.0000, T:1.1s\n",
      "P2 S [120/1000], Loss:0.0264, RegLoss:0.0000, T:1.2s\n",
      "P2 S [130/1000], Loss:0.0204, RegLoss:0.0000, T:1.1s\n",
      "P2 S [140/1000], Loss:0.0248, RegLoss:0.0000, T:1.2s\n",
      "P2 S [150/1000], Loss:0.0172, RegLoss:0.0000, T:1.2s\n",
      "P2 S [160/1000], Loss:0.0193, RegLoss:0.0000, T:1.2s\n",
      "P2 S [170/1000], Loss:0.0251, RegLoss:0.0000, T:1.1s\n",
      "P2 S [180/1000], Loss:0.0261, RegLoss:0.0000, T:1.2s\n",
      "P2 S [190/1000], Loss:0.0173, RegLoss:0.0000, T:1.1s\n",
      "P2 S [200/1000], Loss:0.0280, RegLoss:0.0000, T:1.2s\n",
      "P2 S [210/1000], Loss:0.0226, RegLoss:0.0000, T:1.2s\n",
      "P2 S [220/1000], Loss:0.0237, RegLoss:0.0000, T:1.1s\n",
      "P2 S [230/1000], Loss:0.0287, RegLoss:0.0000, T:1.2s\n",
      "P2 S [240/1000], Loss:0.0338, RegLoss:0.0000, T:1.2s\n",
      "P2 S [250/1000], Loss:0.0395, RegLoss:0.0000, T:1.1s\n",
      "P2 S [260/1000], Loss:0.0280, RegLoss:0.0000, T:1.2s\n",
      "P2 S [270/1000], Loss:0.0351, RegLoss:0.0000, T:1.2s\n",
      "P2 S [280/1000], Loss:0.0359, RegLoss:0.0000, T:1.3s\n",
      "P2 S [290/1000], Loss:0.0294, RegLoss:0.0000, T:1.2s\n",
      "P2 S [300/1000], Loss:0.0302, RegLoss:0.0000, T:1.2s\n",
      "P2 S [310/1000], Loss:0.0411, RegLoss:0.0000, T:1.1s\n",
      "P2 S [320/1000], Loss:0.0437, RegLoss:0.0000, T:1.2s\n",
      "P2 S [330/1000], Loss:0.0376, RegLoss:0.0000, T:1.2s\n",
      "P2 S [340/1000], Loss:0.0319, RegLoss:0.0000, T:1.2s\n",
      "P2 S [350/1000], Loss:0.0431, RegLoss:0.0000, T:1.2s\n",
      "P2 S [360/1000], Loss:0.0310, RegLoss:0.0000, T:1.1s\n",
      "P2 S [370/1000], Loss:0.0394, RegLoss:0.0000, T:1.2s\n",
      "P2 S [380/1000], Loss:0.0333, RegLoss:0.0000, T:1.2s\n",
      "P2 S [390/1000], Loss:0.0515, RegLoss:0.0000, T:1.1s\n",
      "P2 S [400/1000], Loss:0.0354, RegLoss:0.0000, T:1.2s\n",
      "P2 S [410/1000], Loss:0.0173, RegLoss:0.0000, T:1.2s\n",
      "P2 S [420/1000], Loss:0.0290, RegLoss:0.0000, T:1.1s\n",
      "P2 S [430/1000], Loss:0.0377, RegLoss:0.0000, T:1.2s\n",
      "P2 S [440/1000], Loss:0.0420, RegLoss:0.0000, T:1.2s\n",
      "P2 S [450/1000], Loss:0.0533, RegLoss:0.0000, T:1.1s\n",
      "P2 S [460/1000], Loss:0.0411, RegLoss:0.0000, T:1.2s\n",
      "P2 S [470/1000], Loss:0.0279, RegLoss:0.0000, T:1.2s\n",
      "P2 S [480/1000], Loss:0.0447, RegLoss:0.0000, T:1.1s\n",
      "P2 S [490/1000], Loss:0.0497, RegLoss:0.0000, T:1.2s\n",
      "P2 S [500/1000], Loss:0.0492, RegLoss:0.0000, T:1.2s\n",
      "P2 S [510/1000], Loss:0.0527, RegLoss:0.0000, T:1.6s\n",
      "P2 S [520/1000], Loss:0.0402, RegLoss:0.0000, T:1.1s\n",
      "P2 S [530/1000], Loss:0.0323, RegLoss:0.0000, T:1.2s\n",
      "P2 S [540/1000], Loss:0.0437, RegLoss:0.0000, T:1.2s\n",
      "P2 S [550/1000], Loss:0.0495, RegLoss:0.0000, T:1.1s\n",
      "P2 S [560/1000], Loss:0.0622, RegLoss:0.0000, T:1.2s\n",
      "P2 S [570/1000], Loss:0.0449, RegLoss:0.0000, T:1.2s\n",
      "P2 S [580/1000], Loss:0.0569, RegLoss:0.0000, T:1.2s\n",
      "P2 S [590/1000], Loss:0.0474, RegLoss:0.0000, T:1.1s\n",
      "P2 S [600/1000], Loss:0.0571, RegLoss:0.0000, T:1.2s\n",
      "P2 S [610/1000], Loss:0.0617, RegLoss:0.0000, T:1.2s\n",
      "P2 S [620/1000], Loss:0.0579, RegLoss:0.0000, T:1.1s\n",
      "P2 S [630/1000], Loss:0.0413, RegLoss:0.0000, T:1.2s\n",
      "P2 S [640/1000], Loss:0.0764, RegLoss:0.0000, T:1.2s\n",
      "P2 S [650/1000], Loss:0.0682, RegLoss:0.0000, T:1.1s\n",
      "P2 S [660/1000], Loss:0.0603, RegLoss:0.0000, T:1.2s\n",
      "P2 S [670/1000], Loss:0.0581, RegLoss:0.0000, T:1.1s\n",
      "P2 S [680/1000], Loss:0.0553, RegLoss:0.0000, T:1.2s\n",
      "P2 S [690/1000], Loss:0.0759, RegLoss:0.0000, T:1.2s\n",
      "P2 S [700/1000], Loss:0.0576, RegLoss:0.0000, T:1.1s\n",
      "P2 S [710/1000], Loss:0.0613, RegLoss:0.0000, T:1.2s\n",
      "P2 S [720/1000], Loss:0.0933, RegLoss:0.0000, T:1.1s\n",
      "P2 S [730/1000], Loss:0.0758, RegLoss:0.0000, T:1.2s\n",
      "P2 S [740/1000], Loss:0.0490, RegLoss:0.0000, T:1.2s\n",
      "P2 S [750/1000], Loss:0.0699, RegLoss:0.0000, T:1.2s\n",
      "P2 S [760/1000], Loss:0.0641, RegLoss:0.0000, T:1.2s\n",
      "P2 S [770/1000], Loss:0.0670, RegLoss:0.0000, T:1.1s\n",
      "P2 S [780/1000], Loss:0.0632, RegLoss:0.0000, T:1.2s\n",
      "P2 S [790/1000], Loss:0.0640, RegLoss:0.0000, T:1.2s\n",
      "P2 S [800/1000], Loss:0.0645, RegLoss:0.0000, T:1.1s\n",
      "P2 S [810/1000], Loss:0.0650, RegLoss:0.0000, T:1.2s\n",
      "P2 S [820/1000], Loss:0.0852, RegLoss:0.0000, T:1.1s\n",
      "P2 S [830/1000], Loss:0.1005, RegLoss:0.0000, T:1.2s\n",
      "P2 S [840/1000], Loss:0.0712, RegLoss:0.0000, T:1.2s\n",
      "P2 S [850/1000], Loss:0.0765, RegLoss:0.0000, T:1.1s\n",
      "P2 S [860/1000], Loss:0.0672, RegLoss:0.0000, T:1.2s\n",
      "P2 S [870/1000], Loss:0.0720, RegLoss:0.0000, T:1.2s\n",
      "P2 S [880/1000], Loss:0.0939, RegLoss:0.0000, T:1.2s\n",
      "P2 S [890/1000], Loss:0.0738, RegLoss:0.0000, T:1.2s\n",
      "P2 S [900/1000], Loss:0.0745, RegLoss:0.0000, T:1.2s\n",
      "P2 S [910/1000], Loss:0.0776, RegLoss:0.0000, T:1.1s\n",
      "P2 S [920/1000], Loss:0.0747, RegLoss:0.0000, T:1.2s\n",
      "P2 S [930/1000], Loss:0.0688, RegLoss:0.0000, T:1.2s\n",
      "P2 S [940/1000], Loss:0.0948, RegLoss:0.0000, T:1.2s\n",
      "P2 S [950/1000], Loss:0.1117, RegLoss:0.0000, T:1.1s\n",
      "P2 S [960/1000], Loss:0.0562, RegLoss:0.0000, T:1.2s\n",
      "P2 S [970/1000], Loss:0.0989, RegLoss:0.0000, T:1.1s\n",
      "P2 S [980/1000], Loss:0.1202, RegLoss:0.0000, T:1.2s\n",
      "P2 S [990/1000], Loss:0.0871, RegLoss:0.0000, T:1.2s\n",
      "P2 S [1000/1000], Loss:0.1214, RegLoss:0.0000, T:1.1s\n",
      "Phase 2 training complete.\n",
      "Logs saved to Hopf_experiments_new/NM0_H128_20250514-072733/logs/NM0_H128_logs.pkl\n",
      "Model parameters saved to Hopf_experiments_new/NM0_H128_20250514-072733/models/NM0_H128_model_state_dict.pth\n",
      "\n",
      "--- Generating Final Plots ---\n",
      "Final plots saved to Hopf_experiments_new/NM0_H128_20250514-072733/plots\n",
      "Training movie frames saved to Hopf_experiments_new/NM0_H128_20250514-072733/training_movie_for_NM0_H128\n",
      "====== Experiment NM0_H128 Complete ======\n",
      "\n",
      "\n",
      "====== Running Experiment: sNM4_H128 ======\n",
      "Hyperparameters: {'n_in': 3, 'n_out': 1, 'n_rnn': 128, 'N_NM': 4, 'decay': 0.95, 'activation': 'tanh', 'keepW0': True, 'use_bias': False, 'learning_rate': 0.0001, 'seed': 123, 'clip': 1.0, 'grad_value_clip': 0.1, 'l1_h': 0, 'l2_h': 0, 'l1_weight': 0, 'l2_weight': 0, 'l2_nmVelo': 0.0001, 'use_spatial_weights': True, 'spatial_ell': 0.2, 'spatial_scale': 1.0, 'use_modulated_readout': False, 'use_nm_decoder_loss': True, 'nm_decoder_loss_weight': 1.0, 'nm_init_scale': 1.0, 'experiment_name': 'sNM4_H128'}\n",
      "Saving results to: Hopf_experiments_new/sNM4_H128_20250514-073926\n",
      "Using device: cpu\n",
      "\n",
      "Main Model (Model_nm_CombinedFeatures, H=128, NM=4) params: 82976\n",
      "Surrogate Model (Model_RNN, H=128) params: 16896\n",
      "\n",
      "\n",
      "--- Train Phase 1: Stationary (5000 steps) ---\n",
      "Settings: SpatialW=True, ModReadout=False, NMDecodeLoss=True\n",
      "Loss calculated from T_settle=50. Total SEQ_LEN=150\n",
      "P1 S [1/5000], Loss:1.3869, RegLoss:0.0000, NMDec:0.2020, CosSim:-0.284, DotProd:-0.235, T:4.3s\n",
      "P1 S [10/5000], Loss:0.0607, RegLoss:0.0000, NMDec:0.1521, CosSim:0.003, DotProd:0.000, T:40.2s\n",
      "P1 S [20/5000], Loss:0.0236, RegLoss:0.0000, NMDec:0.1581, CosSim:-0.001, DotProd:-0.000, T:43.6s\n",
      "P1 S [30/5000], Loss:0.0259, RegLoss:0.0000, NMDec:0.1382, CosSim:-0.008, DotProd:-0.000, T:44.3s\n",
      "P1 S [40/5000], Loss:0.0183, RegLoss:0.0000, NMDec:0.1434, CosSim:-0.020, DotProd:-0.000, T:44.5s\n",
      "P1 S [50/5000], Loss:0.0330, RegLoss:0.0000, NMDec:0.1137, CosSim:-0.039, DotProd:-0.001, T:42.8s\n",
      "P1 S [60/5000], Loss:0.0243, RegLoss:0.0000, NMDec:0.1111, CosSim:-0.037, DotProd:-0.001, T:42.1s\n",
      "P1 S [70/5000], Loss:0.0205, RegLoss:0.0000, NMDec:0.1120, CosSim:-0.002, DotProd:-0.000, T:43.2s\n",
      "P1 S [80/5000], Loss:0.0158, RegLoss:0.0000, NMDec:0.1042, CosSim:0.032, DotProd:0.009, T:44.7s\n",
      "P1 S [90/5000], Loss:0.0157, RegLoss:0.0000, NMDec:0.0989, CosSim:0.044, DotProd:0.024, T:43.7s\n",
      "P1 S [100/5000], Loss:0.0197, RegLoss:0.0000, NMDec:0.0845, CosSim:0.047, DotProd:0.044, T:44.1s\n",
      "P1 S [110/5000], Loss:0.0153, RegLoss:0.0000, NMDec:0.0794, CosSim:0.041, DotProd:0.042, T:44.3s\n",
      "P1 S [120/5000], Loss:0.0285, RegLoss:0.0000, NMDec:0.0629, CosSim:0.031, DotProd:0.034, T:43.6s\n",
      "P1 S [130/5000], Loss:0.0100, RegLoss:0.0000, NMDec:0.0778, CosSim:0.015, DotProd:0.021, T:43.4s\n",
      "P1 S [140/5000], Loss:0.0210, RegLoss:0.0000, NMDec:0.0604, CosSim:0.010, DotProd:0.014, T:42.9s\n",
      "P1 S [150/5000], Loss:0.0144, RegLoss:0.0000, NMDec:0.0683, CosSim:0.010, DotProd:0.018, T:44.3s\n",
      "P1 S [160/5000], Loss:0.0131, RegLoss:0.0000, NMDec:0.0628, CosSim:-0.008, DotProd:-0.015, T:44.0s\n",
      "P1 S [170/5000], Loss:0.0148, RegLoss:0.0000, NMDec:0.0602, CosSim:0.010, DotProd:0.024, T:44.6s\n",
      "P1 S [180/5000], Loss:0.0152, RegLoss:0.0000, NMDec:0.0513, CosSim:-0.011, DotProd:-0.023, T:42.8s\n",
      "P1 S [190/5000], Loss:0.0090, RegLoss:0.0000, NMDec:0.0522, CosSim:-0.013, DotProd:-0.024, T:43.1s\n",
      "P1 S [200/5000], Loss:0.0089, RegLoss:0.0000, NMDec:0.0523, CosSim:-0.011, DotProd:-0.018, T:42.0s\n",
      "P1 S [210/5000], Loss:0.0096, RegLoss:0.0000, NMDec:0.0478, CosSim:-0.022, DotProd:-0.038, T:41.8s\n",
      "P1 S [220/5000], Loss:0.0121, RegLoss:0.0000, NMDec:0.0411, CosSim:-0.020, DotProd:-0.031, T:42.5s\n",
      "P1 S [230/5000], Loss:0.0087, RegLoss:0.0000, NMDec:0.0406, CosSim:-0.016, DotProd:-0.028, T:42.6s\n",
      "P1 S [240/5000], Loss:0.0078, RegLoss:0.0000, NMDec:0.0398, CosSim:-0.013, DotProd:-0.022, T:42.3s\n",
      "P1 S [250/5000], Loss:0.0080, RegLoss:0.0000, NMDec:0.0370, CosSim:-0.017, DotProd:-0.026, T:41.7s\n",
      "P1 S [260/5000], Loss:0.0067, RegLoss:0.0000, NMDec:0.0404, CosSim:-0.008, DotProd:-0.012, T:42.2s\n",
      "P1 S [270/5000], Loss:0.0103, RegLoss:0.0000, NMDec:0.0374, CosSim:-0.016, DotProd:-0.026, T:43.2s\n",
      "P1 S [280/5000], Loss:0.0078, RegLoss:0.0000, NMDec:0.0310, CosSim:-0.020, DotProd:-0.036, T:43.4s\n",
      "P1 S [290/5000], Loss:0.0072, RegLoss:0.0000, NMDec:0.0296, CosSim:-0.006, DotProd:-0.009, T:43.0s\n",
      "P1 S [300/5000], Loss:0.0070, RegLoss:0.0000, NMDec:0.0317, CosSim:-0.012, DotProd:-0.019, T:43.0s\n",
      "P1 S [310/5000], Loss:0.0045, RegLoss:0.0000, NMDec:0.0340, CosSim:-0.001, DotProd:-0.001, T:43.5s\n",
      "P1 S [320/5000], Loss:0.0054, RegLoss:0.0000, NMDec:0.0249, CosSim:0.017, DotProd:0.038, T:43.7s\n",
      "P1 S [330/5000], Loss:0.0035, RegLoss:0.0000, NMDec:0.0321, CosSim:-0.006, DotProd:-0.012, T:43.1s\n",
      "P1 S [340/5000], Loss:0.0044, RegLoss:0.0000, NMDec:0.0310, CosSim:0.004, DotProd:0.005, T:42.5s\n",
      "P1 S [350/5000], Loss:0.0050, RegLoss:0.0000, NMDec:0.0258, CosSim:-0.063, DotProd:-0.224, T:42.3s\n",
      "P1 S [360/5000], Loss:0.0037, RegLoss:0.0000, NMDec:0.0298, CosSim:-0.024, DotProd:-0.036, T:41.9s\n",
      "P1 S [370/5000], Loss:0.0049, RegLoss:0.0000, NMDec:0.0217, CosSim:-0.018, DotProd:-0.027, T:42.1s\n",
      "P1 S [380/5000], Loss:0.0030, RegLoss:0.0000, NMDec:0.0272, CosSim:-0.027, DotProd:-0.038, T:42.7s\n",
      "P1 S [390/5000], Loss:0.0037, RegLoss:0.0000, NMDec:0.0181, CosSim:-0.024, DotProd:-0.038, T:42.8s\n",
      "P1 S [400/5000], Loss:0.0027, RegLoss:0.0000, NMDec:0.0237, CosSim:-0.025, DotProd:-0.035, T:42.8s\n",
      "P1 S [410/5000], Loss:0.0025, RegLoss:0.0000, NMDec:0.0245, CosSim:-0.024, DotProd:-0.035, T:43.9s\n",
      "P1 S [420/5000], Loss:0.0031, RegLoss:0.0000, NMDec:0.0216, CosSim:-0.003, DotProd:-0.004, T:43.0s\n",
      "P1 S [430/5000], Loss:0.0038, RegLoss:0.0000, NMDec:0.0190, CosSim:-0.037, DotProd:-0.052, T:42.4s\n",
      "P1 S [440/5000], Loss:0.0031, RegLoss:0.0000, NMDec:0.0190, CosSim:-0.037, DotProd:-0.051, T:41.3s\n",
      "P1 S [450/5000], Loss:0.0024, RegLoss:0.0000, NMDec:0.0196, CosSim:-0.005, DotProd:-0.008, T:42.9s\n",
      "P1 S [460/5000], Loss:0.0024, RegLoss:0.0000, NMDec:0.0161, CosSim:-0.031, DotProd:-0.042, T:42.2s\n",
      "P1 S [470/5000], Loss:0.0028, RegLoss:0.0000, NMDec:0.0187, CosSim:-0.012, DotProd:-0.014, T:42.4s\n",
      "P1 S [480/5000], Loss:0.0021, RegLoss:0.0000, NMDec:0.0206, CosSim:0.007, DotProd:0.010, T:43.7s\n",
      "P1 S [490/5000], Loss:0.0022, RegLoss:0.0000, NMDec:0.0189, CosSim:0.004, DotProd:0.006, T:43.7s\n",
      "P1 S [500/5000], Loss:0.0026, RegLoss:0.0000, NMDec:0.0178, CosSim:0.011, DotProd:0.015, T:43.1s\n",
      "P1 S [510/5000], Loss:0.0031, RegLoss:0.0000, NMDec:0.0142, CosSim:-0.032, DotProd:-0.036, T:45.1s\n",
      "P1 S [520/5000], Loss:0.0024, RegLoss:0.0000, NMDec:0.0165, CosSim:-0.006, DotProd:-0.008, T:43.9s\n",
      "P1 S [530/5000], Loss:0.0028, RegLoss:0.0000, NMDec:0.0146, CosSim:-0.008, DotProd:-0.011, T:42.0s\n",
      "P1 S [540/5000], Loss:0.0031, RegLoss:0.0000, NMDec:0.0126, CosSim:-0.044, DotProd:-0.046, T:42.0s\n",
      "P1 S [550/5000], Loss:0.0024, RegLoss:0.0000, NMDec:0.0131, CosSim:-0.013, DotProd:-0.014, T:43.9s\n",
      "P1 S [560/5000], Loss:0.0025, RegLoss:0.0000, NMDec:0.0148, CosSim:0.003, DotProd:0.004, T:43.3s\n",
      "P1 S [570/5000], Loss:0.0031, RegLoss:0.0000, NMDec:0.0154, CosSim:-0.020, DotProd:-0.020, T:42.3s\n",
      "P1 S [580/5000], Loss:0.0025, RegLoss:0.0000, NMDec:0.0141, CosSim:-0.003, DotProd:-0.004, T:43.0s\n",
      "P1 S [590/5000], Loss:0.0018, RegLoss:0.0000, NMDec:0.0160, CosSim:0.034, DotProd:0.039, T:43.8s\n",
      "P1 S [600/5000], Loss:0.0016, RegLoss:0.0000, NMDec:0.0157, CosSim:0.009, DotProd:0.010, T:43.1s\n",
      "P1 S [610/5000], Loss:0.0020, RegLoss:0.0000, NMDec:0.0130, CosSim:0.014, DotProd:0.016, T:43.0s\n",
      "P1 S [620/5000], Loss:0.0020, RegLoss:0.0000, NMDec:0.0128, CosSim:0.028, DotProd:0.035, T:43.2s\n",
      "P1 S [630/5000], Loss:0.0020, RegLoss:0.0000, NMDec:0.0126, CosSim:0.010, DotProd:0.010, T:42.3s\n",
      "P1 S [640/5000], Loss:0.0021, RegLoss:0.0000, NMDec:0.0113, CosSim:0.020, DotProd:0.022, T:42.3s\n",
      "P1 S [650/5000], Loss:0.0021, RegLoss:0.0000, NMDec:0.0104, CosSim:-0.014, DotProd:-0.011, T:44.6s\n",
      "P1 S [660/5000], Loss:0.0015, RegLoss:0.0000, NMDec:0.0115, CosSim:0.035, DotProd:0.037, T:44.4s\n",
      "P1 S [670/5000], Loss:0.0022, RegLoss:0.0000, NMDec:0.0101, CosSim:0.013, DotProd:0.014, T:44.0s\n",
      "P1 S [680/5000], Loss:0.0020, RegLoss:0.0000, NMDec:0.0111, CosSim:-0.003, DotProd:-0.002, T:44.4s\n",
      "P1 S [690/5000], Loss:0.0019, RegLoss:0.0000, NMDec:0.0107, CosSim:0.024, DotProd:0.021, T:44.3s\n",
      "P1 S [700/5000], Loss:0.0020, RegLoss:0.0000, NMDec:0.0128, CosSim:0.043, DotProd:0.042, T:44.4s\n",
      "P1 S [710/5000], Loss:0.0017, RegLoss:0.0000, NMDec:0.0086, CosSim:0.014, DotProd:0.010, T:43.3s\n",
      "P1 S [720/5000], Loss:0.0018, RegLoss:0.0000, NMDec:0.0098, CosSim:-0.011, DotProd:-0.011, T:43.1s\n",
      "P1 S [730/5000], Loss:0.0013, RegLoss:0.0000, NMDec:0.0098, CosSim:0.019, DotProd:0.020, T:44.1s\n",
      "P1 S [740/5000], Loss:0.0013, RegLoss:0.0000, NMDec:0.0095, CosSim:0.008, DotProd:0.007, T:44.2s\n",
      "P1 S [750/5000], Loss:0.0015, RegLoss:0.0000, NMDec:0.0121, CosSim:0.040, DotProd:0.042, T:44.2s\n",
      "P1 S [760/5000], Loss:0.0012, RegLoss:0.0000, NMDec:0.0123, CosSim:0.032, DotProd:0.033, T:43.8s\n",
      "P1 S [770/5000], Loss:0.0017, RegLoss:0.0000, NMDec:0.0080, CosSim:0.011, DotProd:0.009, T:42.8s\n",
      "P1 S [780/5000], Loss:0.0011, RegLoss:0.0000, NMDec:0.0103, CosSim:0.028, DotProd:0.032, T:42.3s\n",
      "P1 S [790/5000], Loss:0.0012, RegLoss:0.0000, NMDec:0.0086, CosSim:0.014, DotProd:0.014, T:42.3s\n",
      "P1 S [800/5000], Loss:0.0015, RegLoss:0.0000, NMDec:0.0070, CosSim:0.012, DotProd:0.009, T:42.5s\n",
      "P1 S [810/5000], Loss:0.0012, RegLoss:0.0000, NMDec:0.0085, CosSim:0.020, DotProd:0.020, T:42.8s\n",
      "P1 S [820/5000], Loss:0.0015, RegLoss:0.0000, NMDec:0.0070, CosSim:0.019, DotProd:0.015, T:43.1s\n",
      "P1 S [830/5000], Loss:0.0016, RegLoss:0.0000, NMDec:0.0063, CosSim:0.002, DotProd:0.002, T:42.0s\n",
      "P1 S [840/5000], Loss:0.0018, RegLoss:0.0000, NMDec:0.0066, CosSim:0.004, DotProd:0.003, T:44.7s\n",
      "P1 S [850/5000], Loss:0.0013, RegLoss:0.0000, NMDec:0.0080, CosSim:0.023, DotProd:0.018, T:43.0s\n",
      "P1 S [860/5000], Loss:0.0011, RegLoss:0.0000, NMDec:0.0065, CosSim:0.017, DotProd:0.016, T:42.6s\n",
      "P1 S [870/5000], Loss:0.0013, RegLoss:0.0000, NMDec:0.0078, CosSim:0.030, DotProd:0.027, T:43.2s\n",
      "P1 S [880/5000], Loss:0.0014, RegLoss:0.0000, NMDec:0.0061, CosSim:0.015, DotProd:0.011, T:44.0s\n",
      "P1 S [890/5000], Loss:0.0012, RegLoss:0.0000, NMDec:0.0070, CosSim:0.033, DotProd:0.028, T:44.1s\n",
      "P1 S [900/5000], Loss:0.0014, RegLoss:0.0000, NMDec:0.0066, CosSim:0.004, DotProd:0.003, T:44.5s\n",
      "P1 S [910/5000], Loss:0.0012, RegLoss:0.0000, NMDec:0.0071, CosSim:0.036, DotProd:0.026, T:44.4s\n",
      "P1 S [920/5000], Loss:0.0008, RegLoss:0.0000, NMDec:0.0058, CosSim:0.025, DotProd:0.027, T:44.4s\n",
      "P1 S [930/5000], Loss:0.0014, RegLoss:0.0000, NMDec:0.0067, CosSim:0.008, DotProd:0.009, T:43.6s\n",
      "P1 S [940/5000], Loss:0.0015, RegLoss:0.0000, NMDec:0.0060, CosSim:0.024, DotProd:0.018, T:43.3s\n",
      "P1 S [950/5000], Loss:0.0011, RegLoss:0.0000, NMDec:0.0070, CosSim:0.028, DotProd:0.025, T:42.2s\n",
      "P1 S [960/5000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0068, CosSim:-0.006, DotProd:-0.031, T:42.6s\n",
      "P1 S [970/5000], Loss:0.0008, RegLoss:0.0000, NMDec:0.0068, CosSim:0.022, DotProd:0.048, T:42.2s\n",
      "P1 S [980/5000], Loss:0.0010, RegLoss:0.0000, NMDec:0.0078, CosSim:0.037, DotProd:0.027, T:44.5s\n",
      "P1 S [990/5000], Loss:0.0010, RegLoss:0.0000, NMDec:0.0059, CosSim:0.026, DotProd:0.021, T:44.1s\n",
      "P1 S [1000/5000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0056, CosSim:0.010, DotProd:0.010, T:43.4s\n",
      "P1 S [1010/5000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0049, CosSim:0.018, DotProd:0.017, T:43.7s\n",
      "P1 S [1020/5000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0045, CosSim:0.017, DotProd:0.015, T:42.6s\n",
      "P1 S [1030/5000], Loss:0.0008, RegLoss:0.0000, NMDec:0.0066, CosSim:0.037, DotProd:0.121, T:43.2s\n",
      "P1 S [1040/5000], Loss:0.0011, RegLoss:0.0000, NMDec:0.0053, CosSim:0.030, DotProd:0.036, T:43.1s\n",
      "P1 S [1050/5000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0059, CosSim:0.028, DotProd:0.025, T:42.6s\n",
      "P1 S [1060/5000], Loss:0.0010, RegLoss:0.0000, NMDec:0.0047, CosSim:0.023, DotProd:0.039, T:42.8s\n",
      "P1 S [1070/5000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0055, CosSim:0.034, DotProd:0.031, T:42.1s\n",
      "P1 S [1080/5000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0051, CosSim:0.026, DotProd:0.023, T:42.5s\n",
      "P1 S [1090/5000], Loss:0.0010, RegLoss:0.0000, NMDec:0.0053, CosSim:0.018, DotProd:0.046, T:44.5s\n",
      "P1 S [1100/5000], Loss:0.0008, RegLoss:0.0000, NMDec:0.0065, CosSim:0.022, DotProd:0.017, T:42.9s\n",
      "P1 S [1110/5000], Loss:0.0008, RegLoss:0.0000, NMDec:0.0058, CosSim:0.033, DotProd:0.028, T:42.4s\n",
      "P1 S [1120/5000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0037, CosSim:0.015, DotProd:0.018, T:43.4s\n",
      "P1 S [1130/5000], Loss:0.0010, RegLoss:0.0000, NMDec:0.0039, CosSim:0.011, DotProd:0.017, T:44.0s\n",
      "P1 S [1140/5000], Loss:0.0012, RegLoss:0.0000, NMDec:0.0041, CosSim:0.009, DotProd:0.032, T:42.7s\n",
      "P1 S [1150/5000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0050, CosSim:0.027, DotProd:0.025, T:44.7s\n",
      "P1 S [1160/5000], Loss:0.0008, RegLoss:0.0000, NMDec:0.0056, CosSim:0.003, DotProd:0.003, T:44.2s\n",
      "P1 S [1170/5000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0049, CosSim:0.028, DotProd:0.028, T:44.7s\n",
      "P1 S [1180/5000], Loss:0.0008, RegLoss:0.0000, NMDec:0.0037, CosSim:0.027, DotProd:0.036, T:44.2s\n",
      "P1 S [1190/5000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0051, CosSim:0.041, DotProd:0.052, T:43.9s\n",
      "P1 S [1200/5000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0046, CosSim:-0.033, DotProd:-0.024, T:43.2s\n",
      "P1 S [1210/5000], Loss:0.0011, RegLoss:0.0000, NMDec:0.0047, CosSim:0.018, DotProd:0.019, T:43.7s\n",
      "P1 S [1220/5000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0037, CosSim:0.019, DotProd:0.023, T:43.2s\n",
      "P1 S [1230/5000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0038, CosSim:-0.039, DotProd:-0.036, T:43.7s\n",
      "P1 S [1240/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0039, CosSim:-0.006, DotProd:-0.071, T:43.6s\n",
      "P1 S [1250/5000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0040, CosSim:-0.041, DotProd:-0.318, T:42.4s\n",
      "P1 S [1260/5000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0050, CosSim:-0.000, DotProd:-0.000, T:42.8s\n",
      "P1 S [1270/5000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0042, CosSim:0.000, DotProd:0.001, T:42.3s\n",
      "P1 S [1280/5000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0038, CosSim:0.029, DotProd:0.127, T:42.8s\n",
      "P1 S [1290/5000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0031, CosSim:-0.005, DotProd:-0.012, T:42.8s\n",
      "P1 S [1300/5000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0040, CosSim:-0.011, DotProd:-0.012, T:43.2s\n",
      "P1 S [1310/5000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0043, CosSim:0.008, DotProd:0.008, T:42.8s\n",
      "P1 S [1320/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0039, CosSim:-0.037, DotProd:-0.041, T:42.5s\n",
      "P1 S [1330/5000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0029, CosSim:0.010, DotProd:0.019, T:42.1s\n",
      "P1 S [1340/5000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0032, CosSim:-0.003, DotProd:-0.005, T:43.1s\n",
      "P1 S [1350/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0031, CosSim:0.007, DotProd:0.015, T:44.2s\n",
      "P1 S [1360/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0030, CosSim:-0.019, DotProd:-0.019, T:42.6s\n",
      "P1 S [1370/5000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0029, CosSim:0.023, DotProd:1.332, T:43.7s\n",
      "P1 S [1380/5000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0029, CosSim:-0.007, DotProd:-0.008, T:43.1s\n",
      "P1 S [1390/5000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0027, CosSim:0.007, DotProd:0.013, T:42.5s\n",
      "P1 S [1400/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0047, CosSim:-0.037, DotProd:-0.031, T:42.2s\n",
      "P1 S [1410/5000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0035, CosSim:-0.052, DotProd:-0.052, T:42.6s\n",
      "P1 S [1420/5000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0029, CosSim:-0.046, DotProd:-0.070, T:44.4s\n",
      "P1 S [1430/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0029, CosSim:-0.043, DotProd:-0.035, T:44.2s\n",
      "P1 S [1440/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0027, CosSim:-0.024, DotProd:-0.049, T:43.9s\n",
      "P1 S [1450/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0035, CosSim:-0.031, DotProd:-0.041, T:42.6s\n",
      "P1 S [1460/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0028, CosSim:-0.015, DotProd:-0.027, T:42.5s\n",
      "P1 S [1470/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0030, CosSim:-0.017, DotProd:-0.028, T:42.0s\n",
      "P1 S [1480/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0026, CosSim:-0.054, DotProd:-0.061, T:42.4s\n",
      "P1 S [1490/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0030, CosSim:-0.033, DotProd:-0.067, T:42.4s\n",
      "P1 S [1500/5000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0037, CosSim:-0.013, DotProd:-0.039, T:43.0s\n",
      "P1 S [1510/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0031, CosSim:-0.026, DotProd:-0.056, T:44.1s\n",
      "P1 S [1520/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0025, CosSim:-0.039, DotProd:-0.073, T:42.5s\n",
      "P1 S [1530/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0030, CosSim:-0.057, DotProd:-0.056, T:42.4s\n",
      "P1 S [1540/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0025, CosSim:-0.022, DotProd:-0.042, T:43.4s\n",
      "P1 S [1550/5000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0028, CosSim:-0.028, DotProd:-0.032, T:44.4s\n",
      "P1 S [1560/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0022, CosSim:0.023, DotProd:0.185, T:43.5s\n",
      "P1 S [1570/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0028, CosSim:-0.025, DotProd:-0.038, T:42.5s\n",
      "P1 S [1580/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0018, CosSim:-0.053, DotProd:-0.052, T:43.0s\n",
      "P1 S [1590/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0029, CosSim:-0.000, DotProd:-0.001, T:43.6s\n",
      "P1 S [1600/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0023, CosSim:0.021, DotProd:0.057, T:44.5s\n",
      "P1 S [1610/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0017, CosSim:-0.053, DotProd:-0.060, T:44.8s\n",
      "P1 S [1620/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0022, CosSim:0.012, DotProd:0.028, T:44.6s\n",
      "P1 S [1630/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0022, CosSim:-0.060, DotProd:-0.060, T:43.4s\n",
      "P1 S [1640/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0019, CosSim:-0.025, DotProd:-0.038, T:44.3s\n",
      "P1 S [1650/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0023, CosSim:-0.037, DotProd:-0.045, T:44.2s\n",
      "P1 S [1660/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0025, CosSim:-0.005, DotProd:-0.024, T:44.2s\n",
      "P1 S [1670/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0025, CosSim:-0.028, DotProd:-0.027, T:42.9s\n",
      "P1 S [1680/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0020, CosSim:-0.044, DotProd:-0.037, T:42.8s\n",
      "P1 S [1690/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0018, CosSim:-0.017, DotProd:-0.028, T:43.3s\n",
      "P1 S [1700/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0020, CosSim:-0.022, DotProd:-0.028, T:43.2s\n",
      "P1 S [1710/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0018, CosSim:-0.020, DotProd:-0.017, T:43.7s\n",
      "P1 S [1720/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0016, CosSim:0.001, DotProd:0.008, T:44.1s\n",
      "P1 S [1730/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0021, CosSim:-0.023, DotProd:-0.019, T:43.3s\n",
      "P1 S [1740/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0019, CosSim:-0.025, DotProd:-0.033, T:44.7s\n",
      "P1 S [1750/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0021, CosSim:-0.049, DotProd:-0.057, T:44.3s\n",
      "P1 S [1760/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0020, CosSim:-0.039, DotProd:-0.035, T:43.8s\n",
      "P1 S [1770/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0017, CosSim:-0.015, DotProd:-0.017, T:45.0s\n",
      "P1 S [1780/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0017, CosSim:-0.034, DotProd:-0.033, T:45.5s\n",
      "P1 S [1790/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0014, CosSim:-0.040, DotProd:-0.035, T:43.5s\n",
      "P1 S [1800/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0016, CosSim:-0.020, DotProd:-0.030, T:43.1s\n",
      "P1 S [1810/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0013, CosSim:-0.013, DotProd:-0.012, T:43.4s\n",
      "P1 S [1820/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0017, CosSim:-0.034, DotProd:-0.031, T:43.1s\n",
      "P1 S [1830/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0013, CosSim:-0.001, DotProd:-0.001, T:43.4s\n",
      "P1 S [1840/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0017, CosSim:-0.035, DotProd:-0.035, T:42.6s\n",
      "P1 S [1850/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0016, CosSim:-0.030, DotProd:-0.026, T:42.8s\n",
      "P1 S [1860/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0015, CosSim:-0.042, DotProd:-0.038, T:43.7s\n",
      "P1 S [1870/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0014, CosSim:-0.022, DotProd:-0.021, T:43.9s\n",
      "P1 S [1880/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0015, CosSim:-0.012, DotProd:-0.030, T:44.2s\n",
      "P1 S [1890/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0015, CosSim:-0.024, DotProd:-0.019, T:44.2s\n",
      "P1 S [1900/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0011, CosSim:0.001, DotProd:0.009, T:44.0s\n",
      "P1 S [1910/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.007, DotProd:-0.040, T:43.0s\n",
      "P1 S [1920/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.026, DotProd:-0.022, T:43.0s\n",
      "P1 S [1930/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.055, DotProd:-0.051, T:43.2s\n",
      "P1 S [1940/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0014, CosSim:0.018, DotProd:0.016, T:43.2s\n",
      "P1 S [1950/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0013, CosSim:0.011, DotProd:0.019, T:43.0s\n",
      "P1 S [1960/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0014, CosSim:-0.011, DotProd:-0.012, T:43.0s\n",
      "P1 S [1970/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0015, CosSim:0.010, DotProd:0.010, T:43.0s\n",
      "P1 S [1980/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0013, CosSim:0.009, DotProd:0.010, T:43.0s\n",
      "P1 S [1990/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0013, CosSim:-0.026, DotProd:-0.026, T:43.7s\n",
      "P1 S [2000/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0011, CosSim:-0.011, DotProd:-0.009, T:44.0s\n",
      "P1 S [2010/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0011, CosSim:-0.022, DotProd:-0.026, T:46.1s\n",
      "P1 S [2020/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0011, CosSim:0.011, DotProd:0.310, T:47.1s\n",
      "P1 S [2030/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.023, DotProd:-0.036, T:47.6s\n",
      "P1 S [2040/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0008, CosSim:0.016, DotProd:0.031, T:48.3s\n",
      "P1 S [2050/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0012, CosSim:-0.003, DotProd:-0.007, T:44.8s\n",
      "P1 S [2060/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.036, DotProd:-0.044, T:44.2s\n",
      "P1 S [2070/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.016, DotProd:-0.016, T:44.0s\n",
      "P1 S [2080/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.001, DotProd:-0.000, T:44.4s\n",
      "P1 S [2090/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0012, CosSim:-0.008, DotProd:-0.009, T:43.6s\n",
      "P1 S [2100/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.011, DotProd:-0.012, T:43.6s\n",
      "P1 S [2110/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.015, DotProd:-0.017, T:43.6s\n",
      "P1 S [2120/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0011, CosSim:-0.033, DotProd:-0.033, T:45.1s\n",
      "P1 S [2130/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0011, CosSim:-0.011, DotProd:-0.010, T:45.4s\n",
      "P1 S [2140/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0010, CosSim:0.005, DotProd:0.010, T:44.0s\n",
      "P1 S [2150/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.032, DotProd:-0.036, T:44.8s\n",
      "P1 S [2160/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0009, CosSim:0.002, DotProd:0.003, T:44.8s\n",
      "P1 S [2170/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.005, DotProd:-0.005, T:44.5s\n",
      "P1 S [2180/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.010, DotProd:-0.009, T:44.1s\n",
      "P1 S [2190/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0010, CosSim:0.012, DotProd:0.017, T:44.8s\n",
      "P1 S [2200/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.012, DotProd:-0.020, T:44.9s\n",
      "P1 S [2210/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0009, CosSim:0.014, DotProd:0.224, T:44.5s\n",
      "P1 S [2220/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.014, DotProd:-0.015, T:44.7s\n",
      "P1 S [2230/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.005, DotProd:-0.005, T:46.7s\n",
      "P1 S [2240/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.020, DotProd:-0.029, T:44.2s\n",
      "P1 S [2250/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0008, CosSim:0.007, DotProd:0.008, T:42.5s\n",
      "P1 S [2260/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.013, DotProd:-0.021, T:42.8s\n",
      "P1 S [2270/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.011, DotProd:-0.012, T:42.7s\n",
      "P1 S [2280/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.009, DotProd:-0.010, T:44.0s\n",
      "P1 S [2290/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0008, CosSim:0.002, DotProd:0.002, T:44.7s\n",
      "P1 S [2300/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0006, CosSim:0.004, DotProd:0.024, T:45.1s\n",
      "P1 S [2310/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0007, CosSim:0.019, DotProd:0.579, T:45.1s\n",
      "P1 S [2320/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.008, DotProd:-0.015, T:43.7s\n",
      "P1 S [2330/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.022, DotProd:-0.032, T:44.4s\n",
      "P1 S [2340/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0007, CosSim:0.022, DotProd:0.103, T:43.0s\n",
      "P1 S [2350/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0006, CosSim:0.008, DotProd:0.010, T:42.8s\n",
      "P1 S [2360/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.009, DotProd:-0.013, T:43.0s\n",
      "P1 S [2370/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.054, DotProd:-0.173, T:43.0s\n",
      "P1 S [2380/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0007, CosSim:0.020, DotProd:0.025, T:43.1s\n",
      "P1 S [2390/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.024, DotProd:-0.030, T:42.8s\n",
      "P1 S [2400/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.003, DotProd:-0.003, T:42.7s\n",
      "P1 S [2410/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.001, DotProd:-0.000, T:43.0s\n",
      "P1 S [2420/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0006, CosSim:0.044, DotProd:8.402, T:42.9s\n",
      "P1 S [2430/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0006, CosSim:0.013, DotProd:0.014, T:43.5s\n",
      "P1 S [2440/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.003, DotProd:-0.003, T:43.6s\n",
      "P1 S [2450/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.007, DotProd:-0.012, T:43.8s\n",
      "P1 S [2460/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.007, DotProd:-0.013, T:43.5s\n",
      "P1 S [2470/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0005, CosSim:0.004, DotProd:0.007, T:43.8s\n",
      "P1 S [2480/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0005, CosSim:0.009, DotProd:0.032, T:44.1s\n",
      "P1 S [2490/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.015, DotProd:-0.018, T:43.8s\n",
      "P1 S [2500/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0005, CosSim:0.004, DotProd:0.004, T:43.3s\n",
      "P1 S [2510/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.001, DotProd:-0.001, T:45.4s\n",
      "P1 S [2520/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0006, CosSim:0.019, DotProd:0.083, T:43.5s\n",
      "P1 S [2530/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0005, CosSim:0.020, DotProd:0.021, T:42.2s\n",
      "P1 S [2540/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.016, DotProd:-0.020, T:43.0s\n",
      "P1 S [2550/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.041, DotProd:-0.071, T:42.8s\n",
      "P1 S [2560/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.024, DotProd:-0.025, T:43.5s\n",
      "P1 S [2570/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.043, DotProd:-0.266, T:43.3s\n",
      "P1 S [2580/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.014, DotProd:-0.014, T:43.7s\n",
      "P1 S [2590/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.035, DotProd:-0.063, T:45.1s\n",
      "P1 S [2600/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0004, CosSim:0.029, DotProd:0.034, T:45.2s\n",
      "P1 S [2610/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.024, DotProd:-0.020, T:44.0s\n",
      "P1 S [2620/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.027, DotProd:-0.050, T:42.7s\n",
      "P1 S [2630/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0004, CosSim:0.008, DotProd:0.013, T:43.0s\n",
      "P1 S [2640/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.008, DotProd:-0.036, T:42.5s\n",
      "P1 S [2650/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0004, CosSim:0.008, DotProd:0.012, T:44.3s\n",
      "P1 S [2660/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.009, DotProd:-0.009, T:42.5s\n",
      "P1 S [2670/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0004, CosSim:0.008, DotProd:0.008, T:43.0s\n",
      "P1 S [2680/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.007, DotProd:-0.008, T:42.9s\n",
      "P1 S [2690/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0004, CosSim:0.058, DotProd:2.546, T:42.6s\n",
      "P1 S [2700/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.005, DotProd:-0.004, T:42.4s\n",
      "P1 S [2710/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.047, DotProd:-0.467, T:43.2s\n",
      "P1 S [2720/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:0.022, DotProd:0.045, T:43.4s\n",
      "P1 S [2730/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.008, DotProd:-0.007, T:42.3s\n",
      "P1 S [2740/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:0.011, DotProd:0.010, T:42.4s\n",
      "P1 S [2750/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.006, DotProd:-0.008, T:41.9s\n",
      "P1 S [2760/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:0.020, DotProd:0.024, T:44.3s\n",
      "P1 S [2770/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:0.011, DotProd:0.013, T:44.3s\n",
      "P1 S [2780/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:0.007, DotProd:0.008, T:44.9s\n",
      "P1 S [2790/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0004, CosSim:0.033, DotProd:0.032, T:44.7s\n",
      "P1 S [2800/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.046, DotProd:-0.066, T:44.6s\n",
      "P1 S [2810/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.012, DotProd:-0.011, T:44.6s\n",
      "P1 S [2820/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.019, DotProd:-0.021, T:44.0s\n",
      "P1 S [2830/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.009, DotProd:-0.009, T:43.1s\n",
      "P1 S [2840/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.026, DotProd:-0.040, T:44.8s\n",
      "P1 S [2850/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.024, DotProd:-0.106, T:45.5s\n",
      "P1 S [2860/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.024, DotProd:-0.023, T:44.5s\n",
      "P1 S [2870/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.004, DotProd:-0.005, T:42.9s\n",
      "P1 S [2880/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:0.001, DotProd:0.001, T:42.7s\n",
      "P1 S [2890/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:0.008, DotProd:0.008, T:43.4s\n",
      "P1 S [2900/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:0.023, DotProd:0.029, T:44.1s\n",
      "P1 S [2910/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.006, DotProd:-0.007, T:43.1s\n",
      "P1 S [2920/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.018, DotProd:-0.076, T:43.2s\n",
      "P1 S [2930/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.049, DotProd:-0.230, T:44.8s\n",
      "P1 S [2940/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.006, DotProd:-0.005, T:45.0s\n",
      "P1 S [2950/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.017, DotProd:-0.015, T:43.9s\n",
      "P1 S [2960/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.002, DotProd:-0.008, T:44.0s\n",
      "P1 S [2970/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.020, DotProd:-0.696, T:44.4s\n",
      "P1 S [2980/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:0.004, DotProd:0.003, T:43.7s\n",
      "P1 S [2990/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.013, DotProd:-0.012, T:44.8s\n",
      "P1 S [3000/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:0.008, DotProd:0.032, T:44.6s\n",
      "P1 S [3010/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.039, DotProd:-0.111, T:46.4s\n",
      "P1 S [3020/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:0.010, DotProd:0.012, T:45.0s\n",
      "P1 S [3030/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:0.001, DotProd:0.001, T:43.1s\n",
      "P1 S [3040/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.032, DotProd:-0.062, T:44.8s\n",
      "P1 S [3050/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:0.008, DotProd:0.007, T:44.4s\n",
      "P1 S [3060/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:0.014, DotProd:0.013, T:43.7s\n",
      "P1 S [3070/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:0.011, DotProd:0.009, T:43.5s\n",
      "P1 S [3080/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.009, DotProd:-0.012, T:43.3s\n",
      "P1 S [3090/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.016, DotProd:-0.037, T:42.8s\n",
      "P1 S [3100/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.043, DotProd:-0.170, T:42.9s\n",
      "P1 S [3110/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:0.009, DotProd:0.008, T:42.9s\n",
      "P1 S [3120/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.006, T:44.6s\n",
      "P1 S [3130/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:0.025, DotProd:0.030, T:43.5s\n",
      "P1 S [3140/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.032, DotProd:-0.029, T:43.7s\n",
      "P1 S [3150/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:0.052, DotProd:0.169, T:44.3s\n",
      "P1 S [3160/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:0.004, DotProd:0.005, T:44.6s\n",
      "P1 S [3170/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.029, DotProd:-0.055, T:44.2s\n",
      "P1 S [3180/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:0.007, DotProd:0.006, T:44.4s\n",
      "P1 S [3190/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.010, DotProd:-0.012, T:43.8s\n",
      "P1 S [3200/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:0.014, DotProd:0.078, T:44.8s\n",
      "P1 S [3210/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:0.008, DotProd:0.009, T:44.4s\n",
      "P1 S [3220/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:0.024, DotProd:0.127, T:43.7s\n",
      "P1 S [3230/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:0.001, DotProd:0.001, T:42.8s\n",
      "P1 S [3240/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:0.001, DotProd:0.002, T:43.3s\n",
      "P1 S [3250/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:0.016, DotProd:0.017, T:42.8s\n",
      "P1 S [3260/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.020, DotProd:-0.031, T:43.7s\n",
      "P1 S [3270/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.004, DotProd:-0.004, T:44.0s\n",
      "P1 S [3280/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.014, DotProd:0.015, T:43.5s\n",
      "P1 S [3290/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.019, DotProd:-0.035, T:42.8s\n",
      "P1 S [3300/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:0.012, DotProd:0.010, T:42.5s\n",
      "P1 S [3310/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.005, DotProd:-0.010, T:43.2s\n",
      "P1 S [3320/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.007, T:42.6s\n",
      "P1 S [3330/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.010, DotProd:-0.009, T:44.5s\n",
      "P1 S [3340/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.009, DotProd:-0.010, T:45.0s\n",
      "P1 S [3350/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.005, DotProd:-0.005, T:43.3s\n",
      "P1 S [3360/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.006, T:43.2s\n",
      "P1 S [3370/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.005, DotProd:-0.006, T:44.6s\n",
      "P1 S [3380/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.047, DotProd:-0.469, T:43.4s\n",
      "P1 S [3390/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.006, DotProd:-0.055, T:43.3s\n",
      "P1 S [3400/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.041, DotProd:-0.080, T:44.3s\n",
      "P1 S [3410/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.003, DotProd:0.003, T:43.3s\n",
      "P1 S [3420/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.003, DotProd:0.046, T:44.2s\n",
      "P1 S [3430/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:0.049, DotProd:0.368, T:44.5s\n",
      "P1 S [3440/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.023, DotProd:0.022, T:44.5s\n",
      "P1 S [3450/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.014, DotProd:-0.013, T:44.4s\n",
      "P1 S [3460/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.024, DotProd:0.026, T:42.9s\n",
      "P1 S [3470/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.001, DotProd:-0.001, T:43.0s\n",
      "P1 S [3480/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.003, DotProd:0.003, T:43.2s\n",
      "P1 S [3490/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.029, DotProd:-0.054, T:43.7s\n",
      "P1 S [3500/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.028, DotProd:-0.046, T:43.8s\n",
      "P1 S [3510/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.013, DotProd:0.013, T:45.5s\n",
      "P1 S [3520/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.026, DotProd:-0.530, T:43.6s\n",
      "P1 S [3530/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.011, DotProd:-0.011, T:43.7s\n",
      "P1 S [3540/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.009, DotProd:-0.011, T:43.9s\n",
      "P1 S [3550/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.059, DotProd:-0.240, T:44.1s\n",
      "P1 S [3560/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.007, DotProd:0.009, T:43.9s\n",
      "P1 S [3570/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.012, DotProd:0.025, T:44.2s\n",
      "P1 S [3580/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.010, DotProd:-0.010, T:43.9s\n",
      "P1 S [3590/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.008, DotProd:-0.008, T:44.3s\n",
      "P1 S [3600/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.029, DotProd:-0.037, T:42.8s\n",
      "P1 S [3610/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.002, DotProd:0.003, T:43.1s\n",
      "P1 S [3620/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.032, DotProd:-0.038, T:44.1s\n",
      "P1 S [3630/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.029, DotProd:-0.028, T:44.3s\n",
      "P1 S [3640/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.020, DotProd:-0.033, T:44.5s\n",
      "P1 S [3650/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.007, DotProd:0.006, T:43.8s\n",
      "P1 S [3660/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.007, DotProd:0.007, T:43.2s\n",
      "P1 S [3670/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.039, DotProd:-0.051, T:43.4s\n",
      "P1 S [3680/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.026, DotProd:0.480, T:44.3s\n",
      "P1 S [3690/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.033, DotProd:-0.042, T:44.9s\n",
      "P1 S [3700/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.007, DotProd:-0.008, T:44.3s\n",
      "P1 S [3710/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.051, DotProd:-0.086, T:43.7s\n",
      "P1 S [3720/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.003, DotProd:-0.003, T:45.3s\n",
      "P1 S [3730/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.017, DotProd:-0.017, T:43.3s\n",
      "P1 S [3740/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.018, DotProd:-0.020, T:42.1s\n",
      "P1 S [3750/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.013, DotProd:-0.013, T:43.0s\n",
      "P1 S [3760/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.019, DotProd:0.018, T:43.3s\n",
      "P1 S [3770/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.004, DotProd:0.005, T:42.5s\n",
      "P1 S [3780/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.015, DotProd:-0.013, T:43.6s\n",
      "P1 S [3790/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.013, DotProd:-0.013, T:43.7s\n",
      "P1 S [3800/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.010, DotProd:0.010, T:43.3s\n",
      "P1 S [3810/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.006, DotProd:-0.006, T:42.8s\n",
      "P1 S [3820/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.008, DotProd:-0.008, T:42.9s\n",
      "P1 S [3830/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.022, DotProd:-0.022, T:43.3s\n",
      "P1 S [3840/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.014, DotProd:-0.014, T:44.4s\n",
      "P1 S [3850/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.003, DotProd:-0.003, T:44.9s\n",
      "P1 S [3860/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.009, DotProd:-0.009, T:44.7s\n",
      "P1 S [3870/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.004, DotProd:-0.004, T:42.6s\n",
      "P1 S [3880/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0001, CosSim:0.008, DotProd:0.009, T:43.7s\n",
      "P1 S [3890/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.022, DotProd:-0.021, T:42.7s\n",
      "P1 S [3900/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.051, DotProd:-0.074, T:42.7s\n",
      "P1 S [3910/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.036, DotProd:0.138, T:44.1s\n",
      "P1 S [3920/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.001, DotProd:-0.001, T:43.1s\n",
      "P1 S [3930/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.030, DotProd:-0.032, T:43.4s\n",
      "P1 S [3940/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.007, DotProd:0.007, T:43.2s\n",
      "P1 S [3950/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.022, DotProd:-0.051, T:43.0s\n",
      "P1 S [3960/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.022, DotProd:-0.029, T:43.2s\n",
      "P1 S [3970/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.036, DotProd:-0.050, T:44.3s\n",
      "P1 S [3980/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.032, DotProd:-0.032, T:43.1s\n",
      "P1 S [3990/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.028, DotProd:-0.030, T:43.3s\n",
      "P1 S [4000/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.015, DotProd:-0.015, T:42.9s\n",
      "P1 S [4010/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.007, DotProd:-0.013, T:43.9s\n",
      "P1 S [4020/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.011, DotProd:-0.011, T:43.5s\n",
      "P1 S [4030/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.020, DotProd:-0.021, T:42.8s\n",
      "P1 S [4040/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.032, DotProd:0.118, T:41.8s\n",
      "P1 S [4050/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.008, DotProd:0.008, T:42.2s\n",
      "P1 S [4060/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.004, DotProd:-0.004, T:42.2s\n",
      "P1 S [4070/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.005, DotProd:-0.009, T:42.1s\n",
      "P1 S [4080/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.007, DotProd:-0.006, T:42.4s\n",
      "P1 S [4090/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.024, DotProd:-0.023, T:42.5s\n",
      "P1 S [4100/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0001, CosSim:0.009, DotProd:0.009, T:43.2s\n",
      "P1 S [4110/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.000, DotProd:-0.000, T:44.1s\n",
      "P1 S [4120/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.029, DotProd:0.067, T:43.0s\n",
      "P1 S [4130/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.009, DotProd:-0.009, T:42.2s\n",
      "P1 S [4140/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.060, DotProd:-0.123, T:42.2s\n",
      "P1 S [4150/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.010, DotProd:-0.010, T:43.0s\n",
      "P1 S [4160/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.046, DotProd:-0.064, T:43.5s\n",
      "P1 S [4170/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.001, DotProd:0.001, T:42.8s\n",
      "P1 S [4180/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.008, DotProd:-0.007, T:43.6s\n",
      "P1 S [4190/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.039, DotProd:-0.041, T:44.3s\n",
      "P1 S [4200/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.001, DotProd:-0.002, T:44.1s\n",
      "P1 S [4210/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.022, DotProd:-0.024, T:42.1s\n",
      "P1 S [4220/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.004, DotProd:-0.005, T:44.1s\n",
      "P1 S [4230/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.032, DotProd:-0.032, T:45.1s\n",
      "P1 S [4240/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.036, DotProd:0.060, T:43.6s\n",
      "P1 S [4250/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.019, DotProd:-0.020, T:42.5s\n",
      "P1 S [4260/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.008, DotProd:-0.007, T:42.9s\n",
      "P1 S [4270/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.021, DotProd:-0.021, T:42.6s\n",
      "P1 S [4280/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.007, DotProd:-0.006, T:43.1s\n",
      "P1 S [4290/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.005, DotProd:-0.005, T:43.0s\n",
      "P1 S [4300/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.004, DotProd:-0.004, T:43.7s\n",
      "P1 S [4310/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.020, DotProd:-0.021, T:43.7s\n",
      "P1 S [4320/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.025, DotProd:-0.029, T:43.4s\n",
      "P1 S [4330/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.011, DotProd:-0.011, T:43.5s\n",
      "P1 S [4340/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.004, DotProd:-0.004, T:43.0s\n",
      "P1 S [4350/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.034, DotProd:-0.037, T:43.9s\n",
      "P1 S [4360/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:0.003, DotProd:0.002, T:43.0s\n",
      "P1 S [4370/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:0.013, DotProd:0.017, T:41.9s\n",
      "P1 S [4380/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.003, DotProd:-0.003, T:43.4s\n",
      "P1 S [4390/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.005, DotProd:-0.004, T:44.2s\n",
      "P1 S [4400/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.017, DotProd:-0.019, T:43.9s\n",
      "P1 S [4410/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.026, DotProd:-0.025, T:43.7s\n",
      "P1 S [4420/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.026, DotProd:-0.022, T:43.2s\n",
      "P1 S [4430/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.002, DotProd:0.001, T:42.8s\n",
      "P1 S [4440/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:0.003, DotProd:0.003, T:42.7s\n",
      "P1 S [4450/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.019, DotProd:-0.018, T:43.0s\n",
      "P1 S [4460/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:0.005, DotProd:0.004, T:42.5s\n",
      "P1 S [4470/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.006, DotProd:-0.007, T:42.4s\n",
      "P1 S [4480/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.017, DotProd:-0.018, T:42.6s\n",
      "P1 S [4490/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.006, DotProd:-0.006, T:42.5s\n",
      "P1 S [4500/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.018, DotProd:-0.018, T:42.1s\n",
      "P1 S [4510/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.015, DotProd:-0.015, T:42.3s\n",
      "P1 S [4520/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.034, DotProd:-0.430, T:41.3s\n",
      "P1 S [4530/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.046, DotProd:0.760, T:41.0s\n",
      "P1 S [4540/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.005, DotProd:-0.005, T:41.9s\n",
      "P1 S [4550/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.004, DotProd:-0.004, T:41.1s\n",
      "P1 S [4560/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:0.005, DotProd:0.004, T:41.0s\n",
      "P1 S [4570/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.072, DotProd:-0.177, T:41.1s\n",
      "P1 S [4580/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.015, DotProd:-0.014, T:41.3s\n",
      "P1 S [4590/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.016, DotProd:-0.016, T:42.7s\n",
      "P1 S [4600/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.040, DotProd:-0.050, T:41.8s\n",
      "P1 S [4610/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.002, DotProd:-0.002, T:41.1s\n",
      "P1 S [4620/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.011, DotProd:-0.011, T:41.8s\n",
      "P1 S [4630/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.005, DotProd:-0.006, T:41.6s\n",
      "P1 S [4640/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.011, DotProd:-0.011, T:40.8s\n",
      "P1 S [4650/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.002, DotProd:-0.002, T:42.2s\n",
      "P1 S [4660/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.032, DotProd:-0.032, T:41.8s\n",
      "P1 S [4670/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.006, DotProd:-0.006, T:40.8s\n",
      "P1 S [4680/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.024, DotProd:-0.024, T:40.9s\n",
      "P1 S [4690/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.008, DotProd:-0.007, T:42.0s\n",
      "P1 S [4700/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.015, DotProd:-0.016, T:42.1s\n",
      "P1 S [4710/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.004, DotProd:-0.004, T:42.7s\n",
      "P1 S [4720/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.025, DotProd:-0.023, T:41.7s\n",
      "P1 S [4730/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0001, CosSim:0.013, DotProd:0.013, T:41.6s\n",
      "P1 S [4740/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.018, DotProd:-0.018, T:41.3s\n",
      "P1 S [4750/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.034, DotProd:-0.034, T:40.8s\n",
      "P1 S [4760/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.039, DotProd:-0.035, T:40.9s\n",
      "P1 S [4770/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:0.026, DotProd:0.060, T:41.9s\n",
      "P1 S [4780/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.017, DotProd:-0.015, T:42.6s\n",
      "P1 S [4790/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.004, DotProd:-0.004, T:42.5s\n",
      "P1 S [4800/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.014, DotProd:-0.012, T:42.4s\n",
      "P1 S [4810/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:0.009, DotProd:0.009, T:43.6s\n",
      "P1 S [4820/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.047, DotProd:-0.046, T:42.6s\n",
      "P1 S [4830/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.034, DotProd:-0.047, T:42.6s\n",
      "P1 S [4840/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.065, DotProd:-0.213, T:42.6s\n",
      "P1 S [4850/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.012, DotProd:-0.013, T:42.8s\n",
      "P1 S [4860/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.044, DotProd:-0.048, T:41.0s\n",
      "P1 S [4870/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:0.006, DotProd:0.007, T:41.2s\n",
      "P1 S [4880/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.043, DotProd:-0.049, T:41.0s\n",
      "P1 S [4890/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.006, DotProd:-0.007, T:41.5s\n",
      "P1 S [4900/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.023, DotProd:-0.029, T:41.4s\n",
      "P1 S [4910/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:0.005, DotProd:0.005, T:41.5s\n",
      "P1 S [4920/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.040, DotProd:-0.040, T:41.4s\n",
      "P1 S [4930/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.004, DotProd:-0.004, T:42.7s\n",
      "P1 S [4940/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.060, DotProd:-0.062, T:41.9s\n",
      "P1 S [4950/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.027, DotProd:-0.042, T:41.8s\n",
      "P1 S [4960/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.014, DotProd:-0.014, T:41.6s\n",
      "P1 S [4970/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:0.012, DotProd:0.013, T:41.7s\n",
      "P1 S [4980/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.020, DotProd:-0.019, T:41.6s\n",
      "P1 S [4990/5000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.039, DotProd:-0.039, T:41.6s\n",
      "P1 S [5000/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.027, DotProd:-0.025, T:41.7s\n",
      "Phase 1 training complete.\n",
      "\n",
      "Phase 2 LR: 5e-05\n",
      "\n",
      "--- Train Phase 2: Curriculum (1000 steps) ---\n",
      "Settings: SpatialW=True, ModReadout=False, NMDecodeLoss=True\n",
      "Loss calculated from T_settle=50. Total SEQ_LEN=150\n",
      "P2 S [1/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.002, DotProd:-0.002, T:4.2s\n",
      "P2 S [10/1000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.025, DotProd:-0.024, T:38.2s\n",
      "P2 S [20/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.029, DotProd:-0.029, T:42.0s\n",
      "P2 S [30/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.044, DotProd:-0.045, T:42.0s\n",
      "P2 S [40/1000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.007, DotProd:-0.007, T:41.5s\n",
      "P2 S [50/1000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.038, DotProd:-0.068, T:42.4s\n",
      "P2 S [60/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.042, DotProd:-0.093, T:42.4s\n",
      "P2 S [70/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:0.003, DotProd:0.003, T:42.4s\n",
      "P2 S [80/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.024, DotProd:-0.023, T:42.9s\n",
      "P2 S [90/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.026, DotProd:-0.024, T:42.5s\n",
      "P2 S [100/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.023, DotProd:-0.025, T:42.6s\n",
      "P2 S [110/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.033, DotProd:-0.029, T:42.4s\n",
      "P2 S [120/1000], Loss:0.0000, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.017, DotProd:-0.017, T:42.9s\n",
      "P2 S [130/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:0.019, DotProd:0.052, T:42.5s\n",
      "P2 S [140/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.007, DotProd:-0.007, T:42.5s\n",
      "P2 S [150/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.022, DotProd:-0.019, T:42.4s\n",
      "P2 S [160/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.044, DotProd:-0.037, T:42.6s\n",
      "P2 S [170/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.047, DotProd:-0.053, T:42.2s\n",
      "P2 S [180/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.046, DotProd:-0.069, T:42.0s\n",
      "P2 S [190/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.028, DotProd:-0.028, T:40.6s\n",
      "P2 S [200/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.045, DotProd:-0.054, T:42.0s\n",
      "P2 S [210/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.027, DotProd:-0.026, T:43.0s\n",
      "P2 S [220/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.007, DotProd:-0.007, T:43.0s\n",
      "P2 S [230/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.025, DotProd:-0.028, T:42.5s\n",
      "P2 S [240/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.038, DotProd:-0.037, T:42.4s\n",
      "P2 S [250/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.057, DotProd:-0.058, T:43.6s\n",
      "P2 S [260/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.031, DotProd:-0.028, T:43.8s\n",
      "P2 S [270/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.025, DotProd:-0.023, T:42.4s\n",
      "P2 S [280/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.031, DotProd:-0.031, T:42.8s\n",
      "P2 S [290/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.002, DotProd:-0.002, T:42.5s\n",
      "P2 S [300/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.057, DotProd:-0.171, T:41.5s\n",
      "P2 S [310/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.007, DotProd:-0.008, T:42.2s\n",
      "P2 S [320/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.043, DotProd:-0.045, T:41.7s\n",
      "P2 S [330/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.012, DotProd:-0.012, T:41.6s\n",
      "P2 S [340/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.048, DotProd:-0.045, T:41.4s\n",
      "P2 S [350/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.026, DotProd:-0.028, T:42.7s\n",
      "P2 S [360/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.041, DotProd:-0.042, T:41.2s\n",
      "P2 S [370/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.013, DotProd:-0.015, T:40.7s\n",
      "P2 S [380/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.028, DotProd:-0.028, T:40.9s\n",
      "P2 S [390/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.041, DotProd:-0.048, T:40.9s\n",
      "P2 S [400/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.041, DotProd:-0.045, T:40.9s\n",
      "P2 S [410/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.019, DotProd:-0.022, T:41.2s\n",
      "P2 S [420/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.045, DotProd:-0.041, T:42.6s\n",
      "P2 S [430/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.030, DotProd:-0.033, T:41.3s\n",
      "P2 S [440/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.005, DotProd:-0.031, T:41.2s\n",
      "P2 S [450/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.037, DotProd:-0.033, T:41.2s\n",
      "P2 S [460/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.010, DotProd:-0.016, T:40.6s\n",
      "P2 S [470/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.010, DotProd:-0.033, T:40.9s\n",
      "P2 S [480/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.035, DotProd:-0.037, T:41.2s\n",
      "P2 S [490/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.012, DotProd:-0.015, T:41.2s\n",
      "P2 S [500/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.012, DotProd:-0.017, T:41.0s\n",
      "P2 S [510/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0001, CosSim:0.005, DotProd:0.007, T:42.4s\n",
      "P2 S [520/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.021, DotProd:-0.026, T:41.4s\n",
      "P2 S [530/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.020, DotProd:-0.026, T:41.1s\n",
      "P2 S [540/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.038, DotProd:-0.055, T:41.4s\n",
      "P2 S [550/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.013, DotProd:-0.017, T:41.8s\n",
      "P2 S [560/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.051, DotProd:-0.069, T:40.6s\n",
      "P2 S [570/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.050, DotProd:-0.053, T:40.8s\n",
      "P2 S [580/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.027, DotProd:-0.026, T:40.6s\n",
      "P2 S [590/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.044, DotProd:-0.049, T:40.6s\n",
      "P2 S [600/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.042, DotProd:-0.042, T:41.1s\n",
      "P2 S [610/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0000, CosSim:-0.046, DotProd:-0.049, T:41.9s\n",
      "P2 S [620/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.026, DotProd:-0.054, T:42.0s\n",
      "P2 S [630/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.050, DotProd:-0.054, T:41.0s\n",
      "P2 S [640/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.063, DotProd:-0.086, T:41.6s\n",
      "P2 S [650/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.051, DotProd:-0.055, T:41.7s\n",
      "P2 S [660/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.064, DotProd:-0.099, T:42.2s\n",
      "P2 S [670/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.028, DotProd:-0.056, T:42.3s\n",
      "P2 S [680/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0001, CosSim:0.012, DotProd:0.049, T:41.9s\n",
      "P2 S [690/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.054, DotProd:-0.100, T:41.3s\n",
      "P2 S [700/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.044, DotProd:-0.158, T:41.0s\n",
      "P2 S [710/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.066, DotProd:-0.088, T:42.2s\n",
      "P2 S [720/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.041, DotProd:-0.045, T:42.0s\n",
      "P2 S [730/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.031, DotProd:-0.037, T:41.3s\n",
      "P2 S [740/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.049, DotProd:-0.065, T:41.0s\n",
      "P2 S [750/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.037, DotProd:-0.044, T:41.0s\n",
      "P2 S [760/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0001, CosSim:0.050, DotProd:0.182, T:41.3s\n",
      "P2 S [770/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.016, DotProd:-0.024, T:41.6s\n",
      "P2 S [780/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.058, DotProd:-0.157, T:40.8s\n",
      "P2 S [790/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.025, DotProd:-0.035, T:40.9s\n",
      "P2 S [800/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.065, DotProd:-0.094, T:40.9s\n",
      "P2 S [810/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.033, DotProd:-0.037, T:40.9s\n",
      "P2 S [820/1000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0003, CosSim:0.039, DotProd:0.561, T:40.9s\n",
      "P2 S [830/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.040, DotProd:-0.052, T:41.2s\n",
      "P2 S [840/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.027, DotProd:-0.035, T:41.0s\n",
      "P2 S [850/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.031, DotProd:-0.048, T:41.2s\n",
      "P2 S [860/1000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.039, DotProd:-0.053, T:40.7s\n",
      "P2 S [870/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.012, DotProd:-0.017, T:40.7s\n",
      "P2 S [880/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.050, DotProd:-0.067, T:40.8s\n",
      "P2 S [890/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.024, DotProd:-0.035, T:40.9s\n",
      "P2 S [900/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.016, DotProd:-0.029, T:40.9s\n",
      "P2 S [910/1000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.021, DotProd:-0.056, T:40.8s\n",
      "P2 S [920/1000], Loss:0.0008, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.036, DotProd:-0.071, T:40.7s\n",
      "P2 S [930/1000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.059, DotProd:-0.091, T:40.6s\n",
      "P2 S [940/1000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.023, DotProd:-0.040, T:41.1s\n",
      "P2 S [950/1000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.026, DotProd:-0.042, T:41.6s\n",
      "P2 S [960/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.024, DotProd:-0.034, T:41.6s\n",
      "P2 S [970/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.015, DotProd:-0.030, T:40.5s\n",
      "P2 S [980/1000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.039, DotProd:-0.062, T:40.9s\n",
      "P2 S [990/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.048, DotProd:-0.073, T:40.8s\n",
      "P2 S [1000/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0002, CosSim:0.011, DotProd:0.209, T:40.5s\n",
      "Phase 2 training complete.\n",
      "Logs saved to Hopf_experiments_new/sNM4_H128_20250514-073926/logs/sNM4_H128_logs.pkl\n",
      "Model parameters saved to Hopf_experiments_new/sNM4_H128_20250514-073926/models/sNM4_H128_model_state_dict.pth\n",
      "\n",
      "--- Generating Final Plots ---\n",
      "Final plots saved to Hopf_experiments_new/sNM4_H128_20250514-073926/plots\n",
      "Training movie frames saved to Hopf_experiments_new/sNM4_H128_20250514-073926/training_movie_for_sNM4_H128\n",
      "====== Experiment sNM4_H128 Complete ======\n",
      "\n",
      "\n",
      "====== Running Experiment: dNM4_H128 ======\n",
      "Hyperparameters: {'n_in': 3, 'n_out': 1, 'n_rnn': 128, 'N_NM': 4, 'decay': 0.95, 'activation': 'tanh', 'keepW0': True, 'use_bias': False, 'learning_rate': 0.0001, 'seed': 123, 'clip': 1.0, 'grad_value_clip': 0.1, 'l1_h': 0, 'l2_h': 0, 'l1_weight': 0, 'l2_weight': 0, 'l2_nmVelo': 0.0001, 'use_spatial_weights': False, 'spatial_ell': 0.2, 'spatial_scale': 1.0, 'use_modulated_readout': True, 'use_nm_decoder_loss': True, 'nm_decoder_loss_weight': 1.0, 'nm_init_scale': 1.0, 'experiment_name': 'dNM4_H128'}\n",
      "Saving results to: Hopf_experiments_new/dNM4_H128_20250514-144958\n",
      "Using device: cpu\n",
      "\n",
      "Main Model (Model_nm_CombinedFeatures, H=128, NM=4) params: 83360\n",
      "Surrogate Model (Model_RNN, H=128) params: 16896\n",
      "\n",
      "\n",
      "--- Train Phase 1: Stationary (5000 steps) ---\n",
      "Settings: SpatialW=False, ModReadout=True, NMDecodeLoss=True\n",
      "Loss calculated from T_settle=50. Total SEQ_LEN=150\n",
      "P1 S [1/5000], Loss:0.0276, RegLoss:0.0000, NMDec:0.1361, CosSim:-0.014, DotProd:-0.000, T:4.5s\n",
      "P1 S [10/5000], Loss:0.0233, RegLoss:0.0000, NMDec:0.1377, CosSim:-0.015, DotProd:-0.000, T:41.1s\n",
      "P1 S [20/5000], Loss:0.0162, RegLoss:0.0000, NMDec:0.1554, CosSim:-0.011, DotProd:-0.000, T:44.2s\n",
      "P1 S [30/5000], Loss:0.0181, RegLoss:0.0000, NMDec:0.1173, CosSim:0.002, DotProd:0.000, T:43.0s\n",
      "P1 S [40/5000], Loss:0.0166, RegLoss:0.0000, NMDec:0.1268, CosSim:-0.001, DotProd:-0.000, T:42.9s\n",
      "P1 S [50/5000], Loss:0.0216, RegLoss:0.0000, NMDec:0.1042, CosSim:-0.003, DotProd:-0.000, T:43.2s\n",
      "P1 S [60/5000], Loss:0.0293, RegLoss:0.0000, NMDec:0.0801, CosSim:-0.003, DotProd:-0.000, T:42.9s\n",
      "P1 S [70/5000], Loss:0.0202, RegLoss:0.0000, NMDec:0.0922, CosSim:-0.003, DotProd:-0.000, T:43.4s\n",
      "P1 S [80/5000], Loss:0.0204, RegLoss:0.0000, NMDec:0.0820, CosSim:0.005, DotProd:0.000, T:43.3s\n",
      "P1 S [90/5000], Loss:0.0238, RegLoss:0.0000, NMDec:0.0728, CosSim:0.007, DotProd:0.000, T:43.6s\n",
      "P1 S [100/5000], Loss:0.0156, RegLoss:0.0000, NMDec:0.0743, CosSim:0.001, DotProd:0.000, T:42.4s\n",
      "P1 S [110/5000], Loss:0.0189, RegLoss:0.0000, NMDec:0.0633, CosSim:-0.003, DotProd:-0.000, T:42.4s\n",
      "P1 S [120/5000], Loss:0.0145, RegLoss:0.0000, NMDec:0.0570, CosSim:0.004, DotProd:0.000, T:42.2s\n",
      "P1 S [130/5000], Loss:0.0158, RegLoss:0.0000, NMDec:0.0565, CosSim:0.013, DotProd:0.000, T:42.1s\n",
      "P1 S [140/5000], Loss:0.0268, RegLoss:0.0000, NMDec:0.0449, CosSim:0.012, DotProd:0.000, T:42.2s\n",
      "P1 S [150/5000], Loss:0.0228, RegLoss:0.0000, NMDec:0.0409, CosSim:-0.047, DotProd:-0.000, T:42.5s\n",
      "P1 S [160/5000], Loss:0.0166, RegLoss:0.0000, NMDec:0.0440, CosSim:-0.066, DotProd:-0.000, T:43.1s\n",
      "P1 S [170/5000], Loss:0.0261, RegLoss:0.0000, NMDec:0.0364, CosSim:-0.065, DotProd:-0.000, T:42.9s\n",
      "P1 S [180/5000], Loss:0.0258, RegLoss:0.0000, NMDec:0.0355, CosSim:-0.068, DotProd:-0.000, T:43.1s\n",
      "P1 S [190/5000], Loss:0.0181, RegLoss:0.0000, NMDec:0.0331, CosSim:-0.061, DotProd:-0.000, T:43.9s\n",
      "P1 S [200/5000], Loss:0.0177, RegLoss:0.0000, NMDec:0.0269, CosSim:-0.049, DotProd:-0.000, T:43.4s\n",
      "P1 S [210/5000], Loss:0.0274, RegLoss:0.0000, NMDec:0.0247, CosSim:-0.052, DotProd:-0.000, T:43.2s\n",
      "P1 S [220/5000], Loss:0.0259, RegLoss:0.0000, NMDec:0.0306, CosSim:-0.048, DotProd:-0.000, T:43.4s\n",
      "P1 S [230/5000], Loss:0.0186, RegLoss:0.0000, NMDec:0.0301, CosSim:-0.041, DotProd:-0.000, T:44.1s\n",
      "P1 S [240/5000], Loss:0.0169, RegLoss:0.0000, NMDec:0.0310, CosSim:-0.039, DotProd:-0.000, T:42.9s\n",
      "P1 S [250/5000], Loss:0.0205, RegLoss:0.0000, NMDec:0.0295, CosSim:-0.034, DotProd:-0.000, T:42.2s\n",
      "P1 S [260/5000], Loss:0.0200, RegLoss:0.0000, NMDec:0.0223, CosSim:-0.030, DotProd:-0.000, T:42.8s\n",
      "P1 S [270/5000], Loss:0.0208, RegLoss:0.0000, NMDec:0.0213, CosSim:-0.027, DotProd:-0.000, T:44.0s\n",
      "P1 S [280/5000], Loss:0.0201, RegLoss:0.0000, NMDec:0.0225, CosSim:-0.025, DotProd:-0.000, T:43.9s\n",
      "P1 S [290/5000], Loss:0.0243, RegLoss:0.0000, NMDec:0.0195, CosSim:-0.024, DotProd:-0.000, T:44.1s\n",
      "P1 S [300/5000], Loss:0.0204, RegLoss:0.0000, NMDec:0.0180, CosSim:-0.020, DotProd:-0.000, T:43.9s\n",
      "P1 S [310/5000], Loss:0.0127, RegLoss:0.0000, NMDec:0.0186, CosSim:-0.014, DotProd:-0.000, T:44.1s\n",
      "P1 S [320/5000], Loss:0.0168, RegLoss:0.0000, NMDec:0.0196, CosSim:-0.013, DotProd:-0.000, T:44.0s\n",
      "P1 S [330/5000], Loss:0.0216, RegLoss:0.0000, NMDec:0.0190, CosSim:-0.014, DotProd:-0.000, T:43.9s\n",
      "P1 S [340/5000], Loss:0.0201, RegLoss:0.0000, NMDec:0.0200, CosSim:-0.013, DotProd:-0.000, T:43.9s\n",
      "P1 S [350/5000], Loss:0.0168, RegLoss:0.0000, NMDec:0.0172, CosSim:-0.011, DotProd:-0.000, T:42.7s\n",
      "P1 S [360/5000], Loss:0.0177, RegLoss:0.0000, NMDec:0.0168, CosSim:-0.012, DotProd:-0.000, T:42.2s\n",
      "P1 S [370/5000], Loss:0.0194, RegLoss:0.0000, NMDec:0.0151, CosSim:-0.009, DotProd:-0.000, T:43.2s\n",
      "P1 S [380/5000], Loss:0.0225, RegLoss:0.0000, NMDec:0.0134, CosSim:-0.006, DotProd:-0.000, T:43.9s\n",
      "P1 S [390/5000], Loss:0.0170, RegLoss:0.0000, NMDec:0.0139, CosSim:-0.006, DotProd:-0.000, T:43.6s\n",
      "P1 S [400/5000], Loss:0.0196, RegLoss:0.0000, NMDec:0.0131, CosSim:-0.006, DotProd:-0.000, T:43.6s\n",
      "P1 S [410/5000], Loss:0.0178, RegLoss:0.0000, NMDec:0.0140, CosSim:-0.007, DotProd:-0.000, T:42.8s\n",
      "P1 S [420/5000], Loss:0.0128, RegLoss:0.0000, NMDec:0.0115, CosSim:-0.006, DotProd:-0.000, T:42.5s\n",
      "P1 S [430/5000], Loss:0.0226, RegLoss:0.0000, NMDec:0.0130, CosSim:-0.010, DotProd:-0.000, T:42.8s\n",
      "P1 S [440/5000], Loss:0.0196, RegLoss:0.0000, NMDec:0.0116, CosSim:-0.008, DotProd:-0.000, T:42.7s\n",
      "P1 S [450/5000], Loss:0.0224, RegLoss:0.0000, NMDec:0.0094, CosSim:-0.011, DotProd:-0.000, T:42.5s\n",
      "P1 S [460/5000], Loss:0.0156, RegLoss:0.0000, NMDec:0.0076, CosSim:-0.010, DotProd:-0.000, T:43.4s\n",
      "P1 S [470/5000], Loss:0.0211, RegLoss:0.0000, NMDec:0.0096, CosSim:-0.013, DotProd:-0.000, T:43.7s\n",
      "P1 S [480/5000], Loss:0.0169, RegLoss:0.0000, NMDec:0.0088, CosSim:-0.009, DotProd:-0.000, T:42.7s\n",
      "P1 S [490/5000], Loss:0.0133, RegLoss:0.0000, NMDec:0.0117, CosSim:-0.002, DotProd:-0.000, T:42.5s\n",
      "P1 S [500/5000], Loss:0.0199, RegLoss:0.0000, NMDec:0.0100, CosSim:-0.012, DotProd:-0.000, T:42.4s\n",
      "P1 S [510/5000], Loss:0.0162, RegLoss:0.0000, NMDec:0.0127, CosSim:-0.003, DotProd:-0.000, T:43.7s\n",
      "P1 S [520/5000], Loss:0.0117, RegLoss:0.0000, NMDec:0.0096, CosSim:-0.004, DotProd:-0.000, T:42.5s\n",
      "P1 S [530/5000], Loss:0.0151, RegLoss:0.0000, NMDec:0.0070, CosSim:-0.007, DotProd:-0.000, T:42.4s\n",
      "P1 S [540/5000], Loss:0.0164, RegLoss:0.0000, NMDec:0.0095, CosSim:-0.003, DotProd:-0.000, T:42.6s\n",
      "P1 S [550/5000], Loss:0.0121, RegLoss:0.0000, NMDec:0.0114, CosSim:0.004, DotProd:0.000, T:42.2s\n",
      "P1 S [560/5000], Loss:0.0139, RegLoss:0.0000, NMDec:0.0072, CosSim:-0.003, DotProd:-0.000, T:42.7s\n",
      "P1 S [570/5000], Loss:0.0117, RegLoss:0.0000, NMDec:0.0099, CosSim:0.002, DotProd:-0.000, T:42.1s\n",
      "P1 S [580/5000], Loss:0.0152, RegLoss:0.0000, NMDec:0.0073, CosSim:-0.001, DotProd:-0.000, T:42.1s\n",
      "P1 S [590/5000], Loss:0.0077, RegLoss:0.0000, NMDec:0.0087, CosSim:0.000, DotProd:-0.000, T:42.1s\n",
      "P1 S [600/5000], Loss:0.0082, RegLoss:0.0000, NMDec:0.0098, CosSim:-0.010, DotProd:-0.000, T:42.1s\n",
      "P1 S [610/5000], Loss:0.0123, RegLoss:0.0000, NMDec:0.0078, CosSim:0.001, DotProd:-0.000, T:42.0s\n",
      "P1 S [620/5000], Loss:0.0105, RegLoss:0.0000, NMDec:0.0069, CosSim:0.003, DotProd:-0.000, T:42.3s\n",
      "P1 S [630/5000], Loss:0.0112, RegLoss:0.0000, NMDec:0.0055, CosSim:-0.007, DotProd:-0.000, T:42.4s\n",
      "P1 S [640/5000], Loss:0.0089, RegLoss:0.0000, NMDec:0.0081, CosSim:-0.011, DotProd:-0.000, T:42.3s\n",
      "P1 S [650/5000], Loss:0.0092, RegLoss:0.0000, NMDec:0.0084, CosSim:-0.002, DotProd:-0.000, T:42.8s\n",
      "P1 S [660/5000], Loss:0.0078, RegLoss:0.0000, NMDec:0.0113, CosSim:-0.017, DotProd:-0.000, T:43.2s\n",
      "P1 S [670/5000], Loss:0.0114, RegLoss:0.0000, NMDec:0.0076, CosSim:0.000, DotProd:-0.000, T:43.0s\n",
      "P1 S [680/5000], Loss:0.0115, RegLoss:0.0000, NMDec:0.0081, CosSim:-0.007, DotProd:-0.000, T:42.9s\n",
      "P1 S [690/5000], Loss:0.0096, RegLoss:0.0000, NMDec:0.0072, CosSim:0.004, DotProd:-0.000, T:42.8s\n",
      "P1 S [700/5000], Loss:0.0091, RegLoss:0.0000, NMDec:0.0054, CosSim:0.004, DotProd:-0.000, T:42.8s\n",
      "P1 S [710/5000], Loss:0.0051, RegLoss:0.0000, NMDec:0.0087, CosSim:-0.023, DotProd:-0.001, T:42.7s\n",
      "P1 S [720/5000], Loss:0.0087, RegLoss:0.0000, NMDec:0.0069, CosSim:-0.003, DotProd:-0.000, T:42.6s\n",
      "P1 S [730/5000], Loss:0.0111, RegLoss:0.0000, NMDec:0.0056, CosSim:0.002, DotProd:-0.000, T:42.5s\n",
      "P1 S [740/5000], Loss:0.0067, RegLoss:0.0000, NMDec:0.0076, CosSim:-0.004, DotProd:-0.000, T:43.8s\n",
      "P1 S [750/5000], Loss:0.0065, RegLoss:0.0000, NMDec:0.0069, CosSim:0.007, DotProd:-0.000, T:44.2s\n",
      "P1 S [760/5000], Loss:0.0082, RegLoss:0.0000, NMDec:0.0065, CosSim:-0.001, DotProd:-0.000, T:44.1s\n",
      "P1 S [770/5000], Loss:0.0055, RegLoss:0.0000, NMDec:0.0064, CosSim:-0.005, DotProd:-0.000, T:44.5s\n",
      "P1 S [780/5000], Loss:0.0065, RegLoss:0.0000, NMDec:0.0051, CosSim:-0.006, DotProd:-0.000, T:44.3s\n",
      "P1 S [790/5000], Loss:0.0067, RegLoss:0.0000, NMDec:0.0065, CosSim:-0.008, DotProd:-0.000, T:43.9s\n",
      "P1 S [800/5000], Loss:0.0066, RegLoss:0.0000, NMDec:0.0084, CosSim:-0.025, DotProd:-0.000, T:42.9s\n",
      "P1 S [810/5000], Loss:0.0088, RegLoss:0.0000, NMDec:0.0040, CosSim:-0.003, DotProd:-0.000, T:44.1s\n",
      "P1 S [820/5000], Loss:0.0058, RegLoss:0.0000, NMDec:0.0056, CosSim:-0.017, DotProd:-0.000, T:42.3s\n",
      "P1 S [830/5000], Loss:0.0042, RegLoss:0.0000, NMDec:0.0050, CosSim:-0.006, DotProd:-0.000, T:42.2s\n",
      "P1 S [840/5000], Loss:0.0040, RegLoss:0.0000, NMDec:0.0043, CosSim:-0.022, DotProd:-0.000, T:42.2s\n",
      "P1 S [850/5000], Loss:0.0033, RegLoss:0.0000, NMDec:0.0051, CosSim:-0.009, DotProd:-0.000, T:42.0s\n",
      "P1 S [860/5000], Loss:0.0042, RegLoss:0.0000, NMDec:0.0061, CosSim:-0.019, DotProd:-0.000, T:42.1s\n",
      "P1 S [870/5000], Loss:0.0043, RegLoss:0.0000, NMDec:0.0065, CosSim:-0.013, DotProd:-0.000, T:43.7s\n",
      "P1 S [880/5000], Loss:0.0039, RegLoss:0.0000, NMDec:0.0047, CosSim:-0.005, DotProd:-0.000, T:44.0s\n",
      "P1 S [890/5000], Loss:0.0039, RegLoss:0.0000, NMDec:0.0047, CosSim:-0.008, DotProd:-0.000, T:44.1s\n",
      "P1 S [900/5000], Loss:0.0036, RegLoss:0.0000, NMDec:0.0057, CosSim:-0.006, DotProd:-0.000, T:43.6s\n",
      "P1 S [910/5000], Loss:0.0023, RegLoss:0.0000, NMDec:0.0053, CosSim:-0.010, DotProd:0.000, T:42.9s\n",
      "P1 S [920/5000], Loss:0.0032, RegLoss:0.0000, NMDec:0.0036, CosSim:-0.006, DotProd:0.000, T:42.9s\n",
      "P1 S [930/5000], Loss:0.0050, RegLoss:0.0000, NMDec:0.0038, CosSim:0.001, DotProd:0.000, T:43.7s\n",
      "P1 S [940/5000], Loss:0.0029, RegLoss:0.0000, NMDec:0.0036, CosSim:-0.010, DotProd:0.000, T:44.2s\n",
      "P1 S [950/5000], Loss:0.0031, RegLoss:0.0000, NMDec:0.0049, CosSim:-0.004, DotProd:-0.000, T:44.1s\n",
      "P1 S [960/5000], Loss:0.0028, RegLoss:0.0000, NMDec:0.0051, CosSim:-0.005, DotProd:0.000, T:43.9s\n",
      "P1 S [970/5000], Loss:0.0029, RegLoss:0.0000, NMDec:0.0051, CosSim:-0.006, DotProd:0.000, T:42.9s\n",
      "P1 S [980/5000], Loss:0.0035, RegLoss:0.0000, NMDec:0.0037, CosSim:-0.003, DotProd:0.000, T:43.9s\n",
      "P1 S [990/5000], Loss:0.0021, RegLoss:0.0000, NMDec:0.0026, CosSim:-0.012, DotProd:0.000, T:44.0s\n",
      "P1 S [1000/5000], Loss:0.0019, RegLoss:0.0000, NMDec:0.0048, CosSim:-0.011, DotProd:0.000, T:43.1s\n",
      "P1 S [1010/5000], Loss:0.0021, RegLoss:0.0000, NMDec:0.0054, CosSim:-0.014, DotProd:0.000, T:44.4s\n",
      "P1 S [1020/5000], Loss:0.0025, RegLoss:0.0000, NMDec:0.0048, CosSim:-0.008, DotProd:0.001, T:43.8s\n",
      "P1 S [1030/5000], Loss:0.0024, RegLoss:0.0000, NMDec:0.0036, CosSim:-0.003, DotProd:0.000, T:43.1s\n",
      "P1 S [1040/5000], Loss:0.0018, RegLoss:0.0000, NMDec:0.0040, CosSim:-0.006, DotProd:0.000, T:42.6s\n",
      "P1 S [1050/5000], Loss:0.0015, RegLoss:0.0000, NMDec:0.0045, CosSim:-0.016, DotProd:0.000, T:43.7s\n",
      "P1 S [1060/5000], Loss:0.0015, RegLoss:0.0000, NMDec:0.0040, CosSim:-0.013, DotProd:0.000, T:42.9s\n",
      "P1 S [1070/5000], Loss:0.0016, RegLoss:0.0000, NMDec:0.0034, CosSim:-0.003, DotProd:0.000, T:43.2s\n",
      "P1 S [1080/5000], Loss:0.0016, RegLoss:0.0000, NMDec:0.0032, CosSim:-0.013, DotProd:0.001, T:42.9s\n",
      "P1 S [1090/5000], Loss:0.0024, RegLoss:0.0000, NMDec:0.0047, CosSim:-0.008, DotProd:0.000, T:42.5s\n",
      "P1 S [1100/5000], Loss:0.0017, RegLoss:0.0000, NMDec:0.0045, CosSim:-0.012, DotProd:0.000, T:42.5s\n",
      "P1 S [1110/5000], Loss:0.0016, RegLoss:0.0000, NMDec:0.0043, CosSim:-0.016, DotProd:0.000, T:42.5s\n",
      "P1 S [1120/5000], Loss:0.0015, RegLoss:0.0000, NMDec:0.0041, CosSim:-0.014, DotProd:0.000, T:42.4s\n",
      "P1 S [1130/5000], Loss:0.0012, RegLoss:0.0000, NMDec:0.0058, CosSim:-0.012, DotProd:0.000, T:42.0s\n",
      "P1 S [1140/5000], Loss:0.0012, RegLoss:0.0000, NMDec:0.0034, CosSim:-0.011, DotProd:0.000, T:43.1s\n",
      "P1 S [1150/5000], Loss:0.0011, RegLoss:0.0000, NMDec:0.0040, CosSim:-0.006, DotProd:0.000, T:45.3s\n",
      "P1 S [1160/5000], Loss:0.0012, RegLoss:0.0000, NMDec:0.0034, CosSim:-0.011, DotProd:0.000, T:44.3s\n",
      "P1 S [1170/5000], Loss:0.0014, RegLoss:0.0000, NMDec:0.0043, CosSim:-0.000, DotProd:0.000, T:43.8s\n",
      "P1 S [1180/5000], Loss:0.0013, RegLoss:0.0000, NMDec:0.0036, CosSim:-0.005, DotProd:0.000, T:44.0s\n",
      "P1 S [1190/5000], Loss:0.0014, RegLoss:0.0000, NMDec:0.0037, CosSim:-0.010, DotProd:0.000, T:44.3s\n",
      "P1 S [1200/5000], Loss:0.0010, RegLoss:0.0000, NMDec:0.0027, CosSim:-0.010, DotProd:-0.000, T:43.6s\n",
      "P1 S [1210/5000], Loss:0.0011, RegLoss:0.0000, NMDec:0.0036, CosSim:-0.007, DotProd:-0.000, T:42.3s\n",
      "P1 S [1220/5000], Loss:0.0010, RegLoss:0.0000, NMDec:0.0040, CosSim:-0.007, DotProd:-0.000, T:42.4s\n",
      "P1 S [1230/5000], Loss:0.0013, RegLoss:0.0000, NMDec:0.0039, CosSim:-0.003, DotProd:-0.000, T:43.9s\n",
      "P1 S [1240/5000], Loss:0.0011, RegLoss:0.0000, NMDec:0.0033, CosSim:-0.002, DotProd:-0.001, T:44.5s\n",
      "P1 S [1250/5000], Loss:0.0016, RegLoss:0.0000, NMDec:0.0038, CosSim:0.006, DotProd:-0.001, T:44.0s\n",
      "P1 S [1260/5000], Loss:0.0015, RegLoss:0.0000, NMDec:0.0030, CosSim:-0.000, DotProd:-0.001, T:43.8s\n",
      "P1 S [1270/5000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0028, CosSim:-0.007, DotProd:-0.001, T:43.1s\n",
      "P1 S [1280/5000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0031, CosSim:-0.020, DotProd:-0.001, T:42.4s\n",
      "P1 S [1290/5000], Loss:0.0010, RegLoss:0.0000, NMDec:0.0032, CosSim:-0.016, DotProd:-0.002, T:42.8s\n",
      "P1 S [1300/5000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0026, CosSim:-0.006, DotProd:-0.002, T:43.2s\n",
      "P1 S [1310/5000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0034, CosSim:-0.008, DotProd:-0.002, T:43.3s\n",
      "P1 S [1320/5000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0026, CosSim:-0.011, DotProd:-0.002, T:43.3s\n",
      "P1 S [1330/5000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0032, CosSim:-0.010, DotProd:-0.002, T:42.9s\n",
      "P1 S [1340/5000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0026, CosSim:-0.011, DotProd:-0.002, T:42.3s\n",
      "P1 S [1350/5000], Loss:0.0010, RegLoss:0.0000, NMDec:0.0025, CosSim:-0.006, DotProd:-0.003, T:42.3s\n",
      "P1 S [1360/5000], Loss:0.0011, RegLoss:0.0000, NMDec:0.0017, CosSim:0.003, DotProd:-0.002, T:43.6s\n",
      "P1 S [1370/5000], Loss:0.0008, RegLoss:0.0000, NMDec:0.0032, CosSim:-0.011, DotProd:-0.002, T:42.5s\n",
      "P1 S [1380/5000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0035, CosSim:-0.006, DotProd:-0.002, T:43.8s\n",
      "P1 S [1390/5000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0028, CosSim:-0.008, DotProd:-0.002, T:43.8s\n",
      "P1 S [1400/5000], Loss:0.0011, RegLoss:0.0000, NMDec:0.0032, CosSim:-0.008, DotProd:-0.002, T:43.7s\n",
      "P1 S [1410/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0024, CosSim:-0.007, DotProd:-0.002, T:43.4s\n",
      "P1 S [1420/5000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0026, CosSim:-0.010, DotProd:-0.003, T:43.0s\n",
      "P1 S [1430/5000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0026, CosSim:-0.008, DotProd:-0.003, T:43.7s\n",
      "P1 S [1440/5000], Loss:0.0010, RegLoss:0.0000, NMDec:0.0021, CosSim:-0.004, DotProd:-0.002, T:43.2s\n",
      "P1 S [1450/5000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0018, CosSim:-0.008, DotProd:-0.003, T:42.4s\n",
      "P1 S [1460/5000], Loss:0.0008, RegLoss:0.0000, NMDec:0.0023, CosSim:-0.003, DotProd:-0.001, T:42.7s\n",
      "P1 S [1470/5000], Loss:0.0008, RegLoss:0.0000, NMDec:0.0026, CosSim:-0.010, DotProd:-0.002, T:43.0s\n",
      "P1 S [1480/5000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0020, CosSim:-0.003, DotProd:-0.002, T:42.7s\n",
      "P1 S [1490/5000], Loss:0.0008, RegLoss:0.0000, NMDec:0.0022, CosSim:-0.007, DotProd:-0.002, T:42.7s\n",
      "P1 S [1500/5000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0019, CosSim:-0.008, DotProd:-0.003, T:43.2s\n",
      "P1 S [1510/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0024, CosSim:-0.006, DotProd:-0.002, T:45.7s\n",
      "P1 S [1520/5000], Loss:0.0008, RegLoss:0.0000, NMDec:0.0020, CosSim:-0.010, DotProd:-0.003, T:44.2s\n",
      "P1 S [1530/5000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0025, CosSim:-0.009, DotProd:-0.002, T:44.0s\n",
      "P1 S [1540/5000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0022, CosSim:-0.004, DotProd:-0.001, T:44.0s\n",
      "P1 S [1550/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0025, CosSim:-0.013, DotProd:-0.002, T:44.3s\n",
      "P1 S [1560/5000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0022, CosSim:-0.009, DotProd:-0.002, T:44.3s\n",
      "P1 S [1570/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0017, CosSim:-0.019, DotProd:-0.003, T:44.0s\n",
      "P1 S [1580/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0016, CosSim:-0.012, DotProd:-0.002, T:44.4s\n",
      "P1 S [1590/5000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0020, CosSim:-0.006, DotProd:-0.002, T:44.1s\n",
      "P1 S [1600/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0014, CosSim:-0.010, DotProd:-0.003, T:44.2s\n",
      "P1 S [1610/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0017, CosSim:-0.012, DotProd:-0.002, T:44.2s\n",
      "P1 S [1620/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0020, CosSim:-0.009, DotProd:-0.002, T:42.8s\n",
      "P1 S [1630/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0022, CosSim:-0.007, DotProd:-0.002, T:42.3s\n",
      "P1 S [1640/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0021, CosSim:-0.012, DotProd:-0.002, T:42.3s\n",
      "P1 S [1650/5000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0018, CosSim:-0.009, DotProd:-0.002, T:42.2s\n",
      "P1 S [1660/5000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0016, CosSim:-0.012, DotProd:-0.002, T:42.4s\n",
      "P1 S [1670/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0012, CosSim:-0.008, DotProd:-0.002, T:42.3s\n",
      "P1 S [1680/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0014, CosSim:-0.011, DotProd:-0.002, T:42.6s\n",
      "P1 S [1690/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0015, CosSim:-0.008, DotProd:-0.002, T:43.2s\n",
      "P1 S [1700/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0025, CosSim:-0.009, DotProd:-0.001, T:43.0s\n",
      "P1 S [1710/5000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0021, CosSim:-0.011, DotProd:-0.002, T:43.0s\n",
      "P1 S [1720/5000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0017, CosSim:-0.007, DotProd:-0.002, T:43.2s\n",
      "P1 S [1730/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0015, CosSim:-0.007, DotProd:-0.002, T:43.1s\n",
      "P1 S [1740/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0018, CosSim:-0.012, DotProd:-0.002, T:42.7s\n",
      "P1 S [1750/5000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0012, CosSim:-0.006, DotProd:-0.002, T:42.1s\n",
      "P1 S [1760/5000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0014, CosSim:-0.010, DotProd:-0.002, T:42.2s\n",
      "P1 S [1770/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.014, DotProd:-0.002, T:43.8s\n",
      "P1 S [1780/5000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0013, CosSim:-0.007, DotProd:-0.002, T:44.0s\n",
      "P1 S [1790/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0012, CosSim:-0.006, DotProd:-0.002, T:42.9s\n",
      "P1 S [1800/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0015, CosSim:-0.011, DotProd:-0.001, T:44.2s\n",
      "P1 S [1810/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0015, CosSim:-0.008, DotProd:-0.002, T:43.9s\n",
      "P1 S [1820/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0017, CosSim:-0.011, DotProd:-0.002, T:43.9s\n",
      "P1 S [1830/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0011, CosSim:-0.009, DotProd:-0.002, T:44.7s\n",
      "P1 S [1840/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0012, CosSim:-0.007, DotProd:-0.001, T:43.9s\n",
      "P1 S [1850/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.008, DotProd:-0.002, T:44.1s\n",
      "P1 S [1860/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0011, CosSim:-0.012, DotProd:-0.002, T:44.0s\n",
      "P1 S [1870/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0015, CosSim:-0.010, DotProd:-0.002, T:44.1s\n",
      "P1 S [1880/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0017, CosSim:-0.014, DotProd:-0.002, T:43.5s\n",
      "P1 S [1890/5000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0011, CosSim:-0.009, DotProd:-0.002, T:43.0s\n",
      "P1 S [1900/5000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0020, CosSim:-0.010, DotProd:-0.002, T:43.0s\n",
      "P1 S [1910/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.008, DotProd:-0.002, T:43.6s\n",
      "P1 S [1920/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.008, DotProd:-0.002, T:43.8s\n",
      "P1 S [1930/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0012, CosSim:-0.009, DotProd:-0.001, T:43.4s\n",
      "P1 S [1940/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.007, DotProd:-0.001, T:42.5s\n",
      "P1 S [1950/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0011, CosSim:-0.009, DotProd:-0.001, T:42.6s\n",
      "P1 S [1960/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0011, CosSim:-0.014, DotProd:-0.002, T:43.5s\n",
      "P1 S [1970/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0013, CosSim:-0.010, DotProd:-0.002, T:43.5s\n",
      "P1 S [1980/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.013, DotProd:-0.002, T:43.4s\n",
      "P1 S [1990/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0014, CosSim:-0.012, DotProd:-0.001, T:43.3s\n",
      "P1 S [2000/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0013, CosSim:-0.016, DotProd:-0.001, T:43.7s\n",
      "P1 S [2010/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.007, DotProd:-0.001, T:44.6s\n",
      "P1 S [2020/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0011, CosSim:-0.012, DotProd:-0.001, T:44.3s\n",
      "P1 S [2030/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0011, CosSim:-0.014, DotProd:-0.002, T:47.1s\n",
      "P1 S [2040/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.005, DotProd:-0.001, T:43.2s\n",
      "P1 S [2050/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.007, DotProd:-0.001, T:43.9s\n",
      "P1 S [2060/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.007, DotProd:-0.001, T:43.1s\n",
      "P1 S [2070/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0013, CosSim:-0.012, DotProd:-0.002, T:44.5s\n",
      "P1 S [2080/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.010, DotProd:-0.002, T:45.2s\n",
      "P1 S [2090/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0014, CosSim:-0.006, DotProd:-0.001, T:47.2s\n",
      "P1 S [2100/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0011, CosSim:-0.009, DotProd:-0.001, T:45.5s\n",
      "P1 S [2110/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.013, DotProd:-0.001, T:50.0s\n",
      "P1 S [2120/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0011, CosSim:-0.009, DotProd:-0.001, T:45.3s\n",
      "P1 S [2130/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.012, DotProd:-0.001, T:45.5s\n",
      "P1 S [2140/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.013, DotProd:-0.001, T:48.1s\n",
      "P1 S [2150/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.008, DotProd:-0.001, T:47.7s\n",
      "P1 S [2160/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0011, CosSim:-0.011, DotProd:-0.001, T:44.3s\n",
      "P1 S [2170/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.009, DotProd:-0.001, T:43.9s\n",
      "P1 S [2180/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.008, DotProd:-0.001, T:47.4s\n",
      "P1 S [2190/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.009, DotProd:-0.001, T:44.8s\n",
      "P1 S [2200/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.006, DotProd:-0.001, T:45.1s\n",
      "P1 S [2210/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.007, DotProd:-0.002, T:42.5s\n",
      "P1 S [2220/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.008, DotProd:-0.001, T:42.6s\n",
      "P1 S [2230/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0011, CosSim:-0.009, DotProd:-0.002, T:43.1s\n",
      "P1 S [2240/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.010, DotProd:-0.001, T:44.1s\n",
      "P1 S [2250/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0011, CosSim:-0.008, DotProd:-0.001, T:43.7s\n",
      "P1 S [2260/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.009, DotProd:-0.001, T:43.0s\n",
      "P1 S [2270/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.010, DotProd:-0.001, T:45.4s\n",
      "P1 S [2280/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.017, DotProd:-0.001, T:48.9s\n",
      "P1 S [2290/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.008, DotProd:-0.001, T:50.6s\n",
      "P1 S [2300/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.013, DotProd:-0.001, T:44.9s\n",
      "P1 S [2310/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.008, DotProd:-0.001, T:44.1s\n",
      "P1 S [2320/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0011, CosSim:-0.005, DotProd:-0.001, T:42.7s\n",
      "P1 S [2330/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.010, DotProd:-0.001, T:44.0s\n",
      "P1 S [2340/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.011, DotProd:-0.001, T:43.9s\n",
      "P1 S [2350/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.009, DotProd:-0.001, T:44.4s\n",
      "P1 S [2360/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.011, DotProd:-0.002, T:44.5s\n",
      "P1 S [2370/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.013, DotProd:-0.002, T:44.4s\n",
      "P1 S [2380/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.009, DotProd:-0.001, T:44.5s\n",
      "P1 S [2390/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.008, DotProd:-0.001, T:43.1s\n",
      "P1 S [2400/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.009, DotProd:-0.001, T:44.6s\n",
      "P1 S [2410/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.009, DotProd:-0.001, T:44.4s\n",
      "P1 S [2420/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.009, DotProd:-0.001, T:44.2s\n",
      "P1 S [2430/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.009, DotProd:-0.001, T:43.3s\n",
      "P1 S [2440/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.009, DotProd:-0.001, T:43.0s\n",
      "P1 S [2450/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.010, DotProd:-0.001, T:42.5s\n",
      "P1 S [2460/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.010, DotProd:-0.001, T:42.5s\n",
      "P1 S [2470/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.007, DotProd:-0.001, T:42.8s\n",
      "P1 S [2480/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.008, DotProd:-0.001, T:43.4s\n",
      "P1 S [2490/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.009, DotProd:-0.001, T:44.3s\n",
      "P1 S [2500/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.008, DotProd:-0.001, T:43.8s\n",
      "P1 S [2510/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.010, DotProd:-0.001, T:43.6s\n",
      "P1 S [2520/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.008, DotProd:-0.001, T:44.1s\n",
      "P1 S [2530/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.008, DotProd:-0.001, T:44.2s\n",
      "P1 S [2540/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.008, DotProd:-0.001, T:43.3s\n",
      "P1 S [2550/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.007, DotProd:-0.001, T:43.9s\n",
      "P1 S [2560/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.008, DotProd:-0.001, T:44.0s\n",
      "P1 S [2570/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.010, DotProd:-0.001, T:44.4s\n",
      "P1 S [2580/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.010, DotProd:-0.001, T:47.3s\n",
      "P1 S [2590/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.011, DotProd:-0.001, T:50.7s\n",
      "P1 S [2600/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.008, DotProd:-0.001, T:49.3s\n",
      "P1 S [2610/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.010, DotProd:-0.001, T:52.5s\n",
      "P1 S [2620/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.009, DotProd:-0.001, T:46.3s\n",
      "P1 S [2630/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.011, DotProd:-0.001, T:42.9s\n",
      "P1 S [2640/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.009, DotProd:-0.002, T:43.6s\n",
      "P1 S [2650/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.009, DotProd:-0.001, T:42.7s\n",
      "P1 S [2660/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.009, DotProd:-0.001, T:44.5s\n",
      "P1 S [2670/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.010, DotProd:-0.001, T:44.4s\n",
      "P1 S [2680/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.009, DotProd:-0.001, T:44.2s\n",
      "P1 S [2690/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.009, DotProd:-0.001, T:44.1s\n",
      "P1 S [2700/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.008, DotProd:-0.001, T:44.1s\n",
      "P1 S [2710/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.009, DotProd:-0.001, T:45.0s\n",
      "P1 S [2720/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.011, DotProd:-0.001, T:43.0s\n",
      "P1 S [2730/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.009, DotProd:-0.001, T:42.6s\n",
      "P1 S [2740/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.011, DotProd:-0.001, T:43.1s\n",
      "P1 S [2750/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.011, DotProd:-0.001, T:44.3s\n",
      "P1 S [2760/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.009, DotProd:-0.001, T:44.2s\n",
      "P1 S [2770/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.009, DotProd:-0.001, T:43.3s\n",
      "P1 S [2780/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.010, DotProd:-0.001, T:44.6s\n",
      "P1 S [2790/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.008, DotProd:-0.001, T:43.0s\n",
      "P1 S [2800/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.009, DotProd:-0.001, T:43.6s\n",
      "P1 S [2810/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.009, DotProd:-0.001, T:45.5s\n",
      "P1 S [2820/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.007, DotProd:-0.001, T:44.0s\n",
      "P1 S [2830/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.008, DotProd:-0.001, T:44.2s\n",
      "P1 S [2840/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.007, DotProd:-0.001, T:43.1s\n",
      "P1 S [2850/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.008, DotProd:-0.001, T:44.0s\n",
      "P1 S [2860/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.007, DotProd:-0.001, T:44.3s\n",
      "P1 S [2870/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.007, DotProd:-0.000, T:44.2s\n",
      "P1 S [2880/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.009, DotProd:-0.001, T:43.7s\n",
      "P1 S [2890/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.008, DotProd:-0.001, T:44.1s\n",
      "P1 S [2900/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.009, DotProd:-0.001, T:43.7s\n",
      "P1 S [2910/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.009, DotProd:-0.001, T:43.0s\n",
      "P1 S [2920/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.010, DotProd:-0.001, T:43.7s\n",
      "P1 S [2930/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.008, DotProd:-0.001, T:43.0s\n",
      "P1 S [2940/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.010, DotProd:-0.001, T:43.1s\n",
      "P1 S [2950/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.009, DotProd:-0.001, T:43.7s\n",
      "P1 S [2960/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.008, DotProd:-0.001, T:43.6s\n",
      "P1 S [2970/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.008, DotProd:-0.001, T:42.2s\n",
      "P1 S [2980/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.008, DotProd:-0.001, T:44.0s\n",
      "P1 S [2990/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.008, DotProd:-0.001, T:43.3s\n",
      "P1 S [3000/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.008, DotProd:-0.001, T:43.2s\n",
      "P1 S [3010/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.008, DotProd:-0.001, T:44.9s\n",
      "P1 S [3020/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.007, DotProd:-0.001, T:44.1s\n",
      "P1 S [3030/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.009, DotProd:-0.001, T:43.6s\n",
      "P1 S [3040/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.008, DotProd:-0.001, T:42.6s\n",
      "P1 S [3050/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.007, DotProd:-0.001, T:42.9s\n",
      "P1 S [3060/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.007, DotProd:-0.000, T:43.1s\n",
      "P1 S [3070/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.008, DotProd:-0.001, T:43.0s\n",
      "P1 S [3080/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.008, DotProd:-0.001, T:42.4s\n",
      "P1 S [3090/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.008, DotProd:-0.001, T:43.4s\n",
      "P1 S [3100/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.009, DotProd:-0.001, T:43.9s\n",
      "P1 S [3110/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.007, DotProd:-0.001, T:43.1s\n",
      "P1 S [3120/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.008, DotProd:-0.001, T:44.3s\n",
      "P1 S [3130/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.008, DotProd:-0.001, T:43.4s\n",
      "P1 S [3140/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.007, DotProd:-0.001, T:46.2s\n",
      "P1 S [3150/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.009, DotProd:-0.001, T:43.2s\n",
      "P1 S [3160/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.009, DotProd:-0.001, T:44.5s\n",
      "P1 S [3170/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.008, DotProd:-0.001, T:43.2s\n",
      "P1 S [3180/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.009, DotProd:-0.001, T:42.7s\n",
      "P1 S [3190/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.008, DotProd:-0.001, T:43.2s\n",
      "P1 S [3200/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.009, DotProd:-0.001, T:46.7s\n",
      "P1 S [3210/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.008, DotProd:-0.001, T:45.1s\n",
      "P1 S [3220/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.009, DotProd:-0.001, T:44.8s\n",
      "P1 S [3230/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.007, DotProd:-0.001, T:45.4s\n",
      "P1 S [3240/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.008, DotProd:-0.001, T:45.1s\n",
      "P1 S [3250/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.007, DotProd:-0.000, T:50.0s\n",
      "P1 S [3260/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.007, DotProd:-0.001, T:45.6s\n",
      "P1 S [3270/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.008, DotProd:-0.001, T:45.0s\n",
      "P1 S [3280/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.006, DotProd:-0.000, T:43.0s\n",
      "P1 S [3290/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.009, DotProd:-0.001, T:43.4s\n",
      "P1 S [3300/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.006, DotProd:-0.000, T:44.0s\n",
      "P1 S [3310/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.007, DotProd:-0.001, T:42.8s\n",
      "P1 S [3320/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.008, DotProd:-0.001, T:43.0s\n",
      "P1 S [3330/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.007, DotProd:-0.001, T:43.7s\n",
      "P1 S [3340/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.005, DotProd:-0.000, T:44.3s\n",
      "P1 S [3350/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.008, DotProd:-0.001, T:44.2s\n",
      "P1 S [3360/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.007, DotProd:-0.000, T:44.1s\n",
      "P1 S [3370/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.008, DotProd:-0.001, T:43.6s\n",
      "P1 S [3380/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.006, DotProd:-0.000, T:43.1s\n",
      "P1 S [3390/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.008, DotProd:-0.001, T:42.9s\n",
      "P1 S [3400/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.008, DotProd:-0.001, T:43.0s\n",
      "P1 S [3410/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.008, DotProd:-0.001, T:43.2s\n",
      "P1 S [3420/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.006, DotProd:-0.000, T:42.3s\n",
      "P1 S [3430/5000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.007, DotProd:-0.001, T:42.5s\n",
      "P1 S [3440/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.007, DotProd:-0.001, T:42.3s\n",
      "P1 S [3450/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.007, DotProd:-0.001, T:43.8s\n",
      "P1 S [3460/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.009, DotProd:-0.001, T:43.6s\n",
      "P1 S [3470/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.001, T:43.8s\n",
      "P1 S [3480/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.006, DotProd:-0.000, T:43.9s\n",
      "P1 S [3490/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.004, DotProd:-0.000, T:43.3s\n",
      "P1 S [3500/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.006, DotProd:-0.001, T:42.6s\n",
      "P1 S [3510/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.005, DotProd:-0.000, T:44.1s\n",
      "P1 S [3520/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.008, DotProd:-0.001, T:44.0s\n",
      "P1 S [3530/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.008, DotProd:-0.001, T:45.5s\n",
      "P1 S [3540/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.007, DotProd:-0.001, T:42.6s\n",
      "P1 S [3550/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.006, DotProd:-0.000, T:42.8s\n",
      "P1 S [3560/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.008, DotProd:-0.001, T:43.0s\n",
      "P1 S [3570/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.008, DotProd:-0.001, T:43.4s\n",
      "P1 S [3580/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.004, DotProd:-0.000, T:44.2s\n",
      "P1 S [3590/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.001, T:44.4s\n",
      "P1 S [3600/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.008, DotProd:-0.001, T:44.1s\n",
      "P1 S [3610/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.005, DotProd:-0.000, T:43.6s\n",
      "P1 S [3620/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.006, DotProd:-0.000, T:42.3s\n",
      "P1 S [3630/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.001, T:42.4s\n",
      "P1 S [3640/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.001, T:42.1s\n",
      "P1 S [3650/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.007, DotProd:-0.001, T:43.7s\n",
      "P1 S [3660/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.001, T:43.5s\n",
      "P1 S [3670/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.006, DotProd:-0.001, T:42.8s\n",
      "P1 S [3680/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.008, DotProd:-0.001, T:42.5s\n",
      "P1 S [3690/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.005, DotProd:-0.000, T:43.8s\n",
      "P1 S [3700/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.001, T:43.0s\n",
      "P1 S [3710/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.007, DotProd:-0.001, T:43.0s\n",
      "P1 S [3720/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.005, DotProd:-0.000, T:43.6s\n",
      "P1 S [3730/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.006, DotProd:-0.001, T:44.9s\n",
      "P1 S [3740/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.007, DotProd:-0.001, T:44.1s\n",
      "P1 S [3750/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.007, DotProd:-0.001, T:44.0s\n",
      "P1 S [3760/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.007, DotProd:-0.001, T:43.5s\n",
      "P1 S [3770/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.001, T:42.6s\n",
      "P1 S [3780/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.008, DotProd:-0.001, T:43.0s\n",
      "P1 S [3790/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.005, DotProd:-0.000, T:43.7s\n",
      "P1 S [3800/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.001, T:43.9s\n",
      "P1 S [3810/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.003, DotProd:0.000, T:44.0s\n",
      "P1 S [3820/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.001, T:43.1s\n",
      "P1 S [3830/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.007, DotProd:-0.001, T:42.2s\n",
      "P1 S [3840/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.007, DotProd:-0.001, T:42.6s\n",
      "P1 S [3850/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.007, DotProd:-0.001, T:43.9s\n",
      "P1 S [3860/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.004, DotProd:-0.000, T:43.5s\n",
      "P1 S [3870/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.001, T:43.8s\n",
      "P1 S [3880/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.001, T:43.6s\n",
      "P1 S [3890/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.004, DotProd:-0.000, T:43.3s\n",
      "P1 S [3900/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.001, T:43.2s\n",
      "P1 S [3910/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.007, DotProd:-0.001, T:43.5s\n",
      "P1 S [3920/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.005, DotProd:-0.000, T:43.7s\n",
      "P1 S [3930/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.005, DotProd:-0.000, T:42.6s\n",
      "P1 S [3940/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.007, DotProd:-0.001, T:42.7s\n",
      "P1 S [3950/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.005, DotProd:-0.000, T:42.6s\n",
      "P1 S [3960/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.001, T:42.3s\n",
      "P1 S [3970/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.006, DotProd:-0.001, T:43.5s\n",
      "P1 S [3980/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.005, DotProd:-0.000, T:43.6s\n",
      "P1 S [3990/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.005, DotProd:-0.000, T:43.8s\n",
      "P1 S [4000/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.001, T:43.5s\n",
      "P1 S [4010/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.002, DotProd:-0.000, T:44.9s\n",
      "P1 S [4020/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.004, DotProd:-0.000, T:44.0s\n",
      "P1 S [4030/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.004, DotProd:-0.000, T:44.2s\n",
      "P1 S [4040/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.003, DotProd:-0.000, T:44.3s\n",
      "P1 S [4050/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.005, DotProd:-0.001, T:44.9s\n",
      "P1 S [4060/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.007, DotProd:-0.001, T:44.2s\n",
      "P1 S [4070/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.002, DotProd:-0.000, T:44.5s\n",
      "P1 S [4080/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.007, DotProd:-0.001, T:44.4s\n",
      "P1 S [4090/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.004, DotProd:-0.000, T:44.8s\n",
      "P1 S [4100/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.004, DotProd:-0.000, T:44.2s\n",
      "P1 S [4110/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.004, DotProd:-0.000, T:44.8s\n",
      "P1 S [4120/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.007, DotProd:-0.001, T:49.0s\n",
      "P1 S [4130/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.007, DotProd:-0.001, T:43.6s\n",
      "P1 S [4140/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.004, DotProd:-0.000, T:43.5s\n",
      "P1 S [4150/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.003, DotProd:-0.000, T:44.7s\n",
      "P1 S [4160/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.008, DotProd:-0.001, T:43.4s\n",
      "P1 S [4170/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.005, DotProd:-0.000, T:45.2s\n",
      "P1 S [4180/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.001, DotProd:0.000, T:42.5s\n",
      "P1 S [4190/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.004, DotProd:-0.000, T:42.6s\n",
      "P1 S [4200/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.002, DotProd:0.001, T:42.6s\n",
      "P1 S [4210/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.007, DotProd:-0.001, T:42.7s\n",
      "P1 S [4220/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.000, DotProd:0.000, T:42.4s\n",
      "P1 S [4230/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.001, T:43.5s\n",
      "P1 S [4240/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.005, DotProd:-0.000, T:44.6s\n",
      "P1 S [4250/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.001, DotProd:0.000, T:51.3s\n",
      "P1 S [4260/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.001, DotProd:0.000, T:47.2s\n",
      "P1 S [4270/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.004, DotProd:-0.001, T:46.5s\n",
      "P1 S [4280/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.004, DotProd:-0.000, T:49.4s\n",
      "P1 S [4290/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.005, DotProd:-0.000, T:50.5s\n",
      "P1 S [4300/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.003, DotProd:0.000, T:45.8s\n",
      "P1 S [4310/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.001, DotProd:0.000, T:44.7s\n",
      "P1 S [4320/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.004, DotProd:-0.000, T:42.9s\n",
      "P1 S [4330/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.004, DotProd:-0.000, T:44.7s\n",
      "P1 S [4340/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.004, DotProd:-0.000, T:43.6s\n",
      "P1 S [4350/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.003, DotProd:-0.000, T:43.3s\n",
      "P1 S [4360/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.000, DotProd:0.001, T:43.4s\n",
      "P1 S [4370/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.001, DotProd:0.000, T:43.9s\n",
      "P1 S [4380/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.004, DotProd:-0.000, T:43.4s\n",
      "P1 S [4390/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.001, T:43.4s\n",
      "P1 S [4400/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.001, T:43.0s\n",
      "P1 S [4410/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.004, DotProd:-0.000, T:44.3s\n",
      "P1 S [4420/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.001, DotProd:0.000, T:44.6s\n",
      "P1 S [4430/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.001, DotProd:0.000, T:44.4s\n",
      "P1 S [4440/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.001, DotProd:0.000, T:44.4s\n",
      "P1 S [4450/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.002, DotProd:0.000, T:42.9s\n",
      "P1 S [4460/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.004, DotProd:-0.000, T:42.6s\n",
      "P1 S [4470/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.004, DotProd:-0.000, T:43.1s\n",
      "P1 S [4480/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.001, DotProd:0.000, T:42.5s\n",
      "P1 S [4490/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.001, T:45.3s\n",
      "P1 S [4500/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.001, DotProd:0.000, T:43.1s\n",
      "P1 S [4510/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.004, DotProd:-0.000, T:46.1s\n",
      "P1 S [4520/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.000, DotProd:0.000, T:44.4s\n",
      "P1 S [4530/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.002, DotProd:0.000, T:44.5s\n",
      "P1 S [4540/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.002, DotProd:-0.000, T:44.3s\n",
      "P1 S [4550/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.005, DotProd:-0.001, T:43.9s\n",
      "P1 S [4560/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.003, DotProd:-0.000, T:42.7s\n",
      "P1 S [4570/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.003, DotProd:-0.000, T:42.7s\n",
      "P1 S [4580/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.003, DotProd:-0.000, T:42.7s\n",
      "P1 S [4590/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.003, DotProd:-0.000, T:44.4s\n",
      "P1 S [4600/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.004, DotProd:-0.000, T:44.1s\n",
      "P1 S [4610/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.002, DotProd:0.000, T:42.6s\n",
      "P1 S [4620/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.004, DotProd:-0.000, T:43.2s\n",
      "P1 S [4630/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.004, DotProd:-0.000, T:43.1s\n",
      "P1 S [4640/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.003, DotProd:0.000, T:43.7s\n",
      "P1 S [4650/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.001, DotProd:0.000, T:43.6s\n",
      "P1 S [4660/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.004, DotProd:-0.000, T:43.7s\n",
      "P1 S [4670/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.001, DotProd:0.000, T:43.2s\n",
      "P1 S [4680/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.003, DotProd:-0.000, T:42.7s\n",
      "P1 S [4690/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.004, DotProd:-0.000, T:42.9s\n",
      "P1 S [4700/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.002, DotProd:0.001, T:43.6s\n",
      "P1 S [4710/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.003, DotProd:-0.000, T:44.6s\n",
      "P1 S [4720/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.001, DotProd:0.001, T:44.5s\n",
      "P1 S [4730/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.004, DotProd:-0.000, T:44.5s\n",
      "P1 S [4740/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.003, DotProd:0.000, T:44.7s\n",
      "P1 S [4750/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.005, DotProd:-0.000, T:44.3s\n",
      "P1 S [4760/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.000, DotProd:0.000, T:44.1s\n",
      "P1 S [4770/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.003, DotProd:0.000, T:44.2s\n",
      "P1 S [4780/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.003, DotProd:-0.000, T:45.3s\n",
      "P1 S [4790/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.003, DotProd:-0.000, T:44.9s\n",
      "P1 S [4800/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.001, DotProd:0.000, T:44.5s\n",
      "P1 S [4810/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.003, DotProd:0.000, T:44.6s\n",
      "P1 S [4820/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.003, DotProd:-0.000, T:44.7s\n",
      "P1 S [4830/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.002, DotProd:0.000, T:44.4s\n",
      "P1 S [4840/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.003, DotProd:-0.000, T:44.4s\n",
      "P1 S [4850/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:0.001, DotProd:0.000, T:45.7s\n",
      "P1 S [4860/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.004, DotProd:-0.000, T:44.0s\n",
      "P1 S [4870/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.002, DotProd:0.001, T:44.8s\n",
      "P1 S [4880/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.001, DotProd:0.000, T:44.4s\n",
      "P1 S [4890/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.000, DotProd:0.000, T:45.3s\n",
      "P1 S [4900/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.003, DotProd:0.000, T:43.3s\n",
      "P1 S [4910/5000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.000, DotProd:0.000, T:42.8s\n",
      "P1 S [4920/5000], Loss:0.0008, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.002, DotProd:-0.000, T:43.4s\n",
      "P1 S [4930/5000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.002, DotProd:-0.000, T:43.8s\n",
      "P1 S [4940/5000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.004, DotProd:-0.000, T:44.1s\n",
      "P1 S [4950/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.002, DotProd:0.000, T:43.8s\n",
      "P1 S [4960/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.000, DotProd:0.000, T:43.3s\n",
      "P1 S [4970/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.005, DotProd:-0.000, T:43.0s\n",
      "P1 S [4980/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.002, DotProd:0.000, T:44.5s\n",
      "P1 S [4990/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.003, DotProd:-0.000, T:44.7s\n",
      "P1 S [5000/5000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.001, DotProd:0.000, T:43.6s\n",
      "Phase 1 training complete.\n",
      "\n",
      "Phase 2 LR: 5e-05\n",
      "\n",
      "--- Train Phase 2: Curriculum (1000 steps) ---\n",
      "Settings: SpatialW=False, ModReadout=True, NMDecodeLoss=True\n",
      "Loss calculated from T_settle=50. Total SEQ_LEN=150\n",
      "P2 S [1/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.002, DotProd:0.001, T:4.1s\n",
      "P2 S [10/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0001, CosSim:0.004, DotProd:0.001, T:39.3s\n",
      "P2 S [20/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.003, DotProd:0.001, T:42.5s\n",
      "P2 S [30/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.003, DotProd:-0.000, T:42.5s\n",
      "P2 S [40/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.002, DotProd:0.001, T:42.7s\n",
      "P2 S [50/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.003, DotProd:-0.000, T:42.9s\n",
      "P2 S [60/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.002, DotProd:0.001, T:44.1s\n",
      "P2 S [70/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.001, DotProd:0.000, T:44.5s\n",
      "P2 S [80/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.003, DotProd:-0.000, T:44.7s\n",
      "P2 S [90/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.003, DotProd:0.001, T:44.3s\n",
      "P2 S [100/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.005, DotProd:-0.001, T:43.5s\n",
      "P2 S [110/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.000, DotProd:0.000, T:42.4s\n",
      "P2 S [120/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.005, DotProd:0.001, T:43.1s\n",
      "P2 S [130/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.003, DotProd:-0.000, T:43.2s\n",
      "P2 S [140/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.000, DotProd:0.000, T:44.0s\n",
      "P2 S [150/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.001, T:43.1s\n",
      "P2 S [160/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0001, CosSim:-0.002, DotProd:-0.000, T:43.1s\n",
      "P2 S [170/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.008, DotProd:-0.001, T:42.7s\n",
      "P2 S [180/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.003, DotProd:0.000, T:43.7s\n",
      "P2 S [190/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:0.001, DotProd:0.000, T:42.5s\n",
      "P2 S [200/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0001, CosSim:0.003, DotProd:0.001, T:42.3s\n",
      "P2 S [210/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.001, DotProd:0.000, T:42.6s\n",
      "P2 S [220/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.003, DotProd:-0.000, T:43.0s\n",
      "P2 S [230/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.005, DotProd:-0.001, T:44.6s\n",
      "P2 S [240/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.002, DotProd:-0.000, T:45.0s\n",
      "P2 S [250/1000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.006, DotProd:-0.001, T:45.3s\n",
      "P2 S [260/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.005, DotProd:-0.001, T:44.4s\n",
      "P2 S [270/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.004, DotProd:-0.000, T:44.4s\n",
      "P2 S [280/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.006, DotProd:-0.001, T:44.4s\n",
      "P2 S [290/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.009, DotProd:-0.002, T:45.5s\n",
      "P2 S [300/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.005, DotProd:-0.001, T:44.3s\n",
      "P2 S [310/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.007, DotProd:-0.001, T:42.9s\n",
      "P2 S [320/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.007, DotProd:-0.001, T:42.4s\n",
      "P2 S [330/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.006, DotProd:-0.001, T:42.7s\n",
      "P2 S [340/1000], Loss:0.0001, RegLoss:0.0000, NMDec:0.0002, CosSim:-0.003, DotProd:0.000, T:42.5s\n",
      "P2 S [350/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.007, DotProd:-0.002, T:42.5s\n",
      "P2 S [360/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.005, DotProd:-0.000, T:43.4s\n",
      "P2 S [370/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.007, DotProd:-0.001, T:42.9s\n",
      "P2 S [380/1000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.008, DotProd:-0.001, T:42.9s\n",
      "P2 S [390/1000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.007, DotProd:-0.001, T:44.8s\n",
      "P2 S [400/1000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.005, DotProd:-0.000, T:44.2s\n",
      "P2 S [410/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.007, DotProd:-0.001, T:43.6s\n",
      "P2 S [420/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.007, DotProd:-0.001, T:42.4s\n",
      "P2 S [430/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.007, DotProd:-0.001, T:42.8s\n",
      "P2 S [440/1000], Loss:0.0008, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.009, DotProd:-0.002, T:42.8s\n",
      "P2 S [450/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.006, DotProd:-0.001, T:43.3s\n",
      "P2 S [460/1000], Loss:0.0008, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.008, DotProd:-0.002, T:44.3s\n",
      "P2 S [470/1000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.006, DotProd:-0.001, T:42.9s\n",
      "P2 S [480/1000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.008, DotProd:-0.002, T:43.2s\n",
      "P2 S [490/1000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.008, DotProd:-0.002, T:43.2s\n",
      "P2 S [500/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.005, DotProd:-0.001, T:44.7s\n",
      "P2 S [510/1000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.011, DotProd:-0.003, T:46.1s\n",
      "P2 S [520/1000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.010, DotProd:-0.002, T:44.2s\n",
      "P2 S [530/1000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.008, DotProd:-0.001, T:43.2s\n",
      "P2 S [540/1000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.009, DotProd:-0.002, T:44.7s\n",
      "P2 S [550/1000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.010, DotProd:-0.002, T:43.9s\n",
      "P2 S [560/1000], Loss:0.0003, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.005, DotProd:-0.000, T:44.0s\n",
      "P2 S [570/1000], Loss:0.0008, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.009, DotProd:-0.002, T:44.1s\n",
      "P2 S [580/1000], Loss:0.0010, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.011, DotProd:-0.002, T:46.1s\n",
      "P2 S [590/1000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.007, DotProd:-0.001, T:45.1s\n",
      "P2 S [600/1000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.010, DotProd:-0.002, T:44.6s\n",
      "P2 S [610/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.008, DotProd:-0.002, T:44.3s\n",
      "P2 S [620/1000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.006, DotProd:-0.001, T:43.0s\n",
      "P2 S [630/1000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.011, DotProd:-0.002, T:42.5s\n",
      "P2 S [640/1000], Loss:0.0004, RegLoss:0.0000, NMDec:0.0004, CosSim:-0.007, DotProd:-0.001, T:42.8s\n",
      "P2 S [650/1000], Loss:0.0002, RegLoss:0.0000, NMDec:0.0003, CosSim:-0.004, DotProd:-0.000, T:43.4s\n",
      "P2 S [660/1000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.009, DotProd:-0.002, T:43.3s\n",
      "P2 S [670/1000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.009, DotProd:-0.002, T:43.3s\n",
      "P2 S [680/1000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.010, DotProd:-0.002, T:43.5s\n",
      "P2 S [690/1000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0008, CosSim:-0.009, DotProd:-0.002, T:42.8s\n",
      "P2 S [700/1000], Loss:0.0016, RegLoss:0.0000, NMDec:0.0015, CosSim:-0.010, DotProd:-0.003, T:42.6s\n",
      "P2 S [710/1000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.007, DotProd:-0.002, T:43.1s\n",
      "P2 S [720/1000], Loss:0.0010, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.008, DotProd:-0.002, T:42.6s\n",
      "P2 S [730/1000], Loss:0.0012, RegLoss:0.0000, NMDec:0.0012, CosSim:-0.010, DotProd:-0.003, T:42.4s\n",
      "P2 S [740/1000], Loss:0.0011, RegLoss:0.0000, NMDec:0.0013, CosSim:-0.009, DotProd:-0.003, T:42.6s\n",
      "P2 S [750/1000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.009, DotProd:-0.002, T:42.8s\n",
      "P2 S [760/1000], Loss:0.0010, RegLoss:0.0000, NMDec:0.0012, CosSim:-0.009, DotProd:-0.002, T:51.3s\n",
      "P2 S [770/1000], Loss:0.0010, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.011, DotProd:-0.003, T:43.6s\n",
      "P2 S [780/1000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.006, DotProd:-0.001, T:42.9s\n",
      "P2 S [790/1000], Loss:0.0013, RegLoss:0.0000, NMDec:0.0012, CosSim:-0.011, DotProd:-0.003, T:42.8s\n",
      "P2 S [800/1000], Loss:0.0010, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.008, DotProd:-0.002, T:47.2s\n",
      "P2 S [810/1000], Loss:0.0006, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.005, DotProd:-0.001, T:45.9s\n",
      "P2 S [820/1000], Loss:0.0005, RegLoss:0.0000, NMDec:0.0005, CosSim:-0.007, DotProd:-0.002, T:55.7s\n",
      "P2 S [830/1000], Loss:0.0011, RegLoss:0.0000, NMDec:0.0010, CosSim:-0.008, DotProd:-0.002, T:44.1s\n",
      "P2 S [840/1000], Loss:0.0011, RegLoss:0.0000, NMDec:0.0012, CosSim:-0.008, DotProd:-0.002, T:56.8s\n",
      "P2 S [850/1000], Loss:0.0013, RegLoss:0.0000, NMDec:0.0012, CosSim:-0.009, DotProd:-0.003, T:43.9s\n",
      "P2 S [860/1000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.009, DotProd:-0.003, T:44.2s\n",
      "P2 S [870/1000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0007, CosSim:-0.007, DotProd:-0.002, T:54.4s\n",
      "P2 S [880/1000], Loss:0.0009, RegLoss:0.0000, NMDec:0.0011, CosSim:-0.009, DotProd:-0.003, T:43.8s\n",
      "P2 S [890/1000], Loss:0.0011, RegLoss:0.0000, NMDec:0.0013, CosSim:-0.008, DotProd:-0.002, T:43.9s\n",
      "P2 S [900/1000], Loss:0.0010, RegLoss:0.0000, NMDec:0.0012, CosSim:-0.008, DotProd:-0.002, T:57.6s\n",
      "P2 S [910/1000], Loss:0.0008, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.006, DotProd:-0.001, T:42.5s\n",
      "P2 S [920/1000], Loss:0.0010, RegLoss:0.0000, NMDec:0.0013, CosSim:-0.009, DotProd:-0.003, T:54.9s\n",
      "P2 S [930/1000], Loss:0.0017, RegLoss:0.0000, NMDec:0.0017, CosSim:-0.009, DotProd:-0.003, T:42.8s\n",
      "P2 S [940/1000], Loss:0.0008, RegLoss:0.0000, NMDec:0.0009, CosSim:-0.008, DotProd:-0.003, T:42.6s\n",
      "P2 S [950/1000], Loss:0.0013, RegLoss:0.0000, NMDec:0.0013, CosSim:-0.007, DotProd:-0.002, T:43.4s\n",
      "P2 S [960/1000], Loss:0.0015, RegLoss:0.0000, NMDec:0.0015, CosSim:-0.007, DotProd:-0.003, T:44.5s\n",
      "P2 S [970/1000], Loss:0.0011, RegLoss:0.0000, NMDec:0.0011, CosSim:-0.007, DotProd:-0.002, T:43.3s\n",
      "P2 S [980/1000], Loss:0.0014, RegLoss:0.0000, NMDec:0.0013, CosSim:-0.007, DotProd:-0.002, T:44.2s\n",
      "P2 S [990/1000], Loss:0.0010, RegLoss:0.0000, NMDec:0.0011, CosSim:-0.007, DotProd:-0.002, T:43.2s\n",
      "P2 S [1000/1000], Loss:0.0007, RegLoss:0.0000, NMDec:0.0006, CosSim:-0.006, DotProd:-0.002, T:43.4s\n",
      "Phase 2 training complete.\n",
      "Logs saved to Hopf_experiments_new/dNM4_H128_20250514-144958/logs/dNM4_H128_logs.pkl\n",
      "Model parameters saved to Hopf_experiments_new/dNM4_H128_20250514-144958/models/dNM4_H128_model_state_dict.pth\n",
      "\n",
      "--- Generating Final Plots ---\n",
      "Final plots saved to Hopf_experiments_new/dNM4_H128_20250514-144958/plots\n",
      "Training movie frames saved to Hopf_experiments_new/dNM4_H128_20250514-144958/training_movie_for_dNM4_H128\n",
      "====== Experiment dNM4_H128 Complete ======\n",
      "\n",
      "\n",
      "All experiments finished.\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import sys\n",
    "import numpy as np\n",
    "import torch\n",
    "import torch.optim as optim\n",
    "import torch.nn as nn\n",
    "import time\n",
    "import math  # For pi\n",
    "import scipy.spatial as ss  # Needed for SpatialWeight\n",
    "import matplotlib.pyplot as plt\n",
    "import datetime\n",
    "import pickle # To save logs\n",
    "\n",
    "# Ensure matplotlib uses a non-interactive backend for saving plots without displaying\n",
    "# This might already be handled by %matplotlib inline in some environments,\n",
    "# but explicit setting is safer for scripting.\n",
    "# plt.switch_backend('Agg') # Uncomment if running as a script without a display\n",
    "\n",
    "# --- Spatial Weight Module ---\n",
    "class SpatialWeight(nn.Module):\n",
    "    \"\"\"\n",
    "    Applies a spatial structure (distance-dependent decay, inhibition)\n",
    "    to a base weight tensor.\n",
    "    \"\"\"\n",
    "    def __init__(self, hidden_size, N_nm=4, ell=0.1, scale=1.0, pinhib=0.5, seed=1):\n",
    "        super(SpatialWeight, self).__init__()\n",
    "        # Use a local variable for seed within the constructor\n",
    "        current_seed = seed\n",
    "        np.random.seed(current_seed)\n",
    "\n",
    "        # pos should be registered as a buffer or not a parameter if not trained\n",
    "        self.register_buffer('pos', torch.tensor(np.random.random([hidden_size, 2]), dtype=torch.float32))\n",
    "        delpoints_2d = ss.distance.cdist(self.pos.cpu().numpy(), self.pos.cpu().numpy())\n",
    "        # delpoints should be a buffer too\n",
    "        self.register_buffer('delpoints', torch.tensor(delpoints_2d[:, :, None] * np.ones([1, 1, N_nm]), dtype=torch.float32))\n",
    "        self.ell = ell\n",
    "        self.scale = scale\n",
    "        inhib_np = np.random.choice([0, 1], hidden_size, p=[1-pinhib, pinhib])[:, None, None] * np.ones(self.delpoints.shape)\n",
    "        # inhib should be a buffer\n",
    "        self.register_buffer('inhib', torch.tensor(inhib_np, dtype=torch.float32))\n",
    "        # Delta should be a buffer\n",
    "        self.register_buffer('Delta', self.delpoints / self.ell)\n",
    "        mask_np = np.logical_and(\n",
    "            delpoints_2d[:, :, None] < 5 * self.ell,\n",
    "            np.eye(hidden_size)[:, :, None] * np.ones(self.delpoints.shape) == 0\n",
    "        )\n",
    "        # mask should be a buffer\n",
    "        self.register_buffer('mask', torch.tensor(mask_np, dtype=torch.float32))\n",
    "\n",
    "    def forward(self, W_base):\n",
    "        # W_base shape can be (H, H, N) or (B, H, H, N) if spatial weights are batched\n",
    "        # Delta, inhib, mask are (H, H, N)\n",
    "        if W_base.shape != self.Delta.shape:\n",
    "             # Allow broadcasting for batch dimension in W_base (B, H, H, N)\n",
    "             if W_base.dim() == 4 and W_base.shape[1:] == self.Delta.shape:\n",
    "                 Delta = self.Delta.unsqueeze(0).expand_as(W_base)\n",
    "                 inhib = self.inhib.unsqueeze(0).expand_as(W_base)\n",
    "                 mask = self.mask.unsqueeze(0).expand_as(W_base)\n",
    "             else:\n",
    "                # If N_NM is 0, Delta.shape will have last dim 0. W_base might be (H, H, 0).\n",
    "                # In this case, the spatial weight is effectively zero.\n",
    "                # Let's handle the N_NM=0 case explicitly here for safety, although\n",
    "                # nmRNNCellBase should prevent calling SpatialWeight if N_NM=0.\n",
    "                if self.Delta.shape[-1] == 0:\n",
    "                     # If N_NM is 0, Delta and related buffers have last dim 0.\n",
    "                     # The spatial weight should be a tensor of zeros matching W_base shape.\n",
    "                     # This branch should ideally not be reached if nmRNNCellBase handles N_NM=0 correctly,\n",
    "                     # but adding it makes SpatialWeight more robust.\n",
    "                     return torch.zeros_like(W_base, device=W_base.device)\n",
    "                else:\n",
    "                    raise ValueError(f\"Shape mismatch in SpatialWeight: W_base {W_base.shape} != Delta {self.Delta.shape}\")\n",
    "        else:\n",
    "            inhib = self.inhib.to(W_base.device)\n",
    "            Delta = self.Delta.to(W_base.device)\n",
    "            mask = self.mask.to(W_base.device)\n",
    "\n",
    "        return self.scale * ((-1)**inhib) * torch.exp(W_base - Delta) * mask\n",
    "\n",
    "# --- Base nmRNN Cell ---\n",
    "class nmRNNCellBase(nn.Module):\n",
    "    def __init__(self, input_size, hidden_size, N_nm, activation_fn, bias, keepW0, use_spatial_weights,\n",
    "                 spatial_ell, spatial_scale, seed=0):\n",
    "        super().__init__()\n",
    "        # Use a local variable for seed within the constructor\n",
    "        current_seed = seed\n",
    "        torch.manual_seed(current_seed)\n",
    "        np.random.seed(current_seed)\n",
    "\n",
    "        self.input_size, self.hidden_size, self.N_nm = input_size, hidden_size, N_nm\n",
    "        self.activation_fn, self.keepW0, self.use_spatial_weights = activation_fn, keepW0, use_spatial_weights\n",
    "\n",
    "        self.weight_ih = nn.Parameter(torch.Tensor(hidden_size, input_size))\n",
    "\n",
    "        # Only create NM-related parameters if N_NM > 0\n",
    "        if N_nm > 0:\n",
    "            self.weight_h2nm = nn.Parameter(torch.Tensor(N_nm, hidden_size))\n",
    "            self.weight_nm2nm = nn.Parameter(torch.Tensor(N_nm, N_nm))\n",
    "            self.bias_nm = nn.Parameter(torch.Tensor(N_nm)) if bias else None\n",
    "        else:\n",
    "            self.register_parameter('weight_h2nm', None)\n",
    "            self.register_parameter('weight_nm2nm', None)\n",
    "            self.register_parameter('bias_nm', None)\n",
    "\n",
    "        # weight0_hh (fixed part of recurrent weight)\n",
    "        if keepW0:\n",
    "            self.weight0_hh = nn.Parameter(torch.Tensor(hidden_size, hidden_size))\n",
    "        else:\n",
    "            self.register_parameter('weight0_hh', None)\n",
    "\n",
    "        # weight_hh (NM-modulated part of recurrent weight, T_ijk)\n",
    "        # Only create if N_NM > 0\n",
    "        if N_nm > 0:\n",
    "            if use_spatial_weights:\n",
    "                # Pass the original seed parameter, NOT current_seed, to the child constructor\n",
    "                self.spatial_net = SpatialWeight(hidden_size,N_nm,spatial_ell,spatial_scale,seed=seed)\n",
    "                initial_W_base_hh = torch.Tensor(hidden_size,hidden_size,N_nm)\n",
    "                nn.init.kaiming_uniform_(initial_W_base_hh, a=math.sqrt(5))\n",
    "                self.weight_hh = nn.Parameter(self.spatial_net(initial_W_base_hh)) # T_ijk\n",
    "            else:\n",
    "                self.weight_hh = nn.Parameter(torch.Tensor(hidden_size,hidden_size,N_nm)) # T_ijk\n",
    "        else:\n",
    "            self.register_parameter('weight_hh', None) # Ensure it's None if N_NM is 0\n",
    "\n",
    "        self.bias = nn.Parameter(torch.Tensor(hidden_size)) if bias else None\n",
    "        self.reset_parameters_custom()\n",
    "\n",
    "    def reset_parameters_custom(self):\n",
    "        nn.init.kaiming_uniform_(self.weight_ih, a=math.sqrt(5))\n",
    "\n",
    "        # Only initialize NM-related parameters if they exist (N_NM > 0)\n",
    "        if self.N_nm > 0:\n",
    "            if not self.use_spatial_weights and self.weight_hh is not None:\n",
    "                # Normalization for T_ijk\n",
    "                 nn.init.normal_(self.weight_hh, mean=0, std=0.1/math.sqrt(self.hidden_size*self.N_nm))\n",
    "            if self.weight_h2nm is not None:\n",
    "                nn.init.kaiming_uniform_(self.weight_h2nm, a=math.sqrt(5))\n",
    "            if self.weight_nm2nm is not None:\n",
    "                nn.init.zeros_(self.weight_nm2nm)\n",
    "            if self.bias_nm is not None:\n",
    "                nn.init.zeros_(self.bias_nm)\n",
    "\n",
    "        if self.weight0_hh is not None: # If keepW0 is true, it's a Parameter\n",
    "             nn.init.kaiming_uniform_(self.weight0_hh,a=math.sqrt(5))\n",
    "\n",
    "        if self.bias is not None:\n",
    "            fan_in,_=nn.init._calculate_fan_in_and_fan_out(self.weight_ih)\n",
    "            bound=1/math.sqrt(fan_in) if fan_in > 0 else 0; nn.init.uniform_(self.bias,-bound,bound)\n",
    "\n",
    "# --- nmRNN Cell ---\n",
    "class NMRNNCell(nmRNNCellBase):\n",
    "    def __init__(self, input_size, hidden_size, N_nm, activation_fn, decay, bias, keepW0,\n",
    "                 use_spatial_weights, spatial_ell, spatial_scale, seed=0):\n",
    "        super().__init__(input_size,hidden_size,N_nm,activation_fn,bias,keepW0,\n",
    "                         use_spatial_weights,spatial_ell,spatial_scale,seed=seed)\n",
    "        self.alpha = 1.0 - decay\n",
    "\n",
    "    def forward(self, input, prev_hidden, prev_nm):\n",
    "        # RNN dynamics (Hidden state update)\n",
    "        hidden_input = input @ self.weight_ih.t()\n",
    "        if self.weight0_hh is not None:\n",
    "            hidden_input += prev_hidden @ self.weight0_hh.t()\n",
    "\n",
    "        # Only add NM-modulated recurrent input if N_NM > 0 and weight_hh exists\n",
    "        if self.N_nm > 0 and self.weight_hh is not None and prev_nm is not None:\n",
    "            # Calculate the neuromodulated part of W_hh\n",
    "            T_hh_perm = self.weight_hh.permute(2,0,1) # (N_nm, H_out, H_in)\n",
    "            W_eff_mod = torch.einsum('kji,bk->bij', T_hh_perm, prev_nm) # (B, H_out, H_in)\n",
    "            hidden_input += torch.einsum('bh,bhj->bj', prev_hidden, W_eff_mod) # (B, H_in), (B, H_out, H_in) -> (B, H_out)\n",
    "\n",
    "        if self.bias is not None:\n",
    "            hidden_input += self.bias\n",
    "        activity_hidden = self.activation_fn(hidden_input)\n",
    "        next_hidden = (1.0 - self.alpha) * prev_hidden + self.alpha * activity_hidden\n",
    "\n",
    "        # Neuromodulatory state update\n",
    "        next_nm = prev_nm # Default: NM states don't change if N_nm=0 or no NM weights\n",
    "        # Only update NM states if N_NM > 0\n",
    "        if self.N_nm > 0:\n",
    "             if prev_nm is None: # Initialize NM states if None\n",
    "                 next_nm = torch.zeros(input.shape[0], self.N_nm, device=input.device)\n",
    "             # Only update if there are weights feeding into NM states\n",
    "             if self.weight_h2nm is not None or self.weight_nm2nm is not None:\n",
    "                 nm_input = torch.zeros(input.shape[0], self.N_nm, device=input.device) # Initialize input to 0\n",
    "                 if self.weight_h2nm is not None:\n",
    "                     nm_input += prev_hidden @ self.weight_h2nm.t()\n",
    "                 if self.weight_nm2nm is not None:\n",
    "                     nm_input += prev_nm @ self.weight_nm2nm.t()\n",
    "                 if self.bias_nm is not None:\n",
    "                      nm_input += self.bias_nm\n",
    "                 activity_nm = torch.tanh(nm_input) # Assuming tanh for NM activation\n",
    "                 next_nm = (1.0 - self.alpha) * next_nm + self.alpha * activity_nm # Apply decay/alpha\n",
    "\n",
    "        return next_hidden, next_nm\n",
    "\n",
    "# --- nmRNN Layer ---\n",
    "class NMRNNLayer(nn.Module):\n",
    "    def __init__(self, input_size, hidden_size, output_size, N_nm, activation_fn, decay, bias, keepW0,\n",
    "                 use_spatial_weights, spatial_ell, spatial_scale, use_modulated_readout, seed=0, device='cpu'):\n",
    "        super().__init__()\n",
    "        self.hidden_size, self.N_nm, self.output_size = hidden_size, N_nm, output_size\n",
    "        self.device = device # Store device\n",
    "\n",
    "        # Modulated readout only makes sense with NM and if the flag is True\n",
    "        self.use_modulated_readout = use_modulated_readout and N_nm > 0\n",
    "\n",
    "        self.cell = NMRNNCell(input_size,hidden_size,N_nm,activation_fn,decay,bias,keepW0,\n",
    "                              use_spatial_weights,spatial_ell,spatial_scale,seed=seed)\n",
    "\n",
    "        # Readout layer definition\n",
    "        if self.use_modulated_readout:\n",
    "            self.weight_readout_modulated = nn.Parameter(torch.Tensor(output_size,hidden_size,N_nm)) # D_oik\n",
    "            # Kaiming init for the tensor D_oik\n",
    "            nn.init.kaiming_uniform_(self.weight_readout_modulated, a=1/math.sqrt(hidden_size) if hidden_size>0 else 0.01)\n",
    "            self.readout_bias = nn.Parameter(torch.Tensor(output_size)) if bias else None\n",
    "            if self.readout_bias is not None:\n",
    "                 nn.init.zeros_(self.readout_bias)\n",
    "            # Ensure standard readout is None if modulated is used\n",
    "            self.readout_fc = None\n",
    "        else:\n",
    "            # If not modulated readout or N_nm == 0, use a standard linear readout\n",
    "            self.readout_fc = nn.Linear(hidden_size,output_size,bias=bias)\n",
    "            nn.init.xavier_uniform_(self.readout_fc.weight)\n",
    "            if self.readout_fc.bias is not None:\n",
    "                 nn.init.zeros_(self.readout_fc.bias)\n",
    "            # Ensure modulated readout parameters are None if standard is used\n",
    "            self.register_parameter('weight_readout_modulated', None)\n",
    "            self.register_parameter('readout_bias', None)\n",
    "\n",
    "\n",
    "    def forward(self, input_seq, hidden_init, nm_init):\n",
    "        # input_seq shape: (Batch, SeqLen, InputSize)\n",
    "        # hidden_init shape: (Batch, HiddenSize)\n",
    "        # nm_init shape: (Batch, N_nm) or None\n",
    "\n",
    "        inputs = input_seq.unbind(1); seq_len = len(inputs)\n",
    "        hidden, nm = hidden_init, nm_init\n",
    "        outputs_list, hidden_states_list = [], []\n",
    "        # Only collect NM states if N_NM > 0\n",
    "        nm_states_list = [] if self.N_nm > 0 else None\n",
    "\n",
    "        for i in range(seq_len):\n",
    "            hidden, nm = self.cell(inputs[i],hidden,nm) # hidden is next_hidden, nm is next_nm\n",
    "\n",
    "            # Calculate output\n",
    "            # Only use modulated readout if N_NM > 0 and it's enabled\n",
    "            if self.use_modulated_readout and nm is not None and self.N_nm > 0:\n",
    "                D_eff_mod_batched = torch.einsum('ohn,bn->boh', self.weight_readout_modulated, nm) # (Batch, Output, Hidden)\n",
    "                output_t = torch.einsum('bh,boh->bo', hidden, D_eff_mod_batched)\n",
    "                if self.readout_bias is not None:\n",
    "                    output_t += self.readout_bias # Broadcast bias\n",
    "            else:\n",
    "                 # Use standard linear readout\n",
    "                 output_t = self.readout_fc(hidden)\n",
    "\n",
    "            outputs_list.append(output_t)\n",
    "            hidden_states_list.append(hidden)\n",
    "            if nm_states_list is not None and nm is not None:\n",
    "                 nm_states_list.append(nm)\n",
    "\n",
    "        output_seq = torch.stack(outputs_list,dim=1) # (Batch, SeqLen, OutputSize)\n",
    "        hidden_states_seq = torch.stack(hidden_states_list,dim=1) # (Batch, SeqLen, HiddenSize)\n",
    "        # nm_states_seq will be None if nm_states_list was None\n",
    "        nm_states_seq = torch.stack(nm_states_list,dim=1) if nm_states_list is not None and len(nm_states_list)>0 else None\n",
    "\n",
    "        # Return final states along with sequences\n",
    "        # Return decoded_conds as the 4th element only if use_nm_decoder is True\n",
    "        # The forward pass of the main model will handle the decoding.\n",
    "        return output_seq, hidden, hidden_states_seq, nm, nm_states_seq\n",
    "\n",
    "# --- Main Model with Combined Features ---\n",
    "class Model_nm_CombinedFeatures(nn.Module):\n",
    "    def __init__(self, hp):\n",
    "        super().__init__()\n",
    "        self.hp = hp\n",
    "        n_in,n_rnn,n_out,N_NM = hp['n_in'],hp['n_rnn'],hp['n_out'],hp['N_NM']\n",
    "        decay,act_str,bias,keepW0 = hp['decay'],hp['activation'],hp['use_bias'],hp['keepW0']\n",
    "        use_spatial,s_ell,s_scale = hp.get('use_spatial_weights',False),hp.get('spatial_ell',0.2),hp.get('spatial_scale',1.0)\n",
    "\n",
    "        # NM decoder is only possible if N_NM > 0 and the flag is True\n",
    "        self.use_nm_decoder = hp.get('use_nm_decoder_loss',False) and N_NM > 0\n",
    "        clip_val = hp.get('grad_value_clip', hp.get('clip_value', 0.0)) # Clip value from hp, fallback to 'clip'\n",
    "\n",
    "        self.device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "\n",
    "        # Activation function setup\n",
    "        if act_str=='relu': nl=nn.ReLU()\n",
    "        elif act_str=='tanh': nl=nn.Tanh()\n",
    "        elif act_str=='relu-tanh':\n",
    "             nl = nn.ReLU(nn.Tanh())\n",
    "\n",
    "        else:\n",
    "             raise NotImplementedError(act_str)\n",
    "\n",
    "        self.n_rnn,self.N_nm = n_rnn,N_NM\n",
    "\n",
    "        # Initial scale for NM states - only create if N_NM > 0\n",
    "        if self.N_nm > 0:\n",
    "            self.scale0 = nn.Parameter(torch.tensor([hp.get('nm_init_scale', 1.0)]),requires_grad=True)\n",
    "        else:\n",
    "            self.register_parameter('scale0', None) # Ensure it's None if N_NM is 0\n",
    "\n",
    "\n",
    "        # The main RNN layer\n",
    "        # Pass use_modulated_readout flag from hp, NMRNNLayer will handle N_NM check internally\n",
    "        use_mod_readout = hp.get('use_modulated_readout',False)\n",
    "        self.rnn_layer = NMRNNLayer(n_in,n_rnn,n_out,N_NM,nl,decay,bias,keepW0,\n",
    "                                    use_spatial,s_ell,s_scale,use_mod_readout,hp.get('seed',0),self.device) # Pass seed\n",
    "\n",
    "        # Optional NM decoder - only create if use_nm_decoder is True (which already implies N_NM > 0)\n",
    "        if self.use_nm_decoder:\n",
    "             self.nm_decoder=nn.Linear(N_NM,3) # Assuming 3 conditions (A, omega, phi)\n",
    "        else:\n",
    "             self.nm_decoder=None\n",
    "\n",
    "        # Gradient clipping hook\n",
    "        if clip_val > 0:\n",
    "            # print(f\"Model_nm_Combined: Applying grad value clip hook: {clip_val}\") # Suppress during runs\n",
    "            for p in self.parameters():\n",
    "                if p.requires_grad:\n",
    "                     p.register_hook(lambda grad: torch.clamp(grad,-clip_val,clip_val))\n",
    "\n",
    "    def forward(self, x):\n",
    "        # x shape: (Batch, SeqLen, InputSize)\n",
    "        batch_size = x.shape[0]\n",
    "        # Initialize hidden state with zeros\n",
    "        hidden0 = torch.zeros(batch_size,self.n_rnn,device=self.device)\n",
    "        # Initialize NM state with scale0 (if N_NM > 0)\n",
    "        # nm0 will be None if self.N_nm is 0\n",
    "        nm0 = self.scale0*torch.ones(batch_size,self.N_nm,device=self.device) if self.N_nm > 0 and self.scale0 is not None else None\n",
    "\n",
    "        # Run the RNN layer\n",
    "        # rnn_layer returns (out_seq, hidden, hid_seq, nm, nm_seq)\n",
    "        # nm and nm_seq will be None if self.N_nm is 0\n",
    "        out_seq, _, hid_seq, _, nm_seq = self.rnn_layer(x,hidden0,nm0)\n",
    "        # out_seq: (B, S, O), hid_seq: (B, S, H), nm_seq: (B, S, N) or None\n",
    "\n",
    "        decoded_conds = None\n",
    "        # Decode NM states if requested and possible (implies N_NM > 0)\n",
    "        if self.use_nm_decoder and self.nm_decoder is not None and nm_seq is not None:\n",
    "            # Use the average NM state over the *whole* sequence for decoding loss as in original code\n",
    "            avg_nm = nm_seq.mean(dim=1) # Mean over time dimension\n",
    "            decoded_conds = self.nm_decoder(avg_nm) # (B, 3)\n",
    "\n",
    "        # Return appropriate tuple based on whether decoder loss is used\n",
    "        # Always return 4 elements, decoded_conds will be None if not used\n",
    "        return (out_seq,hid_seq,nm_seq,decoded_conds)\n",
    "\n",
    "\n",
    "# --- Standard RNN Components (for Model_RNN surrogate) ---\n",
    "# This class is only used for the surrogate model, which we will skip if N_NM=0\n",
    "class StandardRNNCell_base(nn.Module): # Renamed to avoid conflict with nmRNNCell_base\n",
    "    def __init__(self, input_size, hidden_size, nonlinearity, bias):\n",
    "        super().__init__()\n",
    "        self.input_size, self.hidden_size, self.nonlinearity = input_size, hidden_size, nonlinearity\n",
    "        self.weight_ih = nn.Parameter(torch.Tensor(hidden_size, input_size))\n",
    "        self.weight_hh = nn.Parameter(torch.Tensor(hidden_size, hidden_size))\n",
    "        if bias:\n",
    "            self.bias = nn.Parameter(torch.Tensor(hidden_size))\n",
    "        else:\n",
    "            self.register_parameter('bias', None)\n",
    "        self.reset_parameters()\n",
    "\n",
    "    def reset_parameters(self):\n",
    "        nn.init.kaiming_uniform_(self.weight_ih, a=math.sqrt(5))\n",
    "        nn.init.kaiming_uniform_(self.weight_hh, a=math.sqrt(5))\n",
    "        if self.bias is not None:\n",
    "            fan_in,_=nn.init._calculate_fan_in_and_fan_out(self.weight_ih)\n",
    "            bound = 1/math.sqrt(fan_in) if fan_in > 0 else 0\n",
    "            nn.init.uniform_(self.bias, -bound, bound)\n",
    "\n",
    "class StandardRNNCell(StandardRNNCell_base): # Renamed\n",
    "    def __init__(self, input_size, hidden_size, nonlinearity=None, decay=0.9, bias=True):\n",
    "        super().__init__(input_size,hidden_size,nonlinearity,bias)\n",
    "        self.alpha = 1.0 - decay\n",
    "\n",
    "    def forward(self, input, hidden):\n",
    "        # Standard RNN cell dynamics\n",
    "        hidden_input = input @ self.weight_ih.t() + hidden @ self.weight_hh.t()\n",
    "        if self.bias is not None:\n",
    "            hidden_input += self.bias\n",
    "        activity = self.nonlinearity(hidden_input)\n",
    "        hidden = (1.0 - self.alpha) * hidden + self.alpha * activity\n",
    "        return hidden\n",
    "\n",
    "class StandardRNNLayer(nn.Module): # Renamed\n",
    "    def __init__(self, input_size, hidden_size, nonlinearity, decay, bias):\n",
    "        super().__init__()\n",
    "        self.rnncell = StandardRNNCell(input_size,hidden_size,nonlinearity=nonlinearity,decay=decay,bias=bias)\n",
    "\n",
    "    def forward(self, input, hidden_init):\n",
    "        # input shape: (Batch, SeqLen, InputSize)\n",
    "        # hidden_init shape: (Batch, 1, HiddenSize) - squeeze the redundant dim\n",
    "        inputs = input.unbind(1) # List of (Batch, InputSize)\n",
    "        hidden = hidden_init.squeeze(1) # (Batch, HiddenSize)\n",
    "        outputs_hidden = []\n",
    "\n",
    "        for i in range(len(inputs)):\n",
    "            hidden = self.rnncell(inputs[i], hidden) # hidden is the state for *next* timestep\n",
    "            outputs_hidden.append(hidden) # Append the state *after* processing current input\n",
    "\n",
    "        return torch.stack(outputs_hidden,dim=1), hidden # Stacked hidden states (B, S, H), final hidden state (B, H)\n",
    "\n",
    "\n",
    "class Model_RNN(nn.Module):\n",
    "    def __init__(self, hp):\n",
    "        super().__init__()\n",
    "        n_in,n_rnn,n_out = hp['n_in'],hp['n_rnn'],hp['n_out']\n",
    "        decay,act_str,bias = hp['decay'],hp['activation'],hp['use_bias']\n",
    "        clip_val = hp.get('grad_value_clip', hp.get('clip_value', 0.0)) # Clip value from hp, fallback to 'clip'\n",
    "\n",
    "        self.device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "\n",
    "        # Activation function setup\n",
    "        if act_str=='relu': nl=nn.ReLU()\n",
    "        elif act_str=='tanh': nl=nn.Tanh()\n",
    "        elif act_str=='relu-tanh':\n",
    "             nl=nn.ReLU(nn.Tanh())\n",
    "        else:\n",
    "            raise NotImplementedError(act_str)\n",
    "\n",
    "        self.n_rnn = n_rnn\n",
    "\n",
    "        # Standard RNN layer\n",
    "        self.rnn = StandardRNNLayer(n_in,n_rnn,nl,decay,bias) # Use renamed StandardRNNLayer\n",
    "\n",
    "        # Readout layer\n",
    "        self.readout = nn.Linear(n_rnn,n_out,bias=bias)\n",
    "        # Weight initialization for readout is standard for nn.Linear\n",
    "\n",
    "        # Gradient clipping hook\n",
    "        if clip_val > 0:\n",
    "            # print(f\"Model_RNN (Surrogate): Applying grad value clip hook: {clip_val}\") # Suppress during runs\n",
    "            for p in self.parameters():\n",
    "                if p.requires_grad:\n",
    "                     p.register_hook(lambda grad:torch.clamp(grad,-clip_val,clip_val))\n",
    "\n",
    "    def forward(self, x):\n",
    "        # x shape: (Batch, SeqLen, InputSize)\n",
    "        batch_size = x.shape[0]\n",
    "        # Initialize hidden state with zeros\n",
    "        hidden0 = torch.zeros(batch_size,1,self.n_rnn,device=self.device) # StandardRNNLayer expects (B, 1, H) for init\n",
    "        # Run the RNN layer\n",
    "        hid_seq, _ = self.rnn(x,hidden0) # hid_seq shape: (Batch, SeqLen, HiddenSize)\n",
    "        # Apply readout to the hidden state sequence\n",
    "        out = self.readout(hid_seq) # out shape: (Batch, SeqLen, OutputSize)\n",
    "        return out, hid_seq\n",
    "\n",
    "    def sync_weights(self, model_nm, nm_state_for_eff_W=None):\n",
    "        \"\"\"\n",
    "        Syncs the weights of the surrogate RNN model to match the effective\n",
    "        weights of the nmRNN model based on a reference NM state.\n",
    "        This method should only be called if model_nm has N_NM > 0.\n",
    "        \"\"\"\n",
    "        # Sync RNN Cell base weights (weight_ih, bias)\n",
    "        if hasattr(model_nm,'rnn_layer') and hasattr(model_nm.rnn_layer.cell,'weight_ih') and \\\n",
    "           hasattr(self,'rnn') and hasattr(self.rnn.rnncell,'weight_ih'):\n",
    "            self.rnn.rnncell.weight_ih.data.copy_(model_nm.rnn_layer.cell.weight_ih.data)\n",
    "        if hasattr(model_nm,'rnn_layer') and hasattr(model_nm.rnn_layer.cell,'bias') and \\\n",
    "           model_nm.rnn_layer.cell.bias is not None and \\\n",
    "           hasattr(self,'rnn') and hasattr(self.rnn.rnncell,'bias') and \\\n",
    "           self.rnn.rnncell.bias is not None:\n",
    "            self.rnn.rnncell.bias.data.copy_(model_nm.rnn_layer.cell.bias.data)\n",
    "\n",
    "        # Sync Recurrent weights (W_hh for surrogate = W0_nm + T_nm * nm_ref)\n",
    "        # weight0_hh in Model_nm_CombinedFeatures's cell is the W0 part\n",
    "        # This will be None if keepW0 is False, but we assume keepW0 is True based on HP\n",
    "        W0_nm = model_nm.rnn_layer.cell.weight0_hh\n",
    "\n",
    "        # weight_hh in Model_nm_CombinedFeatures's cell is the T_ijk tensor\n",
    "        # This will be None if N_NM is 0\n",
    "        T_hh_nm = model_nm.rnn_layer.cell.weight_hh\n",
    "\n",
    "        # Initialize surrogate's W_hh with zeros or W0 if it exists\n",
    "        current_W_eff_surrogate = torch.zeros_like(self.rnn.rnncell.weight_hh.data)\n",
    "        if W0_nm is not None:\n",
    "            current_W_eff_surrogate.copy_(W0_nm.data)\n",
    "\n",
    "        # Add the NM-modulated part if T_hh and nm_ref are available\n",
    "        # This block is only executed if model_nm.N_nm > 0, as checked by the caller\n",
    "        if T_hh_nm is not None and nm_state_for_eff_W is not None and model_nm.N_nm > 0:\n",
    "            nm_ref = nm_state_for_eff_W # Assuming nm_state_for_eff_W is already processed (e.g., averaged over batch/time)\n",
    "            # Ensure nm_ref is a 1D tensor of shape (N_NM,)\n",
    "            if nm_ref.dim() == 2 and nm_ref.shape[0] > 1: nm_ref = nm_ref.mean(dim=0) # Average over batch\n",
    "            elif nm_ref.dim() == 2 and nm_ref.shape[0] == 1: nm_ref = nm_ref.squeeze(0) # Remove batch dim if size 1\n",
    "            elif nm_ref.dim() == 0 and model_nm.N_nm == 1 : nm_ref = nm_ref.unsqueeze(0) # Handle scalar case for N_NM=1, B=1\n",
    "\n",
    "            if nm_ref.dim() == 1 and nm_ref.shape[0] == model_nm.N_nm:\n",
    "                # Calculate the modulated term: sum over N_nm dimension (k) of T_ijk * nm_k\n",
    "                # T_hh_nm is (H_out, H_in, N_nm)\n",
    "                # nm_ref is (N_nm,)\n",
    "                # einsum('ijn,n->ij', T_hh_nm.data, nm_ref.data) does (H_out, H_in, N), (N) -> (H_out, H_in)\n",
    "                W_eff_mod_term = torch.einsum('ijn,n->ij', T_hh_nm.data, nm_ref.data)\n",
    "                current_W_eff_surrogate += W_eff_mod_term\n",
    "\n",
    "        # Update the surrogate's W_hh parameter\n",
    "        self.rnn.rnncell.weight_hh = nn.Parameter(current_W_eff_surrogate.clone(), requires_grad=True)\n",
    "\n",
    "\n",
    "        # Sync Readout Layer (D_oik * nm_ref or standard D_oi)\n",
    "        # Check if the nmRNN model uses modulated readout (implies N_NM > 0 and flag is True)\n",
    "        if model_nm.rnn_layer.use_modulated_readout and nm_state_for_eff_W is not None:\n",
    "             # nm_ref was already calculated and averaged if needed from above\n",
    "             D_tensor = model_nm.rnn_layer.weight_readout_modulated.data # D_oik shape: (Output, Hidden, NM)\n",
    "\n",
    "             # Ensure nm_ref is correct shape before einsum\n",
    "             if nm_ref.dim() == 1 and nm_ref.shape[0] == model_nm.N_nm:\n",
    "                 # Calculate effective D: sum over NM dimension (k) of D_oik * nm_k\n",
    "                 effective_D_weight = torch.einsum('ohn,n->oh', D_tensor, nm_ref.data)\n",
    "                 self.readout.weight = nn.Parameter(effective_D_weight.clone(), requires_grad=True)\n",
    "\n",
    "             if hasattr(model_nm.rnn_layer, 'readout_bias') and model_nm.rnn_layer.readout_bias is not None and \\\n",
    "                hasattr(self.readout, 'bias') and self.readout.bias is not None:\n",
    "                  self.readout.bias.data.copy_(model_nm.rnn_layer.readout_bias.data)\n",
    "\n",
    "        # If nmRNN model uses a fixed readout (either N_NM=0 or use_modulated_readout is False)\n",
    "        # This branch should ideally not be reached if N_NM > 0 and modulated readout is used,\n",
    "        # but it's needed if N_NM=0 or modulated readout is off.\n",
    "        # However, if N_NM=0, this sync_weights method isn't called.\n",
    "        # If N_NM > 0 but modulated readout is OFF, sync the standard readout.\n",
    "        elif hasattr(model_nm.rnn_layer, 'readout_fc') and hasattr(self, 'readout'):\n",
    "            self.readout.weight.data.copy_(model_nm.rnn_layer.readout_fc.weight.data)\n",
    "            if model_nm.rnn_layer.readout_fc.bias is not None and self.readout.bias is not None:\n",
    "                 self.readout.bias.data.copy_(model_nm.rnn_layer.readout_fc.bias.data)\n",
    "\n",
    "\n",
    "# --- End of Model Definitions ---\n",
    "\n",
    "# --- Hyperparameters (Original set, will be copied and modified) ---\n",
    "# This is the base HP config, used for the NM=4 case after modification\n",
    "base_hp = {\n",
    "    'n_in': 3, 'n_out': 1, 'n_rnn': 128, 'N_NM': 4,\n",
    "    'decay': 0.95,\n",
    "    'activation': 'tanh',\n",
    "    'keepW0': True,\n",
    "    'use_bias': False,\n",
    "    'learning_rate': 1e-4,\n",
    "    'seed': 123,\n",
    "    'clip': 1.0,\n",
    "    'grad_value_clip': 0.1,\n",
    "    'l1_h': 0,\n",
    "    'l2_h': 0,\n",
    "    'l1_weight': 0,\n",
    "    'l2_weight': 0,\n",
    "    'l2_nmVelo': 1e-4, # NM velocity regularization\n",
    "    'use_spatial_weights': False, # Keep False based on original hp\n",
    "    'spatial_ell': 0.2,\n",
    "    'spatial_scale': 1.0,\n",
    "    'use_modulated_readout': False, # Keep False based on original hp\n",
    "    'use_nm_decoder_loss': True, # Keep True based on original hp\n",
    "    'nm_decoder_loss_weight': 1.0,\n",
    "    'nm_init_scale': 1.0, # Added initial scale for NM states\n",
    "}\n",
    "\n",
    "T_SETTLE = 50\n",
    "T_TRAIN = 100\n",
    "SEQ_LEN = T_SETTLE + T_TRAIN\n",
    "BATCH_SIZE = 64\n",
    "\n",
    "Z_COMPARE_STEPS = 10 # Steps interval for surrogate comparison metric calculation\n",
    "\n",
    "STEPS_PHASE1 = 5000\n",
    "STEPS_PHASE2 = 1000\n",
    "\n",
    "# Time steps tensor, moved outside functions as it's constant\n",
    "time_steps = torch.arange(SEQ_LEN, dtype=torch.float32).unsqueeze(0)\n",
    "\n",
    "# Data ranges for training\n",
    "STATIONARY_A_RANGE = [-0.5,0.5]\n",
    "STATIONARY_OMEGA_RANGE=[0.2,0.20001]\n",
    "STATIONARY_PHI_RANGE=[-0.1,0.1]\n",
    "INITIAL_A_RANGE=STATIONARY_A_RANGE\n",
    "INITIAL_OMEGA_RANGE=STATIONARY_OMEGA_RANGE\n",
    "MAX_A_RANGE=[-0.5,1.0]\n",
    "MAX_OMEGA_RANGE=[0.2, 0.20001]\n",
    "MAX_PHI_RANGE=[-0.1, 0.1]\n",
    "\n",
    "# Function to sample data batches\n",
    "def sample_batch_for_models(batch_size, seq_len, time_steps_tensor, phase, current_step=0, total_steps_phase2=STEPS_PHASE2):\n",
    "    \"\"\"Samples a batch of inputs, targets, and conditions for training.\"\"\"\n",
    "    if phase == 1:\n",
    "        a_min, a_max = STATIONARY_A_RANGE\n",
    "        omega_min, omega_max = STATIONARY_OMEGA_RANGE\n",
    "        phi_min, phi_max = STATIONARY_PHI_RANGE\n",
    "    elif phase == 2:\n",
    "        progress = min(current_step / total_steps_phase2, 1.0)\n",
    "        def interp_range(initial_range, max_range, prog):\n",
    "            imin, imax = initial_range\n",
    "            mmin, mmax = max_range\n",
    "            cmin = imin + prog * (mmin - imin)\n",
    "            cmax = imax + prog * (mmax - imax)\n",
    "            return cmin, cmax\n",
    "        a_min, a_max = interp_range(INITIAL_A_RANGE, MAX_A_RANGE, progress)\n",
    "        omega_min, omega_max = interp_range(INITIAL_OMEGA_RANGE, MAX_OMEGA_RANGE, progress)\n",
    "        phi_min, phi_max = interp_range(STATIONARY_PHI_RANGE, MAX_PHI_RANGE, progress)\n",
    "    else:\n",
    "        raise ValueError(\"Phase must be 1 or 2\")\n",
    "\n",
    "    A_raw = torch.rand(batch_size) * (a_max - a_min) + a_min\n",
    "    omega = torch.rand(batch_size) * (omega_max - omega_min) + omega_min\n",
    "    phi = torch.rand(batch_size) * (phi_max - phi_min) + phi_min\n",
    "\n",
    "    # Amplitude should be non-negative for target sine wave\n",
    "    A = torch.clamp(A_raw, min=0.0)\n",
    "\n",
    "    target_wave = A.unsqueeze(1) * torch.sin(omega.unsqueeze(1) * time_steps_tensor + phi.unsqueeze(1))\n",
    "    targets = target_wave.unsqueeze(-1) # Add output dimension\n",
    "\n",
    "    # Conditions to potentially decode (A_raw, omega, phi)\n",
    "    conditions = torch.stack([A_raw, omega, phi], dim=1) # Shape (Batch, 3)\n",
    "\n",
    "    # Input is the conditions broadcast across the sequence length\n",
    "    inputs = conditions.unsqueeze(1).expand(-1, seq_len, -1) # Shape (Batch, SeqLen, 3)\n",
    "\n",
    "    return inputs, targets, conditions\n",
    "\n",
    "\n",
    "# Function to save intermediate training plots for the movie\n",
    "def save_training_plot_frame(step, logs, model, model_surrogate, inputs, targets, nm_s, t_settle, hp, movie_dir, frame_counter):\n",
    "    \"\"\"Generates and saves a single frame plot of training progress.\"\"\"\n",
    "    model.eval() # Set model to evaluation mode for plotting inference\n",
    "    with torch.no_grad():\n",
    "        inputs_dev = inputs[:4].to(next(model.parameters()).device) # Plot first few batch items\n",
    "        targets_dev = targets[:4].to(next(model.parameters()).device)\n",
    "        # nm_s is already on device from train_step, take first few batch items\n",
    "        nm_s_plot_data = nm_s[:4] if nm_s is not None else None\n",
    "\n",
    "        # Run model forward to get output and states for plotting\n",
    "        fwd_out = model(inputs_dev)\n",
    "        output = fwd_out[0]\n",
    "        hid_s_plot = fwd_out[1]\n",
    "        nm_s_plot = fwd_out[2] # This will be None if N_NM is 0\n",
    "\n",
    "        # Plot configuration depends on whether NM states exist\n",
    "        num_subplots = 4 if hp['N_NM'] > 0 else 4\n",
    "        fig, axs = plt.subplots(1, num_subplots, figsize=([16,3] if hp['N_NM'] > 0 else [12,3]), squeeze=False)\n",
    "        axs = axs.flatten() # Flatten to easily index\n",
    "\n",
    "        idx_plt = 0\n",
    "\n",
    "        # Plot outputs vs targets\n",
    "        axs[idx_plt].plot(targets_dev[:,t_settle:,0].detach().cpu().numpy().T,'--',label=\"Tgt\",color='k',alpha=0.7)\n",
    "        axs[idx_plt].plot(output[:,t_settle:,0].detach().cpu().numpy().T,label=\"Out\",alpha=0.8)\n",
    "        axs[idx_plt].set_ylim([-0.5,0.5])\n",
    "        axs[idx_plt].set_title(f\"S {step+1} Output (Train)\")\n",
    "        axs[idx_plt].set_xlabel(\"Time Steps\")\n",
    "        axs[idx_plt].set_ylabel(\"Amplitude\")\n",
    "        # Add legend if needed, maybe outside the loop\n",
    "        # axs[idx_plt].legend(fontsize=8)\n",
    "        idx_plt += 1\n",
    "\n",
    "        # Plot NM states if they exist (N_NM > 0)\n",
    "        if hp['N_NM'] > 0 and nm_s_plot is not None:\n",
    "            for q_nm in range(min(hp['N_NM'],4)): # Plot up to 4 NM states\n",
    "                axs[idx_plt].plot(nm_s_plot[0,:,q_nm].detach().cpu().numpy(),label=f'NM{q_nm}')\n",
    "            axs[idx_plt].axvspan(0,t_settle,color='gray',alpha=0.2);\n",
    "            axs[idx_plt].set_title(\"NM States\")\n",
    "            axs[idx_plt].set_xlabel(\"Time Steps\")\n",
    "            axs[idx_plt].set_ylabel(\"NM Value\")\n",
    "            axs[idx_plt].legend(fontsize=8)\n",
    "            idx_plt += 1\n",
    "        else:\n",
    "            # Hide the NM plot if N_NM is 0\n",
    "            axs[idx_plt].set_visible(False)\n",
    "            idx_plt += 1 # Still increment to move to the next subplot index\n",
    "\n",
    "\n",
    "        # Plot Loss Curves\n",
    "        # Note: logs list contains values per log interval, not per step\n",
    "        log_steps = np.arange(len(logs['loss_main'])) * (logs['_log_interval_val'] if '_log_interval_val' in logs else 1) # Use actual log interval\n",
    "        axs[idx_plt].plot(log_steps, logs['loss_main'],label='Main Loss')\n",
    "        if logs['loss_total']: axs[idx_plt].plot(log_steps, logs['loss_total'],label='Total Loss', alpha=0.7)\n",
    "        if hp.get('use_nm_decoder_loss', False) and logs['loss_nm_decode']: axs[idx_plt].plot(log_steps, logs['loss_nm_decode'],label='NM Decode Loss', alpha=0.7)\n",
    "\n",
    "        axs[idx_plt].set_yscale('log')\n",
    "        axs[idx_plt].set_title(\"Logged Losses\")\n",
    "        axs[idx_plt].set_xlabel(\"Training Steps\")\n",
    "        axs[idx_plt].set_ylabel(\"Loss Value (log scale)\")\n",
    "        axs[idx_plt].legend(loc='upper left', fontsize=8)\n",
    "        axs[idx_plt].grid(True)\n",
    "        idx_plt += 1\n",
    "\n",
    "        # Plot Comparison Metrics if available (only if N_NM > 0 and surrogate exists)\n",
    "        if model_surrogate is not None and logs['cos']: # Check if surrogate exists AND comparison logs are present\n",
    "            # Comparison metrics are logged at a different cadence (more often than plot cadence)\n",
    "            # Need to map logs['cos'] indices to steps correctly\n",
    "            comp_log_interval = logs.get('_comp_log_interval_val', 1)\n",
    "            comp_log_steps = np.arange(len(logs['cos'])) * comp_log_interval\n",
    "\n",
    "            axs[idx_plt].plot(comp_log_steps, logs['cos'], label='Avg Cosine Sim')\n",
    "            # axs[idx_plt].plot(comp_log_steps, logs['dot'], label='Avg Dot Prod', alpha=0.7) # Optionally plot dot product\n",
    "            axs[idx_plt].set_title(\"Comparison Metrics\")\n",
    "            axs[idx_plt].set_xlabel(\"Training Steps\")\n",
    "            axs[idx_plt].set_ylabel(\"Metric Value\")\n",
    "            axs[idx_plt].legend(fontsize=8)\n",
    "            axs[idx_plt].grid(True)\n",
    "        else:\n",
    "            # Hide the comparison plot if N_NM is 0 or no comparison logs\n",
    "            axs[idx_plt].set_visible(False)\n",
    "\n",
    "\n",
    "        plt.tight_layout()\n",
    "\n",
    "        # Save the figure\n",
    "        frame_filename = os.path.join(movie_dir, f\"{frame_counter:06d}.png\")\n",
    "        plt.savefig(frame_filename)\n",
    "        plt.close(fig) # Close the figure to free memory\n",
    "\n",
    "        model.train() # Set model back to training mode\n",
    "\n",
    "        return frame_counter + 1 # Return updated counter\n",
    "\n",
    "\n",
    "# Function to train the model and optionally the surrogate\n",
    "# Pass model_surrogate as None if N_NM=0\n",
    "def train_dynamic_comparison(model, model_surrogate, phase, total_steps, steps_phase2, hp, device, time_steps_tensor, t_settle, movie_dir=None):\n",
    "    \"\"\"Trains the model and calculates comparison metrics (if surrogate is provided).\"\"\"\n",
    "    criterion = nn.MSELoss()\n",
    "    # Use separate optimizers if surrogate were trained, but here it's just for grad calculation\n",
    "    # So we only need optimizer for the main model\n",
    "    optimizer = optim.Adam(filter(lambda p:p.requires_grad, model.parameters()),lr=hp['learning_rate'])\n",
    "\n",
    "    model.to(device)\n",
    "    # Only move surrogate to device if it exists\n",
    "    if model_surrogate is not None:\n",
    "        model_surrogate.to(device)\n",
    "\n",
    "    time_steps_tensor_dev = time_steps_tensor.to(device)\n",
    "\n",
    "    phase_name = \"Stationary\" if phase==1 else \"Curriculum\"\n",
    "    print(f\"\\n--- Train Phase {phase}: {phase_name} ({total_steps} steps) ---\")\n",
    "    print(f\"Settings: SpatialW={hp.get('use_spatial_weights',False)}, ModReadout={hp.get('use_modulated_readout',False)}, NMDecodeLoss={hp.get('use_nm_decoder_loss',False)}\")\n",
    "    print(f\"Loss calculated from T_settle={t_settle}. Total SEQ_LEN={time_steps_tensor_dev.size(1)}\")\n",
    "\n",
    "    # Determine if surrogate comparison is possible based on model structure, N_NM, AND if surrogate was provided\n",
    "    comparison_possible = (model_surrogate is not None and model.N_nm > 0 and\n",
    "                           hasattr(model,'rnn_layer') and hasattr(model.rnn_layer.cell,'weight_hh') and\n",
    "                           model.rnn_layer.cell.weight_hh is not None and\n",
    "                           hasattr(model_surrogate,'rnn') and hasattr(model_surrogate.rnn.rnncell,'weight_hh'))\n",
    "\n",
    "    if comparison_possible:\n",
    "        T_hh_nm = model.rnn_layer.cell.weight_hh\n",
    "        surr_w_target = model_surrogate.rnn.rnncell.weight_hh\n",
    "        if T_hh_nm is None or T_hh_nm.shape[:2]!=surr_w_target.shape[:2] or T_hh_nm.shape[2]!=hp['N_NM']:\n",
    "            print(\"Warn: T_hh/Surr W_hh dim mismatch or T_hh is None. Comparison OFF.\")\n",
    "            comparison_possible = False\n",
    "        # else: print(\"Comparison logic enabled.\")\n",
    "    # else: print(\"Comparison logic OFF (N_NM=0 or surrogate not provided).\")\n",
    "\n",
    "\n",
    "    # Logging and Plotting intervals\n",
    "    log_interval = 10 # Log to console every 10 steps\n",
    "    plot_interval = log_interval * 50 # Save plot frame every 500 steps (10*50)\n",
    "\n",
    "    # Store logs\n",
    "    logs = {'loss_main':[], 'loss_total':[], 'loss_nm_decode':[],\n",
    "            '_log_interval_val': log_interval} # Store intervals for plotting x-axis\n",
    "    # Only add comparison logs if comparison is possible\n",
    "    if comparison_possible:\n",
    "        logs['cos'] = []\n",
    "        logs['dot'] = []\n",
    "        logs['_comp_log_interval_val'] = log_interval // 5 if log_interval > 20 else 1 # Comparison is logged more often\n",
    "\n",
    "\n",
    "    start_time = time.time()\n",
    "    frame_counter = 0 # Counter for movie frames\n",
    "\n",
    "    for step in range(total_steps):\n",
    "        model.train() # Set model to training mode\n",
    "\n",
    "        # Sample batch (curriculum learning handled by phase and current_step)\n",
    "        curr_step_ph2 = step if phase==2 else 0\n",
    "        inputs,targets,conds = sample_batch_for_models(BATCH_SIZE,SEQ_LEN,time_steps_tensor_dev,phase,curr_step_ph2,steps_phase2)\n",
    "\n",
    "        optimizer.zero_grad()\n",
    "\n",
    "        # Forward pass\n",
    "        # Model_nm_CombinedFeatures always returns 4 elements\n",
    "        output, hid_s, nm_s, decoded_conds = model(inputs)\n",
    "        # output: (B, S, O), hid_s: (B, S, H), nm_s: (B, S, N) or None, decoded_conds: (B, 3) or None\n",
    "\n",
    "        # Calculate losses\n",
    "        # Main loss (output prediction after settle period)\n",
    "        loss_main = criterion(output[:,t_settle:,:],targets[:,t_settle:,:]) if output.size(1)>t_settle else criterion(output,targets)\n",
    "\n",
    "        # Regularization loss (e.g., NM velocity)\n",
    "        loss_r = torch.tensor(0.0,device=device)\n",
    "        # Only calculate NM velocity loss if N_NM > 0 and nm_s exists\n",
    "        if hp.get('l2_nmVelo',0)>0 and nm_s is not None and nm_s.size(1)>1:\n",
    "            loss_r += torch.diff(nm_s,dim=1).pow(2).mean()*hp['l2_nmVelo']\n",
    "\n",
    "        # NM decoder loss\n",
    "        loss_nm_d = torch.tensor(0.0,device=device)\n",
    "        # Only calculate NM decoder loss if use_nm_decoder is True and decoded_conds exists\n",
    "        if model.use_nm_decoder and decoded_conds is not None:\n",
    "             # Calculate loss between decoded conditions and actual conditions\n",
    "             loss_nm_d = criterion(decoded_conds, conds)\n",
    "\n",
    "\n",
    "        # Total loss\n",
    "        loss_tot = loss_main + loss_r + loss_nm_d * hp.get('nm_decoder_loss_weight',0.0)\n",
    "\n",
    "        # Backward pass\n",
    "        loss_tot.backward()\n",
    "\n",
    "        # Calculate comparison metrics frequently, but log them less often\n",
    "        # Only perform comparison if comparison_possible is True\n",
    "        if comparison_possible and (step+1)%logs['_comp_log_interval_val']==0:\n",
    "             # Calculate the gradient of the surrogate's effective W_hh\n",
    "             # Need a reference NM state to sync the surrogate\n",
    "             # Use the average NM state over the training period of the batch\n",
    "             # nm_s will not be None here because comparison_possible implies N_NM > 0\n",
    "             nm_state_for_eff_W = nm_s[:,t_settle:,:].mean(dim=1) if nm_s.size(1)>t_settle else nm_s.mean(dim=1)\n",
    "\n",
    "             # model_surrogate is guaranteed to exist here because comparison_possible is True\n",
    "             model_surrogate.eval() # Set surrogate to eval mode\n",
    "             # Sync surrogate weights with the current main model weights and reference NM state\n",
    "             model_surrogate.sync_weights(model, nm_state_for_eff_W)\n",
    "\n",
    "             # Calculate gradient of surrogate loss w.r.t its W_hh\n",
    "             w_hh_surr = model_surrogate.rnn.rnncell.weight_hh\n",
    "             w_hh_surr.requires_grad_(True) # Ensure surrogate W_hh requires grad for this calculation\n",
    "             if w_hh_surr.grad is not None: w_hh_surr.grad.zero_() # Clear any previous grads\n",
    "\n",
    "             # Calculate surrogate's forward pass and loss\n",
    "             with torch.enable_grad(): # Ensure gradients are calculated for this part\n",
    "                 out_surr, _ = model_surrogate(inputs) # Use the same inputs as the main model\n",
    "                 # Surrogate loss over the same training period\n",
    "                 loss_surr_f = criterion(out_surr[:,t_settle:,:],targets[:,t_settle:,:]) if out_surr.size(1)>t_settle else criterion(out_surr,targets)\n",
    "\n",
    "                 try:\n",
    "                     # Calculate gradient of surrogate loss w.r.t. its effective W_hh\n",
    "                     # This is dL/dW_eff\n",
    "                     grad_W_eff = torch.autograd.grad(loss_surr_f, w_hh_surr, retain_graph=False)[0] # retain_graph=False is fine after grad\n",
    "                     valid_grad = grad_W_eff is not None\n",
    "                     if valid_grad: surr_grad_Weff_flat = grad_W_eff.detach().view(-1) # Flatten for comparison\n",
    "                 except Exception as e:\n",
    "                     # print(f\"Surrogate grad calculation failed at step {step+1}: {e}\") # Suppress during runs\n",
    "                     valid_grad = False # Mark as invalid if grad calculation fails\n",
    "\n",
    "             # Calculate the expected change in W_eff from NM velocity\n",
    "             comp_cos, comp_dot = [],[]\n",
    "             if valid_grad and nm_s is not None and nm_s.size(1) > 1:\n",
    "                  with torch.no_grad(): # Do not track gradients for this comparison calculation\n",
    "                      T_hh_detached = model.rnn_layer.cell.weight_hh.detach() # Get the T_ijk tensor\n",
    "                      T_hh_p = T_hh_detached.permute(2,0,1) # (N_nm, H_out, H_in)\n",
    "\n",
    "                      # Iterate over comparison steps interval\n",
    "                      for t in range(t_settle+Z_COMPARE_STEPS-1, SEQ_LEN): # Check timesteps after settle period\n",
    "                          if t >= nm_s.size(1) or t-1 < 0: continue # Ensure indices are valid\n",
    "\n",
    "                          # Calculate NM velocity (change in NM state) at this timestep\n",
    "                          n_dt = nm_s[:,t,:] - nm_s[:,t-1,:] # (B, N_nm)\n",
    "\n",
    "                          try:\n",
    "                              # Calculate the expected change in W_eff: dW_eff_ij = sum_k T_ijk * dn_k\n",
    "                              delta_W_eff_batched = torch.einsum('kji,bk->bij', T_hh_p, n_dt).view(inputs.size(0), -1) # Flatten for comparison (B, H*H)\n",
    "\n",
    "                              # The gradient is dL/dW_eff. We are comparing it to the *expected change in W_eff* from NM velocity.\n",
    "                              # The paper often relates dL/dW_eff to the *gradient of the loss w.r.t. NM states*,\n",
    "                              # or relates dW_eff to the *negative* gradient of loss w.r.t W_eff.\n",
    "                              # The original code compared delta_W_eff to *negative* surr_grad_Weff_flat. Let's stick to that.\n",
    "\n",
    "                              # Calculate cosine similarity and dot product\n",
    "                              # unsqueeze surr_grad_Weff_flat to (1, H*H) for batch comparison if it's 1D\n",
    "                              surr_grad_Weff_batched = surr_grad_Weff_flat.unsqueeze(0).expand_as(delta_W_eff_batched) # (B, H*H)\n",
    "\n",
    "                              # Cosine similarity between dW_eff and -dL/dW_eff\n",
    "                              cos = nn.functional.cosine_similarity(delta_W_eff_batched, -surr_grad_Weff_batched, dim=1)\n",
    "                              # Dot product between dW_eff and -dL/dW_eff\n",
    "                              dot = torch.sum(delta_W_eff_batched * (-surr_grad_Weff_batched), dim=1)\n",
    "\n",
    "                              # Append mean over batch\n",
    "                              comp_cos.append(torch.nan_to_num(cos,0.0).mean().item())\n",
    "                              comp_dot.append(torch.nan_to_num(dot,0.0).mean().item())\n",
    "\n",
    "                          except RuntimeError as e:\n",
    "                              # print(f\"Comparison metric calculation failed at step {step+1}, time {t}: {e}\") # Suppress during runs\n",
    "                              pass # Skip this step if calculation fails\n",
    "\n",
    "             if comp_cos: # Only append if calculation was successful for at least one step\n",
    "                 logs['cos'].append(np.mean(comp_cos))\n",
    "                 logs['dot'].append(np.mean(comp_dot))\n",
    "         # else:\n",
    "             # print(f\"Skipping comparison at step {step+1}: comparison_possible is False.\") # Suppress during runs\n",
    "\n",
    "\n",
    "        # Apply gradient clipping if specified in hp\n",
    "        if hp.get('clip',0)>0:\n",
    "             torch.nn.utils.clip_grad_norm_(filter(lambda p:p.requires_grad,model.parameters()),hp['clip'])\n",
    "\n",
    "        # Optimizer step\n",
    "        optimizer.step()\n",
    "\n",
    "        # Logging to console\n",
    "        if (step+1)%log_interval==0 or step==0 or step==total_steps-1:\n",
    "            el_time=time.time()-start_time\n",
    "            log = f\"P{phase} S [{step+1}/{total_steps}], Loss:{loss_main.item():.4f}, RegLoss:{loss_r.item():.4f}\"\n",
    "            # Only report NM decode loss if it's used\n",
    "            if model.use_nm_decoder: log+=f\", NMDec:{loss_nm_d.item():.4f}\"\n",
    "            # Only report comparison metrics if logged in this log interval\n",
    "            if comparison_possible and logs['cos'] and (step+1)%(logs['_comp_log_interval_val'])==0 :\n",
    "                 log+=f\", CosSim:{logs['cos'][-1]:.3f}, DotProd:{logs['dot'][-1]:.3f}\"\n",
    "            log+=f\", T:{el_time:.1f}s\"; print(log)\n",
    "\n",
    "            # Store losses for plotting later\n",
    "            logs['loss_main'].append(loss_main.item())\n",
    "            logs['loss_total'].append(loss_tot.item()) # Store total loss too\n",
    "            # Only store nm decode loss if it's used\n",
    "            if model.use_nm_decoder and loss_nm_d is not None :\n",
    "                 logs['loss_nm_decode'].append(loss_nm_d.item())\n",
    "\n",
    "            start_time=time.time() # Reset timer\n",
    "\n",
    "        # Save training plot frame for movie\n",
    "        if movie_dir is not None and ((step+1)%plot_interval==0 or step==0 or step==total_steps-1):\n",
    "             frame_counter = save_training_plot_frame(\n",
    "                 step, logs, model, model_surrogate, inputs, targets, nm_s, t_settle, hp, movie_dir, frame_counter\n",
    "             )\n",
    "\n",
    "\n",
    "    print(f\"Phase {phase} training complete.\")\n",
    "    model.eval() # Set model to evaluation mode after training\n",
    "    return logs # Return the accumulated logs\n",
    "\n",
    "\n",
    "# Function to plot final results after training\n",
    "# Pass model_surrogate as None if N_NM=0\n",
    "def plot_final_results(model, model_surrogate, hp, analysis_inputs, analysis_targets_cpu, t_settle, save_dir, experiment_name, all_logs):\n",
    "    \"\"\"Generates and saves final plots: outputs, dynamics, losses, and comparison metrics.\"\"\"\n",
    "    print(\"\\n--- Generating Final Plots ---\")\n",
    "\n",
    "    # Define plot directory\n",
    "    plot_dir = os.path.join(save_dir, 'plots')\n",
    "    os.makedirs(plot_dir, exist_ok=True)\n",
    "\n",
    "    # --- Plot 1: Outputs vs Targets ---\n",
    "    fig_out, ax_out = plt.subplots(1,1,figsize=(10,5))\n",
    "    # Use the first batch item for analysis plotting\n",
    "    plot_outputs(model, analysis_inputs[0:1], analysis_targets_cpu[0], ax_out, t_settle, f\"({experiment_name})\")\n",
    "    fig_out.suptitle(f\"Output (Settle={T_SETTLE},Train={T_TRAIN})\");\n",
    "    fig_out.tight_layout(rect=[0,0.03,1,0.95]);\n",
    "    plt.savefig(os.path.join(plot_dir, f'{experiment_name}_outputs.png'))\n",
    "    plt.close(fig_out) # Close figure\n",
    "\n",
    "    # --- Plot 2: Hidden and NM Dynamics ---\n",
    "    # Plot configuration depends on whether NM states exist (N_NM > 0)\n",
    "    num_dyn_plots = 2 if hp['N_NM']>0 else 1\n",
    "    fig_dyn, axs_dyn = plt.subplots(1, num_dyn_plots, figsize=(12 if hp['N_NM']>0 else 7,6), squeeze=False)\n",
    "    axs_dyn = axs_dyn.flatten() # Flatten to easily index\n",
    "\n",
    "    # Use the first batch item for analysis plotting\n",
    "    plot_hidden_nm_states(model, analysis_inputs[0:1], axs_dyn[0], axs_dyn[1] if hp['N_NM']>0 else None, f\"({experiment_name})\")\n",
    "    fig_dyn.suptitle(f\"Internal Dynamics\");\n",
    "    fig_dyn.tight_layout(rect=[0,0.03,1,0.95]);\n",
    "    plt.savefig(os.path.join(plot_dir, f'{experiment_name}_dynamics.png'))\n",
    "    plt.close(fig_dyn) # Close figure\n",
    "\n",
    "    # --- Plot 3: Comparison Metrics (if available and N_NM > 0) ---\n",
    "    # Check if comparison metrics were logged at all AND if N_NM > 0\n",
    "    comparison_logged = (hp['N_NM'] > 0 and any(all_logs.get(k, []) for k in ['cos', 'dot']))\n",
    "    if comparison_logged:\n",
    "         fig_met,axs_met=plt.subplots(1,2,figsize=(15,5),sharex=True)\n",
    "         # Plot Cosine Similarity\n",
    "         if all_logs.get('cos', []):\n",
    "             # Need x-axis values matching log intervals\n",
    "             comp_log_interval = all_logs.get('_comp_log_interval_val', 1)\n",
    "             comp_log_steps = np.arange(len(all_logs['cos'])) * comp_log_interval\n",
    "             axs_met[0].plot(comp_log_steps, all_logs['cos']);\n",
    "             axs_met[0].set_title('NM Effect vs -SurrGrad (CosSim)');\n",
    "             axs_met[0].set_ylabel('Avg Cosine Sim');\n",
    "             axs_met[0].grid(True)\n",
    "             axs_met[0].set_xlabel('Training Steps') # Set xlabel here\n",
    "         else:\n",
    "             axs_met[0].set_visible(False) # Hide subplot if no data\n",
    "\n",
    "         # Plot Dot Product\n",
    "         if all_logs.get('dot', []):\n",
    "             comp_log_interval = all_logs.get('_comp_log_interval_val', 1)\n",
    "             comp_log_steps = np.arange(len(all_logs['dot'])) * comp_log_interval\n",
    "             axs_met[1].plot(comp_log_steps, all_logs['dot']);\n",
    "             axs_met[1].set_title('NM Effect vs -SurrGrad (DotProd)');\n",
    "             axs_met[1].set_ylabel('Avg Dot Product');\n",
    "             axs_met[1].grid(True)\n",
    "             axs_met[1].set_xlabel('Training Steps') # Set xlabel here\n",
    "         else:\n",
    "             axs_met[1].set_visible(False) # Hide subplot if no data\n",
    "\n",
    "         fig_met.suptitle(f\"Comparison Metrics ({experiment_name})\");\n",
    "         fig_met.tight_layout(rect=[0,0.03,1,0.95]);\n",
    "         plt.savefig(os.path.join(plot_dir, f'{experiment_name}_comparison_metrics.png'))\n",
    "         plt.close(fig_met) # Close figure\n",
    "\n",
    "    # --- Plot 4: Loss Curves ---\n",
    "    # Determine number of loss subplots needed\n",
    "    num_loss_plots = 0\n",
    "    if 'loss_main' in all_logs and all_logs['loss_main']: num_loss_plots += 1\n",
    "    if 'loss_total' in all_logs and all_logs['loss_total']: num_loss_plots += 1\n",
    "    if hp.get('use_nm_decoder_loss', False) and 'loss_nm_decode' in all_logs and all_logs['loss_nm_decode']: num_loss_plots += 1\n",
    "\n",
    "    if num_loss_plots > 0:\n",
    "         fig_loss,axs_loss=plt.subplots(1, num_loss_plots, figsize=(6 * num_loss_plots,5),sharex=True, squeeze=False)\n",
    "         axs_loss = axs_loss.flatten() # Flatten to easily index\n",
    "         pidx = 0\n",
    "\n",
    "         # Get x-axis values based on logging interval\n",
    "         log_interval_val = all_logs.get('_log_interval_val', 1)\n",
    "         # Only generate log_steps if there's main loss data to plot\n",
    "         if 'loss_main' in all_logs and all_logs['loss_main']:\n",
    "             log_steps = np.arange(len(all_logs['loss_main'])) * log_interval_val\n",
    "         else:\n",
    "             log_steps = [] # Should not happen if num_loss_plots > 0, but for safety\n",
    "\n",
    "\n",
    "         if 'loss_main' in all_logs and all_logs['loss_main']:\n",
    "              axs_loss[pidx].plot(log_steps, all_logs['loss_main']);\n",
    "              axs_loss[pidx].set_title(\"Main Loss\");\n",
    "              axs_loss[pidx].set_ylabel(\"MSE\");\n",
    "              axs_loss[pidx].grid(True);\n",
    "              axs_loss[pidx].set_yscale('log');\n",
    "              axs_loss[pidx].set_xlabel(\"Training Steps\")\n",
    "              pidx+=1\n",
    "         if 'loss_total' in all_logs and all_logs['loss_total']:\n",
    "              axs_loss[pidx].plot(log_steps, all_logs['loss_total']);\n",
    "              axs_loss[pidx].set_title(\"Total Loss\");\n",
    "              axs_loss[pidx].set_ylabel(\"Value\");\n",
    "              axs_loss[pidx].grid(True);\n",
    "              axs_loss[pidx].set_yscale('log');\n",
    "              axs_loss[pidx].set_xlabel(\"Training Steps\")\n",
    "              pidx+=1\n",
    "         if hp.get('use_nm_decoder_loss', False) and 'loss_nm_decode' in all_logs and all_logs['loss_nm_decode']:\n",
    "              axs_loss[pidx].plot(log_steps, all_logs['loss_nm_decode']);\n",
    "              axs_loss[pidx].set_title(\"NM Decode Loss\");\n",
    "              axs_loss[pidx].set_ylabel(\"MSE\");\n",
    "              axs_loss[pidx].grid(True);\n",
    "              axs_loss[pidx].set_yscale('log')\n",
    "              axs_loss[pidx].set_xlabel(\"Training Steps\")\n",
    "              # pidx+=1 # Not needed after the last plot\n",
    "\n",
    "         fig_loss.suptitle(f\"Loss Curves ({experiment_name})\");\n",
    "         fig_loss.tight_layout(rect=[0,0.03,1,0.95]);\n",
    "         plt.savefig(os.path.join(plot_dir, f'{experiment_name}_loss_curves.png'))\n",
    "         plt.close(fig_loss) # Close figure\n",
    "\n",
    "\n",
    "# Helper plotting functions (adapted from original)\n",
    "def plot_outputs(model, input_tensor, target_numpy, ax, t_settle, title_suffix=\"\"):\n",
    "    \"\"\"Plots model output vs target.\"\"\"\n",
    "    model.eval() # Set model to eval mode\n",
    "    seq_len_plot = target_numpy.shape[0]\n",
    "    with torch.no_grad():\n",
    "        # input_tensor is a batch of 1 here\n",
    "        input_dev = input_tensor.to(next(model.parameters()).device)\n",
    "        # Model_nm_CombinedFeatures always returns 4 elements\n",
    "        fwd_out = model(input_dev)\n",
    "        output_tensor = fwd_out[0]\n",
    "        output_np = output_tensor.squeeze(0).cpu().numpy() # Remove batch dim, move to numpy\n",
    "\n",
    "    time_f=np.arange(seq_len_plot) # Full time steps\n",
    "    time_t=np.arange(t_settle,seq_len_plot) # Time steps after settle\n",
    "\n",
    "    # Plot full trajectory (lighter color)\n",
    "    ax.plot(time_f,target_numpy[:,0],'--',c='gray',alpha=0.8,label='Target (Full)')\n",
    "    ax.plot(time_f,output_np[:,0],c='salmon',alpha=0.7,label='Output (Full)')\n",
    "\n",
    "    # Plot training period trajectory (bolder color)\n",
    "    if t_settle < seq_len_plot:\n",
    "        ax.plot(time_t,target_numpy[t_settle:,0],'--',c='k',lw=2, label='Target (Train)')\n",
    "        ax.plot(time_t,output_np[t_settle:,0],c='cornflowerblue',lw=2,label=\"Output (Train)\") # Use different blue\n",
    "\n",
    "    ax.axvline(t_settle,c='k',ls=':',label=f'T_settle');\n",
    "    ax.set_title(f\"Output {title_suffix}\")\n",
    "    ax.set_xlabel(\"Time Steps\");\n",
    "    ax.set_ylabel(\"Amplitude\");\n",
    "    ax.legend();\n",
    "    ax.grid(True)\n",
    "\n",
    "def plot_hidden_nm_states(model, input_tensor, ax_h, ax_nm, title_suffix=\"\"):\n",
    "    \"\"\"Plots hidden and NM state trajectories.\"\"\"\n",
    "    model.eval() # Set model to eval mode\n",
    "    with torch.no_grad():\n",
    "        # input_tensor is a batch of 1 here\n",
    "        input_dev = input_tensor.to(next(model.parameters()).device)\n",
    "        # Model_nm_CombinedFeatures always returns 4 elements\n",
    "        fwd_out = model(input_dev)\n",
    "        hid_s = fwd_out[1].squeeze(0).cpu().numpy() # Hidden states are always returned\n",
    "        nm_s = fwd_out[2].squeeze(0).cpu().numpy() if fwd_out[2] is not None else None # NM states are None if N_NM=0\n",
    "\n",
    "    # Plot Hidden State Dynamics (assuming at least 2 dimensions)\n",
    "    ax_h.set_title(f\"Hidden Dynamics {title_suffix}\");\n",
    "    ax_h.set_xlabel(\"Hidden Dim 0\");\n",
    "    ax_h.set_ylabel(\"Hidden Dim 1\");\n",
    "    ax_h.grid(True)\n",
    "    if hid_s is not None and hid_s.shape[1]>=2:\n",
    "        ax_h.plot(hid_s[:,0],hid_s[:,1],alpha=0.7,label=\"H Traj\",c='b')\n",
    "        # Plot start point\n",
    "        ax_h.scatter(hid_s[0,0],hid_s[0,1],marker='o',s=50,label=\"H0\",c='b',edgecolors='k', zorder=5)\n",
    "    elif hid_s is not None:\n",
    "         # If only 1 hidden dimension, plot vs time\n",
    "         ax_h.plot(np.arange(hid_s.shape[0]), hid_s[:, 0], alpha=0.7, label=\"H0 vs Time\", c='b')\n",
    "         ax_h.set_xlabel(\"Time Steps\"); ax_h.set_ylabel(\"Hidden Dim 0 Value\")\n",
    "\n",
    "    ax_h.legend(loc='best')\n",
    "\n",
    "    # Plot NM State Dynamics (if NM states exist and N_NM > 0)\n",
    "    if nm_s is not None and ax_nm is not None: # Check nm_s is not None AND ax_nm is provided\n",
    "        ax_nm.set_title(f\"NM Dynamics {title_suffix}\");\n",
    "        ax_nm.grid(True)\n",
    "        if nm_s.shape[1]>=2:\n",
    "            # Plot NM trajectory if at least 2 NM dimensions\n",
    "            ax_nm.set_xlabel(\"NM Dim 0\");\n",
    "            ax_nm.set_ylabel(\"NM Dim 1\")\n",
    "            ax_nm.plot(nm_s[:,0],nm_s[:,1],alpha=0.7,ls='--',label=\"NM Traj\",c='g')\n",
    "            # Plot start point\n",
    "            ax_nm.scatter(nm_s[0,0],nm_s[0,1],marker='o',s=50,label=\"NM0\",c='g',edgecolors='k', zorder=5)\n",
    "        elif nm_s.shape[1]==1:\n",
    "            # If only 1 NM dimension, plot vs time\n",
    "            ax_nm.plot(np.arange(nm_s.shape[0]),nm_s[:,0],alpha=0.7,ls='--',label=\"NM0 vs Time\",c='g')\n",
    "            ax_nm.set_xlabel(\"Time Steps\");\n",
    "            ax_nm.set_ylabel(\"NM0 Value\")\n",
    "        ax_nm.legend(loc='best')\n",
    "    elif ax_nm is not None:\n",
    "        # Hide the NM subplot if N_NM is 0 or nm_s is None\n",
    "        ax_nm.set_visible(False)\n",
    "\n",
    "\n",
    "# --- Main Experiment Runner Function ---\n",
    "def run_experiment(hp_config, experiment_name, base_save_dir=\"experiments\"):\n",
    "    \"\"\"Sets up, trains, and saves results for a single experiment configuration.\"\"\"\n",
    "    print(f\"\\n====== Running Experiment: {experiment_name} ======\")\n",
    "    print(f\"Hyperparameters: {hp_config}\")\n",
    "\n",
    "    # Create experiment specific directory\n",
    "    timestamp = datetime.datetime.now().strftime(\"%Y%m%d-%H%M%S\")\n",
    "    save_dir = os.path.join(base_save_dir, f\"{experiment_name}_{timestamp}\")\n",
    "    os.makedirs(save_dir, exist_ok=True)\n",
    "    print(f\"Saving results to: {save_dir}\")\n",
    "\n",
    "    # Create subdirectories\n",
    "    log_dir = os.path.join(save_dir, 'logs')\n",
    "    model_dir = os.path.join(save_dir, 'models')\n",
    "    movie_dir = os.path.join(save_dir, f\"training_movie_for_{experiment_name}\")\n",
    "    os.makedirs(log_dir, exist_ok=True)\n",
    "    os.makedirs(model_dir, exist_ok=True)\n",
    "    os.makedirs(movie_dir, exist_ok=True)\n",
    "\n",
    "    # Save hyperparameters for this run\n",
    "    with open(os.path.join(save_dir, 'hyperparameters.pkl'), 'wb') as f:\n",
    "        pickle.dump(hp_config, f)\n",
    "    with open(os.path.join(save_dir, 'hyperparameters.txt'), 'w') as f:\n",
    "         for k, v in hp_config.items():\n",
    "              f.write(f\"{k}: {v}\\n\")\n",
    "\n",
    "\n",
    "    # Set device\n",
    "    device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "    print(f\"Using device: {device}\")\n",
    "\n",
    "    # Set seeds for reproducibility\n",
    "    seed = hp_config.get('seed', 123)\n",
    "    torch.manual_seed(seed)\n",
    "    np.random.seed(seed)\n",
    "    if torch.cuda.is_available():\n",
    "        torch.cuda.manual_seed_all(seed)\n",
    "\n",
    "    # Instantiate main model\n",
    "    try:\n",
    "        model = Model_nm_CombinedFeatures(hp_config).to(device)\n",
    "        print(f\"\\nMain Model ({model.__class__.__name__}, H={hp_config['n_rnn']}, NM={hp_config['N_NM']}) params: {sum(p.numel() for p in model.parameters() if p.requires_grad)}\")\n",
    "\n",
    "        # Only instantiate the surrogate model if N_NM > 0 for the main model\n",
    "        model_surrogate = None\n",
    "        if hp_config['N_NM'] > 0:\n",
    "             surrogate_hp = hp_config.copy()\n",
    "             # The standard RNN surrogate naturally has N_NM=0 and no NM-specific features\n",
    "             surrogate_hp['N_NM'] = 0 # Explicitly set for clarity, though Model_RNN doesn't use it\n",
    "             surrogate_hp['use_spatial_weights'] = False\n",
    "             surrogate_hp['use_modulated_readout'] = False\n",
    "             surrogate_hp['use_nm_decoder_loss'] = False\n",
    "             surrogate_hp['l2_nmVelo'] = 0 # No NM velocity loss for standard RNN\n",
    "             surrogate_hp['nm_decoder_loss_weight'] = 0\n",
    "             surrogate_hp['nm_init_scale'] = 0 # No initial NM state for standard RNN\n",
    "\n",
    "             model_surrogate = Model_RNN(surrogate_hp).to(device)\n",
    "             print(f\"Surrogate Model ({model_surrogate.__class__.__name__}, H={surrogate_hp['n_rnn']}) params: {sum(p.numel() for p in model_surrogate.parameters() if p.requires_grad)}\\n\")\n",
    "        else:\n",
    "             print(\"\\nSkipping Surrogate Model creation as N_NM is 0.\\n\")\n",
    "\n",
    "\n",
    "    except Exception as e:\n",
    "        print(f\"ERROR: Model instantiation failed for {experiment_name}: {e}\")\n",
    "        import traceback; traceback.print_exc();\n",
    "        return # Exit this experiment run\n",
    "\n",
    "    # Run training phases\n",
    "    # Pass the movie directory to the training function\n",
    "    # Pass model_surrogate (which might be None)\n",
    "    logs1 = train_dynamic_comparison(model, model_surrogate, 1, STEPS_PHASE1, STEPS_PHASE2, hp_config, device, time_steps, T_SETTLE, movie_dir)\n",
    "\n",
    "    # Reduce learning rate for phase 2 as in original code\n",
    "    hp_ph2 = hp_config.copy()\n",
    "    hp_ph2['learning_rate'] /= 2\n",
    "    print(f\"\\nPhase 2 LR: {hp_ph2['learning_rate']}\")\n",
    "    # Pass model_surrogate (which might be None) again\n",
    "    logs2 = train_dynamic_comparison(model, model_surrogate, 2, STEPS_PHASE2, STEPS_PHASE2, hp_ph2, device, time_steps, T_SETTLE, movie_dir)\n",
    "\n",
    "    # Combine logs from both phases\n",
    "    all_logs = {k: logs1.get(k, []) + logs2.get(k, []) for k in set(logs1.keys()).union(logs2.keys())}\n",
    "    # Keep the interval values from the last phase logs (or first if phase2 logs are empty)\n",
    "    all_logs['_log_interval_val'] = logs2.get('_log_interval_val', logs1.get('_log_interval_val', 1))\n",
    "    # Only keep comp log interval if comparison logs exist\n",
    "    if 'cos' in all_logs or 'dot' in all_logs:\n",
    "        all_logs['_comp_log_interval_val'] = logs2.get('_comp_log_interval_val', logs1.get('_comp_log_interval_val', 1))\n",
    "\n",
    "\n",
    "    # Save full logs\n",
    "    log_file_path = os.path.join(log_dir, f'{experiment_name}_logs.pkl')\n",
    "    with open(log_file_path, 'wb') as f:\n",
    "        pickle.dump(all_logs, f)\n",
    "    print(f\"Logs saved to {log_file_path}\")\n",
    "\n",
    "    # Save model parameters (state_dict)\n",
    "    model_params_path = os.path.join(model_dir, f'{experiment_name}_model_state_dict.pth')\n",
    "    torch.save(model.state_dict(), model_params_path)\n",
    "    print(f\"Model parameters saved to {model_params_path}\")\n",
    "\n",
    "    # Generate analysis data for final plots\n",
    "    # Use a fixed seed for analysis data generation for consistency across experiments\n",
    "    analysis_seed = 999\n",
    "    torch.manual_seed(analysis_seed)\n",
    "    np.random.seed(analysis_seed)\n",
    "    if torch.cuda.is_available():\n",
    "        torch.cuda.manual_seed_all(analysis_seed)\n",
    "    # Sample 5 batches, but we'll typically only plot the first one\n",
    "    analysis_inputs, analysis_targets, _ = sample_batch_for_models(5, SEQ_LEN, time_steps, 2, STEPS_PHASE2, STEPS_PHASE2)\n",
    "    analysis_targets_cpu = analysis_targets.cpu().numpy()\n",
    "\n",
    "    # Restore the original training seed for subsequent runs if needed, though it's set per experiment\n",
    "    torch.manual_seed(seed)\n",
    "    np.random.seed(seed)\n",
    "    if torch.cuda.is_available():\n",
    "        torch.cuda.manual_seed_all(seed)\n",
    "\n",
    "\n",
    "    # Plot final results and save them\n",
    "    try:\n",
    "        # Pass the combined logs and model_surrogate (which might be None) to the plotting function\n",
    "        plot_final_results(model, model_surrogate, hp_config, analysis_inputs, analysis_targets_cpu, T_SETTLE, save_dir, experiment_name, all_logs)\n",
    "        print(f\"Final plots saved to {os.path.join(save_dir, 'plots')}\")\n",
    "        print(f\"Training movie frames saved to {movie_dir}\")\n",
    "    except Exception as e:\n",
    "        print(f\"ERROR: Plotting failed for {experiment_name}: {e}\")\n",
    "        import traceback; traceback.print_exc()\n",
    "\n",
    "    print(f\"====== Experiment {experiment_name} Complete ======\\n\")\n",
    "\n",
    "\n",
    "# --- Main Execution ---\n",
    "if __name__ == \"__main__\":\n",
    "    # Define the two experiment configurations based on the base_hp\n",
    "    hp_case1 = base_hp.copy()\n",
    "    hp_case1['n_rnn'] = 128\n",
    "    hp_case1['N_NM'] = 4\n",
    "    hp_case1['experiment_name'] = \"NM4_H128\"\n",
    "\n",
    "    hp_case2 = base_hp.copy()\n",
    "    hp_case2['n_rnn'] = 256\n",
    "    hp_case2['N_NM'] = 0\n",
    "    # Explicitly turn off NM related features for N_NM=0 case\n",
    "    hp_case2['use_spatial_weights'] = False\n",
    "    hp_case2['use_modulated_readout'] = False\n",
    "    hp_case2['use_nm_decoder_loss'] = False\n",
    "    hp_case2['l2_nmVelo'] = 0\n",
    "    hp_case2['nm_decoder_loss_weight'] = 0\n",
    "    hp_case2['nm_init_scale'] = 0 # No initial NM state for scale0\n",
    "    hp_case2['experiment_name'] = \"NM0_H256\"\n",
    "\n",
    "    hp_case3 = base_hp.copy()\n",
    "    hp_case3['n_rnn'] = 128\n",
    "    hp_case3['N_NM'] = 0\n",
    "    hp_case3['use_spatial_weights'] = False\n",
    "    hp_case3['use_modulated_readout'] = False\n",
    "    hp_case3['use_nm_decoder_loss'] = False\n",
    "    hp_case3['l2_nmVelo'] = 0\n",
    "    hp_case3['nm_decoder_loss_weight'] = 0\n",
    "    hp_case3['nm_init_scale'] = 0\n",
    "    hp_case3['experiment_name'] = \"NM0_H128\"\n",
    "    \n",
    "    hp_case4 = base_hp.copy()\n",
    "    hp_case4['n_rnn'] = 128\n",
    "    hp_case4['N_NM'] = 4\n",
    "    hp_case4['use_spatial_weights'] = True\n",
    "    hp_case4['experiment_name'] = \"sNM4_H128\"\n",
    "    \n",
    "    hp_case5 = base_hp.copy()\n",
    "    hp_case5['n_rnn'] = 128\n",
    "    hp_case5['N_NM'] = 4\n",
    "    hp_case5['use_spatial_weights'] = False\n",
    "    hp_case5['use_modulated_readout'] = True\n",
    "    hp_case5['experiment_name'] = \"dNM4_H128\"\n",
    "\n",
    "    # Base directory for all experiments\n",
    "    base_experiment_dir = \"Hopf_experiments_new\" \n",
    "    os.makedirs(base_experiment_dir, exist_ok=True)\n",
    "    \n",
    "    hps = [hp_case2, hp_case3, hp_case4, hp_case5] #hp_case1\n",
    "    \n",
    "    for hp_exp in hps:\n",
    "        run_experiment(hp_exp, hp_exp['experiment_name'], base_experiment_dir)\n",
    "\n",
    "\n",
    "    print(\"\\nAll experiments finished.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "05578de0-f0c8-4293-99e8-a648beeed245",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
