{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import json\n",
    "import os\n",
    "\n",
    "layer = 5  # Manually set layer value\n",
    "\n",
    "# Function to process a single folder\n",
    "def process_folder(base_path, folder_name):\n",
    "    full_path = os.path.join(base_path, folder_name)\n",
    "    model_name = os.path.join(full_path, \"ae.pt\")\n",
    "\n",
    "    if not os.path.exists(model_name):\n",
    "        print(f\"Model file missing: {model_name}\")\n",
    "        return\n",
    "\n",
    "    model = torch.load(model_name)\n",
    "\n",
    "    hidden_dim = model['encoder.weight'].shape[0]\n",
    "    input_dim = model['encoder.weight'].shape[1]\n",
    "\n",
    "    assert hidden_dim % input_dim == 0\n",
    "\n",
    "    expansion_factor = int(hidden_dim / input_dim)\n",
    "    config_path = os.path.join(full_path, \"config.json\")\n",
    "\n",
    "    if not os.path.exists(config_path):\n",
    "        print(f\"Config file missing: {config_path}\")\n",
    "        return\n",
    "\n",
    "    with open(config_path) as f:\n",
    "        config = json.load(f)\n",
    "\n",
    "    lr = format(config['trainer']['lr'], '.0e')\n",
    "    l1 = format(config['trainer']['l1_penalty'], '.0e')\n",
    "\n",
    "    if 'activation_dim' not in config['trainer']:\n",
    "        config['trainer']['activation_dim'] = input_dim\n",
    "\n",
    "    if 'dictionary_size' not in config['trainer']:\n",
    "        config['trainer']['dictionary_size'] = hidden_dim\n",
    "\n",
    "    config['trainer']['layer'] = layer\n",
    "\n",
    "    with open(config_path, 'w') as f:\n",
    "        json.dump(config, f, indent=4)\n",
    "\n",
    "    new_folder_name = os.path.join(base_path, f\"ef={expansion_factor}_lr={lr}_l1={l1}_layer={layer}\")\n",
    "\n",
    "    print(f\"Renaming {full_path} to {new_folder_name}\")\n",
    "    os.rename(full_path, new_folder_name)\n",
    "\n",
    "# Process current directory and one level deep subdirectories\n",
    "for folder in os.listdir():\n",
    "    if os.path.isdir(folder):\n",
    "        process_folder('.', folder)  # Process folders in the current directory\n",
    "        for subfolder in os.listdir(folder):  # Process subfolders\n",
    "            subfolder_path = os.path.join(folder, subfolder)\n",
    "            if os.path.isdir(subfolder_path):\n",
    "                process_folder(folder, subfolder)\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "circuits",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
