================================================================================
ONLINE SNN RUN
================================================================================

==================================================
Testing ONLINE SNN Training
==================================================

===== Running Within-Session Comparison (10 Sessions, Online SNN) =====

--- Session 1/10 (indy_20160411_02.mat) ---
  Using fixed parameters: Bin Width=0.050s, Stride=0.050s (no overlap)
  Using zero causal lag (0 ms) - skipping lag search.
  Using raw spike counts (no normalisation)...
    Sample spike-count matrix (first 4 bins, first 12 neurons):
[[3 4 3 3 1 1 2 3 3 2 6 4]
 [1 2 2 2 3 0 2 2 3 0 4 1]
 [3 2 4 6 1 0 0 5 2 1 2 6]
 [0 0 2 5 0 2 1 1 1 0 2 6]]
    Counts min / max in this session: 0 9
Global count histogram 0-6: [740226 314133 117862  40916  13376   3971   1122]
    Sample rate-NORMALISED matrix (first 4 bins, first 12 neurons):
[[ 3.367  3.971  2.394  1.996  0.907  3.118  1.88   2.387  1.717  2.474
   4.646  2.067]
 [ 0.716  1.607  1.327  1.054  3.942 -0.285  1.88   1.338  1.717 -0.603
   2.74  -0.201]
 [ 3.367  1.607  3.461  4.824  0.907 -0.285 -0.695  4.485  0.834  0.936
   0.835  3.578]
 [-0.61  -0.757  1.327  3.881 -0.611  6.522  0.592  0.29  -0.049 -0.603
   0.835  3.578]]

  --- Running SNN Online Training ---
Starting SNN Online Training for 50 epochs on cpu...
Evaluation every 500 steps, reset states every 200 steps
Warm-starting RMS EMAs with 50 steps...
RMS EMA warm-start complete.
Epoch [1/50], Step 500, Train Loss: 0.9158, Val Avg Corr: 0.2917
  >>> New best validation model saved with Avg Corr: 0.2917 <<<
Epoch [1/50], Step 1000, Train Loss: 0.7000, Val Avg Corr: 0.4986
  >>> New best validation model saved with Avg Corr: 0.4986 <<<
Epoch [1/50], Step 1500, Train Loss: 0.6920, Val Avg Corr: 0.4471
Epoch [1/50], Step 2000, Train Loss: 0.6091, Val Avg Corr: 0.5825
  >>> New best validation model saved with Avg Corr: 0.5825 <<<
Epoch [1/50], Step 2500, Train Loss: 0.8081, Val Avg Corr: 0.6094
  >>> New best validation model saved with Avg Corr: 0.6094 <<<
Epoch [1/50], Step 3000, Train Loss: 0.3990, Val Avg Corr: 0.5949
Epoch [1/50], Step 3500, Train Loss: 0.7613, Val Avg Corr: 0.6417
  >>> New best validation model saved with Avg Corr: 0.6417 <<<
Epoch [1/50], Step 4000, Train Loss: 0.5152, Val Avg Corr: 0.6364
Epoch [1/50], Step 4500, Train Loss: 0.4585, Val Avg Corr: 0.6245
Epoch [1/50], Step 5000, Train Loss: 0.6348, Val Avg Corr: 0.6184
Epoch [1/50], Step 5500, Train Loss: 0.6454, Val Avg Corr: 0.5643
Epoch [1/50], Step 6000, Train Loss: 0.3902, Val Avg Corr: 0.6548
  >>> New best validation model saved with Avg Corr: 0.6548 <<<
Epoch [1/50], Step 6500, Train Loss: 0.5997, Val Avg Corr: 0.6608
  >>> New best validation model saved with Avg Corr: 0.6608 <<<
Epoch [1/50], Step 7000, Train Loss: 0.6002, Val Avg Corr: 0.6338
Epoch [1/50], Step 7500, Train Loss: 0.5632, Val Avg Corr: 0.6749
  >>> New best validation model saved with Avg Corr: 0.6749 <<<
Epoch [1/50], Step 8000, Train Loss: 0.4887, Val Avg Corr: 0.6179
Epoch [1/50], Step 8500, Train Loss: 0.4800, Val Avg Corr: 0.6261
Epoch [1/50], Step 9000, Train Loss: 0.5941, Val Avg Corr: 0.6971
  >>> New best validation model saved with Avg Corr: 0.6971 <<<
Epoch [1/50], Step 9500, Train Loss: 0.6035, Val Avg Corr: 0.6569
Epoch [1/50], Step 10000, Train Loss: 0.3554, Val Avg Corr: 0.7219
  >>> New best validation model saved with Avg Corr: 0.7219 <<<
Epoch [1/50], Step 10500, Train Loss: 0.4979, Val Avg Corr: 0.7088
Epoch [2/50], Step 500, Train Loss: 0.5798, Val Avg Corr: 0.6287
Epoch [2/50], Step 1000, Train Loss: 0.5784, Val Avg Corr: 0.6572
Epoch [2/50], Step 1500, Train Loss: 0.6708, Val Avg Corr: 0.6449
Epoch [2/50], Step 2000, Train Loss: 0.4924, Val Avg Corr: 0.6673
Epoch [2/50], Step 2500, Train Loss: 0.6782, Val Avg Corr: 0.6803
Epoch [2/50], Step 3000, Train Loss: 0.3488, Val Avg Corr: 0.5865
Epoch [2/50], Step 3500, Train Loss: 0.7368, Val Avg Corr: 0.6667
Epoch [2/50], Step 4000, Train Loss: 0.5606, Val Avg Corr: 0.6272
Epoch [2/50], Step 4500, Train Loss: 0.4228, Val Avg Corr: 0.6111
Epoch [2/50], Step 5000, Train Loss: 0.5621, Val Avg Corr: 0.6446
Epoch [2/50], Step 5500, Train Loss: 0.5616, Val Avg Corr: 0.6207
Epoch [2/50], Step 6000, Train Loss: 0.3558, Val Avg Corr: 0.6448
Epoch [2/50], Step 6500, Train Loss: 0.5136, Val Avg Corr: 0.6735
Epoch [2/50], Step 7000, Train Loss: 0.4956, Val Avg Corr: 0.6722
Epoch [2/50], Step 7500, Train Loss: 0.4940, Val Avg Corr: 0.6836
Epoch [2/50], Step 8000, Train Loss: 0.4873, Val Avg Corr: 0.6891
Epoch [2/50], Step 8500, Train Loss: 0.4355, Val Avg Corr: 0.6216
Epoch [2/50], Step 9000, Train Loss: 0.5635, Val Avg Corr: 0.7066
Epoch [2/50], Step 9500, Train Loss: 0.5802, Val Avg Corr: 0.6541
Early stopping triggered after 9500 steps in epoch 2.
Loaded best model with validation Corr: 0.7219
  Re-evaluating SNN with movement mask for fair comparison...
  SNN Test Corr (All Bins): X=0.7969, Y=0.6491
  SNN Test  R²  (All Bins): X=0.6223, Y=0.3932
Time-series velocity figure saved --> snn_velocity_timeseries_slice_indy_20160411_02.mat.png

  --- Running Kalman Filter ---

--- Setting up Kalman Filter ---
Fitting linear velocity decoder (Ridge)
Estimating R from decoder residuals
Initializing Kalman Filter...
Running Kalman Filter for 2751 test steps...
Kalman Filter processing time: 0.14 seconds
--- Kalman Filter Setup and Run Complete ---
  KF Test Corr (Movement Only): X=0.5862, Y=0.5220

  --- Running LSTM ---
Starting LSTM training for 50 epochs on cpu...
Epoch [1/50], Train Loss: 0.330404, Val Loss: 0.380746
  New best validation loss: 0.380746
Epoch [2/50], Train Loss: 0.155251, Val Loss: 0.352873
  New best validation loss: 0.352873
Epoch [3/50], Train Loss: 0.099329, Val Loss: 0.325866
  New best validation loss: 0.325866
Epoch [4/50], Train Loss: 0.072020, Val Loss: 0.331213
Epoch [5/50], Train Loss: 0.056926, Val Loss: 0.308956
  New best validation loss: 0.308956
Epoch [6/50], Train Loss: 0.047563, Val Loss: 0.306100
  New best validation loss: 0.306100
Epoch [7/50], Train Loss: 0.040916, Val Loss: 0.305087
  New best validation loss: 0.305087
Epoch [8/50], Train Loss: 0.037070, Val Loss: 0.313142
Epoch [9/50], Train Loss: 0.032612, Val Loss: 0.309661
Epoch [10/50], Train Loss: 0.030654, Val Loss: 0.331202
Epoch [11/50], Train Loss: 0.030730, Val Loss: 0.312873
Epoch [12/50], Train Loss: 0.025435, Val Loss: 0.301212
  New best validation loss: 0.301212
Epoch [13/50], Train Loss: 0.024118, Val Loss: 0.311400
Epoch [14/50], Train Loss: 0.021642, Val Loss: 0.293928
  New best validation loss: 0.293928
Epoch [15/50], Train Loss: 0.021384, Val Loss: 0.296535
Epoch [16/50], Train Loss: 0.020222, Val Loss: 0.314063
Epoch [17/50], Train Loss: 0.019710, Val Loss: 0.315656
Epoch [18/50], Train Loss: 0.019339, Val Loss: 0.302559
Epoch [19/50], Train Loss: 0.018392, Val Loss: 0.309526
Epoch [20/50], Train Loss: 0.019354, Val Loss: 0.302965
Epoch [21/50], Train Loss: 0.017658, Val Loss: 0.302928
Epoch [22/50], Train Loss: 0.017626, Val Loss: 0.313429
Epoch [23/50], Train Loss: 0.017356, Val Loss: 0.308594
Epoch [24/50], Train Loss: 0.015963, Val Loss: 0.301097
Early stopping triggered after 24 epochs.
Finished LSTM Training.
Loaded best model state from epoch 14.
  LSTM Test Corr (Movement Only): X=0.8858, Y=0.8553
--- Finished Session 1 ---

--- Session 2/10 (indy_20161017_02.mat) ---
  Using fixed parameters: Bin Width=0.050s, Stride=0.050s (no overlap)
  Using zero causal lag (0 ms) - skipping lag search.
  Using raw spike counts (no normalisation)...
    Sample spike-count matrix (first 4 bins, first 12 neurons):
[[3 1 1 2 1 1 1 1 1 2 2 2]
 [2 0 0 0 0 0 1 0 1 0 0 2]
 [3 1 1 0 0 0 0 0 0 1 1 1]
 [4 0 0 0 0 0 0 0 0 1 0 2]]
    Counts min / max in this session: 0 6
Global count histogram 0-6: [581778  89263  18471   3807    684     71      6]
    Sample rate-NORMALISED matrix (first 4 bins, first 12 neurons):
[[ 2.702  1.891  4.841  6.454  7.333  2.582  2.017  3.504  6.445  4.126
   4.117  2.895]
 [ 1.562 -0.422 -0.188 -0.288 -0.132 -0.337  2.017 -0.258  6.445 -0.401
  -0.409  2.895]
 [ 2.702  1.891  4.841 -0.288 -0.132 -0.337 -0.368 -0.258 -0.142  1.862
   1.854  1.2  ]
 [ 3.841 -0.422 -0.188 -0.288 -0.132 -0.337 -0.368 -0.258 -0.142  1.862
  -0.409  2.895]]

  --- Running SNN Online Training ---
Starting SNN Online Training for 50 epochs on cpu...
Evaluation every 500 steps, reset states every 200 steps
Warm-starting RMS EMAs with 50 steps...
RMS EMA warm-start complete.
Epoch [1/50], Step 500, Train Loss: 0.7105, Val Avg Corr: 0.0220
  >>> New best validation model saved with Avg Corr: 0.0220 <<<
Epoch [1/50], Step 1000, Train Loss: 0.8190, Val Avg Corr: 0.2105
  >>> New best validation model saved with Avg Corr: 0.2105 <<<
Epoch [1/50], Step 1500, Train Loss: 0.6090, Val Avg Corr: 0.2356
  >>> New best validation model saved with Avg Corr: 0.2356 <<<
Epoch [1/50], Step 2000, Train Loss: 0.7372, Val Avg Corr: 0.3520
  >>> New best validation model saved with Avg Corr: 0.3520 <<<
Epoch [1/50], Step 2500, Train Loss: 0.5404, Val Avg Corr: 0.3271
Epoch [1/50], Step 3000, Train Loss: 0.6480, Val Avg Corr: 0.4162
  >>> New best validation model saved with Avg Corr: 0.4162 <<<
Epoch [1/50], Step 3500, Train Loss: 0.7257, Val Avg Corr: 0.4384
  >>> New best validation model saved with Avg Corr: 0.4384 <<<
Epoch [1/50], Step 4000, Train Loss: 0.3933, Val Avg Corr: 0.4666
  >>> New best validation model saved with Avg Corr: 0.4666 <<<
Epoch [1/50], Step 4500, Train Loss: 0.5769, Val Avg Corr: 0.4937
  >>> New best validation model saved with Avg Corr: 0.4937 <<<
Epoch [1/50], Step 5000, Train Loss: 0.8064, Val Avg Corr: 0.5061
  >>> New best validation model saved with Avg Corr: 0.5061 <<<
Epoch [1/50], Step 5500, Train Loss: 0.6409, Val Avg Corr: 0.4547
Epoch [1/50], Step 6000, Train Loss: 0.5022, Val Avg Corr: 0.5617
  >>> New best validation model saved with Avg Corr: 0.5617 <<<
Epoch [2/50], Step 500, Train Loss: 0.6376, Val Avg Corr: 0.4265
Epoch [2/50], Step 1000, Train Loss: 0.7289, Val Avg Corr: 0.4961
Epoch [2/50], Step 1500, Train Loss: 0.5085, Val Avg Corr: 0.5804
  >>> New best validation model saved with Avg Corr: 0.5804 <<<
