# Originally called phasor_depth_3


ARCH: 'psychonet'

MODEL:
  # general input output settings
  IMG_SIZE: 224
  IN_CHANN: 3
  N_CLASS: 1000

  # subdepth - used throughout for other layers
  DIM: 64

  # config for first conv layer [kernel_size, padding, stride]
  CONV1: [7, 3, 2]

  # config for ResidualBottleneckBlocks
  RESIDUAL_BLOCKS:
    EXPANSION: 4
    LAYERS:
      # [in_planes, planes, stride], multiples of subdepth
      # note that we have expansion factors in place following regular ResNet
      #   - in_planes of all but the first layer is also multiplied by EXPANSION
      #   - planes of the last layer is divided by EXPANSION

      # resnet101 s1
      - [1, 1, 1]
      - [1, 1, 1]
      - [1, 1, 1]

      # resnet101 s2
      - [1, 2, 2]
      - [2, 2, 1]
      - [2, 2, 1]
      - [2, 2, 1]

      # mostly following phasor_depth_3
      - [2, 2, 1]
      - [2, 2, 1]
      - [2, 2, 1]
      - [2, 2, 1]
      - [2, 4, 1]
      - [4, 4, 1]
      - [4, 4, 1]
      - [4, 4, 1]
      - [4, 4, 1]
      - [4, 4, 2]
      - [4, 6, 1]
      - [6, 6, 1]
      - [6, 6, 1]
      - [6, 6, 1]
      - [6, 6, 1]
      - [6, 6, 1]
      - [6, 6, 1]
      - [6, 8, 1]

  PHASOR_BLOCK_I:
    - [8, 8, 7, 3, 3]  # phase_dwconv1 d_in, d_out, kernel size, padding, kernels_per_layer
    - [8, 8, 7, 3, 3]  # phase_dwconv2 d_in, d_out, kernel size, padding, kernels_per_layer
    - [8, 8, 1]  # cconv1 d_in, d_out, stride

  # Phasor Block (C)
  PHASOR_BLOCKS:
      # d_in, d_bottle (~ for None), d_out, stride, depth, dw_kernel_size, dw_padding, dw_kernels_per_layer
      # last argument is optional and provided if the output of that layer is
      # to be used in spectral branching; provide the output's name

  HADAMARD_FILTER_INIT_TYPE: 'weibull'
  SPECTRAL_BRANCHES:
    POST_PHASOR:
      # [crop, drop, d_in, d_out]
      - [ 14, 8, 8, 8 ]
      - [ 8, 4, 8, 8 ]
      - [ 4, 1, 8, 8 ]
