# @package _global_
defaults:
  - /pipeline: timeseries_synthetics
  - /model: long-conv
  - override /scheduler: cosine_warmup

model:
  dropout: 0.1
  tie_dropout: true
  n_layers: 6
  d_model: 32 #4
  prenorm: false
  layer:
    l_max: 50
    learning_rate: 0.001
    lam: 0.001
    kernel_dropout: 0.2
    postact: glu
    bidirectional: false
 # transposed: true

loader:
  batch_size: 100 #50
  num_workers: 0 #4
  pin_memory: false
  #multiprocessing_context: spawn

optimizer:
  lr: 0.01
  weight_decay: 0.05

trainer:
  max_epochs: 100
  devices: 1


train:
  seed: 2222
  #monitor: val/next_step_mse  #val/next_step_log_loss
  monitor: val/next_step_sharpe_ratio_positive
  mode: max


task:
  loss: next_step_sharpe_ratio   
  metrics: [next_step_sharpe_ratio, next_step_sharpe_ratio_positive, sharpe_ratio_market, compute_portfolio_metrics, next_step_sharpe_ratio_with_transaction_cost_positive]
#task:
  #loss: next_step_mse
  #metrics: [next_step_mse]  #performance_decay log_loss_not_using_path_variable 

#task:
#  loss: next_step_log_loss_ignore_terminal
#  metrics: [next_step_log_loss_ignore_terminal]


wandb:
  name: ts
  project: 'equities-set-seq'

encoder:
  _name_: timeseries_synthetics

dataset:
  _name_: equities_dataset
  dataset_name: "equities_dataset"
  num_states: 3 #2
  __l_max: ${model.layer.l_max}

decoder:
  _name_: tranistion_step_decoder   #${eval:"1 if ${train.gpu_mem} < 40 else 2"}
  hidden_dim: ${model.d_model}
  num_states: 1
  lookback_horizon: 25
  forecast: false
  forecast_horizon: 5
  loan_pool_size: 1  #EE check bz>1
  scale_output: true
  output_scale: 300
  