Epoch [2/50], Step 2000, Train Loss: 0.6140, Val Avg Corr: 0.5590
Epoch [2/50], Step 2500, Train Loss: 0.5051, Val Avg Corr: 0.5483
Epoch [2/50], Step 3000, Train Loss: 0.5893, Val Avg Corr: 0.5268
Epoch [2/50], Step 3500, Train Loss: 0.6521, Val Avg Corr: 0.3867
Epoch [2/50], Step 4000, Train Loss: 0.3482, Val Avg Corr: 0.5264
Epoch [2/50], Step 4500, Train Loss: 0.5530, Val Avg Corr: 0.5340
Epoch [2/50], Step 5000, Train Loss: 0.7502, Val Avg Corr: 0.5654
Epoch [2/50], Step 5500, Train Loss: 0.5718, Val Avg Corr: 0.5124
Epoch [2/50], Step 6000, Train Loss: 0.4411, Val Avg Corr: 0.5621
Epoch [3/50], Step 500, Train Loss: 0.6835, Val Avg Corr: 0.5556
Epoch [3/50], Step 1000, Train Loss: 0.6737, Val Avg Corr: 0.5196
Epoch [3/50], Step 1500, Train Loss: 0.4714, Val Avg Corr: 0.6327
  >>> New best validation model saved with Avg Corr: 0.6327 <<<
Epoch [3/50], Step 2000, Train Loss: 0.5729, Val Avg Corr: 0.6201
Epoch [3/50], Step 2500, Train Loss: 0.4812, Val Avg Corr: 0.5695
Epoch [3/50], Step 3000, Train Loss: 0.5117, Val Avg Corr: 0.5830
Epoch [3/50], Step 3500, Train Loss: 0.5847, Val Avg Corr: 0.4725
Epoch [3/50], Step 4000, Train Loss: 0.3048, Val Avg Corr: 0.4902
Epoch [3/50], Step 4500, Train Loss: 0.4722, Val Avg Corr: 0.5675
Epoch [3/50], Step 5000, Train Loss: 0.7118, Val Avg Corr: 0.5740
Epoch [3/50], Step 5500, Train Loss: 0.5829, Val Avg Corr: 0.5369
Epoch [3/50], Step 6000, Train Loss: 0.4617, Val Avg Corr: 0.5484
Epoch [4/50], Step 500, Train Loss: 0.5940, Val Avg Corr: 0.5384
Epoch [4/50], Step 1000, Train Loss: 0.6486, Val Avg Corr: 0.5362
Epoch [4/50], Step 1500, Train Loss: 0.4675, Val Avg Corr: 0.5399
Epoch [4/50], Step 2000, Train Loss: 0.5771, Val Avg Corr: 0.5883
Epoch [4/50], Step 2500, Train Loss: 0.4601, Val Avg Corr: 0.5839
Epoch [4/50], Step 3000, Train Loss: 0.5243, Val Avg Corr: 0.5959
Epoch [4/50], Step 3500, Train Loss: 0.6080, Val Avg Corr: 0.5059
Epoch [4/50], Step 4000, Train Loss: 0.2988, Val Avg Corr: 0.5419
Epoch [4/50], Step 4500, Train Loss: 0.4527, Val Avg Corr: 0.5542
Epoch [4/50], Step 5000, Train Loss: 0.7434, Val Avg Corr: 0.5667
Epoch [4/50], Step 5500, Train Loss: 0.5476, Val Avg Corr: 0.5435
Early stopping triggered after 5500 steps in epoch 4.
Loaded best model with validation Corr: 0.6327
  Re-evaluating SNN with movement mask for fair comparison...
  SNN Test Corr (All Bins): X=0.6281, Y=0.7641
  SNN Test  R²  (All Bins): X=0.3874, Y=0.4850
Time-series velocity figure saved --> snn_velocity_timeseries_slice_indy_20161017_02.mat.png

  --- Running Kalman Filter ---

--- Setting up Kalman Filter ---
Fitting linear velocity decoder (Ridge)
Estimating R from decoder residuals
Initializing Kalman Filter...
Running Kalman Filter for 1550 test steps...
Kalman Filter processing time: 0.12 seconds
--- Kalman Filter Setup and Run Complete ---
  KF Test Corr (Movement Only): X=0.3775, Y=0.4768

  --- Running LSTM ---
Starting LSTM training for 50 epochs on cpu...
Epoch [1/50], Train Loss: 0.470563, Val Loss: 0.402546
  New best validation loss: 0.402546
Epoch [2/50], Train Loss: 0.192538, Val Loss: 0.366440
  New best validation loss: 0.366440
Epoch [3/50], Train Loss: 0.115804, Val Loss: 0.362823
  New best validation loss: 0.362823
Epoch [4/50], Train Loss: 0.085362, Val Loss: 0.320493
  New best validation loss: 0.320493
Epoch [5/50], Train Loss: 0.065461, Val Loss: 0.340851
Epoch [6/50], Train Loss: 0.063082, Val Loss: 0.338164
Epoch [7/50], Train Loss: 0.051290, Val Loss: 0.328953
Epoch [8/50], Train Loss: 0.044240, Val Loss: 0.320813
Epoch [9/50], Train Loss: 0.038159, Val Loss: 0.343948
Epoch [10/50], Train Loss: 0.035700, Val Loss: 0.338484
Epoch [11/50], Train Loss: 0.035215, Val Loss: 0.328276
Epoch [12/50], Train Loss: 0.031138, Val Loss: 0.327975
Epoch [13/50], Train Loss: 0.031728, Val Loss: 0.333057
Epoch [14/50], Train Loss: 0.029236, Val Loss: 0.330083
Early stopping triggered after 14 epochs.
Finished LSTM Training.
Loaded best model state from epoch 4.
  LSTM Test Corr (Movement Only): X=0.7258, Y=0.8567
--- Finished Session 2 ---

--- Session 3/10 (indy_20160630_01.mat) ---
  Using fixed parameters: Bin Width=0.050s, Stride=0.050s (no overlap)
  Using zero causal lag (0 ms) - skipping lag search.
  Using raw spike counts (no normalisation)...
    Sample spike-count matrix (first 4 bins, first 12 neurons):
[[3 4 2 1 1 2 2 1 2 1 2 2]
 [1 2 0 0 0 1 1 0 3 1 0 1]
 [2 1 1 1 0 1 1 1 2 0 3 0]
 [1 4 2 0 1 3 0 0 4 0 0 0]]
    Counts min / max in this session: 0 11
Global count histogram 0-6: [1535625  334324  107352   41863   17385    7401    2975]
    Sample rate-NORMALISED matrix (first 4 bins, first 12 neurons):
[[ 2.672  1.805  3.195  2.913  1.505  0.255  3.545  3.367  1.718  2.758
   3.152  5.122]
 [ 0.41   0.407 -0.491 -0.313 -0.458 -0.349  1.528 -0.269  2.881  2.758
  -0.535  2.377]
 [ 1.541 -0.292  1.352  2.913 -0.458 -0.349  1.528  3.367  1.718 -0.327
   4.996 -0.368]
 [ 0.41   1.805  3.195 -0.313  1.505  0.858 -0.49  -0.269  4.044 -0.327
  -0.535 -0.368]]

  --- Running SNN Online Training ---
Starting SNN Online Training for 50 epochs on cpu...
Evaluation every 500 steps, reset states every 200 steps
Warm-starting RMS EMAs with 50 steps...
RMS EMA warm-start complete.
Epoch [1/50], Step 500, Train Loss: 1.0918, Val Avg Corr: 0.0915
  >>> New best validation model saved with Avg Corr: 0.0915 <<<
Epoch [1/50], Step 1000, Train Loss: 0.8747, Val Avg Corr: 0.3311
  >>> New best validation model saved with Avg Corr: 0.3311 <<<
Epoch [1/50], Step 1500, Train Loss: 0.6748, Val Avg Corr: 0.4895
  >>> New best validation model saved with Avg Corr: 0.4895 <<<
Epoch [1/50], Step 2000, Train Loss: 0.7174, Val Avg Corr: 0.4944
  >>> New best validation model saved with Avg Corr: 0.4944 <<<
Epoch [1/50], Step 2500, Train Loss: 0.7689, Val Avg Corr: 0.4130
Epoch [1/50], Step 3000, Train Loss: 0.5620, Val Avg Corr: 0.6111
  >>> New best validation model saved with Avg Corr: 0.6111 <<<
Epoch [1/50], Step 3500, Train Loss: 0.7351, Val Avg Corr: 0.5989
Epoch [1/50], Step 4000, Train Loss: 0.5303, Val Avg Corr: 0.6065
Epoch [1/50], Step 4500, Train Loss: 0.4419, Val Avg Corr: 0.6136
  >>> New best validation model saved with Avg Corr: 0.6136 <<<
Epoch [1/50], Step 5000, Train Loss: 0.5813, Val Avg Corr: 0.6434
  >>> New best validation model saved with Avg Corr: 0.6434 <<<
Epoch [1/50], Step 5500, Train Loss: 0.6008, Val Avg Corr: 0.5365
Epoch [1/50], Step 6000, Train Loss: 0.6932, Val Avg Corr: 0.5659
Epoch [1/50], Step 6500, Train Loss: 0.6077, Val Avg Corr: 0.6012
Epoch [1/50], Step 7000, Train Loss: 0.5279, Val Avg Corr: 0.6349
Epoch [1/50], Step 7500, Train Loss: 0.7738, Val Avg Corr: 0.6251
Epoch [1/50], Step 8000, Train Loss: 0.7099, Val Avg Corr: 0.6570
  >>> New best validation model saved with Avg Corr: 0.6570 <<<
Epoch [1/50], Step 8500, Train Loss: 0.6135, Val Avg Corr: 0.5548
Epoch [1/50], Step 9000, Train Loss: 0.5117, Val Avg Corr: 0.6300
Epoch [1/50], Step 9500, Train Loss: 0.6222, Val Avg Corr: 0.6712
  >>> New best validation model saved with Avg Corr: 0.6712 <<<
Epoch [1/50], Step 10000, Train Loss: 0.6617, Val Avg Corr: 0.6418
Epoch [1/50], Step 10500, Train Loss: 0.6666, Val Avg Corr: 0.6395
Epoch [1/50], Step 11000, Train Loss: 0.5002, Val Avg Corr: 0.6554
Epoch [1/50], Step 11500, Train Loss: 0.6406, Val Avg Corr: 0.6824
  >>> New best validation model saved with Avg Corr: 0.6824 <<<
Epoch [1/50], Step 12000, Train Loss: 0.4881, Val Avg Corr: 0.6729
Epoch [1/50], Step 12500, Train Loss: 0.4710, Val Avg Corr: 0.6515
Epoch [1/50], Step 13000, Train Loss: 0.5157, Val Avg Corr: 0.6081
Epoch [1/50], Step 13500, Train Loss: 0.4649, Val Avg Corr: 0.6613
Epoch [1/50], Step 14000, Train Loss: 0.5452, Val Avg Corr: 0.6088
Epoch [1/50], Step 14500, Train Loss: 0.4997, Val Avg Corr: 0.6937
  >>> New best validation model saved with Avg Corr: 0.6937 <<<
Epoch [1/50], Step 15000, Train Loss: 0.5531, Val Avg Corr: 0.5965
Epoch [1/50], Step 15500, Train Loss: 0.4243, Val Avg Corr: 0.6589
Epoch [1/50], Step 16000, Train Loss: 0.5973, Val Avg Corr: 0.6611
Epoch [1/50], Step 16500, Train Loss: 0.5775, Val Avg Corr: 0.6378
Epoch [1/50], Step 17000, Train Loss: 0.5415, Val Avg Corr: 0.6632
Epoch [1/50], Step 17500, Train Loss: 0.6249, Val Avg Corr: 0.6641
Epoch [1/50], Step 18000, Train Loss: 0.4843, Val Avg Corr: 0.5683
Epoch [2/50], Step 500, Train Loss: 0.8988, Val Avg Corr: 0.5895
Epoch [2/50], Step 1000, Train Loss: 0.7281, Val Avg Corr: 0.6626
Epoch [2/50], Step 1500, Train Loss: 0.5886, Val Avg Corr: 0.6966
  >>> New best validation model saved with Avg Corr: 0.6966 <<<
Epoch [2/50], Step 2000, Train Loss: 0.6236, Val Avg Corr: 0.6192
Epoch [2/50], Step 2500, Train Loss: 0.6961, Val Avg Corr: 0.6489
Epoch [2/50], Step 3000, Train Loss: 0.4796, Val Avg Corr: 0.7006
  >>> New best validation model saved with Avg Corr: 0.7006 <<<
Epoch [2/50], Step 3500, Train Loss: 0.5121, Val Avg Corr: 0.6795
Epoch [2/50], Step 4000, Train Loss: 0.4290, Val Avg Corr: 0.6697
Epoch [2/50], Step 4500, Train Loss: 0.3622, Val Avg Corr: 0.6531
Epoch [2/50], Step 5000, Train Loss: 0.4999, Val Avg Corr: 0.6889
Epoch [2/50], Step 5500, Train Loss: 0.5434, Val Avg Corr: 0.6549
Epoch [2/50], Step 6000, Train Loss: 0.6166, Val Avg Corr: 0.6468
Epoch [2/50], Step 6500, Train Loss: 0.5471, Val Avg Corr: 0.6481
Epoch [2/50], Step 7000, Train Loss: 0.4794, Val Avg Corr: 0.6631
Epoch [2/50], Step 7500, Train Loss: 0.6550, Val Avg Corr: 0.6677
Epoch [2/50], Step 8000, Train Loss: 0.6193, Val Avg Corr: 0.6712
Epoch [2/50], Step 8500, Train Loss: 0.5214, Val Avg Corr: 0.6429
Epoch [2/50], Step 9000, Train Loss: 0.4917, Val Avg Corr: 0.6693
Epoch [2/50], Step 9500, Train Loss: 0.5511, Val Avg Corr: 0.6692
Epoch [2/50], Step 10000, Train Loss: 0.6085, Val Avg Corr: 0.6656
Epoch [2/50], Step 10500, Train Loss: 0.6034, Val Avg Corr: 0.6372
Epoch [2/50], Step 11000, Train Loss: 0.4917, Val Avg Corr: 0.6865
Epoch [2/50], Step 11500, Train Loss: 0.6259, Val Avg Corr: 0.6780
Epoch [2/50], Step 12000, Train Loss: 0.4560, Val Avg Corr: 0.6636
Epoch [2/50], Step 12500, Train Loss: 0.4595, Val Avg Corr: 0.6633
Epoch [2/50], Step 13000, Train Loss: 0.5215, Val Avg Corr: 0.6220
Early stopping triggered after 13000 steps in epoch 2.
Loaded best model with validation Corr: 0.7006
  Re-evaluating SNN with movement mask for fair comparison...
  SNN Test Corr (All Bins): X=0.5821, Y=0.7991
  SNN Test  R²  (All Bins): X=0.3157, Y=0.6227
Time-series velocity figure saved --> snn_velocity_timeseries_slice_indy_20160630_01.mat.png

  --- Running Kalman Filter ---

