defaults:
###### Dynamical systems ######
#  - dynamical_systems@dynamics : bistable1D
#  - dynamical_systems@dynamics : bistable2D
#  - dynamical_systems@dynamics : bistable3D
#  - dynamical_systems@dynamics : bistable2D_scaled
#  - dynamical_systems@dynamics : radial2D
#  - dynamical_systems@dynamics : radial2D_bistable
#  - dynamical_systems@dynamics  : perceptual_decision_making
#  - dynamical_systems@dynamics  : kbitflipflop
#  - dynamical_systems@dynamics : duffing
#  - dynamical_systems@dynamics : multistable1D
#  - dynamical_systems@dynamics : hopfield
#  - dynamical_systems@dynamics : hopfield_ring
#  - dynamical_systems@dynamics : parting2D_twobasins
#  - dynamical_systems@dynamics : parting2D
#  - dynamical_systems@dynamics : bistable_oscillator2D
#  - dynamical_systems@dynamics : quadstable2D

  - dynamical_systems@bistable1D : bistable1D
  - dynamical_systems@bistable2D : bistable2D
  - dynamical_systems@affine_bistable2D : affine_bistable2D
  - dynamical_systems@bifurcating_bistable1D : bifurcating_bistable1D
  - dynamical_systems@duffing : duffing
  - dynamical_systems@1bitflipflop_2D  : 1bitflipflop_2D
  - dynamical_systems@2bitflipflop_2D  : 2bitflipflop_2D
  - dynamical_systems@2bitflipflop_3D  : 2bitflipflop_3D
  - dynamical_systems@1bitflipflop_3D  : 1bitflipflop_3D
  - dynamical_systems@1bitflipflop_32D  : 1bitflipflop_32D
  - dynamical_systems@2bitflipflop_32D_long  : 2bitflipflop_32D_long
  - dynamical_systems@1bitflipflop_32D_long  : 1bitflipflop_32D_long
  - dynamical_systems@1bitflipflop_32D_long_isotropic  : 1bitflipflop_32D_long_isotropic
  - dynamical_systems@1bitflipflop_Vanilla64D_long_isotropic  : 1bitflipflop_Vanilla64D_long_isotropic
  - dynamical_systems@1bitflipflop_Vanilla64D_long_hermitecurvesampler  : 1bitflipflop_Vanilla64D_long_hermitecurvesampler
  - dynamical_systems@1bitflipflop_Vanilla668D_long_isotropic  : 1bitflipflop_Vanilla668D_long_isotropic
  - dynamical_systems@1bitflipflop_Vanilla668D_long_hermitecurvesampler : 1bitflipflop_Vanilla668D_long_hermitecurvesampler
  - dynamical_systems@1bitflipflop_2D_long  : 1bitflipflop_2D_long
  - dynamical_systems@finkelstein_fontolan_RNN  : finkelstein_fontolan_RNN
  - dynamical_systems@finkelstein_fontolan_RNN_multiscale  : finkelstein_fontolan_RNN_multiscale
  - dynamical_systems@radial2D_bistable  : radial2D_bistable
  - dynamical_systems@multistable1D : multistable1D
  - dynamical_systems@radial2D_bistable_limit_cycle : radial2D_bistable_limit_cycle
  - dynamical_systems@hypercube : hypercube
  - dynamical_systems@bistableND : bistableND
  - dynamical_systems@bistable4D_nonnormal : bistable4D_nonnormal
  - dynamical_systems@finkelstein_fontolan_RNN_multiscale_on_separatrix : finkelstein_fontolan_RNN_multiscale_on_separatrix
  - dynamical_systems@finkelstein_fontolan_RNN_multiscale_on_separatrix_speed40 : finkelstein_fontolan_RNN_multiscale_on_separatrix_speed40
  - dynamical_systems@finkelstein_fontolan_RNN_hermitecurvesampler_speed40 : finkelstein_fontolan_RNN_hermitecurvesampler_speed40
  - dynamical_systems@microbiome_SSR_GLV_2D : microbiome_SSR_GLV_2D
  - dynamical_systems@microbiome_GLV_11D : microbiome_GLV_11D
