# Steps for adding models.

1. Inherit `BaseTargetModel` class in `base.py`, and implement the abstract methods you need. The details are described [here](#abstract-methods).
2. Resize inputs at the beginning of `forward`.
3. The return of `forward` function should be an instance of `ModelResult` class in `modelresult.py`.
    + result: the output of the model.
    + feat: a list of some features during the `forward` function. The input of the last linear layer (the last feature) should be contained in the list.
    + addition_info: a dict of some other infos.
4. Add the model to `get_model` function in `get_models.py`


## Abstract Methods

### `get_feature_dim`

The method is used by the defense algorithm `ViB`. It return the dim of the input of the last linear layer.

### `create_hidden_hooks`

The method is used by the defense algorithm `BiDO`. It return a list of `OutputHook` defined in `src/modelinversion/utils/torchutils`, which monitor intermediate results when calling forward function.

### `freeze_front_layers`

The method is used by the defense algorithm `TL`. It freeze the front some layers.

For example, the forward process 
$$
x \stackrel{T}{\rightarrow} y
$$

can also be view as

$$
x \stackrel{E}{\rightarrow} h \stackrel{C}{\rightarrow} y.
$$

The method is to freeze the parameters in $E$.