--- Setting up Kalman Filter ---
Fitting linear velocity decoder (Ridge)
/scratch/zt1/project/sshah389-prj/user/snallani/myenv/lib/python3.10/site-packages/sklearn/linear_model/_ridge.py:215: LinAlgWarning: Ill-conditioned matrix (rcond=3.2608e-09): result may not be accurate.
  return linalg.solve(A, Xy, assume_a="pos", overwrite_a=True).T
Estimating R from decoder residuals
Initializing Kalman Filter...
Running Kalman Filter for 4574 test steps...
Kalman Filter processing time: 0.19 seconds
--- Kalman Filter Setup and Run Complete ---
  KF Test Corr (Movement Only): X=0.4686, Y=0.5064

  --- Running LSTM ---
Starting LSTM training for 50 epochs on cpu...
Epoch [1/50], Train Loss: 0.402944, Val Loss: 0.309598
  New best validation loss: 0.309598
Epoch [2/50], Train Loss: 0.204637, Val Loss: 0.305841
  New best validation loss: 0.305841
Epoch [3/50], Train Loss: 0.136537, Val Loss: 0.306511
Epoch [4/50], Train Loss: 0.099535, Val Loss: 0.309485
Epoch [5/50], Train Loss: 0.079249, Val Loss: 0.313017
Epoch [6/50], Train Loss: 0.065465, Val Loss: 0.314361
Epoch [7/50], Train Loss: 0.054920, Val Loss: 0.317244
Epoch [8/50], Train Loss: 0.048458, Val Loss: 0.314453
Epoch [9/50], Train Loss: 0.041617, Val Loss: 0.318245
Epoch [10/50], Train Loss: 0.037497, Val Loss: 0.316300
Epoch [11/50], Train Loss: 0.035787, Val Loss: 0.328473
Epoch [12/50], Train Loss: 0.033185, Val Loss: 0.324290
Early stopping triggered after 12 epochs.
Finished LSTM Training.
Loaded best model state from epoch 2.
  LSTM Test Corr (Movement Only): X=0.6187, Y=0.8042
--- Finished Session 3 ---

--- Session 4/10 (indy_20161212_02.mat) ---
  Using fixed parameters: Bin Width=0.050s, Stride=0.050s (no overlap)
  Using zero causal lag (0 ms) - skipping lag search.
  Using raw spike counts (no normalisation)...
    Sample spike-count matrix (first 4 bins, first 12 neurons):
[[1 2 1 1 1 1 2 1 1 1 1 1]
 [2 0 1 0 2 0 2 0 0 0 0 0]
 [0 1 0 1 1 0 0 0 0 0 0 0]
 [0 0 0 0 1 0 0 0 0 0 1 1]]
    Counts min / max in this session: 0 5
Global count histogram 0-6: [710929  64945   7998    984    120     16      0]
    Sample rate-NORMALISED matrix (first 4 bins, first 12 neurons):
[[ 2.061  5.117  1.658  2.252  2.266  2.607  3.277  4.276  3.335  4.2
   3.032  2.353]
 [ 4.507 -0.355  1.658 -0.353  4.879 -0.329  3.277 -0.222 -0.274 -0.212
  -0.297 -0.34 ]
 [-0.384  2.381 -0.428  2.252  2.266 -0.329 -0.492 -0.222 -0.274 -0.212
  -0.297 -0.34 ]
 [-0.384 -0.355 -0.428 -0.353  2.266 -0.329 -0.492 -0.222 -0.274 -0.212
   3.032  2.353]]

  --- Running SNN Online Training ---
Starting SNN Online Training for 50 epochs on cpu...
Evaluation every 500 steps, reset states every 200 steps
Warm-starting RMS EMAs with 50 steps...
RMS EMA warm-start complete.
Epoch [1/50], Step 500, Train Loss: 0.6473, Val Avg Corr: 0.0000
  >>> New best validation model saved with Avg Corr: 0.0000 <<<
Epoch [1/50], Step 1000, Train Loss: 0.7293, Val Avg Corr: 0.0302
  >>> New best validation model saved with Avg Corr: 0.0302 <<<
Epoch [1/50], Step 1500, Train Loss: 0.8416, Val Avg Corr: 0.0689
  >>> New best validation model saved with Avg Corr: 0.0689 <<<
Epoch [1/50], Step 2000, Train Loss: 0.7121, Val Avg Corr: 0.1823
  >>> New best validation model saved with Avg Corr: 0.1823 <<<
Epoch [1/50], Step 2500, Train Loss: 0.7038, Val Avg Corr: 0.3263
  >>> New best validation model saved with Avg Corr: 0.3263 <<<
Epoch [1/50], Step 3000, Train Loss: 0.7549, Val Avg Corr: 0.3825
  >>> New best validation model saved with Avg Corr: 0.3825 <<<
Epoch [1/50], Step 3500, Train Loss: 0.6124, Val Avg Corr: 0.2395
Epoch [1/50], Step 4000, Train Loss: 0.6763, Val Avg Corr: 0.4063
  >>> New best validation model saved with Avg Corr: 0.4063 <<<
Epoch [1/50], Step 4500, Train Loss: 0.5146, Val Avg Corr: 0.3833
Epoch [1/50], Step 5000, Train Loss: 0.5527, Val Avg Corr: 0.4090
  >>> New best validation model saved with Avg Corr: 0.4090 <<<
Epoch [1/50], Step 5500, Train Loss: 0.5718, Val Avg Corr: 0.4255
  >>> New best validation model saved with Avg Corr: 0.4255 <<<
Epoch [1/50], Step 6000, Train Loss: 0.7350, Val Avg Corr: 0.3931
Epoch [1/50], Step 6500, Train Loss: 0.7719, Val Avg Corr: 0.4179
Epoch [2/50], Step 500, Train Loss: 0.5885, Val Avg Corr: 0.4000
Epoch [2/50], Step 1000, Train Loss: 0.6785, Val Avg Corr: 0.3965
Epoch [2/50], Step 1500, Train Loss: 0.6450, Val Avg Corr: 0.4395
  >>> New best validation model saved with Avg Corr: 0.4395 <<<
Epoch [2/50], Step 2000, Train Loss: 0.6238, Val Avg Corr: 0.4445
  >>> New best validation model saved with Avg Corr: 0.4445 <<<
Epoch [2/50], Step 2500, Train Loss: 0.5749, Val Avg Corr: 0.4674
  >>> New best validation model saved with Avg Corr: 0.4674 <<<
Epoch [2/50], Step 3000, Train Loss: 0.6404, Val Avg Corr: 0.3828
Epoch [2/50], Step 3500, Train Loss: 0.5558, Val Avg Corr: 0.4414
Epoch [2/50], Step 4000, Train Loss: 0.5814, Val Avg Corr: 0.4263
Epoch [2/50], Step 4500, Train Loss: 0.4906, Val Avg Corr: 0.4479
Epoch [2/50], Step 5000, Train Loss: 0.5170, Val Avg Corr: 0.4586
Epoch [2/50], Step 5500, Train Loss: 0.5974, Val Avg Corr: 0.4310
Epoch [2/50], Step 6000, Train Loss: 0.7410, Val Avg Corr: 0.3855
Epoch [2/50], Step 6500, Train Loss: 0.7889, Val Avg Corr: 0.4470
Epoch [3/50], Step 500, Train Loss: 0.5452, Val Avg Corr: 0.4577
Epoch [3/50], Step 1000, Train Loss: 0.6436, Val Avg Corr: 0.4148
Epoch [3/50], Step 1500, Train Loss: 0.5913, Val Avg Corr: 0.4594
Epoch [3/50], Step 2000, Train Loss: 0.5714, Val Avg Corr: 0.4489
Epoch [3/50], Step 2500, Train Loss: 0.5734, Val Avg Corr: 0.5050
  >>> New best validation model saved with Avg Corr: 0.5050 <<<
Epoch [3/50], Step 3000, Train Loss: 0.6198, Val Avg Corr: 0.4673
Epoch [3/50], Step 3500, Train Loss: 0.5533, Val Avg Corr: 0.4744
Epoch [3/50], Step 4000, Train Loss: 0.5301, Val Avg Corr: 0.4048
Epoch [3/50], Step 4500, Train Loss: 0.4573, Val Avg Corr: 0.4593
Epoch [3/50], Step 5000, Train Loss: 0.4595, Val Avg Corr: 0.4803
Epoch [3/50], Step 5500, Train Loss: 0.5578, Val Avg Corr: 0.3910
Epoch [3/50], Step 6000, Train Loss: 0.6990, Val Avg Corr: 0.4727
Epoch [3/50], Step 6500, Train Loss: 0.7887, Val Avg Corr: 0.4679
Epoch [4/50], Step 500, Train Loss: 0.5518, Val Avg Corr: 0.4511
Epoch [4/50], Step 1000, Train Loss: 0.6540, Val Avg Corr: 0.4352
Epoch [4/50], Step 1500, Train Loss: 0.6020, Val Avg Corr: 0.4764
Epoch [4/50], Step 2000, Train Loss: 0.5652, Val Avg Corr: 0.4518
Epoch [4/50], Step 2500, Train Loss: 0.5454, Val Avg Corr: 0.4883
Epoch [4/50], Step 3000, Train Loss: 0.5844, Val Avg Corr: 0.4887
Epoch [4/50], Step 3500, Train Loss: 0.5482, Val Avg Corr: 0.4599
Epoch [4/50], Step 4000, Train Loss: 0.5441, Val Avg Corr: 0.4660
Epoch [4/50], Step 4500, Train Loss: 0.4271, Val Avg Corr: 0.4802
Epoch [4/50], Step 5000, Train Loss: 0.4520, Val Avg Corr: 0.5045
Epoch [4/50], Step 5500, Train Loss: 0.5292, Val Avg Corr: 0.3838
Epoch [4/50], Step 6000, Train Loss: 0.7171, Val Avg Corr: 0.4386
Early stopping triggered after 6000 steps in epoch 4.
Loaded best model with validation Corr: 0.5050
  Re-evaluating SNN with movement mask for fair comparison...
  SNN Test Corr (All Bins): X=0.4616, Y=0.6198
  SNN Test  R²  (All Bins): X=0.1816, Y=0.3167
Time-series velocity figure saved --> snn_velocity_timeseries_slice_indy_20161212_02.mat.png

  --- Running Kalman Filter ---

--- Setting up Kalman Filter ---
Fitting linear velocity decoder (Ridge)
Estimating R from decoder residuals
Initializing Kalman Filter...
Running Kalman Filter for 1753 test steps...
Kalman Filter processing time: 0.10 seconds
--- Kalman Filter Setup and Run Complete ---
  KF Test Corr (Movement Only): X=0.3369, Y=0.3719

  --- Running LSTM ---
Starting LSTM training for 50 epochs on cpu...
Epoch [1/50], Train Loss: 0.498918, Val Loss: 0.536083
  New best validation loss: 0.536083
Epoch [2/50], Train Loss: 0.211278, Val Loss: 0.502095
  New best validation loss: 0.502095
Epoch [3/50], Train Loss: 0.124229, Val Loss: 0.485054
  New best validation loss: 0.485054
Epoch [4/50], Train Loss: 0.093378, Val Loss: 0.506888
Epoch [5/50], Train Loss: 0.076797, Val Loss: 0.502172
Epoch [6/50], Train Loss: 0.063096, Val Loss: 0.481511
  New best validation loss: 0.481511
Epoch [7/50], Train Loss: 0.054906, Val Loss: 0.473374
  New best validation loss: 0.473374
Epoch [8/50], Train Loss: 0.047958, Val Loss: 0.502020
Epoch [9/50], Train Loss: 0.040340, Val Loss: 0.497424
Epoch [10/50], Train Loss: 0.039116, Val Loss: 0.496928
Epoch [11/50], Train Loss: 0.035685, Val Loss: 0.505895
Epoch [12/50], Train Loss: 0.029928, Val Loss: 0.498314
Epoch [13/50], Train Loss: 0.028576, Val Loss: 0.481842
Epoch [14/50], Train Loss: 0.028178, Val Loss: 0.484025
Epoch [15/50], Train Loss: 0.029904, Val Loss: 0.477547
Epoch [16/50], Train Loss: 0.025656, Val Loss: 0.466056
  New best validation loss: 0.466056
Epoch [17/50], Train Loss: 0.023831, Val Loss: 0.486234
Epoch [18/50], Train Loss: 0.021454, Val Loss: 0.505770
Epoch [19/50], Train Loss: 0.020715, Val Loss: 0.479067
Epoch [20/50], Train Loss: 0.022144, Val Loss: 0.497712
Epoch [21/50], Train Loss: 0.021326, Val Loss: 0.490382
Epoch [22/50], Train Loss: 0.021144, Val Loss: 0.483523
Epoch [23/50], Train Loss: 0.018803, Val Loss: 0.477905
Epoch [24/50], Train Loss: 0.017943, Val Loss: 0.472221
Epoch [25/50], Train Loss: 0.019322, Val Loss: 0.462791
  New best validation loss: 0.462791
Epoch [26/50], Train Loss: 0.018643, Val Loss: 0.495400
Epoch [27/50], Train Loss: 0.018051, Val Loss: 0.482007
Epoch [28/50], Train Loss: 0.017436, Val Loss: 0.469342
Epoch [29/50], Train Loss: 0.019947, Val Loss: 0.482198
Epoch [30/50], Train Loss: 0.018471, Val Loss: 0.481460
Epoch [31/50], Train Loss: 0.015542, Val Loss: 0.499900
Epoch [32/50], Train Loss: 0.016606, Val Loss: 0.478305
Epoch [33/50], Train Loss: 0.014588, Val Loss: 0.484403
Epoch [34/50], Train Loss: 0.014343, Val Loss: 0.482562
Epoch [35/50], Train Loss: 0.015719, Val Loss: 0.463904
Early stopping triggered after 35 epochs.
Finished LSTM Training.
Loaded best model state from epoch 25.
  LSTM Test Corr (Movement Only): X=0.6986, Y=0.8358
--- Finished Session 4 ---

--- Session 5/10 (indy_20161013_03.mat) ---
  Using fixed parameters: Bin Width=0.050s, Stride=0.050s (no overlap)
  Using zero causal lag (0 ms) - skipping lag search.
  Using raw spike counts (no normalisation)...
    Sample spike-count matrix (first 4 bins, first 12 neurons):
[[3 1 2 1 0 1 1 1 1 2 1 1]
 [3 0 1 0 0 0 0 0 0 1 0 1]
 [3 0 0 0 0 0 0 0 0 0 0 0]
 [1 0 2 1 0 0 0 0 0 0 0 0]]
    Counts min / max in this session: 0 5