####### Models #########
#  - models@DNN_model  : DNN_layers6

  - models@DNN_layers2  : DNN_layers2
  - models@DNN_layers4  : DNN_layers4
  - models@DNN_layers6  : DNN_layers6
  - models@DNN_layers8  : DNN_layers8
  - models@input_scaled_DNN_layers6 : input_scaled_DNN_layers6
  - models@input_scaled_DNN_layers8 : input_scaled_DNN_layers8
  - models@DNN_ReLU_layers8  : DNN_ReLU_layers8
  - models@richDNN_layers8  : richDNN_layers8
  - models@multimax_DNN_layers8 : multimax_DNN_layers8
  - models@RBF : RBF
  - models@AnisotropicRBF : AnisotropicRBF
  - models@DNN_softmax_layers8 : DNN_softmax_layers8
  - models@RBF_DNN_layers6  : RBF_DNN_layers6
  - models@ResNet_layers6 : ResNet_layers6
  - models@RBFResNet_layers6 : RBFResNet_layers6
  - models@ResNet_layers10 : ResNet_layers10
  - models@ResNet_layers15 : ResNet_layers15
  - models@ResNet_layers20 : ResNet_layers20
  - models@ResNet_layers25 : ResNet_layers25
  - models@ResNet_layers40 : ResNet_layers40
  - models@transformer : transformer
  - models@s4 : s4
  - models@BistableLinear : BistableLinear
#  - models@model : ResNet_layers25_bottleneck
#  - models@model : DeepResNet
#  - models@model : DNN_layers2
  - models@ResRBF : ResRBF

  - _self_

#  - hydra: multirun


##### End defaults ######


save_KEF_model    : true
load_KEF_model    : false
plot_KEF_of_traj  : false
save_results      : false
run_analysis      : false
runGD_analytical  : false
runGD             : false
run_fixed_point_finder  : false

device  : cuda:0

#model_choice  : s4
#model_choice  : DNN_layers6
model_choice  : ResRBF
#model_choice  : transformer
#model_choice  : ResNet_layers40
#model_choice  : BistableLinear
#model_choice  : RBFResNet_layers15
#model_choice  : RBF_DNN_layers6
#model_choice  : input_scaled_DNN_layers6
#model_choice  : input_scaled_DNN_layers8
#model_choice  : DNN_layers2
#model_choice  : DNN_softmax_layers8
#model_choice  : RBF
#model_choice  : AnisotropicRBF

#dynamics_choice : bistable1D #1bitflipflop_2D #bistable1D # # #duffing #  # #
#dynamics_choice : affine_bistable2D
#dynamics_choice : bifurcating_bistable1D
#dynamics_choice : 1bitflipflop_2D #radial2D_bistable #2bitflipflop_2D #bistable2D #duffing #
#dynamics_choice : duffing
#dynamics_choice : radial2D_bistable_limit_cycle
#dynamics_choice : 1bitflipflop_3D
dynamics_choice : 2bitflipflop_3D
#dynamics_choice : 1bitflipflop_32D_long
#dynamics_choice : 1bitflipflop_32D_long_isotropic
#dynamics_choice : 1bitflipflop_Vanilla64D_long_isotropic
#dynamics_choice : 1bitflipflop_Vanilla64D_long_hermitecurvesampler
#dynamics_choice : 1bitflipflop_Vanilla668D_long_isotropic
#dynamics_choice : 1bitflipflop_Vanilla668D_long_hermitecurvesampler
#dynamics_choice : 1bitflipflop_2D_long
#dynamics_choice : finkelstein_fontolan_RNN
#dynamics_choice : finkelstein_fontolan_RNN
#dynamics_choice : finkelstein_fontolan_RNN_multiscale
#dynamics_choice : finkelstein_fontolan_RNN_multiscale_on_separatrix
#dynamics_choice : finkelstein_fontolan_RNN_multiscale_on_separatrix_speed40
#dynamics_choice : finkelstein_fontolan_RNN_hermitecurvesampler_speed40
#dynamics_choice  : microbiome_SSR_GLV_2D
#dynamics_choice  : microbiome_GLV_11D
#dynamics_choice : hypercube
#dynamics_choice : hypercube
#dynamics_choice : bistableND
#dynamics_choice : bistable4D_nonnormal
#dynamics_choice : radial2D_bistable


### main train func
#train_func_teacher :
#  _target_  : learn_koopman_eig.train_on_teacher
#  _partial_ : true
#  num_epochs    : 1000 #00 #0 #3000
#  learning_rate : 1e-2
#  learning_rate : 1e-2
#  batch_size    : 50 #1000
#  dynamics_dim  : ${dynamics.dim}
#  print_every_num_epochs  : 10

####### EDMD ###########

