{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from gurobipy import *\n",
    "from scipy.spatial.distance import cdist\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "a = np.random.random((50,30))\n",
    "b = np.random.random((3,30))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[2.30153566, 2.29803371, 2.19469163],\n",
       "       [2.70565146, 1.93761195, 1.92483425],\n",
       "       [2.49453252, 2.13364934, 2.41031786],\n",
       "       [2.32762212, 2.10144535, 2.42573016],\n",
       "       [2.05124577, 2.40956459, 2.23511449],\n",
       "       [2.06848447, 2.55096427, 2.67340683],\n",
       "       [2.40208877, 2.14387994, 2.15070992],\n",
       "       [2.02962871, 2.2599729 , 2.58781819],\n",
       "       [2.15018743, 2.15603866, 1.82254038],\n",
       "       [2.07341695, 2.37108834, 2.58035523],\n",
       "       [2.73822054, 2.27777782, 2.67261517],\n",
       "       [2.27184833, 2.02481055, 2.54309088],\n",
       "       [2.36495967, 2.23594724, 2.3739614 ],\n",
       "       [2.72374316, 2.17840555, 2.15767978],\n",
       "       [2.43021145, 2.2101679 , 2.67054678],\n",
       "       [2.06315312, 2.3586674 , 2.41574027],\n",
       "       [2.53777063, 2.34140812, 2.36960974],\n",
       "       [2.68234296, 2.37540082, 2.63388843],\n",
       "       [2.06613437, 2.05739953, 2.29623207],\n",
       "       [2.45247191, 2.21283701, 2.48397099],\n",
       "       [1.72899295, 2.26736232, 2.47999787],\n",
       "       [2.04450079, 2.19215742, 2.31281982],\n",
       "       [2.43849658, 2.70204076, 2.41038989],\n",
       "       [2.43898419, 2.23474625, 2.02066738],\n",
       "       [2.60385041, 2.08171945, 2.15138725],\n",
       "       [2.43440249, 2.25169422, 2.33370838],\n",
       "       [2.35744347, 2.32988704, 2.10813037],\n",
       "       [2.14757572, 1.91602583, 2.15042017],\n",
       "       [2.31207727, 1.99523122, 2.43077686],\n",
       "       [2.03392384, 2.28000868, 2.76038297],\n",
       "       [2.41102132, 2.14670433, 2.2904148 ],\n",
       "       [2.70752422, 2.33535253, 2.1442161 ],\n",
       "       [1.9305426 , 2.31467572, 2.16043708],\n",
       "       [2.32932665, 1.92137844, 2.11796028],\n",
       "       [2.1702905 , 2.30624372, 2.64457899],\n",
       "       [2.22456152, 2.18353966, 2.05518302],\n",
       "       [2.37573594, 2.0561506 , 2.38037641],\n",
       "       [2.55044567, 2.22367006, 2.32644023],\n",
       "       [2.05049808, 2.35829471, 2.00512815],\n",
       "       [2.29118577, 2.73955496, 2.76942782],\n",
       "       [2.20479473, 1.95598148, 2.35051135],\n",
       "       [2.48854302, 2.29900061, 1.99762661],\n",
       "       [2.25431382, 2.17746961, 2.26324649],\n",
       "       [2.56578051, 2.12022155, 2.11798346],\n",
       "       [2.33801243, 2.02708926, 2.058548  ],\n",
       "       [2.20473688, 2.35987954, 2.48373038],\n",
       "       [2.20472775, 1.94888375, 1.80717716],\n",
       "       [2.34203746, 2.54618943, 2.24730606],\n",
       "       [2.4301784 , 2.06427953, 2.35313617],\n",
       "       [2.17865767, 2.07639606, 2.46199024]])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dist = cdist(a, b)\n",
    "dist"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.9248342522093718"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dist[1,2]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{(1, 2): <gurobi.Var *Awaiting Model Update*>,\n",
       " (4, 5): <gurobi.Var *Awaiting Model Update*>}"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model = Model('mip')\n",
    "\n",
    "n = a.shape[0]\n",
    "k = b.shape[0]\n",
    "\n",
    "frac_list = [1,3,5]\n",
    "\n",
    "phi = model.addVars([(1,2),(4,5)], vtype=GRB.CONTINUOUS, ub = 1, name = 'assignment')\n",
    "# phi[(1,2)] = model.addVar()\n",
    "# Y = model.addVars(5,3, vtype=GRB.CONTINUOUS)\n",
    "phi"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "ename": "KeyError",
     "evalue": "(0, 0)",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyError\u001b[0m                                  Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[17], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m model\u001b[39m.\u001b[39;49maddConstrs(\u001b[39msum\u001b[39;49m(phi[(i,\u001b[39m0\u001b[39;49m)] \u001b[39m+\u001b[39;49m phi[(j,\u001b[39m0\u001b[39;49m)] \u001b[39mfor\u001b[39;49;00m i \u001b[39min\u001b[39;49;00m \u001b[39mrange\u001b[39;49m(\u001b[39m5\u001b[39;49m)) \u001b[39m<\u001b[39;49m\u001b[39m=\u001b[39;49m \u001b[39msum\u001b[39;49m(phi[(i,\u001b[39m0\u001b[39;49m)] \u001b[39m+\u001b[39;49m phi[(j,\u001b[39m0\u001b[39;49m)] \u001b[39mfor\u001b[39;49;00m i \u001b[39min\u001b[39;49;00m \u001b[39mrange\u001b[39;49m(\u001b[39m5\u001b[39;49m)) \u001b[39mfor\u001b[39;49;00m j \u001b[39min\u001b[39;49;00m \u001b[39mrange\u001b[39;49m(\u001b[39m5\u001b[39;49m))\n",
      "File \u001b[0;32msrc/gurobipy/model.pxi:3877\u001b[0m, in \u001b[0;36mgurobipy.Model.addConstrs\u001b[0;34m()\u001b[0m\n",
      "Cell \u001b[0;32mIn[17], line 1\u001b[0m, in \u001b[0;36m<genexpr>\u001b[0;34m(.0)\u001b[0m\n\u001b[0;32m----> 1\u001b[0m model\u001b[39m.\u001b[39maddConstrs(\u001b[39msum\u001b[39;49m(phi[(i,\u001b[39m0\u001b[39;49m)] \u001b[39m+\u001b[39;49m phi[(j,\u001b[39m0\u001b[39;49m)] \u001b[39mfor\u001b[39;49;00m i \u001b[39min\u001b[39;49;00m \u001b[39mrange\u001b[39;49m(\u001b[39m5\u001b[39;49m)) \u001b[39m<\u001b[39m\u001b[39m=\u001b[39m \u001b[39msum\u001b[39m(phi[(i,\u001b[39m0\u001b[39m)] \u001b[39m+\u001b[39m phi[(j,\u001b[39m0\u001b[39m)] \u001b[39mfor\u001b[39;00m i \u001b[39min\u001b[39;00m \u001b[39mrange\u001b[39m(\u001b[39m5\u001b[39m)) \u001b[39mfor\u001b[39;00m j \u001b[39min\u001b[39;00m \u001b[39mrange\u001b[39m(\u001b[39m5\u001b[39m))\n",
      "Cell \u001b[0;32mIn[17], line 1\u001b[0m, in \u001b[0;36m<genexpr>\u001b[0;34m(.0)\u001b[0m\n\u001b[0;32m----> 1\u001b[0m model\u001b[39m.\u001b[39maddConstrs(\u001b[39msum\u001b[39m(phi[(i,\u001b[39m0\u001b[39m)] \u001b[39m+\u001b[39m phi[(j,\u001b[39m0\u001b[39m)] \u001b[39mfor\u001b[39;00m i \u001b[39min\u001b[39;00m \u001b[39mrange\u001b[39m(\u001b[39m5\u001b[39m)) \u001b[39m<\u001b[39m\u001b[39m=\u001b[39m \u001b[39msum\u001b[39m(phi[(i,\u001b[39m0\u001b[39m)] \u001b[39m+\u001b[39m phi[(j,\u001b[39m0\u001b[39m)] \u001b[39mfor\u001b[39;00m i \u001b[39min\u001b[39;00m \u001b[39mrange\u001b[39m(\u001b[39m5\u001b[39m)) \u001b[39mfor\u001b[39;00m j \u001b[39min\u001b[39;00m \u001b[39mrange\u001b[39m(\u001b[39m5\u001b[39m))\n",
      "\u001b[0;31mKeyError\u001b[0m: (0, 0)"
     ]
    }
   ],
   "source": [
    "model.addConstrs(sum(phi[(i,0)] + phi[(j,0)] for i in range(5)) <= sum(phi[(i,0)] + phi[(j,0)] for i in range(5)) for j in range(5))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "ename": "GurobiError",
     "evalue": "Variable not in model",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mGurobiError\u001b[0m                               Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[91], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m model\u001b[39m.\u001b[39;49msetObjective(\u001b[39msum\u001b[39;49m(X[(i,j)]\u001b[39m*\u001b[39;49m dist[i,j] \u001b[39mfor\u001b[39;49;00m i \u001b[39min\u001b[39;49;00m \u001b[39mrange\u001b[39;49m(\u001b[39m5\u001b[39;49m) \u001b[39mfor\u001b[39;49;00m j \u001b[39min\u001b[39;49;00m \u001b[39mrange\u001b[39;49m(\u001b[39m3\u001b[39;49m)), GRB\u001b[39m.\u001b[39;49mMINIMIZE)\n",
      "File \u001b[0;32msrc/gurobipy/model.pxi:1506\u001b[0m, in \u001b[0;36mgurobipy.Model.setObjective\u001b[0;34m()\u001b[0m\n",
      "\u001b[0;31mGurobiError\u001b[0m: Variable not in model"
     ]
    }
   ],
   "source": [
    "model.setObjective(sum(X[(i,j)]* dist[i,j] for i in range(5) for j in range(3)), GRB.MINIMIZE)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ph",
   "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.13"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