Global count histogram 0-6: [622420  80888  16612   3655    664     81      0]
    Sample rate-NORMALISED matrix (first 4 bins, first 12 neurons):
[[ 2.4660e+00  1.0898e+01  4.1040e+00  3.6730e+00 -3.3000e-02  1.4863e+01
   6.9980e+00  3.5170e+00  8.6856e+01  4.3050e+00  3.4900e+00  1.0350e+00]
 [ 2.4660e+00 -8.9000e-02  1.8440e+00 -2.4300e-01 -3.3000e-02 -6.3000e-02
  -1.4100e-01 -2.4600e-01 -1.2000e-02  1.9590e+00 -2.4900e-01  1.0350e+00]
 [ 2.4660e+00 -8.9000e-02 -4.1600e-01 -2.4300e-01 -3.3000e-02 -6.3000e-02
  -1.4100e-01 -2.4600e-01 -1.2000e-02 -3.8600e-01 -2.4900e-01 -6.1000e-01]
 [ 3.2700e-01 -8.9000e-02  4.1040e+00  3.6730e+00 -3.3000e-02 -6.3000e-02
  -1.4100e-01 -2.4600e-01 -1.2000e-02 -3.8600e-01 -2.4900e-01 -6.1000e-01]]

  --- Running SNN Online Training ---
Starting SNN Online Training for 50 epochs on cpu...
Evaluation every 500 steps, reset states every 200 steps
Warm-starting RMS EMAs with 50 steps...
RMS EMA warm-start complete.
Epoch [1/50], Step 500, Train Loss: 0.8800, Val Avg Corr: 0.2863
  >>> New best validation model saved with Avg Corr: 0.2863 <<<
Epoch [1/50], Step 1000, Train Loss: 0.8173, Val Avg Corr: 0.3615
  >>> New best validation model saved with Avg Corr: 0.3615 <<<
Epoch [1/50], Step 1500, Train Loss: 0.7883, Val Avg Corr: 0.4414
  >>> New best validation model saved with Avg Corr: 0.4414 <<<
Epoch [1/50], Step 2000, Train Loss: 0.5239, Val Avg Corr: 0.4896
  >>> New best validation model saved with Avg Corr: 0.4896 <<<
Epoch [1/50], Step 2500, Train Loss: 0.6642, Val Avg Corr: 0.4314
Epoch [1/50], Step 3000, Train Loss: 0.6425, Val Avg Corr: 0.5432
  >>> New best validation model saved with Avg Corr: 0.5432 <<<
Epoch [1/50], Step 3500, Train Loss: 0.7350, Val Avg Corr: 0.5587
  >>> New best validation model saved with Avg Corr: 0.5587 <<<
Epoch [1/50], Step 4000, Train Loss: 0.6433, Val Avg Corr: 0.5758
  >>> New best validation model saved with Avg Corr: 0.5758 <<<
Epoch [1/50], Step 4500, Train Loss: 0.6297, Val Avg Corr: 0.5777
  >>> New best validation model saved with Avg Corr: 0.5777 <<<
Epoch [1/50], Step 5000, Train Loss: 0.5796, Val Avg Corr: 0.5899
  >>> New best validation model saved with Avg Corr: 0.5899 <<<
Epoch [1/50], Step 5500, Train Loss: 0.5972, Val Avg Corr: 0.5937
  >>> New best validation model saved with Avg Corr: 0.5937 <<<
Epoch [1/50], Step 6000, Train Loss: 0.7502, Val Avg Corr: 0.4509
Epoch [2/50], Step 500, Train Loss: 0.7275, Val Avg Corr: 0.5296
Epoch [2/50], Step 1000, Train Loss: 0.6529, Val Avg Corr: 0.5656
Epoch [2/50], Step 1500, Train Loss: 0.6984, Val Avg Corr: 0.5553
Epoch [2/50], Step 2000, Train Loss: 0.4584, Val Avg Corr: 0.5566
Epoch [2/50], Step 2500, Train Loss: 0.5771, Val Avg Corr: 0.5678
Epoch [2/50], Step 3000, Train Loss: 0.5551, Val Avg Corr: 0.5871
Epoch [2/50], Step 3500, Train Loss: 0.6588, Val Avg Corr: 0.6281
  >>> New best validation model saved with Avg Corr: 0.6281 <<<
Epoch [2/50], Step 4000, Train Loss: 0.6110, Val Avg Corr: 0.6313
  >>> New best validation model saved with Avg Corr: 0.6313 <<<
Epoch [2/50], Step 4500, Train Loss: 0.5852, Val Avg Corr: 0.6113
Epoch [2/50], Step 5000, Train Loss: 0.5981, Val Avg Corr: 0.5880
Epoch [2/50], Step 5500, Train Loss: 0.5193, Val Avg Corr: 0.6537
  >>> New best validation model saved with Avg Corr: 0.6537 <<<
Epoch [2/50], Step 6000, Train Loss: 0.7410, Val Avg Corr: 0.6065
Epoch [3/50], Step 500, Train Loss: 0.6375, Val Avg Corr: 0.6238
Epoch [3/50], Step 1000, Train Loss: 0.5941, Val Avg Corr: 0.6036
Epoch [3/50], Step 1500, Train Loss: 0.6269, Val Avg Corr: 0.6171
Epoch [3/50], Step 2000, Train Loss: 0.4303, Val Avg Corr: 0.6445
Epoch [3/50], Step 2500, Train Loss: 0.5366, Val Avg Corr: 0.6455
Epoch [3/50], Step 3000, Train Loss: 0.5659, Val Avg Corr: 0.5598
Epoch [3/50], Step 3500, Train Loss: 0.6373, Val Avg Corr: 0.6451
Epoch [3/50], Step 4000, Train Loss: 0.6071, Val Avg Corr: 0.6436
Epoch [3/50], Step 4500, Train Loss: 0.5978, Val Avg Corr: 0.6265
Epoch [3/50], Step 5000, Train Loss: 0.5788, Val Avg Corr: 0.6499
Epoch [3/50], Step 5500, Train Loss: 0.5200, Val Avg Corr: 0.7155
  >>> New best validation model saved with Avg Corr: 0.7155 <<<
Epoch [3/50], Step 6000, Train Loss: 0.6879, Val Avg Corr: 0.6524
Epoch [4/50], Step 500, Train Loss: 0.6191, Val Avg Corr: 0.5930
Epoch [4/50], Step 1000, Train Loss: 0.6075, Val Avg Corr: 0.6275
Epoch [4/50], Step 1500, Train Loss: 0.5930, Val Avg Corr: 0.5385
Epoch [4/50], Step 2000, Train Loss: 0.4426, Val Avg Corr: 0.6589
Epoch [4/50], Step 2500, Train Loss: 0.5270, Val Avg Corr: 0.6743
Epoch [4/50], Step 3000, Train Loss: 0.5304, Val Avg Corr: 0.6517
Epoch [4/50], Step 3500, Train Loss: 0.5823, Val Avg Corr: 0.7116
Epoch [4/50], Step 4000, Train Loss: 0.6141, Val Avg Corr: 0.6980
Epoch [4/50], Step 4500, Train Loss: 0.5423, Val Avg Corr: 0.6400
Epoch [4/50], Step 5000, Train Loss: 0.5059, Val Avg Corr: 0.6604
Epoch [4/50], Step 5500, Train Loss: 0.4823, Val Avg Corr: 0.7125
Epoch [4/50], Step 6000, Train Loss: 0.7106, Val Avg Corr: 0.6374
Epoch [5/50], Step 500, Train Loss: 0.6510, Val Avg Corr: 0.5709
Epoch [5/50], Step 1000, Train Loss: 0.6445, Val Avg Corr: 0.5968
Epoch [5/50], Step 1500, Train Loss: 0.6383, Val Avg Corr: 0.6016
Epoch [5/50], Step 2000, Train Loss: 0.4438, Val Avg Corr: 0.6233
Epoch [5/50], Step 2500, Train Loss: 0.6045, Val Avg Corr: 0.6574
Epoch [5/50], Step 3000, Train Loss: 0.5625, Val Avg Corr: 0.6150
Epoch [5/50], Step 3500, Train Loss: 0.6623, Val Avg Corr: 0.5425
Early stopping triggered after 3500 steps in epoch 5.
Loaded best model with validation Corr: 0.7155
  Re-evaluating SNN with movement mask for fair comparison...
  SNN Test Corr (All Bins): X=0.6521, Y=0.7543
  SNN Test  R²  (All Bins): X=0.4087, Y=0.5324
Time-series velocity figure saved --> snn_velocity_timeseries_slice_indy_20161013_03.mat.png

  --- Running Kalman Filter ---

--- Setting up Kalman Filter ---
Fitting linear velocity decoder (Ridge)
Estimating R from decoder residuals
Initializing Kalman Filter...
Running Kalman Filter for 1618 test steps...
Kalman Filter processing time: 0.06 seconds
--- Kalman Filter Setup and Run Complete ---
  KF Test Corr (Movement Only): X=0.3732, Y=0.4457

  --- Running LSTM ---
Starting LSTM training for 50 epochs on cpu...
Epoch [1/50], Train Loss: 0.431206, Val Loss: 0.354715
  New best validation loss: 0.354715
Epoch [2/50], Train Loss: 0.168906, Val Loss: 0.314436
  New best validation loss: 0.314436
Epoch [3/50], Train Loss: 0.105075, Val Loss: 0.301079
  New best validation loss: 0.301079
Epoch [4/50], Train Loss: 0.077919, Val Loss: 0.304927
Epoch [5/50], Train Loss: 0.061512, Val Loss: 0.302332
Epoch [6/50], Train Loss: 0.053871, Val Loss: 0.288681
  New best validation loss: 0.288681
Epoch [7/50], Train Loss: 0.045941, Val Loss: 0.307749
Epoch [8/50], Train Loss: 0.041778, Val Loss: 0.299209
Epoch [9/50], Train Loss: 0.037996, Val Loss: 0.292151
Epoch [10/50], Train Loss: 0.033673, Val Loss: 0.276051
  New best validation loss: 0.276051
Epoch [11/50], Train Loss: 0.030269, Val Loss: 0.301263
Epoch [12/50], Train Loss: 0.028347, Val Loss: 0.281801
Epoch [13/50], Train Loss: 0.027016, Val Loss: 0.279839
Epoch [14/50], Train Loss: 0.025804, Val Loss: 0.282118
Epoch [15/50], Train Loss: 0.022181, Val Loss: 0.276736
Epoch [16/50], Train Loss: 0.023145, Val Loss: 0.281711
Epoch [17/50], Train Loss: 0.022527, Val Loss: 0.285554
Epoch [18/50], Train Loss: 0.020460, Val Loss: 0.264596
  New best validation loss: 0.264596
Epoch [19/50], Train Loss: 0.020369, Val Loss: 0.275169
Epoch [20/50], Train Loss: 0.018144, Val Loss: 0.287689
Epoch [21/50], Train Loss: 0.018080, Val Loss: 0.287592
Epoch [22/50], Train Loss: 0.017281, Val Loss: 0.282108
Epoch [23/50], Train Loss: 0.015637, Val Loss: 0.283021
Epoch [24/50], Train Loss: 0.016111, Val Loss: 0.282515
Epoch [25/50], Train Loss: 0.016918, Val Loss: 0.273867
Epoch [26/50], Train Loss: 0.016193, Val Loss: 0.266141
Epoch [27/50], Train Loss: 0.015904, Val Loss: 0.292841
Epoch [28/50], Train Loss: 0.015496, Val Loss: 0.275594
Early stopping triggered after 28 epochs.
Finished LSTM Training.
Loaded best model state from epoch 18.
  LSTM Test Corr (Movement Only): X=0.7161, Y=0.8488
--- Finished Session 5 ---

--- Session 6/10 (indy_20160927_06.mat) ---
  Using fixed parameters: Bin Width=0.050s, Stride=0.050s (no overlap)
  Using zero causal lag (0 ms) - skipping lag search.
  Using raw spike counts (no normalisation)...
    Sample spike-count matrix (first 4 bins, first 12 neurons):
[[1 1 1 1 1 1 1 1 1 1 1 1]
 [1 0 0 0 0 1 0 0 0 0 0 0]
 [0 0 0 0 0 0 0 0 0 0 0 0]
 [1 1 0 1 0 0 2 1 0 1 0 1]]
    Counts min / max in this session: 0 6
Global count histogram 0-6: [492097  75395  16587   4108    972    173     12]
    Sample rate-NORMALISED matrix (first 4 bins, first 12 neurons):
[[ 0.619  1.194  2.545  0.657  1.854  2.549  0.345  1.477  6.522  2.899
   6.937  3.985]
 [ 0.619 -0.54  -0.314 -0.658 -0.43   2.549 -0.8   -0.486 -0.147 -0.296
  -0.135 -0.216]
 [-0.663 -0.54  -0.314 -0.658 -0.43  -0.345 -0.8   -0.486 -0.147 -0.296
  -0.135 -0.216]
 [ 0.619  1.194 -0.314  0.657 -0.43  -0.345  1.49   1.477 -0.147  2.899
  -0.135  3.985]]

  --- Running SNN Online Training ---
Starting SNN Online Training for 50 epochs on cpu...
Evaluation every 500 steps, reset states every 200 steps
Warm-starting RMS EMAs with 50 steps...
RMS EMA warm-start complete.
Epoch [1/50], Step 500, Train Loss: 0.0025, Val Avg Corr: -0.0138
  >>> New best validation model saved with Avg Corr: -0.0138 <<<
Epoch [1/50], Step 1000, Train Loss: 0.3498, Val Avg Corr: 0.1239
  >>> New best validation model saved with Avg Corr: 0.1239 <<<
Epoch [1/50], Step 1500, Train Loss: 0.8192, Val Avg Corr: 0.2257
  >>> New best validation model saved with Avg Corr: 0.2257 <<<
Epoch [1/50], Step 2000, Train Loss: 0.7617, Val Avg Corr: 0.1080
Epoch [1/50], Step 2500, Train Loss: 0.8533, Val Avg Corr: 0.2975
  >>> New best validation model saved with Avg Corr: 0.2975 <<<
Epoch [1/50], Step 3000, Train Loss: 0.7173, Val Avg Corr: 0.2743
Epoch [1/50], Step 3500, Train Loss: 0.9809, Val Avg Corr: 0.3351
  >>> New best validation model saved with Avg Corr: 0.3351 <<<