#dmd:
#  _target_ : pydmd.EDMD


###### Classifier based Separatrix Locator ########
#classifier_based_separatrix_locator :
#  _target_      : validation_methods.ClassifierBasedSeparatrixLocator
#  num_models    : 1
#  dynamics_dim  : ${dynamics.dim}
#  model_class   :
#    _target_  : sklearn.pipeline.make_pipeline
#    _partial_ : true
#    _args_    :
#    - _target_  : sklearn.preprocessing.StandardScaler
##    - _target_  : sklearn.svm.SVC
##      gamma     : auto
##      kernel    : linear
#    - _target_  : sklearn.neural_network.MLPClassifier
#      hidden_layer_sizes :
#        - 1000
#        - 40
#      activation  : relu
#      solver    : adam
#      max_iter  : 1000
#  num_clusters : null #2
#  verbose : true

classifier_based_separatrix_locator_fit_kwargs  :
  batch_size  : 700

###### Koopman based Separatrix Locator ########

separatrix_locator :
  _target_    : separatrixLocator.SeparatrixLocator
  num_models  : 2 #20 #20 #0 #10 #10 #4 #5 #0 #0
  dynamics_dim : ${dynamics.dim}
  use_multiprocessing : false
  verbose : true
  model_class: null
  device  : ${device}

experiment_details : experiment_${model.name}_lr${separatrix_locator_fit_kwargs.optimizer.lr}_noscheduler_l2${separatrix_locator_fit_kwargs.optimizer.weight_decay}_batch${separatrix_locator_fit_kwargs.batch_size}_epochs${separatrix_locator_fit_kwargs.num_epochs}_${separatrix_locator_fit_kwargs.normaliser._target_}_gmmratio${separatrix_locator_fit_kwargs.gmm_mix_ratio}_eigenvalue${eigenvalue}_AdamW_balanceloss${separatrix_locator_fit_kwargs.balance_loss_lambda} #_resetmomentumevery50

eigenvalue  : 1.0 #25e-3

#### best hyperparams for microbiome 11D
## weight_decay : 1e-4
## num_epochs : 5000
## batch_size : 5000

separatrix_locator_fit_kwargs:
  num_epochs: 1000 #10000 #5000 #1000 #500 #1000 #1000 #2000 #200 #500 #5000 #1000 #1000 #10000 #1000 #500 #500 #1000 #500 #1000 #500 #100 #500 #500 #500 # 1000 #1000 #2000 #500 #500 #1000 #400 #1000 #5000 #5000 #3000 #5000 #10000 #5000 #20000 #2000 #500 #2000 #2000 #2000 #1000 #2000 #500 #500 #500 #1000 #1500 #400 #200 #1000 #200 #2000 #400 #2000 #00 #2000 #500 #200 #2000 #0 #2000
  optimizer :
    _target_  : torch.optim.AdamW
    _partial_ : true
    lr: 0.1e-3 #1e-4  #0.5e-3 #3e-3 #3e-3 #1e-3 #45e-3 #5e-3 1e-2
    weight_decay  : 1e-5 #1e-4 #0.0 #1e-3  #5e-3
  batch_size: 5000 #1000 #1500 #3000 #20000 #7000 #5000 #5000 #1000
  ext_inp_batch_size  : 500
  ext_inp_reg_coeff   : 0.0 #0.1
  logger:
    _target_    : csv_logger.CSVLogger
    log_dir     : ${...savepath}/${...experiment_details}
    flush_every : 10
#    - _target_: torch.utils.tensorboard.SummaryWriter
#      log_dir: ${....savepath}/${....experiment_details}
  eigenvalue: ${eigenvalue}
  lr_scheduler:
    _target_: torch.optim.lr_scheduler.StepLR
    _partial_: true
    step_size: 50
    gamma: 0.9
  print_every_num_epochs: 10
  dist_requires_dim : ${dynamics.dist_requires_dim}
  normaliser  :
#    _target_  : learn_koopman_eig.variance_normaliser
#    _partial_  : true
#    axis      : null
#    return_terms  : true
    _target_  : learn_koopman_eig.shuffle_normaliser
    _partial_  : true
    axis      : null
#  gmm_mix_ratio : 0.02 #3
#  gmm_mix_ratio : 0.05
#  gmm_mix_ratio : 0.3
  gmm_mix_ratio : 0.0
#  epoch_callbacks:
#    - _target_  : learn_koopman_eig.reset_adam_momentum_periodically
#      _partial_ : true
#      reset_interval  : 100

