{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from mpl_toolkits.mplot3d.art3d import Poly3DCollection\n",
    "import numpy as np\n",
    "\n",
    "# Define the vertices of the polyhedron\n",
    "vertices = np.array([\n",
    "    [1, 0, 0],  # Intersection of x + y + z = 1, x = 1, y = 0, z = 0\n",
    "    [0, 1, 0],  # Intersection of x + y + z = 1, x = 0, y = 1, z = 0\n",
    "    [0, 0, 1],  # Intersection of x + y + z = 1, x = 0, y = 0, z = 1\n",
    "    [1, 1, 0],  # Intersection of x = y + z - 1, x = 1, y = 1, z = 0\n",
    "    [1, 0, 1],  # Intersection of y = x + z - 1, y = 0, x = 1, z = 1\n",
    "    [0, 1, 1],  # Intersection of z = x + y - 1, z = 1, x = 0, y = 1\n",
    "])\n",
    "\n",
    "# Define the faces of the polyhedron with different colors\n",
    "faces = [\n",
    "    [vertices[0], vertices[1], vertices[2]],  # Face 1\n",
    "    [vertices[0], vertices[3], vertices[4]],  # Face 2\n",
    "    [vertices[1], vertices[3], vertices[5]],  # Face 3\n",
    "    [vertices[2], vertices[4], vertices[5]],  # Face 4\n",
    "    [vertices[0], vertices[1], vertices[3]],  # Face 5\n",
    "    [vertices[0], vertices[2], vertices[4]],  # Face 6\n",
    "    [vertices[1], vertices[2], vertices[5]],  # Face 7\n",
    "    [vertices[3], vertices[4], vertices[5]]   # Face 8\n",
    "]\n",
    "\n",
    "# Colors for each face\n",
    "colors = ['cyan', 'magenta', 'yellow', 'blue', 'green', 'red', 'purple', 'orange']\n",
    "\n",
    "# Plot the polyhedron\n",
    "fig = plt.figure()\n",
    "ax = fig.add_subplot(111, projection='3d')\n",
    "\n",
    "# Add each face with a different color\n",
    "for face, color in zip(faces, colors):\n",
    "    poly3d = [[tuple(vertex) for vertex in face]]\n",
    "    ax.add_collection3d(Poly3DCollection(poly3d, facecolors=color, linewidths=1, edgecolors='black', alpha=.5))\n",
    "\n",
    "# Annotate the vertices\n",
    "for vertex in vertices:\n",
    "    ax.text(vertex[0], vertex[1], vertex[2], f'({vertex[0]}, {vertex[1]}, {vertex[2]})', color='black')\n",
    "\n",
    "# Set plot labels and title\n",
    "ax.set_xlabel(r'$d_{sc}$')\n",
    "ax.set_ylabel(r'$d_{ls}$')\n",
    "ax.set_zlabel(r'$d_{cs}$')\n",
    "ax.set_title('Solution Set of Inequalities Forming a Closed Shape')\n",
    "\n",
    "# Set the limits of the plot\n",
    "ax.set_xlim([0, 1])\n",
    "ax.set_ylim([0, 1])\n",
    "ax.set_zlim([0, 1])\n",
    "\n",
    "# Set equal aspect ratio\n",
    "ax.set_box_aspect([1, 1, 1])  # aspect ratio is 1:1:1\n",
    "\n",
    "# plt.show()\n",
    "\n",
    "# Save the plot in high eresolution\n",
    "plt.savefig('polyhedron.pdf', dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "div_backup",
   "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.9.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