Epoch [1/50], Step 4000, Train Loss: 0.6449, Val Avg Corr: 0.3834
  >>> New best validation model saved with Avg Corr: 0.3834 <<<
Epoch [1/50], Step 4500, Train Loss: 0.5490, Val Avg Corr: 0.4903
  >>> New best validation model saved with Avg Corr: 0.4903 <<<
Epoch [1/50], Step 5000, Train Loss: 0.5647, Val Avg Corr: 0.4481
Epoch [2/50], Step 500, Train Loss: 0.0228, Val Avg Corr: 0.2928
Epoch [2/50], Step 1000, Train Loss: 0.3376, Val Avg Corr: 0.3426
Epoch [2/50], Step 1500, Train Loss: 0.7090, Val Avg Corr: 0.4396
Epoch [2/50], Step 2000, Train Loss: 0.6665, Val Avg Corr: 0.5076
  >>> New best validation model saved with Avg Corr: 0.5076 <<<
Epoch [2/50], Step 2500, Train Loss: 0.7664, Val Avg Corr: 0.4043
Epoch [2/50], Step 3000, Train Loss: 0.6233, Val Avg Corr: 0.4489
Epoch [2/50], Step 3500, Train Loss: 0.8762, Val Avg Corr: 0.5020
Epoch [2/50], Step 4000, Train Loss: 0.5316, Val Avg Corr: 0.5527
  >>> New best validation model saved with Avg Corr: 0.5527 <<<
Epoch [2/50], Step 4500, Train Loss: 0.5319, Val Avg Corr: 0.5826
  >>> New best validation model saved with Avg Corr: 0.5826 <<<
Epoch [2/50], Step 5000, Train Loss: 0.5038, Val Avg Corr: 0.4570
Epoch [3/50], Step 500, Train Loss: 0.0086, Val Avg Corr: 0.2526
Epoch [3/50], Step 1000, Train Loss: 0.3163, Val Avg Corr: 0.4812
Epoch [3/50], Step 1500, Train Loss: 0.6327, Val Avg Corr: 0.4601
Epoch [3/50], Step 2000, Train Loss: 0.5998, Val Avg Corr: 0.5251
Epoch [3/50], Step 2500, Train Loss: 0.7355, Val Avg Corr: 0.5341
Epoch [3/50], Step 3000, Train Loss: 0.5658, Val Avg Corr: 0.4979
Epoch [3/50], Step 3500, Train Loss: 0.8191, Val Avg Corr: 0.5579
Epoch [3/50], Step 4000, Train Loss: 0.5289, Val Avg Corr: 0.5937
  >>> New best validation model saved with Avg Corr: 0.5937 <<<
Epoch [3/50], Step 4500, Train Loss: 0.4695, Val Avg Corr: 0.5673
Epoch [3/50], Step 5000, Train Loss: 0.5179, Val Avg Corr: 0.4531
Epoch [4/50], Step 500, Train Loss: 0.0103, Val Avg Corr: 0.4524
Epoch [4/50], Step 1000, Train Loss: 0.3291, Val Avg Corr: 0.4946
Epoch [4/50], Step 1500, Train Loss: 0.6027, Val Avg Corr: 0.4710
Epoch [4/50], Step 2000, Train Loss: 0.6118, Val Avg Corr: 0.5520
Epoch [4/50], Step 2500, Train Loss: 0.7280, Val Avg Corr: 0.4802
Epoch [4/50], Step 3000, Train Loss: 0.5665, Val Avg Corr: 0.4832
Epoch [4/50], Step 3500, Train Loss: 0.7864, Val Avg Corr: 0.5616
Epoch [4/50], Step 4000, Train Loss: 0.5029, Val Avg Corr: 0.6172
  >>> New best validation model saved with Avg Corr: 0.6172 <<<
Epoch [4/50], Step 4500, Train Loss: 0.4876, Val Avg Corr: 0.4786
Epoch [4/50], Step 5000, Train Loss: 0.5318, Val Avg Corr: 0.4106
Epoch [5/50], Step 500, Train Loss: 0.0066, Val Avg Corr: 0.3961
Epoch [5/50], Step 1000, Train Loss: 0.3253, Val Avg Corr: 0.5308
Epoch [5/50], Step 1500, Train Loss: 0.5733, Val Avg Corr: 0.4169
Epoch [5/50], Step 2000, Train Loss: 0.6433, Val Avg Corr: 0.5415
Epoch [5/50], Step 2500, Train Loss: 0.7565, Val Avg Corr: 0.5652
Epoch [5/50], Step 3000, Train Loss: 0.5089, Val Avg Corr: 0.4969
Epoch [5/50], Step 3500, Train Loss: 0.8197, Val Avg Corr: 0.4695
Epoch [5/50], Step 4000, Train Loss: 0.5297, Val Avg Corr: 0.5665
Epoch [5/50], Step 4500, Train Loss: 0.5254, Val Avg Corr: 0.4788
Epoch [5/50], Step 5000, Train Loss: 0.5277, Val Avg Corr: 0.4437
Epoch [6/50], Step 500, Train Loss: 0.0067, Val Avg Corr: 0.3473
Epoch [6/50], Step 1000, Train Loss: 0.3249, Val Avg Corr: 0.5063
Epoch [6/50], Step 1500, Train Loss: 0.5886, Val Avg Corr: 0.3835
Epoch [6/50], Step 2000, Train Loss: 0.6108, Val Avg Corr: 0.5739
Epoch [6/50], Step 2500, Train Loss: 0.7852, Val Avg Corr: 0.5511
Epoch [6/50], Step 3000, Train Loss: 0.5193, Val Avg Corr: 0.4355
Epoch [6/50], Step 3500, Train Loss: 0.7904, Val Avg Corr: 0.5232
Epoch [6/50], Step 4000, Train Loss: 0.5345, Val Avg Corr: 0.5424
Early stopping triggered after 4000 steps in epoch 6.
Loaded best model with validation Corr: 0.6172
  Re-evaluating SNN with movement mask for fair comparison...
  SNN Test Corr (All Bins): X=0.6753, Y=0.7068
  SNN Test  R²  (All Bins): X=0.4536, Y=0.4868
Time-series velocity figure saved --> snn_velocity_timeseries_slice_indy_20160927_06.mat.png

  --- Running Kalman Filter ---

--- Setting up Kalman Filter ---
Fitting linear velocity decoder (Ridge)
Estimating R from decoder residuals
Initializing Kalman Filter...
Running Kalman Filter for 1316 test steps...
Kalman Filter processing time: 0.05 seconds
--- Kalman Filter Setup and Run Complete ---
  KF Test Corr (Movement Only): X=0.3977, Y=0.5245

  --- Running LSTM ---
Starting LSTM training for 50 epochs on cpu...
Epoch [1/50], Train Loss: 0.476319, Val Loss: 0.496482
  New best validation loss: 0.496482
Epoch [2/50], Train Loss: 0.181706, Val Loss: 0.517193
Epoch [3/50], Train Loss: 0.104151, Val Loss: 0.449013
  New best validation loss: 0.449013
Epoch [4/50], Train Loss: 0.076853, Val Loss: 0.454150
Epoch [5/50], Train Loss: 0.067518, Val Loss: 0.431165
  New best validation loss: 0.431165
Epoch [6/50], Train Loss: 0.052601, Val Loss: 0.452676
Epoch [7/50], Train Loss: 0.047876, Val Loss: 0.421732
  New best validation loss: 0.421732
Epoch [8/50], Train Loss: 0.039862, Val Loss: 0.424313
Epoch [9/50], Train Loss: 0.035840, Val Loss: 0.438675
Epoch [10/50], Train Loss: 0.031884, Val Loss: 0.447181
Epoch [11/50], Train Loss: 0.030683, Val Loss: 0.450777
Epoch [12/50], Train Loss: 0.032021, Val Loss: 0.420552
  New best validation loss: 0.420552
Epoch [13/50], Train Loss: 0.028236, Val Loss: 0.433049
Epoch [14/50], Train Loss: 0.024398, Val Loss: 0.425977
Epoch [15/50], Train Loss: 0.021234, Val Loss: 0.429768
Epoch [16/50], Train Loss: 0.022330, Val Loss: 0.435835
Epoch [17/50], Train Loss: 0.023160, Val Loss: 0.436373
Epoch [18/50], Train Loss: 0.024012, Val Loss: 0.439339
Epoch [19/50], Train Loss: 0.020128, Val Loss: 0.436317
Epoch [20/50], Train Loss: 0.020129, Val Loss: 0.453688
Epoch [21/50], Train Loss: 0.019761, Val Loss: 0.455961
Epoch [22/50], Train Loss: 0.017783, Val Loss: 0.439944
Early stopping triggered after 22 epochs.
Finished LSTM Training.
Loaded best model state from epoch 12.
  LSTM Test Corr (Movement Only): X=0.7463, Y=0.8363
--- Finished Session 6 ---

--- Session 7/10 (indy_20160921_01.mat) ---
  Using fixed parameters: Bin Width=0.050s, Stride=0.050s (no overlap)
  Using zero causal lag (0 ms) - skipping lag search.
  Using raw spike counts (no normalisation)...
    Sample spike-count matrix (first 4 bins, first 12 neurons):
[[1 1 1 1 1 1 1 1 1 2 2 1]
 [0 1 0 0 0 0 1 0 0 0 0 0]
 [1 0 1 0 1 0 0 0 0 0 0 2]
 [0 1 0 1 0 1 0 0 0 0 1 0]]
    Counts min / max in this session: 0 6
Global count histogram 0-6: [407503  77294  15691   3138    518     45      3]
    Sample rate-NORMALISED matrix (first 4 bins, first 12 neurons):
[[ 1.45   1.016  1.493  2.412  2.058  2.783  1.31   1.716  4.391  6.504
   3.166  1.891]
 [-0.461  1.016 -0.466 -0.348 -0.398 -0.331  1.31  -0.459 -0.211 -0.268
  -0.516 -0.386]
 [ 1.45  -0.604  1.493 -0.348  2.058 -0.331 -0.524 -0.459 -0.211 -0.268
  -0.516  4.168]
 [-0.461  1.016 -0.466  2.412 -0.398  2.783 -0.524 -0.459 -0.211 -0.268
   1.325 -0.386]]

  --- Running SNN Online Training ---
Starting SNN Online Training for 50 epochs on cpu...
Evaluation every 500 steps, reset states every 200 steps
Warm-starting RMS EMAs with 50 steps...
RMS EMA warm-start complete.
Epoch [1/50], Step 500, Train Loss: 0.8429, Val Avg Corr: 0.1004
  >>> New best validation model saved with Avg Corr: 0.1004 <<<
Epoch [1/50], Step 1000, Train Loss: 0.6923, Val Avg Corr: 0.3046
  >>> New best validation model saved with Avg Corr: 0.3046 <<<
Epoch [1/50], Step 1500, Train Loss: 0.6045, Val Avg Corr: 0.3666
  >>> New best validation model saved with Avg Corr: 0.3666 <<<
Epoch [1/50], Step 2000, Train Loss: 0.6541, Val Avg Corr: 0.5029
  >>> New best validation model saved with Avg Corr: 0.5029 <<<
Epoch [1/50], Step 2500, Train Loss: 0.4897, Val Avg Corr: 0.5518
  >>> New best validation model saved with Avg Corr: 0.5518 <<<
Epoch [1/50], Step 3000, Train Loss: 0.7482, Val Avg Corr: 0.6083
  >>> New best validation model saved with Avg Corr: 0.6083 <<<
Epoch [1/50], Step 3500, Train Loss: 0.6918, Val Avg Corr: 0.6924
  >>> New best validation model saved with Avg Corr: 0.6924 <<<
Epoch [1/50], Step 4000, Train Loss: 0.6206, Val Avg Corr: 0.7178
  >>> New best validation model saved with Avg Corr: 0.7178 <<<
Epoch [2/50], Step 500, Train Loss: 0.7392, Val Avg Corr: 0.6719
Epoch [2/50], Step 1000, Train Loss: 0.5828, Val Avg Corr: 0.7179
  >>> New best validation model saved with Avg Corr: 0.7179 <<<
Epoch [2/50], Step 1500, Train Loss: 0.4802, Val Avg Corr: 0.6955
Epoch [2/50], Step 2000, Train Loss: 0.5133, Val Avg Corr: 0.5237
Epoch [2/50], Step 2500, Train Loss: 0.4439, Val Avg Corr: 0.6428
Epoch [2/50], Step 3000, Train Loss: 0.6470, Val Avg Corr: 0.6988
Epoch [2/50], Step 3500, Train Loss: 0.6206, Val Avg Corr: 0.6497
Epoch [2/50], Step 4000, Train Loss: 0.5984, Val Avg Corr: 0.6760
Epoch [3/50], Step 500, Train Loss: 0.7377, Val Avg Corr: 0.6990
Epoch [3/50], Step 1000, Train Loss: 0.5283, Val Avg Corr: 0.6816
Epoch [3/50], Step 1500, Train Loss: 0.4425, Val Avg Corr: 0.7080
Epoch [3/50], Step 2000, Train Loss: 0.4810, Val Avg Corr: 0.6071
Epoch [3/50], Step 2500, Train Loss: 0.4521, Val Avg Corr: 0.7030
Epoch [3/50], Step 3000, Train Loss: 0.6097, Val Avg Corr: 0.6897
Epoch [3/50], Step 3500, Train Loss: 0.5634, Val Avg Corr: 0.6825
Epoch [3/50], Step 4000, Train Loss: 0.5724, Val Avg Corr: 0.7028
Epoch [4/50], Step 500, Train Loss: 0.7085, Val Avg Corr: 0.6831
Epoch [4/50], Step 1000, Train Loss: 0.5440, Val Avg Corr: 0.7081
Epoch [4/50], Step 1500, Train Loss: 0.4421, Val Avg Corr: 0.7081
Epoch [4/50], Step 2000, Train Loss: 0.4030, Val Avg Corr: 0.5849
Epoch [4/50], Step 2500, Train Loss: 0.3843, Val Avg Corr: 0.6885
Epoch [4/50], Step 3000, Train Loss: 0.5810, Val Avg Corr: 0.6701
Early stopping triggered after 3000 steps in epoch 4.
Loaded best model with validation Corr: 0.7179
  Re-evaluating SNN with movement mask for fair comparison...
  SNN Test Corr (All Bins): X=0.5117, Y=0.7361
  SNN Test  R²  (All Bins): X=0.2532, Y=0.4025