separatrix_locator_score_kwargs:
  batch_size: 2000 #0
  ext_inp_batch_size  : 50
  eigenvalue : ${eigenvalue}
  drop_values_outside_range: null
  dist_requires_dim : ${dynamics.dist_requires_dim}
  normaliser:
    _target_: learn_koopman_eig.shuffle_normaliser
    _partial_: true
  scale_dist  : 1

#separatrix_locator_score_kwargs_2:
#  batch_size: 10000
#  eigenvalue : 1
#  drop_values_outside_range: null
#  dist_requires_dim : ${dynamics.dist_requires_dim}
#  normaliser:
#    _target_: learn_koopman_eig.shuffle_normaliser
#    _partial_: true
#  scale_dist  : 2

separatrix_find_separatrix_kwargs:
  num_steps: 2000 #2000 #000 #300 #0 #0 #5000
  partial_optim:
    _target_: torch.optim.Adam
    _partial_: true
    lr: 1e-4 #1e-3
#  threshold: 1e-5 #0.65 #,#0.1 #-20 #null #5e-4 #5e-2
  threshold :
#    start_threshold: 1e-5
#    end_threshold: 1e0
    start_threshold : 1.0 #5e-2
    end_threshold : 1e-5
#    start_threshold : 1.0
#    end_threshold : 0.3
#  lr_scheduler:
#    _target_: torch.optim.lr_scheduler.StepLR
#    _partial_: true
#    step_size: 1000 #50
#    gamma: 0.9
  batch_size: 1000 #00 #00
  resample_above_threshold: false

#### Fixed point finder params
fpf_hps :
  max_iters: 20000 #00  # 10000
  n_iters_per_print_update: 500
  lr_init: 0.5 #1e-5 #0.5
  lr_patience : 200 #50
#  lr_patience : 10
  lr_factor : 0.95
#  max_iters : 1000  # 10000
#  n_iters_per_print_update : 1000
#  lr_init: 0.1
#  lr_patience : 5
#  lr_factor : 0.95
  outlier_distance_scale: 10.0
  verbose: true
  super_verbose: true
#  tol_q: 1e-6,
#  tol_q: 1e-15,
#  tol_dq: 1e-15



#### Option list

model_options:
  DNN_layers2: ${DNN_layers2}
  DNN_layers4: ${DNN_layers4}
  DNN_layers6: ${DNN_layers6}
  DNN_layers8: ${DNN_layers8}
  input_scaled_DNN_layers6  : ${input_scaled_DNN_layers6}
  input_scaled_DNN_layers8  : ${input_scaled_DNN_layers8}
  DNN_ReLU_layers8: ${DNN_ReLU_layers8}
  richDNN_layers8: ${richDNN_layers8}
  RBF : ${RBF}
  AnisotropicRBF : ${AnisotropicRBF}
  DNN_softmax_layers8 : ${DNN_softmax_layers8}
  RBF_DNN_layers6: ${RBF_DNN_layers6}
  ResNet_layers6 : ${ResNet_layers6}
  RBFResNet_layers6 : ${RBFResNet_layers6}
  ResNet_layers10 : ${ResNet_layers10}
  ResNet_layers15 : ${ResNet_layers15}
  ResNet_layers20 : ${ResNet_layers20}
  ResNet_layers25 : ${ResNet_layers25}
  ResNet_layers40 : ${ResNet_layers40}
  transformer : ${transformer}
  s4  : ${s4}
  BistableLinear  : ${BistableLinear}
  ResRBF  : ${ResRBF}



