# VAECILP



## Install the environment. It`s really importance
```

cd Dassl.pytorch/

pip install -r requirements.txt
python setup.py develop

cd ../
cd VAECILP/
```
## Prepare the datasets by unzipping all the zip files in the datasets folder:
```
|--Dassl.pytorch/
|--VACECILP/
    |--data/
        |--(Your_datasets).zip

```

## Unzip all the datasets:

```
cd data
unzip (Your_datasets).zip
rm -rf Your_datasets/split_fewshot
```
## After unzipping, the  folder should look like this:
```
|--Dassl.pytorch/
|--VACECILP/
    |--data
        |--(Your_datasets).zip
        |--(Your_datasets)
            |--
            |--❌split_fewshot(not needed)
            |--

```
## To train the model, run the following command:查看 
```
scripts/coop/coop_b2n_test.sh
scripts/coop/coop_b2n_train.sh
```
## 这个是数据集的名字请填入你下好对应的名字
```
[caltech101, food101, dtd, ucf101, oxford_flowers, oxford_pets, fgvc_aircraft, stanford_cars, sun397, eurosat]
 ```
 ```
第15行
for DATASET in ()括号中填入你的数据集
```
```
第19行这是每次跑SEED 1～5 5个实验
for SEED in 1 2 3 4 5
想快速验证就可以注释掉一部分
for SEED in 1 # 2 3 4 5
我们需要跑5个实验取平均值
```
## 修改好之后就可以运行fewshot/base training
```
bash scripts/coop/coop_b2n_train.sh
```

```
最终的结果保存在
|--VACECILP/
    |--data
    |--output_coop

```
```
/output_coop/base2new/train_base/${DATASET}/shots_${SHOTS}/${TRAINER}/${CFG}/${EPC}/seed${SEED}.txt
这个下会有这个seed对应的结果
最底下会有result
```
```
如果已经生成了权重并且对结果不满意想重新跑
请删除
output_coop/base2new/train_base/(your_dataset)/
再重新跑
```
## 测试Zero-shot（请匹配你刚才训练的数据集）
```
bash scripts/coop/coop_b2n_test.sh
```
## Zero-shot的结果会自动保存在
```
/output_coop/base2new/test_new/${DATASET}/shots_${SHOTS}/${TRAINER}/${CFG}/${EPC}/seed${SEED}.txt
```
## 后台跑实验，正常跑如果熄屏会断开链接导致服务器不继续训练
使用tmux/安装
```
apt-get update && apt-get install -y tmux
```
使用tmux新建一个会话
```
tmux new -s my_session
```
然后在这个会话里面运行你的脚本就可以了
```
tmux attach -t my_session
```
恢复会话