Time-series velocity figure saved --> snn_velocity_timeseries_slice_indy_20160921_01.mat.png

  --- Running Kalman Filter ---

--- Setting up Kalman Filter ---
Fitting linear velocity decoder (Ridge)
Estimating R from decoder residuals
Initializing Kalman Filter...
Running Kalman Filter for 1126 test steps...
Kalman Filter processing time: 0.04 seconds
--- Kalman Filter Setup and Run Complete ---
  KF Test Corr (Movement Only): X=0.3754, Y=0.4900

  --- Running LSTM ---
Starting LSTM training for 50 epochs on cpu...
Epoch [1/50], Train Loss: 0.512676, Val Loss: 0.401572
  New best validation loss: 0.401572
Epoch [2/50], Train Loss: 0.182484, Val Loss: 0.423560
Epoch [3/50], Train Loss: 0.109353, Val Loss: 0.342034
  New best validation loss: 0.342034
Epoch [4/50], Train Loss: 0.079869, Val Loss: 0.341964
  New best validation loss: 0.341964
Epoch [5/50], Train Loss: 0.061172, Val Loss: 0.338106
  New best validation loss: 0.338106
Epoch [6/50], Train Loss: 0.054372, Val Loss: 0.326794
  New best validation loss: 0.326794
Epoch [7/50], Train Loss: 0.044646, Val Loss: 0.333776
Epoch [8/50], Train Loss: 0.041638, Val Loss: 0.347172
Epoch [9/50], Train Loss: 0.036951, Val Loss: 0.334634
Epoch [10/50], Train Loss: 0.032297, Val Loss: 0.346669
Epoch [11/50], Train Loss: 0.028218, Val Loss: 0.349712
Epoch [12/50], Train Loss: 0.027252, Val Loss: 0.357425
Epoch [13/50], Train Loss: 0.027058, Val Loss: 0.349659
Epoch [14/50], Train Loss: 0.023421, Val Loss: 0.343718
Epoch [15/50], Train Loss: 0.023042, Val Loss: 0.353880
Epoch [16/50], Train Loss: 0.023614, Val Loss: 0.355677
Early stopping triggered after 16 epochs.
Finished LSTM Training.
Loaded best model state from epoch 6.
  LSTM Test Corr (Movement Only): X=0.7496, Y=0.8603
--- Finished Session 7 ---

--- Session 8/10 (indy_20161026_03.mat) ---
  Using fixed parameters: Bin Width=0.050s, Stride=0.050s (no overlap)
  Using zero causal lag (0 ms) - skipping lag search.
  Using raw spike counts (no normalisation)...
    Sample spike-count matrix (first 4 bins, first 12 neurons):
[[1 2 1 1 1 2 1 1 2 1 1 2]
 [0 0 0 0 0 0 0 0 0 0 0 1]
 [0 1 0 0 1 1 0 0 0 0 0 0]
 [0 1 0 0 0 0 0 0 0 2 1 1]]
    Counts min / max in this session: 0 6
Global count histogram 0-6: [614882  69200  10416   1586    271     28      1]
    Sample rate-NORMALISED matrix (first 4 bins, first 12 neurons):
[[ 3.8760e+00  2.3110e+00  4.3140e+00  5.5890e+00  2.2300e+00  6.2970e+00
   8.5165e+01  4.1840e+00  5.7380e+00  3.2300e+00  2.7970e+00  3.8670e+00]
 [-2.3300e-01 -5.7300e-01 -2.1200e-01 -1.7200e-01 -3.4200e-01 -2.9600e-01
  -1.2000e-02 -2.2600e-01 -3.0700e-01 -2.6000e-01 -3.1800e-01  1.7370e+00]
 [-2.3300e-01  8.6900e-01 -2.1200e-01 -1.7200e-01  2.2300e+00  3.0010e+00
  -1.2000e-02 -2.2600e-01 -3.0700e-01 -2.6000e-01 -3.1800e-01 -3.9400e-01]
 [-2.3300e-01  8.6900e-01 -2.1200e-01 -1.7200e-01 -3.4200e-01 -2.9600e-01
  -1.2000e-02 -2.2600e-01 -3.0700e-01  6.7190e+00  2.7970e+00  1.7370e+00]]

  --- Running SNN Online Training ---
Starting SNN Online Training for 50 epochs on cpu...
Evaluation every 500 steps, reset states every 200 steps
Warm-starting RMS EMAs with 50 steps...
RMS EMA warm-start complete.
Epoch [1/50], Step 500, Train Loss: 0.6963, Val Avg Corr: 0.1229
  >>> New best validation model saved with Avg Corr: 0.1229 <<<
Epoch [1/50], Step 1000, Train Loss: 0.6139, Val Avg Corr: 0.2141
  >>> New best validation model saved with Avg Corr: 0.2141 <<<
Epoch [1/50], Step 1500, Train Loss: 0.6917, Val Avg Corr: 0.3098
  >>> New best validation model saved with Avg Corr: 0.3098 <<<
Epoch [1/50], Step 2000, Train Loss: 0.6378, Val Avg Corr: 0.3447
  >>> New best validation model saved with Avg Corr: 0.3447 <<<
Epoch [1/50], Step 2500, Train Loss: 0.7693, Val Avg Corr: 0.3624
  >>> New best validation model saved with Avg Corr: 0.3624 <<<
Epoch [1/50], Step 3000, Train Loss: 0.5498, Val Avg Corr: 0.4119
  >>> New best validation model saved with Avg Corr: 0.4119 <<<
Epoch [1/50], Step 3500, Train Loss: 0.6305, Val Avg Corr: 0.5254
  >>> New best validation model saved with Avg Corr: 0.5254 <<<
Epoch [1/50], Step 4000, Train Loss: 0.5568, Val Avg Corr: 0.5377
  >>> New best validation model saved with Avg Corr: 0.5377 <<<
Epoch [1/50], Step 4500, Train Loss: 0.4845, Val Avg Corr: 0.5476
  >>> New best validation model saved with Avg Corr: 0.5476 <<<
Epoch [1/50], Step 5000, Train Loss: 0.6037, Val Avg Corr: 0.5498
  >>> New best validation model saved with Avg Corr: 0.5498 <<<
Epoch [1/50], Step 5500, Train Loss: 0.4849, Val Avg Corr: 0.5534
  >>> New best validation model saved with Avg Corr: 0.5534 <<<
Epoch [1/50], Step 6000, Train Loss: 0.6567, Val Avg Corr: 0.5525
Epoch [2/50], Step 500, Train Loss: 0.6004, Val Avg Corr: 0.5759
  >>> New best validation model saved with Avg Corr: 0.5759 <<<
Epoch [2/50], Step 1000, Train Loss: 0.4456, Val Avg Corr: 0.5096
Epoch [2/50], Step 1500, Train Loss: 0.5585, Val Avg Corr: 0.5148
Epoch [2/50], Step 2000, Train Loss: 0.5932, Val Avg Corr: 0.5505
Epoch [2/50], Step 2500, Train Loss: 0.6666, Val Avg Corr: 0.5464
Epoch [2/50], Step 3000, Train Loss: 0.4906, Val Avg Corr: 0.5256
Epoch [2/50], Step 3500, Train Loss: 0.5155, Val Avg Corr: 0.4874
Epoch [2/50], Step 4000, Train Loss: 0.4860, Val Avg Corr: 0.5089
Epoch [2/50], Step 4500, Train Loss: 0.4903, Val Avg Corr: 0.5624
Epoch [2/50], Step 5000, Train Loss: 0.5383, Val Avg Corr: 0.5474
Epoch [2/50], Step 5500, Train Loss: 0.4993, Val Avg Corr: 0.5220
Epoch [2/50], Step 6000, Train Loss: 0.5850, Val Avg Corr: 0.5699
Epoch [3/50], Step 500, Train Loss: 0.5699, Val Avg Corr: 0.5738
Epoch [3/50], Step 1000, Train Loss: 0.4187, Val Avg Corr: 0.5441
Epoch [3/50], Step 1500, Train Loss: 0.4732, Val Avg Corr: 0.5501
Epoch [3/50], Step 2000, Train Loss: 0.5108, Val Avg Corr: 0.5735
Epoch [3/50], Step 2500, Train Loss: 0.6584, Val Avg Corr: 0.5695
Epoch [3/50], Step 3000, Train Loss: 0.4350, Val Avg Corr: 0.5458
Epoch [3/50], Step 3500, Train Loss: 0.5274, Val Avg Corr: 0.5700
Epoch [3/50], Step 4000, Train Loss: 0.4881, Val Avg Corr: 0.6011
  >>> New best validation model saved with Avg Corr: 0.6011 <<<
Epoch [3/50], Step 4500, Train Loss: 0.4766, Val Avg Corr: 0.5674
Epoch [3/50], Step 5000, Train Loss: 0.5691, Val Avg Corr: 0.5774
Epoch [3/50], Step 5500, Train Loss: 0.3912, Val Avg Corr: 0.5606
Epoch [3/50], Step 6000, Train Loss: 0.5750, Val Avg Corr: 0.5329
Epoch [4/50], Step 500, Train Loss: 0.5416, Val Avg Corr: 0.6127
  >>> New best validation model saved with Avg Corr: 0.6127 <<<
Epoch [4/50], Step 1000, Train Loss: 0.3663, Val Avg Corr: 0.6008
Epoch [4/50], Step 1500, Train Loss: 0.4483, Val Avg Corr: 0.6010
Epoch [4/50], Step 2000, Train Loss: 0.4868, Val Avg Corr: 0.6093
Epoch [4/50], Step 2500, Train Loss: 0.6373, Val Avg Corr: 0.6161
  >>> New best validation model saved with Avg Corr: 0.6161 <<<
Epoch [4/50], Step 3000, Train Loss: 0.4273, Val Avg Corr: 0.5548
Epoch [4/50], Step 3500, Train Loss: 0.4980, Val Avg Corr: 0.5478
Epoch [4/50], Step 4000, Train Loss: 0.4670, Val Avg Corr: 0.5748
Epoch [4/50], Step 4500, Train Loss: 0.4701, Val Avg Corr: 0.5833
Epoch [4/50], Step 5000, Train Loss: 0.5353, Val Avg Corr: 0.6106
Epoch [4/50], Step 5500, Train Loss: 0.4621, Val Avg Corr: 0.5904
Epoch [4/50], Step 6000, Train Loss: 0.5805, Val Avg Corr: 0.5681
Epoch [5/50], Step 500, Train Loss: 0.5329, Val Avg Corr: 0.5991
Epoch [5/50], Step 1000, Train Loss: 0.3799, Val Avg Corr: 0.6143
Epoch [5/50], Step 1500, Train Loss: 0.4782, Val Avg Corr: 0.5736
Epoch [5/50], Step 2000, Train Loss: 0.4865, Val Avg Corr: 0.6273
  >>> New best validation model saved with Avg Corr: 0.6273 <<<
Epoch [5/50], Step 2500, Train Loss: 0.6508, Val Avg Corr: 0.5974
Epoch [5/50], Step 3000, Train Loss: 0.4541, Val Avg Corr: 0.5429
Epoch [5/50], Step 3500, Train Loss: 0.5432, Val Avg Corr: 0.5791
Epoch [5/50], Step 4000, Train Loss: 0.4344, Val Avg Corr: 0.6179
Epoch [5/50], Step 4500, Train Loss: 0.4243, Val Avg Corr: 0.6322
  >>> New best validation model saved with Avg Corr: 0.6322 <<<
Epoch [5/50], Step 5000, Train Loss: 0.5776, Val Avg Corr: 0.6064
Epoch [5/50], Step 5500, Train Loss: 0.4209, Val Avg Corr: 0.5691
Epoch [5/50], Step 6000, Train Loss: 0.5913, Val Avg Corr: 0.6137
Epoch [6/50], Step 500, Train Loss: 0.5473, Val Avg Corr: 0.6291
Epoch [6/50], Step 1000, Train Loss: 0.3571, Val Avg Corr: 0.5701
Epoch [6/50], Step 1500, Train Loss: 0.4431, Val Avg Corr: 0.5574
Epoch [6/50], Step 2000, Train Loss: 0.4357, Val Avg Corr: 0.5591
Epoch [6/50], Step 2500, Train Loss: 0.6028, Val Avg Corr: 0.5957
Epoch [6/50], Step 3000, Train Loss: 0.4315, Val Avg Corr: 0.5308
Epoch [6/50], Step 3500, Train Loss: 0.5220, Val Avg Corr: 0.5257
Epoch [6/50], Step 4000, Train Loss: 0.4685, Val Avg Corr: 0.6113
Epoch [6/50], Step 4500, Train Loss: 0.4844, Val Avg Corr: 0.6143
Epoch [6/50], Step 5000, Train Loss: 0.5786, Val Avg Corr: 0.6046
Epoch [6/50], Step 5500, Train Loss: 0.4538, Val Avg Corr: 0.5712
Epoch [6/50], Step 6000, Train Loss: 0.6480, Val Avg Corr: 0.5851
Epoch [7/50], Step 500, Train Loss: 0.5792, Val Avg Corr: 0.5449
Epoch [7/50], Step 1000, Train Loss: 0.4346, Val Avg Corr: 0.4550
Epoch [7/50], Step 1500, Train Loss: 0.5694, Val Avg Corr: 0.5560
Epoch [7/50], Step 2000, Train Loss: 0.6039, Val Avg Corr: 0.5692
Epoch [7/50], Step 2500, Train Loss: 0.7071, Val Avg Corr: 0.5521
Early stopping triggered after 2500 steps in epoch 7.
Loaded best model with validation Corr: 0.6322
  Re-evaluating SNN with movement mask for fair comparison...
  SNN Test Corr (All Bins): X=0.6388, Y=0.7051
  SNN Test  R²  (All Bins): X=0.3988, Y=0.4125
Time-series velocity figure saved --> snn_velocity_timeseries_slice_indy_20161026_03.mat.png

  --- Running Kalman Filter ---

--- Setting up Kalman Filter ---
Fitting linear velocity decoder (Ridge)
Estimating R from decoder residuals
Initializing Kalman Filter...
Running Kalman Filter for 1555 test steps...
Kalman Filter processing time: 0.05 seconds
--- Kalman Filter Setup and Run Complete ---
  KF Test Corr (Movement Only): X=0.3937, Y=0.4479

  --- Running LSTM ---
Starting LSTM training for 50 epochs on cpu...
Epoch [1/50], Train Loss: 0.436634, Val Loss: 0.478107
  New best validation loss: 0.478107