dynamics_options:
  bistable1D : ${bistable1D}
  bistableND : ${bistableND}
  affine_bistable2D : ${affine_bistable2D}
  bistable4D_nonnormal  : ${bistable4D_nonnormal}
  bifurcating_bistable1D  : ${bifurcating_bistable1D}
  multistable1D : ${multistable1D}
  bistable2D : ${bistable2D}
  duffing : ${duffing}
  1bitflipflop_2D : ${1bitflipflop_2D}
  2bitflipflop_2D : ${2bitflipflop_2D}
  1bitflipflop_3D : ${1bitflipflop_3D}
  2bitflipflop_3D : ${2bitflipflop_3D}
  radial2D_bistable : ${radial2D_bistable}
  radial2D_bistable_limit_cycle : ${radial2D_bistable_limit_cycle}
  1bitflipflop_32D  : ${1bitflipflop_32D}
  2bitflipflop_32D_long : ${2bitflipflop_32D_long}
  1bitflipflop_32D_long : ${1bitflipflop_32D_long}
  1bitflipflop_2D_long  : ${1bitflipflop_2D_long}
  1bitflipflop_32D_long_isotropic : ${1bitflipflop_32D_long_isotropic}
  1bitflipflop_Vanilla64D_long_isotropic  : ${1bitflipflop_Vanilla64D_long_isotropic}
  1bitflipflop_Vanilla64D_long_hermitecurvesampler  : ${1bitflipflop_Vanilla64D_long_hermitecurvesampler}
  1bitflipflop_Vanilla668D_long_isotropic : ${1bitflipflop_Vanilla668D_long_isotropic}
  1bitflipflop_Vanilla668D_long_hermitecurvesampler : ${1bitflipflop_Vanilla668D_long_hermitecurvesampler}
  finkelstein_fontolan_RNN  : ${finkelstein_fontolan_RNN}
  finkelstein_fontolan_RNN_multiscale : ${finkelstein_fontolan_RNN_multiscale}
  finkelstein_fontolan_RNN_multiscale_on_separatrix : ${finkelstein_fontolan_RNN_multiscale_on_separatrix}
  finkelstein_fontolan_RNN_multiscale_on_separatrix_speed40 : ${finkelstein_fontolan_RNN_multiscale_on_separatrix_speed40}
  finkelstein_fontolan_RNN_hermitecurvesampler_speed40  : ${finkelstein_fontolan_RNN_hermitecurvesampler_speed40}
  hypercube  : ${hypercube}
  microbiome_SSR_GLV_2D : ${microbiome_SSR_GLV_2D}
  microbiome_GLV_11D  : ${microbiome_GLV_11D}


#model: ${dynamics.analytical_eigenfunction}
model :  ${model_options.${model_choice}}
dynamics  : ${dynamics_options.${dynamics_choice}}


hyperparams_to_record_in_results:
  output_size : ${model.output_size}
  num_layers  : ${model.num_layers}
  hidden_size  : ${model.hidden_size}


test_func_var :
  _target_  : learn_koopman_eig.eval_loss
  _partial_ : true
  batch_size    : 50
  dynamics_dim  : ${dynamics.dim}
  eigenvalue  : 1
  drop_values_outside_range : null
  normaliser  :
    _target_  : learn_koopman_eig.variance_normaliser
    _partial_ : true

test_func_shuffle :
  _target_  : learn_koopman_eig.eval_loss
  _partial_ : true
  batch_size    : 500
  dynamics_dim  : ${dynamics.dim}
  eigenvalue  : 1 #0.03
  drop_values_outside_range : null
  normaliser:
    _target_: learn_koopman_eig.shuffle_normaliser
    _partial_: true


test_func: ${test_func_var}


#### Eigenvalue 1 train func
train_func :
  _target_  : learn_koopman_eig.train_with_logger
  _partial_ : true
  num_epochs    : 0 #2000 #2000
  learning_rate : 5e-3 #5e-3 1e-2
  batch_size    : 5000 #5000 #5000 #1000
  dynamics_dim  : ${dynamics.dim}
#  logger  :
#    _target_  : torch.utils.tensorboard.SummaryWriter
#    log_dir   : ${...savepath}/experiment
  eigenvalue  : 1
  lr_scheduler  :
    _target_  : torch.optim.lr_scheduler.StepLR
    _partial_ : true
    step_size : 500
    gamma     : 0.90
  print_every_num_epochs  : 10


### Eigenvalue 0 train func
#train_func :
#  _target_  : learn_koopman_eig.train_with_logger
#  _partial_ : true
#  num_epochs    : 200 #00
#  learning_rate : 5e-3 #5e-3 1e-2
#  batch_size    : 5000 #5000 #5000 #1000
#  dynamics_dim  : ${dynamics.dim}
#  logger  :
#    _target_  : torch.utils.tensorboard.SummaryWriter
#    log_dir   : ${...savepath}/experiment
#  eigenvalue  : 0.03
#  lr_scheduler  :
#    _target_  : torch.optim.lr_scheduler.StepLR
#    _partial_ : true
#    step_size : 200
#    gamma     : 0.90
#  normaliser  : null
#  print_every_num_epochs  : 10

