model_path=xxx/Llama-3-8B
rotation_epoch=0
base_dir=xxx/rotate_input_config/llama-3-8b

rotation_dir=$base_dir/rotation
input_normalized_sorted_dir=$base_dir/input_normalized_sorted

START_LAYER=0      
END_LAYER=31       
STEP_SIZE=16       

mkdir -p $base_dir
mkdir -p $rotation_dir
mkdir -p $input_normalized_sorted_dir 

source activate conda_env_path
cd xxx/norsa

for ((start=$START_LAYER; start<=$END_LAYER; start+=$STEP_SIZE)); do
    end=$((start + STEP_SIZE - 1))
    
    if [ $end -gt $END_LAYER ]; then
        end=$END_LAYER
    fi
    
    echo "Processing layers $start to $end..."
    
    python llama_rotate_input.py $model_path wikitext2 \
           --nsamples 16 \
           --rotate True \
           --rotate_R1 True \
           --rotate_R2 True \
           --rotation_epoch $rotation_epoch \
           --rotation_dir $rotation_dir \
           --rotate_lr 0.0000001 \
           --initialize_with_pca True \
           --input_normalized_sorted_dir $input_normalized_sorted_dir \
           --start_layer_id $start \
           --end_layer_id $end \
           | tee -a $base_dir/log_layers_${start}_${end}.txt
    
    echo "Completed layers $start to $end"
    
    if [ $end -ge $END_LAYER ]; then
        break
    fi
done

echo "All layers processed successfully!"