Epoch [2/50], Train Loss: 0.182891, Val Loss: 0.440643
  New best validation loss: 0.440643
Epoch [3/50], Train Loss: 0.110695, Val Loss: 0.421516
  New best validation loss: 0.421516
Epoch [4/50], Train Loss: 0.077551, Val Loss: 0.416165
  New best validation loss: 0.416165
Epoch [5/50], Train Loss: 0.061258, Val Loss: 0.423740
Epoch [6/50], Train Loss: 0.053968, Val Loss: 0.414229
  New best validation loss: 0.414229
Epoch [7/50], Train Loss: 0.051261, Val Loss: 0.392585
  New best validation loss: 0.392585
Epoch [8/50], Train Loss: 0.041909, Val Loss: 0.400042
Epoch [9/50], Train Loss: 0.038945, Val Loss: 0.396425
Epoch [10/50], Train Loss: 0.038745, Val Loss: 0.394308
Epoch [11/50], Train Loss: 0.029741, Val Loss: 0.381528
  New best validation loss: 0.381528
Epoch [12/50], Train Loss: 0.028730, Val Loss: 0.403661
Epoch [13/50], Train Loss: 0.028485, Val Loss: 0.393885
Epoch [14/50], Train Loss: 0.026801, Val Loss: 0.381993
Epoch [15/50], Train Loss: 0.023037, Val Loss: 0.385219
Epoch [16/50], Train Loss: 0.024772, Val Loss: 0.388800
Epoch [17/50], Train Loss: 0.027845, Val Loss: 0.380922
  New best validation loss: 0.380922
Epoch [18/50], Train Loss: 0.021863, Val Loss: 0.372598
  New best validation loss: 0.372598
Epoch [19/50], Train Loss: 0.018331, Val Loss: 0.381060
Epoch [20/50], Train Loss: 0.020400, Val Loss: 0.385404
Epoch [21/50], Train Loss: 0.020920, Val Loss: 0.378304
Epoch [22/50], Train Loss: 0.017160, Val Loss: 0.367405
  New best validation loss: 0.367405
Epoch [23/50], Train Loss: 0.015367, Val Loss: 0.372867
Epoch [24/50], Train Loss: 0.017477, Val Loss: 0.376303
Epoch [25/50], Train Loss: 0.018084, Val Loss: 0.377181
Epoch [26/50], Train Loss: 0.016317, Val Loss: 0.380735
Epoch [27/50], Train Loss: 0.017123, Val Loss: 0.387731
Epoch [28/50], Train Loss: 0.015386, Val Loss: 0.369302
Epoch [29/50], Train Loss: 0.015862, Val Loss: 0.382192
Epoch [30/50], Train Loss: 0.019045, Val Loss: 0.375582
Epoch [31/50], Train Loss: 0.017113, Val Loss: 0.368739
Epoch [32/50], Train Loss: 0.015315, Val Loss: 0.389360
Early stopping triggered after 32 epochs.
Finished LSTM Training.
Loaded best model state from epoch 22.
  LSTM Test Corr (Movement Only): X=0.7798, Y=0.8755
--- Finished Session 8 ---

--- Session 9/10 (indy_20161027_03.mat) ---
  Using fixed parameters: Bin Width=0.050s, Stride=0.050s (no overlap)
  Using zero causal lag (0 ms) - skipping lag search.
  Using raw spike counts (no normalisation)...
    Sample spike-count matrix (first 4 bins, first 12 neurons):
[[1 1 1 1 1 2 1 1 1 1 1 1]
 [0 0 0 0 0 0 0 1 0 0 0 0]
 [0 0 0 0 1 0 0 0 1 0 0 0]
 [0 0 0 0 0 0 0 0 0 0 0 0]]
    Counts min / max in this session: 0 6
Global count histogram 0-6: [723543  70043  12006   3435   1115    268     22]
    Sample rate-NORMALISED matrix (first 4 bins, first 12 neurons):
[[ 8.8680e+00  1.6420e+00  3.4140e+00  7.1950e+00  3.6360e+00  7.5480e+00
   9.1875e+01  5.3410e+00  4.6200e+00  3.7580e+00  4.5630e+00  2.7500e+00]
 [-1.1100e-01 -4.4100e-01 -2.5200e-01 -1.2500e-01 -2.4800e-01 -2.5000e-01
  -1.1000e-02  5.3410e+00 -1.9000e-01 -2.3000e-01 -1.9800e-01 -2.9000e-01]
 [-1.1100e-01 -4.4100e-01 -2.5200e-01 -1.2500e-01  3.6360e+00 -2.5000e-01
  -1.1000e-02 -1.7500e-01  4.6200e+00 -2.3000e-01 -1.9800e-01 -2.9000e-01]
 [-1.1100e-01 -4.4100e-01 -2.5200e-01 -1.2500e-01 -2.4800e-01 -2.5000e-01
  -1.1000e-02 -1.7500e-01 -1.9000e-01 -2.3000e-01 -1.9800e-01 -2.9000e-01]]

  --- Running SNN Online Training ---
Starting SNN Online Training for 50 epochs on cpu...
Evaluation every 500 steps, reset states every 200 steps
Warm-starting RMS EMAs with 50 steps...
RMS EMA warm-start complete.
Epoch [1/50], Step 500, Train Loss: 0.0502, Val Avg Corr: 0.1368
  >>> New best validation model saved with Avg Corr: 0.1368 <<<
Epoch [1/50], Step 1000, Train Loss: 0.5250, Val Avg Corr: -0.0224
Epoch [1/50], Step 1500, Train Loss: 0.4564, Val Avg Corr: 0.1440
  >>> New best validation model saved with Avg Corr: 0.1440 <<<
Epoch [1/50], Step 2000, Train Loss: 0.5843, Val Avg Corr: 0.2314
  >>> New best validation model saved with Avg Corr: 0.2314 <<<
Epoch [1/50], Step 2500, Train Loss: 0.7573, Val Avg Corr: 0.2425
  >>> New best validation model saved with Avg Corr: 0.2425 <<<
Epoch [1/50], Step 3000, Train Loss: 0.8553, Val Avg Corr: 0.2207
Epoch [1/50], Step 3500, Train Loss: 0.7157, Val Avg Corr: 0.3950
  >>> New best validation model saved with Avg Corr: 0.3950 <<<
Epoch [1/50], Step 4000, Train Loss: 0.7076, Val Avg Corr: 0.4603
  >>> New best validation model saved with Avg Corr: 0.4603 <<<
Epoch [1/50], Step 4500, Train Loss: 0.7984, Val Avg Corr: 0.4058
Epoch [1/50], Step 5000, Train Loss: 0.7948, Val Avg Corr: 0.3918
Epoch [1/50], Step 5500, Train Loss: 0.7167, Val Avg Corr: 0.3048
Epoch [1/50], Step 6000, Train Loss: 0.5662, Val Avg Corr: 0.3099
Epoch [1/50], Step 6500, Train Loss: 0.5359, Val Avg Corr: 0.4637
  >>> New best validation model saved with Avg Corr: 0.4637 <<<
Epoch [1/50], Step 7000, Train Loss: 0.9915, Val Avg Corr: 0.4701
  >>> New best validation model saved with Avg Corr: 0.4701 <<<
Epoch [2/50], Step 500, Train Loss: 0.0579, Val Avg Corr: 0.3349
Epoch [2/50], Step 1000, Train Loss: 0.4847, Val Avg Corr: 0.3751
Epoch [2/50], Step 1500, Train Loss: 0.4343, Val Avg Corr: 0.4859
  >>> New best validation model saved with Avg Corr: 0.4859 <<<
Epoch [2/50], Step 2000, Train Loss: 0.5799, Val Avg Corr: 0.5273
  >>> New best validation model saved with Avg Corr: 0.5273 <<<
Epoch [2/50], Step 2500, Train Loss: 0.6945, Val Avg Corr: 0.5434
  >>> New best validation model saved with Avg Corr: 0.5434 <<<
Epoch [2/50], Step 3000, Train Loss: 0.7944, Val Avg Corr: 0.5070
Epoch [2/50], Step 3500, Train Loss: 0.6183, Val Avg Corr: 0.5576
  >>> New best validation model saved with Avg Corr: 0.5576 <<<
Epoch [2/50], Step 4000, Train Loss: 0.6150, Val Avg Corr: 0.5548
Epoch [2/50], Step 4500, Train Loss: 0.7193, Val Avg Corr: 0.5027
Epoch [2/50], Step 5000, Train Loss: 0.7792, Val Avg Corr: 0.5928
  >>> New best validation model saved with Avg Corr: 0.5928 <<<
Epoch [2/50], Step 5500, Train Loss: 0.6757, Val Avg Corr: 0.5459
Epoch [2/50], Step 6000, Train Loss: 0.4698, Val Avg Corr: 0.4458
Epoch [2/50], Step 6500, Train Loss: 0.5285, Val Avg Corr: 0.5349
Epoch [2/50], Step 7000, Train Loss: 0.9416, Val Avg Corr: 0.5168
Epoch [3/50], Step 500, Train Loss: 0.0584, Val Avg Corr: 0.5043
Epoch [3/50], Step 1000, Train Loss: 0.4692, Val Avg Corr: 0.4804
Epoch [3/50], Step 1500, Train Loss: 0.3989, Val Avg Corr: 0.5369
Epoch [3/50], Step 2000, Train Loss: 0.5600, Val Avg Corr: 0.5757
Epoch [3/50], Step 2500, Train Loss: 0.6956, Val Avg Corr: 0.5888
Epoch [3/50], Step 3000, Train Loss: 0.7561, Val Avg Corr: 0.5353
Epoch [3/50], Step 3500, Train Loss: 0.5839, Val Avg Corr: 0.4915
Epoch [3/50], Step 4000, Train Loss: 0.5503, Val Avg Corr: 0.5666
Epoch [3/50], Step 4500, Train Loss: 0.6908, Val Avg Corr: 0.4793
Epoch [3/50], Step 5000, Train Loss: 0.7372, Val Avg Corr: 0.5960
  >>> New best validation model saved with Avg Corr: 0.5960 <<<
Epoch [3/50], Step 5500, Train Loss: 0.7031, Val Avg Corr: 0.6235
  >>> New best validation model saved with Avg Corr: 0.6235 <<<
Epoch [3/50], Step 6000, Train Loss: 0.4391, Val Avg Corr: 0.4940
Epoch [3/50], Step 6500, Train Loss: 0.5201, Val Avg Corr: 0.5243
Epoch [3/50], Step 7000, Train Loss: 0.9302, Val Avg Corr: 0.5393
Epoch [4/50], Step 500, Train Loss: 0.0561, Val Avg Corr: 0.5938
Epoch [4/50], Step 1000, Train Loss: 0.4423, Val Avg Corr: 0.5147
Epoch [4/50], Step 1500, Train Loss: 0.3796, Val Avg Corr: 0.5265
Epoch [4/50], Step 2000, Train Loss: 0.5565, Val Avg Corr: 0.5742
Epoch [4/50], Step 2500, Train Loss: 0.6454, Val Avg Corr: 0.5422
Epoch [4/50], Step 3000, Train Loss: 0.7714, Val Avg Corr: 0.6175
Epoch [4/50], Step 3500, Train Loss: 0.5673, Val Avg Corr: 0.5610
Epoch [4/50], Step 4000, Train Loss: 0.5620, Val Avg Corr: 0.5711
Epoch [4/50], Step 4500, Train Loss: 0.6805, Val Avg Corr: 0.5610
Epoch [4/50], Step 5000, Train Loss: 0.6898, Val Avg Corr: 0.5866
Epoch [4/50], Step 5500, Train Loss: 0.6365, Val Avg Corr: 0.5960
Epoch [4/50], Step 6000, Train Loss: 0.4359, Val Avg Corr: 0.5708
Epoch [4/50], Step 6500, Train Loss: 0.5015, Val Avg Corr: 0.5794
Epoch [4/50], Step 7000, Train Loss: 0.8946, Val Avg Corr: 0.5217
Epoch [5/50], Step 500, Train Loss: 0.0608, Val Avg Corr: 0.5567
Epoch [5/50], Step 1000, Train Loss: 0.4240, Val Avg Corr: 0.5318
Epoch [5/50], Step 1500, Train Loss: 0.3874, Val Avg Corr: 0.5565
Early stopping triggered after 1500 steps in epoch 5.
Loaded best model with validation Corr: 0.6235
  Re-evaluating SNN with movement mask for fair comparison...
  SNN Test Corr (All Bins): X=0.5754, Y=0.7145
  SNN Test  R²  (All Bins): X=0.2820, Y=0.4938
Time-series velocity figure saved --> snn_velocity_timeseries_slice_indy_20161027_03.mat.png

  --- Running Kalman Filter ---

--- Setting up Kalman Filter ---
Fitting linear velocity decoder (Ridge)
Estimating R from decoder residuals
Initializing Kalman Filter...
Running Kalman Filter for 1810 test steps...
Kalman Filter processing time: 0.12 seconds
--- Kalman Filter Setup and Run Complete ---
  KF Test Corr (Movement Only): X=0.4039, Y=0.2777

  --- Running LSTM ---
Starting LSTM training for 50 epochs on cpu...
Epoch [1/50], Train Loss: 0.492567, Val Loss: 0.559652
  New best validation loss: 0.559652
Epoch [2/50], Train Loss: 0.231311, Val Loss: 0.470290
  New best validation loss: 0.470290
Epoch [3/50], Train Loss: 0.141784, Val Loss: 0.491183
Epoch [4/50], Train Loss: 0.102100, Val Loss: 0.508190
Epoch [5/50], Train Loss: 0.074095, Val Loss: 0.485463
Epoch [6/50], Train Loss: 0.069496, Val Loss: 0.473087
Epoch [7/50], Train Loss: 0.054034, Val Loss: 0.482806
Epoch [8/50], Train Loss: 0.044484, Val Loss: 0.501488
Epoch [9/50], Train Loss: 0.040350, Val Loss: 0.474240
Epoch [10/50], Train Loss: 0.034963, Val Loss: 0.480332
Epoch [11/50], Train Loss: 0.030361, Val Loss: 0.488545
Epoch [12/50], Train Loss: 0.030150, Val Loss: 0.479864
Early stopping triggered after 12 epochs.
Finished LSTM Training.
Loaded best model state from epoch 2.
  LSTM Test Corr (Movement Only): X=0.7685, Y=0.8098
--- Finished Session 9 ---

