{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fc8e64bb-dd22-4c60-bade-931e61a755b3",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "\n",
    "def mand_op(u: torch.Tensor, v: torch.Tensor) -> torch.Tensor:\n",
    "    \"\"\"Implements the AND operation in logit space.\"\"\"\n",
    "    # see https://arxiv.org/pdf/2110.11940 for analytic derivation\n",
    "    logical_acts = torch.sqrt(torch.relu(u) * torch.relu(v))\n",
    "    return logical_acts\n",
    "\n",
    "def and_op(u: torch.Tensor, v: torch.Tensor) -> torch.Tensor:\n",
    "    \"\"\"Implements the AND operation in logit space.\"\"\"\n",
    "    # see https://arxiv.org/pdf/2110.11940 for analytic derivation\n",
    "    cond = (u < 0) & (v < 0)\n",
    "    logical_acts = torch.where(cond, u + v, torch.minimum(u, v)).type_as(u)\n",
    "    return logical_acts\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "95cedf7a-ad85-481c-8dc6-c43df8ea9381",
   "metadata": {},
   "outputs": [],
   "source": [
    "num_range = 4\n",
    "n = 100\n",
    "x = (torch.arange(n * num_range + 1) - (n * num_range) / 2) / n\n",
    "y = (torch.arange(n * num_range + 1) - (n * num_range) / 2) / n\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "id": "efe0b318-6867-4a7f-9b21-07638aacad30",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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ba0qKip08MEHp+yjS5cuTT4ZT2X16tV69dVX5fF4dPbZZxu2BQAA7iml64f3339ff/vb33TDDTdIkm666SZ9++23yQ8nQ6GQPvroI/385z9PPmfnzp36+OOPddZZZxmODQDIPwI3AKYaLi779etn+PiRRx6Z8vGG6rjGz580aZK2bNkiSdq4caM2btyYdvx0F8yplnmcfvrpuu222/Tkk09q7733llR/Ie31elP2YbYcJJFI6Le//a3i8bjOOOMMHXrooYbtAQCAe0rp+uGaa67RXnvtpd/97nd6/vnnlUgk9O9//1tHHXWUpPqTUmOxWJNqthUrVigej1PhBgBFgCWlAEyZBW5LliwxfHz3C9yVK1fqnnvukd/v18qVK5VIJFLeGp63evVq7dy5M9lfqv1XGjTeh8XK/itGy0FisZh+/etf6/nnn1fnzp119913p20LAADcVUrXD88995wWLVqk8ePHq23btjrkkEMkqcmy0oZlrY3DtYb7Gi+JBQAUJgI3AKYaLi7TVbA1BG6pHk8kElq2bJmkXReuV1xxhSKRiC677DIdeOCBacc9+OCDVVZWpng8rn/+85/J+40+oT7yyCPVo0cPvf/++/rHP/4hKfMTxmKxmF5++WUde+yxmjZtmjp16qT58+erS5cuaecKAADcVSrXD/F4XGPHjtX++++viy66SFL9oQo+n69Z4Na6dWvtt99+yfv++c9/NrsPAFCYWFIKwJRRhdu3336rVatWqU2bNjrooIOaPb5mzRpt27ZNvXr10h577KH58+frxRdf1J577qkJEyYYjltRUaF9991Xa9as0fLly3XUUUfp008/1RdffCGv15tyOYXH49HPf/5z3XXXXVq7dq2k5hfWDX1I9RsvP/PMM5Lq90r58ssv9cEHH+ibb75RWVmZfvazn+mee+5Rt27dLLxTAADADaV0/TB79mytWLFCM2fO1I4dO5L377vvvk1OKv3www/Vu3dvlZWVNbvP4/GYvWUAgDwjcANgaP369frqq6/Uo0eP5J4mjS1btkzxeFx9+/ZtckHYoHFYFw6HVV1dLUm68cYb1b59e9PxDz300OQFc+P+DjzwQLVq1Srlc04//XTdddddkqRAINBs35SGPiTp73//uyTJ6/WqXbt22mOPPXTcccfphz/8oU4//XTtv//+pnMEAADuKaXrh1AopPHj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2WGkIA5NWLVqla6//nq9+uqrqqmp0QEHHKCLL75YF198seWTIxYtWqTBgwenffzBBx/U6NGjHZoxAABA/lna5J+DFOyN5cBBClbmwkEKxXWQAoDCwb9JWLF48eImX69bt67ZfZIUi8W0ceNGPfzwwzrggANsjZn3wO0///mPfvjDH6q2tlZnnnmmunbtqmeffVaXXnqp/vOf/+iee+7JqL+BAwdq0KBBze7v06ePMxMGAAAoIIRuRmMRuqWdD6Fb+jYWQjcAQHEZNGhQsqDL4/Fo9uzZmj17dsq2iURCHo9Ht9xyi60x8x64XXLJJdq2bZuee+45nXzyyZKkm266SUOGDNG9996rc845R0cffbTl/gYNGqSJEye6NFsAAIDCYyUQMkPoRuiWCqEbAKAUjB8/Xh6PR4lEQjfeeGPaYi2v16sOHTpo8ODBOvjgg22NmdfAbdWqVVq8eLEGDx6cDNskqby8XDfddJMGDRqkGTNmZBS4AQAAtERmgZCVcIXQjdAtlWIM3cwQugEoRbXhqLz+9B84ONF/sWpcmPXaa69pzJgxGjlypKtj5jVwW7RokSTppJNOavbYscceq9atW+u1117LqM/Vq1dr6tSpqq2tVffu3XXCCSeoW7dups8Lh8MKh3f90N2+fXtG4wIAADgh3TVJJJZQhclzCd2MxiJ0SzufEgzdzKrcJEI3AGipFi5cmJNx8npK6erVqyVJ+++/f7PHvF6v9t13X61bt07RqPUUde7cubryyit13XXXaeTIkaqqqlJ1dbViMeOTnSZPnqx27dolbz169MjsxQAAADjA6JokEjM/PtLsZE0rp1RyeqlZP5xeml7hnF5qdnKp5NzppQCA4vHWW2+purpamzdvTvn4559/rurqar3zzju2xslr4LZt2zZJUrt27VI+XllZqXg8rm+//da0r7322ku33HKLVqxYoR07dmjLli2aN2+evve97+nOO+/UNddcY/j8cePGadu2bcnbxo0bM39BAAAANpldkxC62Z0PoVva+RC6pW9D6AYAJeOOO+7Q3//+d3Xu3Dnl4126dNE//vEP3XnnnbbGcX1JaaoDDK644gq1b9/e0XEOPfRQHXroocmvW7durVNPPVUDBgzQYYcdprvvvltjx47V3nvvnfL5gUBAgYD5D1sAAAA3WbkmicQS8nuNQw2WlxqNxfLStPNheWn6NiwvBYCS8P777+vEE080bHP88cfr5ZdftjWO64HbpEmTmt03evRotW/fPlnZ1lDptrvt27fL4/Gobdu2WY/fuXNnnXrqqZo5c6beffddDRs2LOu+AAAACgWhm9355C50M0PoRugGAMidL774wnSv/86dO+uLL76wNY7rgVsikf6HbMPebQ17uTUWi8W0du1a7bvvvvL57E1zzz33lCTV1NTY6gcAAKCQELrZnU9uQjcr4xC6FVfoBqBweG3mBXDftGnT9Kc//UmbN2/W4YcfrnvuuUf9+/dP2XbQoEEpD8/88Y9/rGeffVaRSETXX3+9nnvuOX3yySdq166dhgwZoltuuUVdu3a1NJ/27dtrw4YNhm3Wr1+vNm3aWOovnbzu4TZw4EBJ0ksvvdTssTfeeEM1NTXJNna8++67kqSqqirbfQEAABQS9nSzO5/c7OlmZRz2dDPppYD2dAMAWPPYY4+purpaEyZM0AcffKDDDz9cQ4cOTVs99tRTT+nzzz9P3lasWCGv16tf/OIXkqSdO3fqgw8+0A033KAPPvhATz31lD766COdcsoplud01FFH6emnn067d/+GDRs0b948/fCHP8z8BTeS18DtwAMP1PHHH6+FCxfq+eefT95fV1enG264QZJ0/vnnN3nO1q1btXLlSm3durXJ/UuXLk05xl133aWFCxdq//3315FHHunwKwAAAMg/Qje78yF0SzsfQjcAwG62b9/e5BYOp68MnjJlii644AKNGTNGhxxyiKZPn65WrVrpgQceSNm+Q4cO6ty5c/L28ssvq1WrVsnArV27dnr55Zd15pln6sADD9RRRx2le++9V0uXLjWtWmtQXV2tnTt36phjjtGcOXP0+eefS6o/nXT27Nk65phjVFtbq6uuuirDd6apvNde/vnPf9Yxxxyj0047TcOHD1eXLl307LPP6t///rcuv/zyZonivffeq0mTJmnChAlNDmQ4/fTT5ff71a9fP3Xv3l01NTV65513tGzZMrVv314PPfSQvF7j8noAAIBixfJSu/NheWna+bC8FACKQrguJl+d8fc2u/1LUo8ePZrcv3s+06Curk5Lly7VuHHjkveVlZVpyJAhevvtty2Nef/99+uss85S69at07bZtm2bPB6P5cM5jz/+eE2ZMkVXXXWVxowZI0nyeDzJLdHKysp011136fjjj7fUXzp5D9wOPfRQvfvuu7r++uv17LPPqqamRgcccICmTZumSy65xHI/l1xyiV588UUtXrxYX331lcrKytSzZ09dccUVuuqqq9S9e3cXXwUAAIC76iJxVZi0sRK6mSF0I3RLOR9CNwDAdzZu3KjKysrk1+lOV9+6datisZg6derU5P5OnTpp5cqVpuO89957WrFihe6///60bUKhkMaOHauzzz67yZzM/Pa3v9XgwYM1ffp0vf/++9q2bZvat2+v/v376+KLL9b3v/99y32lk/fATapfWvr4449bajtx4sSUyenYsWM1duxYh2cGAABQOKwFS8ahm6WQi9DN/liEbgZyF7qZIXQDgMxVVlZmFG5l6/7771fv3r3THrAQiUR05plnKpFI6C9/+UvG/R922GH685//nPbxcDicNky0Iq97uAEAACAz1vYtMw4zLO2hxp5u9sdiTzcDudnTzWw/N4k93QDALXvuuae8Xq+2bNnS5P4tW7aoc+fOhs+tqanRo48+ql/96lcpH28I29avX6+XX37Z0QDwgw8+0GWXXWb51NN0CNwAAACKDKGb0XwI3dIhdDNoQ+gGAI4rLy/XEUccoQULFiTvi8fjWrBggY4++mjD5z7++OMKh8M677zzmj3WELatXr1ar7zyijp27Gh7rt98843uvfde9e3bV0ceeaT+8pe/KBQK2eqTwA0AAKAIEboZzYfQLR1CN4M2hG4A4Ljq6mrNmDFDs2fP1v/93//pkksuUU1NTfKwgpEjRzY5VKHB/fffr9NOO61ZmBaJRHTGGWdoyZIlevjhhxWLxbR582Zt3rxZdXV1Gc/vlVde0dlnn62uXbvqt7/9rT788EMdddRRuu+++7R58+bsXvR3CmIPNwAAAGSOPd2M5sOebum01D3dzA5RkKzv6QagcHjLMw9ZkDvDhw/Xl19+qfHjx2vz5s3q06ePXnjhheRBChs2bFDZbh+sfPTRR3rjjTf00ksvNetv06ZNeuaZZyRJffr0afLYwoULNWjQINM5bdy4UQ8++KAefPBBbdiwQYlEQt26ddOmTZs0evRoPfDAA9m92N0QuAEAABQxQjej+RRW6GaG0K14QjcAgHWXX365Lr/88pSPLVq0qNl9Bx54oBKJ1D8Tqqqq0j5mJBKJaN68ebr//vu1YMECxWIxtW7dWueee65GjhypE044QT6f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FJeXWlmGyfJSs344vRQA4L68B25O++yzzzRt2jTdfPPNuv/++7VmzZp8TwkAAMBVhG7pEbrZ64fQDQBg17Rp01RVVaVgMKgBAwbovffeS9t2xowZOu6447THHntojz320JAhQwzbX3zxxfJ4PJo6daoLM7cn70tKnfbyyy/r5ZdfTn7t8Xh07rnnavr06WrdunXa54XDYYXD4eTX27dvd3WeAAAAqWR7TcLy0vRYXmo0F5aX2h0LAJDeY489purqak2fPl0DBgzQ1KlTNXToUH300Ufae++9m7VftGiRzj77bP3whz9UMBjUrbfeqpNOOkn//ve/1a1btyZtn376ab3zzjvq2rVrrl5ORkqmwq1Vq1a64YYbtHTpUn3zzTf6+uuv9corr6h///566KGHNHLkSMPnT548We3atUveevTokaOZAwAA7JLumqTOUhWWef9OVbqZj0Olm+2xqHQzGItKNwAoBlOmTNEFF1ygMWPG6JBDDtH06dPVqlUrPfDAAynbP/zww7r00kvVp08fHXTQQZo5c6bi8bgWLFjQpN2mTZv061//Wg8//LD8fn8uXkrGXK9wS3WAwRVXXKH27ds7Os7ee++tG2+8scl9J554oo4++mj94Ac/0FNPPaUPPvhAP/jBD1I+f9y4caqurk5+vX37dkI3AACQc0bXJHWxhMpNq7ByU+lmVuVWPw6VbrbHotLNYKzcVboBAHbZvfo+EAgoEAg0a1dXV6elS5dq3LhxyfvKyso0ZMgQvf3225bG2rlzpyKRiDp06JC8Lx6Pa8SIEbr66qt16KGHZvkq3Od64DZp0qRm940ePdrxwC2dVq1aacSIEbr++uv15ptvpg3c0v0FAQAAyCWzaxJCN3ttCN2M5kLoZmccAMi32khCMa/9KvV06iL1fe9enDRhwoSUxVZbt25VLBZTp06dmtzfqVMnrVy50tKYY8eOVdeuXTVkyJDkfbfeeqt8Pp9+85vfZPgKcsv1wC2RcO8P26o999xTklRTU5PnmQAAANhH6GavDaGb0VwI3eyMAwAtwcaNG1VZWZn82q3ipVtuuUWPPvqoFi1apGAwKElaunSp7rrrLn3wwQfyeIx/duZbi6idfvfddyVJVVVV+Z0IAACAQwppTzezk0vrx2FPN9tjsaebwVi52dON/dwAQKqsrGxySxe47bnnnvJ6vdqyZUuT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",
      "text/plain": [
       "<Figure size 1300x600 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "from matplotlib.ticker import MultipleLocator, FormatStrFormatter\n",
    "\n",
    "fig, axs = plt.subplots(1, 2, figsize=(13, 6), sharey=True)\n",
    "for ax in axs:\n",
    "    #ax.minorticks_on()\n",
    "    ax.tick_params(axis='y', which='major',  left=True, right=False,  labelsize=14)\n",
    "    ax.tick_params(axis='y', which='minor',  left=True, right=False)\n",
    "    ax.tick_params(axis='x', which='major',  bottom=True, top=False, labelsize=14)\n",
    "    ax.tick_params(axis='x', which='minor',  bottom=True, top=False)\n",
    "\n",
    "    # ← NEW: force integer steps and integer labels\n",
    "    ax.xaxis.set_major_locator(MultipleLocator(0.5))\n",
    "    ax.yaxis.set_major_locator(MultipleLocator(0.5))\n",
    "    ax.xaxis.set_major_formatter(FormatStrFormatter('%g'))\n",
    "    ax.yaxis.set_major_formatter(FormatStrFormatter('%g'))\n",
    "\n",
    "X, Y = torch.meshgrid(x, y)\n",
    "Zmand = mand_op(X, Y)\n",
    "Zand  = and_op(X, Y)\n",
    "\n",
    "# left panel: mAND\n",
    "cs1 = axs[0].contourf(\n",
    "    X.numpy(), Y.numpy(), Zmand.numpy(),\n",
    "    levels=50, cmap='vlag'\n",
    ")\n",
    "axs[0].set_title(r\"$mAND$\", fontsize = 16)\n",
    "axs[0].set_xlabel(r\"$\\mathbf{p}$\", fontsize = 14)      # bold p on x\n",
    "axs[0].set_ylabel(r\"$\\mathbf{q}$\", rotation=0, fontsize = 14)      # bold q on y\n",
    "axs[0].tick_params(axis='y', which='major', labelsize=14)\n",
    "axs[0].tick_params(axis='x', which='major', labelsize=14)\n",
    "#axs[0].minorticks_on()\n",
    "# right panel: AND\n",
    "cs2 = axs[1].contourf(\n",
    "    X.numpy(), Y.numpy(), Zand.numpy(),\n",
    "    levels=100, cmap='vlag'\n",
    ")\n",
    "\n",
    "axs[1].set_title(\"$AND_{AIL}$\", fontsize=16)\n",
    "axs[1].set_xlabel(r\"$\\mathbf{p}$\", fontsize=14)      # bold p on x\n",
    "axs[1].tick_params(axis='y', which='major', labelsize=14)\n",
    "axs[1].tick_params(axis='x', which='major', labelsize=14)\n",
    "axs[1].set_xlim(-2, 2)\n",
    "axs[1].set_ylim(-2, 2)\n",
    "#axs[1].minorticks_on()\n",
    "# no need to set_ylabel here because sharey=True\n",
    "\n",
    "# single shared colorbar\n",
    "# we need to pick one of the mappable objects (cs1 or cs2) and tell\n",
    "# colorbar which axes to span:\n",
    "cbar_ax = fig.add_axes([0.95, 0.11, 0.02, 0.77])  # [left, bottom, width, height]\n",
    "\n",
    "cbar = fig.colorbar(\n",
    "    cs1, cax=cbar_ax,                       # any of the two contour sets\n",
    "    ax=axs,                    # list of all subplots\n",
    "    orientation=\"vertical\",    # or 'horizontal'\n",
    "    fraction=0.046,            # shrink colorbar to fit\n",
    "    pad=0.04                   # spacing from plots\n",
    ")\n",
    "cbar.set_label(\"Activation value\", fontsize=14)  # optional\n",
    "\n",
    "#plt.tight_layout()\n",
    "fig.savefig(\"mand.pdf\", bbox_inches=\"tight\")\n",
    "plt.show()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.10.17"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
