defaults: 
 - base
 - /step: sequential_markov
 - _self_

name: ffno

params:
  exo_dropout: 0.0
  interlayer_act: null

  _target_: models.s4seq_model.S4DualSeqModel
  input_processor: ConcatTrans
  output_processor: Trans
  step_input_processor: Concat
  step_output_processor: identity
  step_layer_input_processor: ["identity"]
  layer_input_processors: ["BatchTime"]
  layer_output_processors: ["UnbatchTime"]
  final_mlp_hidden_expansion: 2
  final_mlp_act: "identity"
  norm_type:  "identity"
  residual_type: "identity"
  prenorm: True
  ffn_type: "zero"

  modes: -1
  n_layers: 4
  d_model: 128
  encoder_kernel_size: 1
  s4block_args:
    s4block_type: "FFNO1d"
    modes: "${..modes}"
    d_model: ${model.params.d_model}
    activation: "identity"
    
    

  d_state: 1

optimizer:
  _target_: optimizers.setup_s4_optimizer
  lr: 0.001
  weight_decay: 0.0
  # weight_decay: 0.0

batch_size: 32

# # scheduler: None
# scheduler: cosine
scheduler: step
step_size: 200
gamma: 0.5

warmup_epochs: 1