--- Session 10/10 (indy_20160419_01.mat) ---
  Using fixed parameters: Bin Width=0.050s, Stride=0.050s (no overlap)
  Using zero causal lag (0 ms) - skipping lag search.
  Using raw spike counts (no normalisation)...
    Sample spike-count matrix (first 4 bins, first 12 neurons):
[[2 1 1 1 2 2 1 1 1 1 1 3]
 [0 1 0 0 0 0 0 0 0 0 0 1]
 [0 0 0 0 1 0 0 0 0 0 0 0]
 [0 0 0 0 1 1 0 0 1 0 0 0]]
    Counts min / max in this session: 0 8
Global count histogram 0-6: [571721 125803  27440   6549   1545    379     83]
    Sample rate-NORMALISED matrix (first 4 bins, first 12 neurons):
[[ 3.62   1.108  2.99   2.484  3.8    3.04   0.599  2.676  1.469  2.616
   1.281  4.447]
 [-0.438  1.108 -0.274 -0.303 -0.414 -0.53  -0.694 -0.301 -0.44  -0.315
  -0.515  1.145]
 [-0.438 -0.544 -0.274 -0.303  1.693 -0.53  -0.694 -0.301 -0.44  -0.315
  -0.515 -0.506]
 [-0.438 -0.544 -0.274 -0.303  1.693  1.255 -0.694 -0.301  1.469 -0.315
  -0.515 -0.506]]

  --- Running SNN Online Training ---
Starting SNN Online Training for 50 epochs on cpu...
Evaluation every 500 steps, reset states every 200 steps
Warm-starting RMS EMAs with 50 steps...
RMS EMA warm-start complete.
Epoch [1/50], Step 500, Train Loss: 0.8078, Val Avg Corr: 0.3138
  >>> New best validation model saved with Avg Corr: 0.3138 <<<
Epoch [1/50], Step 1000, Train Loss: 0.7819, Val Avg Corr: 0.3993
  >>> New best validation model saved with Avg Corr: 0.3993 <<<
Epoch [1/50], Step 1500, Train Loss: 0.6762, Val Avg Corr: 0.4251
  >>> New best validation model saved with Avg Corr: 0.4251 <<<
Epoch [1/50], Step 2000, Train Loss: 0.6653, Val Avg Corr: 0.4936
  >>> New best validation model saved with Avg Corr: 0.4936 <<<
Epoch [1/50], Step 2500, Train Loss: 0.5118, Val Avg Corr: 0.3983
Epoch [1/50], Step 3000, Train Loss: 0.7617, Val Avg Corr: 0.5433
  >>> New best validation model saved with Avg Corr: 0.5433 <<<
Epoch [1/50], Step 3500, Train Loss: 0.5873, Val Avg Corr: 0.4336
Epoch [1/50], Step 4000, Train Loss: 0.5825, Val Avg Corr: 0.5312
Epoch [1/50], Step 4500, Train Loss: 0.4208, Val Avg Corr: 0.5565
  >>> New best validation model saved with Avg Corr: 0.5565 <<<
Epoch [1/50], Step 5000, Train Loss: 0.7664, Val Avg Corr: 0.5767
  >>> New best validation model saved with Avg Corr: 0.5767 <<<
Epoch [1/50], Step 5500, Train Loss: 0.7140, Val Avg Corr: 0.5838
  >>> New best validation model saved with Avg Corr: 0.5838 <<<
Epoch [1/50], Step 6000, Train Loss: 0.5747, Val Avg Corr: 0.5946
  >>> New best validation model saved with Avg Corr: 0.5946 <<<
Epoch [2/50], Step 500, Train Loss: 0.5588, Val Avg Corr: 0.5619
Epoch [2/50], Step 1000, Train Loss: 0.5880, Val Avg Corr: 0.6136
  >>> New best validation model saved with Avg Corr: 0.6136 <<<
Epoch [2/50], Step 1500, Train Loss: 0.5921, Val Avg Corr: 0.5021
Epoch [2/50], Step 2000, Train Loss: 0.5128, Val Avg Corr: 0.5838
Epoch [2/50], Step 2500, Train Loss: 0.4405, Val Avg Corr: 0.5956
Epoch [2/50], Step 3000, Train Loss: 0.7263, Val Avg Corr: 0.6049
Epoch [2/50], Step 3500, Train Loss: 0.5253, Val Avg Corr: 0.5078
Epoch [2/50], Step 4000, Train Loss: 0.5648, Val Avg Corr: 0.6073
Epoch [2/50], Step 4500, Train Loss: 0.4036, Val Avg Corr: 0.5918
Epoch [2/50], Step 5000, Train Loss: 0.7552, Val Avg Corr: 0.6210
  >>> New best validation model saved with Avg Corr: 0.6210 <<<
Epoch [2/50], Step 5500, Train Loss: 0.7215, Val Avg Corr: 0.6559
  >>> New best validation model saved with Avg Corr: 0.6559 <<<
Epoch [2/50], Step 6000, Train Loss: 0.5341, Val Avg Corr: 0.6497
Epoch [3/50], Step 500, Train Loss: 0.4279, Val Avg Corr: 0.6139
Epoch [3/50], Step 1000, Train Loss: 0.5895, Val Avg Corr: 0.5485
Epoch [3/50], Step 1500, Train Loss: 0.5696, Val Avg Corr: 0.4628
Epoch [3/50], Step 2000, Train Loss: 0.4739, Val Avg Corr: 0.5507
Epoch [3/50], Step 2500, Train Loss: 0.3919, Val Avg Corr: 0.5248
Epoch [3/50], Step 3000, Train Loss: 0.6909, Val Avg Corr: 0.6364
Epoch [3/50], Step 3500, Train Loss: 0.4818, Val Avg Corr: 0.6327
Epoch [3/50], Step 4000, Train Loss: 0.4858, Val Avg Corr: 0.6626
  >>> New best validation model saved with Avg Corr: 0.6626 <<<
Epoch [3/50], Step 4500, Train Loss: 0.3739, Val Avg Corr: 0.6590
Epoch [3/50], Step 5000, Train Loss: 0.7155, Val Avg Corr: 0.6485
Epoch [3/50], Step 5500, Train Loss: 0.6864, Val Avg Corr: 0.6454
Epoch [3/50], Step 6000, Train Loss: 0.5091, Val Avg Corr: 0.6735
  >>> New best validation model saved with Avg Corr: 0.6735 <<<
Epoch [4/50], Step 500, Train Loss: 0.4103, Val Avg Corr: 0.6137
Epoch [4/50], Step 1000, Train Loss: 0.5509, Val Avg Corr: 0.5314
Epoch [4/50], Step 1500, Train Loss: 0.5802, Val Avg Corr: 0.5487
Epoch [4/50], Step 2000, Train Loss: 0.4928, Val Avg Corr: 0.5991
Epoch [4/50], Step 2500, Train Loss: 0.3824, Val Avg Corr: 0.5673
Epoch [4/50], Step 3000, Train Loss: 0.6424, Val Avg Corr: 0.6001
Epoch [4/50], Step 3500, Train Loss: 0.4749, Val Avg Corr: 0.6253
Epoch [4/50], Step 4000, Train Loss: 0.4873, Val Avg Corr: 0.6575
Epoch [4/50], Step 4500, Train Loss: 0.3329, Val Avg Corr: 0.6436
Epoch [4/50], Step 5000, Train Loss: 0.7265, Val Avg Corr: 0.6478
Epoch [4/50], Step 5500, Train Loss: 0.6886, Val Avg Corr: 0.6344
Epoch [4/50], Step 6000, Train Loss: 0.5051, Val Avg Corr: 0.6907
  >>> New best validation model saved with Avg Corr: 0.6907 <<<
Epoch [5/50], Step 500, Train Loss: 0.3776, Val Avg Corr: 0.6356
Epoch [5/50], Step 1000, Train Loss: 0.5530, Val Avg Corr: 0.5043
Epoch [5/50], Step 1500, Train Loss: 0.5473, Val Avg Corr: 0.4833
Epoch [5/50], Step 2000, Train Loss: 0.4498, Val Avg Corr: 0.5499
Epoch [5/50], Step 2500, Train Loss: 0.3836, Val Avg Corr: 0.4950
Epoch [5/50], Step 3000, Train Loss: 0.6355, Val Avg Corr: 0.6249
Epoch [5/50], Step 3500, Train Loss: 0.4522, Val Avg Corr: 0.5826
Epoch [5/50], Step 4000, Train Loss: 0.5024, Val Avg Corr: 0.6189
Epoch [5/50], Step 4500, Train Loss: 0.4149, Val Avg Corr: 0.6453
Epoch [5/50], Step 5000, Train Loss: 0.7668, Val Avg Corr: 0.6495
Epoch [5/50], Step 5500, Train Loss: 0.7159, Val Avg Corr: 0.6204
Epoch [5/50], Step 6000, Train Loss: 0.5003, Val Avg Corr: 0.6594
Epoch [6/50], Step 500, Train Loss: 0.4808, Val Avg Corr: 0.6131
Epoch [6/50], Step 1000, Train Loss: 0.6041, Val Avg Corr: 0.5037
Epoch [6/50], Step 1500, Train Loss: 0.6642, Val Avg Corr: 0.3145
Epoch [6/50], Step 2000, Train Loss: 0.5944, Val Avg Corr: 0.5462
Epoch [6/50], Step 2500, Train Loss: 0.4362, Val Avg Corr: 0.5388
Epoch [6/50], Step 3000, Train Loss: 0.7478, Val Avg Corr: 0.5899
Epoch [6/50], Step 3500, Train Loss: 0.5090, Val Avg Corr: 0.6278
Epoch [6/50], Step 4000, Train Loss: 0.5176, Val Avg Corr: 0.6087
Early stopping triggered after 4000 steps in epoch 6.
Loaded best model with validation Corr: 0.6907
  Re-evaluating SNN with movement mask for fair comparison...
  SNN Test Corr (All Bins): X=0.6029, Y=0.6898
  SNN Test  R²  (All Bins): X=0.3601, Y=0.4086
Time-series velocity figure saved --> snn_velocity_timeseries_slice_indy_20160419_01.mat.png

  --- Running Kalman Filter ---

--- Setting up Kalman Filter ---
Fitting linear velocity decoder (Ridge)
Estimating R from decoder residuals
Initializing Kalman Filter...
Running Kalman Filter for 1638 test steps...
Kalman Filter processing time: 0.05 seconds
--- Kalman Filter Setup and Run Complete ---
  KF Test Corr (Movement Only): X=0.4420, Y=0.4944

  --- Running LSTM ---
Starting LSTM training for 50 epochs on cpu...
Epoch [1/50], Train Loss: 0.413192, Val Loss: 0.343252
  New best validation loss: 0.343252
Epoch [2/50], Train Loss: 0.147568, Val Loss: 0.348715
Epoch [3/50], Train Loss: 0.098159, Val Loss: 0.315194
  New best validation loss: 0.315194
Epoch [4/50], Train Loss: 0.078756, Val Loss: 0.309730
  New best validation loss: 0.309730
Epoch [5/50], Train Loss: 0.054260, Val Loss: 0.317540
Epoch [6/50], Train Loss: 0.046823, Val Loss: 0.314843
Epoch [7/50], Train Loss: 0.042727, Val Loss: 0.317267
Epoch [8/50], Train Loss: 0.037690, Val Loss: 0.316561
Epoch [9/50], Train Loss: 0.034325, Val Loss: 0.308266
  New best validation loss: 0.308266
Epoch [10/50], Train Loss: 0.029135, Val Loss: 0.304540
  New best validation loss: 0.304540
Epoch [11/50], Train Loss: 0.025274, Val Loss: 0.298975
  New best validation loss: 0.298975
Epoch [12/50], Train Loss: 0.021802, Val Loss: 0.304429
Epoch [13/50], Train Loss: 0.019412, Val Loss: 0.302844
Epoch [14/50], Train Loss: 0.022917, Val Loss: 0.306713
Epoch [15/50], Train Loss: 0.020028, Val Loss: 0.302535
Epoch [16/50], Train Loss: 0.019883, Val Loss: 0.293673
  New best validation loss: 0.293673
Epoch [17/50], Train Loss: 0.019586, Val Loss: 0.290637
  New best validation loss: 0.290637
Epoch [18/50], Train Loss: 0.018017, Val Loss: 0.304174
Epoch [19/50], Train Loss: 0.016605, Val Loss: 0.300141
Epoch [20/50], Train Loss: 0.015124, Val Loss: 0.306615
Epoch [21/50], Train Loss: 0.017445, Val Loss: 0.304635
Epoch [22/50], Train Loss: 0.018698, Val Loss: 0.305722
Epoch [23/50], Train Loss: 0.015734, Val Loss: 0.306614
Epoch [24/50], Train Loss: 0.013863, Val Loss: 0.307157
Epoch [25/50], Train Loss: 0.015039, Val Loss: 0.303916
Epoch [26/50], Train Loss: 0.015530, Val Loss: 0.294145
Epoch [27/50], Train Loss: 0.017013, Val Loss: 0.303695
Early stopping triggered after 27 epochs.
Finished LSTM Training.
Loaded best model state from epoch 17.
  LSTM Test Corr (Movement Only): X=0.8228, Y=0.7719
--- Finished Session 10 ---

===== Within-Session Comparison Final Results =====
Full results saved to results_within_session_comparison.csv

--- Average Test Corr & R² --- 
Model: SNN
  X-Corr: Mean=0.6125, Std=0.0917
  Y-Corr: Mean=0.7139, Std=0.0534
  X-R² : Mean=0.3663, Std=0.1216
  Y-R² : Mean=0.4554, Std=0.0864
Model: KF
  X-Corr: Mean=0.4155, Std=0.0704
  Y-Corr: Mean=0.4557, Std=0.0772
  X-R² : Mean=0.1568, Std=0.0579
  Y-R² : Mean=0.1919, Std=0.0633
Model: LSTM
  X-Corr: Mean=0.7512, Std=0.0719
  Y-Corr: Mean=0.8355, Std=0.0315
  X-R² : Mean=0.5500, Std=0.1141
  Y-R² : Mean=0.6845, Std=0.0566
Comparison plot saved to within_session_comparison_plot.png
===== Experiment Complete =====

ONLINE SNN Results:
  Mean X Correlation: 0.6125
  Mean Y Correlation: 0.7139
  Average: 0.6632

================================================================================
COMPARISON COMPLETE
Key differences between modes:
- WINDOWED: Uses 10-timestep sequences, batch updates
- ONLINE: Uses single timesteps, persistent hidden states
- Online mode should show lower but more stable learning
- Online mode simulates real-time BCI operation
================================================================================