#train_func_trajectories :
#  _target_      : learn_koopman_eig.train_model_on_trajectories_sgd
#  _partial_     : true
#  batch_size    : 500
#  num_epochs    : 200
#  learning_rate : 0.01
#train_trajectories          : 5000
#train_points_per_trajectory : 4
#train_trajectory_duration   : 0.1

#  decay_module  :
#    _target_      : learn_koopman_eig.DecayModule
#    initial_decay : 1.0
#    decay_rate    : 0.99
#    start_epoch   : 18000

#train_func :
#  _target_  : learn_koopman_eig.train
#  _partial_ : true
#  num_epochs    : 20000
#  learning_rate : 1e-3
#  batch_size    : 200
#  dynamics_dim  : ${dynamics.dim}
#  decay_module  :
#    _target_      : learn_koopman_eig.DecayModule
#    initial_decay : 1.0
#    decay_rate    : 0.99
#    start_epoch   : 18000


##### Neural Network model ####

#model :
#  _target_  : learn_koopman_eig.partialised_RBF_maker
#  in_features_dim : ${dynamics.dim}
#  num_kernels : 2000
#  out_features_dim : 1
#  normalization : false
  #  _target_  : PytorchRBFLayer.rbf_layer.rbf_layer.RBFLayer
  #  in_features_dim : 1 #${dynamics.dim}
  #  num_kernels : 4
  #  out_features_dim : 1
  #  radial_function :
  #    _target_  : learn_koopman_eig.l_norm
  #    _partial_ : true
  #  norm_function :
  #    _target_  : learn_koopman_eig.rbf_gaussian
  #    _partial_ : true



#model : ${DNN_layers2}

#model_base :
#  _target_  : learn_koopman_eig.create_phi_network
##  _partial_   : true
#  input_dim   : ${dynamics.dim}
#  hidden_dim  : 40
#  output_dim  : 7
#  nonlin      :
#    _target_  : torch.nn.Tanh #Tanh #ReLU  #
##    _target_  : torch.nn.ReLU
#    _partial_ : true

#model :
#  _target_    : learn_koopman_eig.ParallelModels
#  base_model  : ${model_base}
#  num_models  : 3
#  prod_output : false

#model : ${model_base}

#model_base :
#  _target_  : learn_koopman_eig.create_phi_network
#  input_dim   : 10
#  hidden_dim  : 10
#  output_dim  : 10
#  nonlin      :
#    _target_  : torch.nn.Tanh #Tanh #ReLU  #
#    _partial_ : true

#model:
#  _target_  : learn_koopman_eig.ODEBlock
#  odefunc : ${model_base}
#    _target_  : torch.nn.Linear
#    in_features   : 10
#    out_features  : 10
#  odefunc_dim : 10
#  input_dim : 2
#  output_dim : 1

#model:
#  _target_    : learn_koopman_eig.LogOutput #ExpOutput #LogOutput  #
#  base_model  : ${model_base}

##### SIREN #####
#model :
#  _target_    : siren_pytorch.SirenNet #One later SIREN
#  dim_in      : ${dynamics.dim}
#  dim_hidden  : 128
#  num_layers  : 2
#  final_activation :
#    _target_  : torch.nn.Identity
#  w0_initial : 0.1
#  dim_out     : 1

#model:
#  _target_    : learn_koopman_eig.AttentionNN  #AttentionOneHotNN #OneHotOutputNN
#  input_dim   : ${dynamics.dim}
#  output_dim  : 3
#  temperature : 1.0


savepath  : results/${dynamics.name}


#######



GD_on_KEF : ${GD_on_KEF_Adam}

GD_on_KEF_SGD:
  _target_      : learn_koopman_eig.runGD
  _partial_     : true
  input_dim     : ${dynamics.dim}
  num_steps     : 10000
  partial_optim :
    _target_  : torch.optim.SGD
    _partial_ : true
    lr: 1e-1
  batch_size    : 500
  resample_above_threshold  : true


GD_on_KEF_Adam:
  _target_: learn_koopman_eig.runGD
  _partial_: true
  input_dim: ${dynamics.dim}
  num_steps: 5000
  partial_optim:
    _target_    : torch.optim.Adam
    _partial_   : true
    lr          : 1e-3
  threshold: 1e-4 #0.65 #,#0.1 #-20 #null #5e-4 #5e-2
  lr_scheduler  :
    _target_  : torch.optim.lr_scheduler.StepLR
    _partial_ : true
    step_size : 50
    gamma     : 0.9
  batch_size: 1000 #00 #00
  resample_above_threshold  : true

