{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import time\n",
    "from collections import defaultdict\n",
    "from functools import partial, reduce\n",
    "from itertools import combinations, product\n",
    "\n",
    "import cvxpy as cp\n",
    "import matplotlib.pyplot as plt\n",
    "import networkx as nx\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import pickle\n",
    "import scipy.optimize as optimize\n",
    "import scipy.spatial.distance as distance\n",
    "import sympy\n",
    "\n",
    "from scipy.cluster.vq import kmeans, vq\n",
    "from sklearn.cluster import KMeans\n",
    "from tqdm import tqdm\n",
    "import matplotlib.patches as patches"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "from functions import *"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Simple quadratic potential"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG:functions:Potential has 4 non-zero terms\n",
      "DEBUG:functions:SimpleQuadratic: Generated 28 basis functions\n",
      "DEBUG:functions:Using 28 basis functions\n",
      "DEBUG:functions:SimpleQuadratic: Adding moment constraint for [0 0] with value 1.0\n",
      "DEBUG:functions:SimpleQuadratic: Adding moment constraint for [0 1] with value 0\n",
      "DEBUG:functions:SimpleQuadratic: Adding moment constraint for [0 2] with value 0.3333333333333333\n",
      "DEBUG:functions:SimpleQuadratic: Adding moment constraint for [0 3] with value 0\n",
      "DEBUG:functions:SimpleQuadratic: Adding moment constraint for [0 4] with value 0.2\n",
      "DEBUG:functions:SimpleQuadratic: Adding moment constraint for [0 5] with value 0\n",
      "DEBUG:functions:SimpleQuadratic: Adding moment constraint for [0 6] with value 0.14285714285714285\n",
      "DEBUG:functions:SimpleQuadratic: Adding moment constraint for [0 7] with value 0\n",
      "DEBUG:functions:SimpleQuadratic: Adding moment constraint for [0 8] with value 0.1111111111111111\n",
      "DEBUG:functions:SimpleQuadratic: Adding moment constraint for [0 9] with value 0\n",
      "DEBUG:functions:SimpleQuadratic: Adding moment constraint for [ 0 10] with value 0.09090909090909091\n",
      "DEBUG:functions:SimpleQuadratic: Adding moment constraint for [ 0 11] with value 0\n",
      "DEBUG:functions:SimpleQuadratic: Adding moment constraint for [ 0 12] with value 0.07692307692307693\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.2.0                                    \n",
      "===============================================================================\n",
      "(CVXPY) May 22 03:03:36 PM: Your problem has 875 variables, 15 constraints, and 0 parameters.\n",
      "(CVXPY) May 22 03:03:36 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) May 22 03:03:36 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) May 22 03:03:36 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) May 22 03:03:36 PM: Compiling problem (target solver=MOSEK).\n",
      "(CVXPY) May 22 03:03:36 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> MOSEK\n",
      "(CVXPY) May 22 03:03:36 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) May 22 03:03:36 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) May 22 03:03:36 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) May 22 03:03:36 PM: Applying reduction MOSEK\n",
      "(CVXPY) May 22 03:03:36 PM: Finished problem compilation (took 5.468e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) May 22 03:03:36 PM: Invoking solver MOSEK  to obtain a solution.\n",
      "\n",
      "\n",
      "(CVXPY) May 22 03:03:36 PM: Problem\n",
      "(CVXPY) May 22 03:03:36 PM:   Name                   :                 \n",
      "(CVXPY) May 22 03:03:36 PM:   Objective sense        : maximize        \n",
      "(CVXPY) May 22 03:03:36 PM:   Type                   : CONIC (conic optimization problem)\n",
      "(CVXPY) May 22 03:03:36 PM:   Constraints            : 497             \n",
      "(CVXPY) May 22 03:03:36 PM:   Affine conic cons.     : 0               \n",
      "(CVXPY) May 22 03:03:36 PM:   Disjunctive cons.      : 0               \n",
      "(CVXPY) May 22 03:03:36 PM:   Cones                  : 0               \n",
      "(CVXPY) May 22 03:03:36 PM:   Scalar variables       : 797             \n",
      "(CVXPY) May 22 03:03:36 PM:   Matrix variables       : 1               \n",
      "(CVXPY) May 22 03:03:36 PM:   Integer variables      : 0               \n",
      "(CVXPY) May 22 03:03:36 PM: \n",
      "(CVXPY) May 22 03:03:36 PM: Optimizer started.\n",
      "(CVXPY) May 22 03:03:36 PM: Presolve started.\n",
      "(CVXPY) May 22 03:03:36 PM: Linear dependency checker started.\n",
      "(CVXPY) May 22 03:03:36 PM: Linear dependency checker terminated.\n",
      "(CVXPY) May 22 03:03:36 PM: Eliminator started.\n",
      "(CVXPY) May 22 03:03:36 PM: Freed constraints in eliminator : 77\n",
      "(CVXPY) May 22 03:03:36 PM: Eliminator terminated.\n",
      "(CVXPY) May 22 03:03:36 PM: Eliminator started.\n",
      "(CVXPY) May 22 03:03:36 PM: Freed constraints in eliminator : 0\n",
      "(CVXPY) May 22 03:03:36 PM: Eliminator terminated.\n",
      "(CVXPY) May 22 03:03:36 PM: Eliminator - tries                  : 2                 time                   : 0.00            \n",
      "(CVXPY) May 22 03:03:36 PM: Lin. dep.  - tries                  : 1                 time                   : 0.00            \n",
      "(CVXPY) May 22 03:03:36 PM: Lin. dep.  - number                 : 0               \n",
      "(CVXPY) May 22 03:03:36 PM: Presolve terminated. Time: 0.01    \n",
      "(CVXPY) May 22 03:03:36 PM: GP based matrix reordering started.\n",
      "(CVXPY) May 22 03:03:36 PM: GP based matrix reordering terminated.\n",
      "(CVXPY) May 22 03:03:36 PM: Problem\n",
      "(CVXPY) May 22 03:03:36 PM:   Name                   :                 \n",
      "(CVXPY) May 22 03:03:36 PM:   Objective sense        : maximize        \n",
      "(CVXPY) May 22 03:03:36 PM:   Type                   : CONIC (conic optimization problem)\n",
      "(CVXPY) May 22 03:03:36 PM:   Constraints            : 497             \n",
      "(CVXPY) May 22 03:03:36 PM:   Affine conic cons.     : 0               \n",
      "(CVXPY) May 22 03:03:36 PM:   Disjunctive cons.      : 0               \n",
      "(CVXPY) May 22 03:03:36 PM:   Cones                  : 0               \n",
      "(CVXPY) May 22 03:03:36 PM:   Scalar variables       : 797             \n",
      "(CVXPY) May 22 03:03:36 PM:   Matrix variables       : 1               \n",
      "(CVXPY) May 22 03:03:36 PM:   Integer variables      : 0               \n",
      "(CVXPY) May 22 03:03:36 PM: \n",
      "(CVXPY) May 22 03:03:36 PM: Optimizer  - threads                : 10              \n",
      "(CVXPY) May 22 03:03:36 PM: Optimizer  - solved problem         : the primal      \n",
      "(CVXPY) May 22 03:03:36 PM: Optimizer  - Constraints            : 406\n",
      "(CVXPY) May 22 03:03:36 PM: Optimizer  - Cones                  : 1\n",
      "(CVXPY) May 22 03:03:36 PM: Optimizer  - Scalar variables       : 350               conic                  : 350             \n",
      "(CVXPY) May 22 03:03:36 PM: Optimizer  - Semi-definite variables: 1                 scalarized             : 406             \n",
      "(CVXPY) May 22 03:03:36 PM: Factor     - setup time             : 0.01              dense det. time        : 0.00            \n",
      "(CVXPY) May 22 03:03:36 PM: Factor     - ML order time          : 0.00              GP order time          : 0.00            \n",
      "(CVXPY) May 22 03:03:36 PM: Factor     - nonzeros before factor : 8.26e+04          after factor           : 8.26e+04        \n",
      "(CVXPY) May 22 03:03:36 PM: Factor     - dense dim.             : 0                 flops                  : 2.31e+07        \n",
      "(CVXPY) May 22 03:03:36 PM: ITE PFEAS    DFEAS    GFEAS    PRSTATUS   POBJ              DOBJ              MU       TIME  \n",
      "(CVXPY) May 22 03:03:36 PM: 0   2.0e+00  1.0e+00  1.0e+00  0.00e+00   3.333333333e-01   3.333333333e-01   1.0e+00  0.02  \n",
      "(CVXPY) May 22 03:03:36 PM: 1   7.0e-01  3.5e-01  2.2e-01  2.78e-01   -1.263968744e-01  -9.128973737e-02  3.5e-01  0.04  \n",
      "(CVXPY) May 22 03:03:36 PM: 2   9.7e-02  4.8e-02  6.9e-03  1.15e+00   7.364980705e-02   9.677151471e-02   4.8e-02  0.04  \n",
      "(CVXPY) May 22 03:03:36 PM: 3   1.5e-02  7.5e-03  2.7e-04  1.30e+00   1.104602187e-01   1.144759428e-01   7.5e-03  0.04  \n",
      "(CVXPY) May 22 03:03:36 PM: 4   2.3e-03  1.2e-03  1.9e-05  1.24e+00   1.175915504e-01   1.180958827e-01   1.2e-03  0.05  \n",
      "(CVXPY) May 22 03:03:36 PM: 5   3.2e-04  1.6e-04  8.7e-07  1.11e+00   1.185574535e-01   1.186209938e-01   1.6e-04  0.05  \n",
      "(CVXPY) May 22 03:03:36 PM: 6   5.2e-05  2.6e-05  5.9e-08  1.30e+00   1.186640411e-01   1.186714058e-01   2.6e-05  0.05  \n",
      "(CVXPY) May 22 03:03:36 PM: 7   1.7e-05  8.5e-06  1.1e-08  1.19e+00   1.186911575e-01   1.186935632e-01   8.5e-06  0.05  \n",
      "(CVXPY) May 22 03:03:36 PM: 8   1.8e-06  9.1e-07  3.4e-10  9.46e-01   1.186986961e-01   1.186990044e-01   9.1e-07  0.05  \n",
      "(CVXPY) May 22 03:03:36 PM: 9   2.5e-07  1.2e-07  1.6e-11  9.62e-01   1.186991445e-01   1.186991916e-01   1.2e-07  0.06  \n",
      "(CVXPY) May 22 03:03:36 PM: 10  3.6e-08  1.7e-08  7.6e-13  9.69e-01   1.186991826e-01   1.186991896e-01   1.7e-08  0.06  \n",
      "(CVXPY) May 22 03:03:36 PM: Optimizer terminated. Time: 0.06    \n",
      "(CVXPY) May 22 03:03:36 PM: \n",
      "(CVXPY) May 22 03:03:36 PM: \n",
      "(CVXPY) May 22 03:03:36 PM: Interior-point solution summary\n",
      "(CVXPY) May 22 03:03:36 PM:   Problem status  : PRIMAL_AND_DUAL_FEASIBLE\n",
      "(CVXPY) May 22 03:03:36 PM:   Solution status : OPTIMAL\n",
      "(CVXPY) May 22 03:03:36 PM:   Primal.  obj: 1.1869918256e-01    nrm: 2e+00    Viol.  con: 2e-08    var: 0e+00    barvar: 0e+00  \n",
      "(CVXPY) May 22 03:03:36 PM:   Dual.    obj: 1.1869918955e-01    nrm: 5e+00    Viol.  con: 0e+00    var: 9e-09    barvar: 9e-09  \n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) May 22 03:03:36 PM: Problem status: optimal\n",
      "(CVXPY) May 22 03:03:36 PM: Optimal value: 1.187e-01\n",
      "(CVXPY) May 22 03:03:36 PM: Compilation took 5.468e-02 seconds\n",
      "(CVXPY) May 22 03:03:36 PM: Solver (including time spent in interface) took 8.813e-02 seconds\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG:functions:Achieved optimal value: 0.1187\n"
     ]
    }
   ],
   "source": [
    "config = {\n",
    "    'm2_max_degree': 6,\n",
    "    'verbose': True,\n",
    "}\n",
    "quad_problem = SimpleQuadratic(config)\n",
    "prob, M, y, mul2y, ind4, sol_time = quad_problem.solve()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Extract the $W, M$ dual SDP variables and compute the lower-bounding function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "W_sol = prob.constraints[0].dual_value\n",
    "M_sol = M.value"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "w = sympy.symbols('w')\n",
    "x = sympy.symbols('x')\n",
    "u = sympy.Matrix([x, w])\n",
    "potential = (x - w) ** 2 + (w * x) ** 2\n",
    "potential = sympy.Poly(potential, u)\n",
    "\n",
    "m_xw = []\n",
    "for i2 in quad_problem.ind2:\n",
    "    i2 = tuple([int(c) for c in i2])\n",
    "    m_xw.append(x ** i2[0] * w ** i2[1])\n",
    "m_xw = sympy.Matrix(m_xw)\n",
    "\n",
    "def round_small_coeffs(poly, epsilon):\n",
    "    # Convert the polynomial to a list of terms\n",
    "    terms = poly.as_ordered_terms()\n",
    "    new_poly = 0\n",
    "    for term in terms:\n",
    "        sign, packed_term = term.as_coeff_mul()\n",
    "        coeff = packed_term[0]\n",
    "        if abs(coeff) < epsilon:\n",
    "            continue\n",
    "        new_poly += term\n",
    "    return new_poly\n",
    "\n",
    "expr = sympy.simplify((m_xw.T @ (W_sol @ m_xw))[0])\n",
    "gamma_expr = sympy.simplify(potential - expr).as_expr()\n",
    "gamma_expr = round_small_coeffs(gamma_expr, 1e-2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/latex": [
       "$\\displaystyle - 0.123941622996464 w^{10} + 0.46212686319184 w^{8} - 0.805463337975798 w^{6} + 0.964564178348973 w^{4}$"
      ],
      "text/plain": [
       "-0.123941622996464*w**10 + 0.46212686319184*w**8 - 0.805463337975798*w**6 + 0.964564178348973*w**4"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "gamma_expr"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 1D SNL problem"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG:functions:Cluster assignments: [0 0 0 0 0]\n",
      "DEBUG:functions:Keeping 100.00% of sensor-sensor terms\n",
      "DEBUG:functions:Keeping 100.00% of sensor-anchor terms\n",
      "DEBUG:functions:Potential has 66 non-zero terms\n",
      "DEBUG:functions:Using 28 basis functions\n",
      "DEBUG:functions:Adding 0 hard-equality constraints\n",
      "DEBUG:functions:Sensors with hard-equality constraints: []\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.2.0                                    \n",
      "===============================================================================\n",
      "(CVXPY) May 22 03:03:40 PM: Your problem has 994 variables, 7 constraints, and 0 parameters.\n",
      "(CVXPY) May 22 03:03:40 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) May 22 03:03:40 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) May 22 03:03:40 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) May 22 03:03:40 PM: Compiling problem (target solver=MOSEK).\n",
      "(CVXPY) May 22 03:03:40 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> MOSEK\n",
      "(CVXPY) May 22 03:03:40 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) May 22 03:03:40 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) May 22 03:03:40 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) May 22 03:03:40 PM: Applying reduction MOSEK\n",
      "(CVXPY) May 22 03:03:40 PM: Finished problem compilation (took 5.183e-02 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) May 22 03:03:40 PM: Invoking solver MOSEK  to obtain a solution.\n",
      "\n",
      "\n",
      "(CVXPY) May 22 03:03:40 PM: Problem\n",
      "(CVXPY) May 22 03:03:40 PM:   Name                   :                 \n",
      "(CVXPY) May 22 03:03:40 PM:   Objective sense        : maximize        \n",
      "(CVXPY) May 22 03:03:40 PM:   Type                   : CONIC (conic optimization problem)\n",
      "(CVXPY) May 22 03:03:40 PM:   Constraints            : 616             \n",
      "(CVXPY) May 22 03:03:40 PM:   Affine conic cons.     : 0               \n",
      "(CVXPY) May 22 03:03:40 PM:   Disjunctive cons.      : 0               \n",
      "(CVXPY) May 22 03:03:40 PM:   Cones                  : 0               \n",
      "(CVXPY) May 22 03:03:40 PM:   Scalar variables       : 789             \n",
      "(CVXPY) May 22 03:03:40 PM:   Matrix variables       : 1               \n",
      "(CVXPY) May 22 03:03:40 PM:   Integer variables      : 0               \n",
      "(CVXPY) May 22 03:03:40 PM: \n",
      "(CVXPY) May 22 03:03:40 PM: Optimizer started.\n",
      "(CVXPY) May 22 03:03:40 PM: Presolve started.\n",
      "(CVXPY) May 22 03:03:40 PM: Eliminator started.\n",
      "(CVXPY) May 22 03:03:40 PM: Freed constraints in eliminator : 200\n",
      "(CVXPY) May 22 03:03:40 PM: Eliminator terminated.\n",
      "(CVXPY) May 22 03:03:40 PM: Linear dependency checker started.\n",
      "(CVXPY) May 22 03:03:40 PM: Linear dependency checker terminated.\n",
      "(CVXPY) May 22 03:03:40 PM: Eliminator started.\n",
      "(CVXPY) May 22 03:03:40 PM: Freed constraints in eliminator : 0\n",
      "(CVXPY) May 22 03:03:40 PM: Eliminator terminated.\n",
      "(CVXPY) May 22 03:03:40 PM: Eliminator - tries                  : 2                 time                   : 0.00            \n",
      "(CVXPY) May 22 03:03:40 PM: Lin. dep.  - tries                  : 1                 time                   : 0.00            \n",
      "(CVXPY) May 22 03:03:40 PM: Lin. dep.  - number                 : 0               \n",
      "(CVXPY) May 22 03:03:40 PM: Presolve terminated. Time: 0.00    \n",
      "(CVXPY) May 22 03:03:40 PM: GP based matrix reordering started.\n",
      "(CVXPY) May 22 03:03:40 PM: GP based matrix reordering terminated.\n",
      "(CVXPY) May 22 03:03:40 PM: Problem\n",
      "(CVXPY) May 22 03:03:40 PM:   Name                   :                 \n",
      "(CVXPY) May 22 03:03:40 PM:   Objective sense        : maximize        \n",
      "(CVXPY) May 22 03:03:40 PM:   Type                   : CONIC (conic optimization problem)\n",
      "(CVXPY) May 22 03:03:40 PM:   Constraints            : 616             \n",
      "(CVXPY) May 22 03:03:40 PM:   Affine conic cons.     : 0               \n",
      "(CVXPY) May 22 03:03:40 PM:   Disjunctive cons.      : 0               \n",
      "(CVXPY) May 22 03:03:40 PM:   Cones                  : 0               \n",
      "(CVXPY) May 22 03:03:40 PM:   Scalar variables       : 789             \n",
      "(CVXPY) May 22 03:03:40 PM:   Matrix variables       : 1               \n",
      "(CVXPY) May 22 03:03:40 PM:   Integer variables      : 0               \n",
      "(CVXPY) May 22 03:03:40 PM: \n",
      "(CVXPY) May 22 03:03:40 PM: Optimizer  - threads                : 10              \n",
      "(CVXPY) May 22 03:03:40 PM: Optimizer  - solved problem         : the primal      \n",
      "(CVXPY) May 22 03:03:40 PM: Optimizer  - Constraints            : 406\n",
      "(CVXPY) May 22 03:03:40 PM: Optimizer  - Cones                  : 1\n",
      "(CVXPY) May 22 03:03:40 PM: Optimizer  - Scalar variables       : 205               conic                  : 205             \n",
      "(CVXPY) May 22 03:03:40 PM: Optimizer  - Semi-definite variables: 1                 scalarized             : 406             \n",
      "(CVXPY) May 22 03:03:40 PM: Factor     - setup time             : 0.00              dense det. time        : 0.00            \n",
      "(CVXPY) May 22 03:03:40 PM: Factor     - ML order time          : 0.00              GP order time          : 0.00            \n",
      "(CVXPY) May 22 03:03:40 PM: Factor     - nonzeros before factor : 8.26e+04          after factor           : 8.26e+04        \n",
      "(CVXPY) May 22 03:03:40 PM: Factor     - dense dim.             : 0                 flops                  : 2.31e+07        \n",
      "(CVXPY) May 22 03:03:40 PM: ITE PFEAS    DFEAS    GFEAS    PRSTATUS   POBJ              DOBJ              MU       TIME  \n",
      "(CVXPY) May 22 03:03:40 PM: 0   3.4e+01  1.0e+00  1.0e+00  0.00e+00   3.333333333e-07   3.333333333e-07   1.0e+00  0.01  \n",
      "(CVXPY) May 22 03:03:40 PM: 1   1.1e+01  3.2e-01  5.1e-01  -9.36e-01  -2.544574838e+00  -4.092253178e+00  3.2e-01  0.03  \n",
      "(CVXPY) May 22 03:03:40 PM: 2   1.5e+00  4.3e-02  9.8e-02  -6.56e-01  -1.525740124e+01  -2.010866897e+01  4.3e-02  0.03  \n",
      "(CVXPY) May 22 03:03:40 PM: 3   2.3e-01  6.7e-03  4.7e-03  5.51e-01   -1.926119913e+00  -2.347317875e+00  6.7e-03  0.04  \n",
      "(CVXPY) May 22 03:03:40 PM: 4   2.4e-02  7.1e-04  1.3e-04  1.13e+00   -3.846191986e-01  -4.116647603e-01  7.1e-04  0.04  \n",
      "(CVXPY) May 22 03:03:40 PM: 5   3.5e-03  1.0e-04  6.3e-06  1.10e+00   -4.202992180e-02  -4.495175959e-02  1.0e-04  0.04  \n",
      "(CVXPY) May 22 03:03:40 PM: 6   6.2e-04  1.8e-05  5.4e-07  1.04e+00   -7.329449785e-03  -8.079507310e-03  1.8e-05  0.04  \n",
      "(CVXPY) May 22 03:03:40 PM: 7   1.1e-04  3.1e-06  4.2e-08  1.02e+00   -1.269974063e-03  -1.419316221e-03  3.1e-06  0.04  \n",
      "(CVXPY) May 22 03:03:40 PM: 8   1.8e-05  5.1e-07  2.7e-09  1.01e+00   -1.915916992e-04  -2.148230401e-04  5.1e-07  0.05  \n",
      "(CVXPY) May 22 03:03:40 PM: 9   4.7e-06  1.4e-07  3.5e-10  9.70e-01   -5.087684346e-05  -5.622512223e-05  1.4e-07  0.05  \n",
      "(CVXPY) May 22 03:03:40 PM: 10  8.2e-07  2.4e-08  2.5e-11  1.01e+00   -7.854428224e-06  -8.771426007e-06  2.4e-08  0.05  \n",
      "(CVXPY) May 22 03:03:40 PM: 11  1.9e-07  5.7e-09  2.9e-12  9.91e-01   -1.513587737e-06  -1.732644191e-06  5.7e-09  0.05  \n",
      "(CVXPY) May 22 03:03:40 PM: 12  3.6e-08  1.1e-09  2.4e-13  9.93e-01   -1.117927485e-07  -1.548779999e-07  1.1e-09  0.05  \n",
      "(CVXPY) May 22 03:03:40 PM: 13  5.3e-09  1.5e-10  1.4e-14  9.99e-01   2.363645465e-07   2.298513439e-07   1.6e-10  0.06  \n",
      "(CVXPY) May 22 03:03:40 PM: Optimizer terminated. Time: 0.06    \n",
      "(CVXPY) May 22 03:03:40 PM: \n",
      "(CVXPY) May 22 03:03:40 PM: \n",
      "(CVXPY) May 22 03:03:40 PM: Interior-point solution summary\n",
      "(CVXPY) May 22 03:03:40 PM:   Problem status  : PRIMAL_AND_DUAL_FEASIBLE\n",
      "(CVXPY) May 22 03:03:40 PM:   Solution status : OPTIMAL\n",
      "(CVXPY) May 22 03:03:40 PM:   Primal.  obj: 2.3636454649e-07    nrm: 4e+01    Viol.  con: 4e-08    var: 0e+00    barvar: 0e+00  \n",
      "(CVXPY) May 22 03:03:40 PM:   Dual.    obj: 2.2985134595e-07    nrm: 1e+00    Viol.  con: 0e+00    var: 1e-09    barvar: 1e-09  \n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) May 22 03:03:40 PM: Problem status: optimal\n",
      "(CVXPY) May 22 03:03:40 PM: Optimal value: 2.299e-07\n",
      "(CVXPY) May 22 03:03:40 PM: Compilation took 5.183e-02 seconds\n",
      "(CVXPY) May 22 03:03:40 PM: Solver (including time spent in interface) took 8.332e-02 seconds\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG:functions:Achieved optimal value: 0.0000\n"
     ]
    }
   ],
   "source": [
    "config = {\n",
    "    # fixed parameters\n",
    "    'n_sol_dims': 5,\n",
    "    'n_spatial_dims': 1,\n",
    "\n",
    "    'n_noise_dims': 1,\n",
    "    'n_clusters': 1,\n",
    "\n",
    "    # noise model\n",
    "    # linear: perturbs n ss and sa edges\n",
    "    # outlier: sets n ss and sa edges to Uniform [0, 2]\n",
    "    'seed': 42,\n",
    "    'noise_model': 'linear',\n",
    "    'eps': 0.001,\n",
    "    'n_perturb_per_ndim': 1,\n",
    "\n",
    "    'radius': 4.000,\n",
    "\n",
    "    'use_hard_eq': False,\n",
    "    'n_hard_eq_constr': 0,\n",
    "    'use_cluster_basis': False,\n",
    "\n",
    "    # CVXPY params\n",
    "    'verbose': True,\n",
    "}\n",
    "snl_problem = SNL(config)\n",
    "prob, M, y, mul2y, ind4, sol_time = snl_problem.solve()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Extract the sensor positions and compare them to the true positions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "M_sol = M.value"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "x_gt = snl_problem.x_gt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[-0.25091976],\n",
       "       [ 0.90142861],\n",
       "       [ 0.46398788],\n",
       "       [ 0.19731697],\n",
       "       [-0.68796272]])"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_gt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "n_sensors = snl_problem.n_sol_dims\n",
    "n_spatial_dims = snl_problem.n_spatial_dims"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "i2_inds = []\n",
    "for i in range(n_sensors * n_spatial_dims):\n",
    "    # identify i2 in ind2 where only this one is set to 1 and else 0\n",
    "    i2 = np.zeros(n_sensors * n_spatial_dims)\n",
    "    i2[i] = 1\n",
    "    i2 = i2.astype(int)\n",
    "\n",
    "    set_inds = np.all(\n",
    "        (snl_problem.ind2[:, :n_sensors * n_spatial_dims] == i2) &\n",
    "        (snl_problem.ind2[:, n_sensors * n_spatial_dims:] == 0),\n",
    "    axis=1)\n",
    "    assert np.sum(set_inds) == 1\n",
    "    i2_inds.append(np.where(set_inds)[0][0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG:matplotlib.font_manager:findfont: Matching sans\\-serif:style=normal:variant=normal:weight=normal:stretch=normal:size=10.0.\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/cmb10.ttf', name='cmb10', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXSizOneSymReg.ttf', name='STIXSizeOneSym', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXGeneralItalic.ttf', name='STIXGeneral', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXSizThreeSymReg.ttf', name='STIXSizeThreeSym', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/cmsy10.ttf', name='cmsy10', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSansMono-Oblique.ttf', name='DejaVu Sans Mono', style='oblique', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXGeneralBolIta.ttf', name='STIXGeneral', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 11.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXSizTwoSymReg.ttf', name='STIXSizeTwoSym', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSansMono-BoldOblique.ttf', name='DejaVu Sans Mono', style='oblique', variant='normal', weight=700, stretch='normal', size='scalable')) = 11.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXGeneralBol.ttf', name='STIXGeneral', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/cmtt10.ttf', name='cmtt10', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSansDisplay.ttf', name='DejaVu Sans Display', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXGeneral.ttf', name='STIXGeneral', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXSizOneSymBol.ttf', name='STIXSizeOneSym', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/cmss10.ttf', name='cmss10', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXSizFourSymReg.ttf', name='STIXSizeFourSym', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/cmr10.ttf', name='cmr10', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSerif-Italic.ttf', name='DejaVu Serif', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSans-Oblique.ttf', name='DejaVu Sans', style='oblique', variant='normal', weight=400, stretch='normal', size='scalable')) = 1.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXSizTwoSymBol.ttf', name='STIXSizeTwoSym', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXSizFourSymBol.ttf', name='STIXSizeFourSym', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSans-BoldOblique.ttf', name='DejaVu Sans', style='oblique', variant='normal', weight=700, stretch='normal', size='scalable')) = 1.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSerif-Bold.ttf', name='DejaVu Serif', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSerif-BoldItalic.ttf', name='DejaVu Serif', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 11.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSans-Bold.ttf', name='DejaVu Sans', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 0.33499999999999996\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/cmex10.ttf', name='cmex10', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSerif.ttf', name='DejaVu Serif', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSansMono.ttf', name='DejaVu Sans Mono', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXNonUni.ttf', name='STIXNonUnicode', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXNonUniBolIta.ttf', name='STIXNonUnicode', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 11.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSansMono-Bold.ttf', name='DejaVu Sans Mono', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXNonUniBol.ttf', name='STIXNonUnicode', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/cmmi10.ttf', name='cmmi10', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXSizThreeSymBol.ttf', name='STIXSizeThreeSym', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSans.ttf', name='DejaVu Sans', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 0.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXSizFiveSymReg.ttf', name='STIXSizeFiveSym', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXNonUniIta.ttf', name='STIXNonUnicode', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSerifDisplay.ttf', name='DejaVu Serif Display', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/SuperClarendon.ttc', name='Superclarendon', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Zapfino.ttf', name='Zapfino', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansWarangCiti-Regular.ttf', name='Noto Sans Warang Citi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Gujarati Sangam MN.ttc', name='Gujarati Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMendeKikakui-Regular.ttf', name='Noto Sans Mende Kikakui', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Mshtakan.ttc', name='Mshtakan', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Tahoma.ttf', name='Tahoma', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Myanmar Sangam MN.ttc', name='Myanmar Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXIntUpSmReg.otf', name='STIXIntegralsUpSm', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/NotoSansKannada.ttc', name='Noto Sans Kannada', style='normal', variant='normal', weight=900, stretch='normal', size='scalable')) = 10.525\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansNewTaiLue-Regular.ttf', name='Noto Sans New Tai Lue', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial Black.ttf', name='Arial Black', style='normal', variant='normal', weight=900, stretch='normal', size='scalable')) = 10.525\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansLimbu-Regular.ttf', name='Noto Sans Limbu', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansOldSouthArabian-Regular.ttf', name='Noto Sans Old South Arabian', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Wingdings.ttf', name='Wingdings', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansTagalog-Regular.ttf', name='Noto Sans Tagalog', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansInscriptionalParthian-Regular.ttf', name='Noto Sans Inscriptional Parthian', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Verdana.ttf', name='Verdana', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 3.6863636363636365\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial Narrow Italic.ttf', name='Arial Narrow', style='italic', variant='normal', weight=400, stretch='condensed', size='scalable')) = 11.25\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXSizFourSymReg.otf', name='STIXSizeFourSym', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Luminari.ttf', name='Luminari', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/EuphemiaCAS.ttc', name='Euphemia UCAS', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Gurmukhi MN.ttc', name='Gurmukhi MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/AppleSDGothicNeo.ttc', name='Apple SD Gothic Neo', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Wingdings 2.ttf', name='Wingdings 2', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansInscriptionalPahlavi-Regular.ttf', name='Noto Sans Inscriptional Pahlavi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/PlantagenetCherokee.ttf', name='Plantagenet Cherokee', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansYi-Regular.ttf', name='Noto Sans Yi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansOldPermic-Regular.ttf', name='Noto Sans Old Permic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansTaiTham-Regular.ttf', name='Noto Sans Tai Tham', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/PingFang.ttc', name='PingFang HK', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansTifinagh-Regular.ttf', name='Noto Sans Tifinagh', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMultani-Regular.ttf', name='Noto Sans Multani', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Skia.ttf', name='Skia', style='normal', variant='normal', weight=5, stretch='normal', size='scalable')) = 10.42525\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/SFArabic.ttf', name='.SF Arabic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Malayalam Sangam MN.ttc', name='Malayalam Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXIntDReg.otf', name='STIXIntegralsD', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansWancho-Regular.ttf', name='Noto Sans Wancho', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Papyrus.ttc', name='Papyrus', style='normal', variant='normal', weight=400, stretch='condensed', size='scalable')) = 10.25\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Bodoni 72.ttc', name='Bodoni 72', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/DevanagariMT.ttc', name='Devanagari MT', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansBuginese-Regular.ttf', name='Noto Sans Buginese', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Oriya Sangam MN.ttc', name='Oriya Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Trattatello.ttf', name='Trattatello', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Mishafi.ttf', name='Mishafi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/GujaratiMT.ttc', name='Gujarati MT', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Courier New Italic.ttf', name='Courier New', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXIntUpDBol.otf', name='STIXIntegralsUpD', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Verdana Bold Italic.ttf', name='Verdana', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 4.971363636363637\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXIntUpSmBol.otf', name='STIXIntegralsUpSm', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Geneva.ttf', name='Geneva', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 4.595454545454545\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial Bold.ttf', name='Arial', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 6.698636363636363\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/AppleMyungjo.ttf', name='AppleMyungjo', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/SukhumvitSet.ttc', name='Sukhumvit Set', style='normal', variant='normal', weight=250, stretch='normal', size='scalable')) = 10.1925\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMeroitic-Regular.ttf', name='Noto Sans Meroitic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Tahoma Bold.ttf', name='Tahoma', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Sinhala MN.ttc', name='Sinhala MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Kailasa.ttc', name='Kailasa', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansCypriot-Regular.ttf', name='Noto Sans Cypriot', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansCuneiform-Regular.ttf', name='Noto Sans Cuneiform', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Times New Roman.ttf', name='Times New Roman', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Courier New.ttf', name='Courier New', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/PartyLET-plain.ttf', name='Party LET', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Ayuthaya.ttf', name='Ayuthaya', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/HelveticaNeue.ttc', name='Helvetica Neue', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ角ゴシック W1.ttc', name='Hiragino Sans', style='normal', variant='normal', weight=200, stretch='normal', size='scalable')) = 10.24\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansThaana-Regular.ttf', name='Noto Sans Thaana', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSerifYezidi-Regular.otf', name='Noto Serif Yezidi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansPsalterPahlavi-Regular.ttf', name='Noto Sans Psalter Pahlavi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Times.ttc', name='Times', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansUgaritic-Regular.ttf', name='Noto Sans Ugaritic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Apple Symbols.ttf', name='Apple Symbols', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansManichaean-Regular.ttf', name='Noto Sans Manichaean', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Chalkboard.ttc', name='Chalkboard', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Sinhala Sangam MN.ttc', name='Sinhala Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Courier.ttc', name='Courier', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Khmer Sangam MN.ttf', name='Khmer Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Diwan Kufi.ttc', name='Diwan Kufi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansKaithi-Regular.ttf', name='Noto Sans Kaithi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansModi-Regular.ttf', name='Noto Sans Modi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Symbol.ttf', name='Symbol', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansTagbanwa-Regular.ttf', name='Noto Sans Tagbanwa', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/PTMono.ttc', name='PT Mono', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Bodoni Ornaments.ttf', name='Bodoni Ornaments', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Silom.ttf', name='Silom', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NewPeninimMT.ttc', name='New Peninim MT', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXSizThreeSymReg.otf', name='STIXSizeThreeSym', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Library/Fonts/Arial Unicode.ttf', name='Arial Unicode MS', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansCarian-Regular.ttf', name='Noto Sans Carian', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Charter.ttc', name='Charter', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial Unicode.ttf', name='Arial Unicode MS', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansTirhuta-Regular.ttf', name='Noto Sans Tirhuta', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Times New Roman Bold Italic.ttf', name='Times New Roman', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 11.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Bradley Hand Bold.ttf', name='Bradley Hand', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Georgia Italic.ttf', name='Georgia', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Comic Sans MS Bold.ttf', name='Comic Sans MS', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Apple Braille Pinpoint 6 Dot.ttf', name='Apple Braille', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/SFNSItalic.ttf', name='System Font', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Nadeem.ttc', name='Nadeem', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/AppleGothic.ttf', name='AppleGothic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXIntDBol.otf', name='STIXIntegralsD', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Brush Script.ttf', name='Brush Script MT', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Al Tarikh.ttc', name='Al Tarikh', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Muna.ttc', name='Muna', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXNonUniBolIta.otf', name='STIXNonUnicode', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 11.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Beirut.ttc', name='Beirut', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansLydian-Regular.ttf', name='Noto Sans Lydian', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Trebuchet MS Italic.ttf', name='Trebuchet MS', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/SFNSRounded.ttf', name='.SF NS Rounded', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXNonUniIta.otf', name='STIXNonUnicode', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/MarkerFelt.ttc', name='Marker Felt', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/AmericanTypewriter.ttc', name='American Typewriter', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Corsiva.ttc', name='Corsiva Hebrew', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMasaramGondi-Regular.otf', name='Noto Sans Masaram Gondi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXIntSmBol.otf', name='STIXIntegralsSm', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansSiddham-Regular.ttf', name='Noto Sans Siddham', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Songti.ttc', name='Songti SC', style='normal', variant='normal', weight=900, stretch='normal', size='scalable')) = 10.525\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Verdana Bold.ttf', name='Verdana', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 3.9713636363636367\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansPauCinHau-Regular.ttf', name='Noto Sans Pau Cin Hau', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Waseem.ttc', name='Waseem', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Rockwell.ttc', name='Rockwell', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansBassaVah-Regular.ttf', name='Noto Sans Bassa Vah', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/NotoSansMyanmar.ttc', name='Noto Sans Myanmar', style='normal', variant='normal', weight=900, stretch='normal', size='scalable')) = 10.525\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/NewYork.ttf', name='.New York', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXSizFiveSymReg.otf', name='STIXSizeFiveSym', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/BigCaslon.ttf', name='Big Caslon', style='normal', variant='normal', weight=500, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Baskerville.ttc', name='Baskerville', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ZapfDingbats.ttf', name='Zapf Dingbats', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXIntUpBol.otf', name='STIXIntegralsUp', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansOlChiki-Regular.ttf', name='Noto Sans Ol Chiki', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansHanifiRohingya-Regular.ttf', name='Noto Sans Hanifi Rohingya', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansSamaritan-Regular.ttf', name='Noto Sans Samaritan', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Myanmar MN.ttc', name='Myanmar MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/ITFDevanagari.ttc', name='ITF Devanagari', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMandaic-Regular.ttf', name='Noto Sans Mandaic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansTakri-Regular.ttf', name='Noto Sans Takri', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/GeezaPro.ttc', name='Geeza Pro', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Thonburi.ttc', name='Thonburi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansPhagsPa-Regular.ttf', name='Noto Sans PhagsPa', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansOldItalic-Regular.ttf', name='Noto Sans Old Italic', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXSizOneSymReg.otf', name='STIXSizeOneSym', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansLisu-Regular.ttf', name='Noto Sans Lisu', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansPhoenician-Regular.ttf', name='Noto Sans Phoenician', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/NewYorkItalic.ttf', name='.New York', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansAvestan-Regular.ttf', name='Noto Sans Avestan', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Diwan Thuluth.ttf', name='Diwan Thuluth', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Trebuchet MS.ttf', name='Trebuchet MS', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMongolian-Regular.ttf', name='Noto Sans Mongolian', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansVai-Regular.ttf', name='Noto Sans Vai', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Devanagari Sangam MN.ttc', name='Devanagari Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ角ゴシック W3.ttc', name='Hiragino Sans', style='normal', variant='normal', weight=300, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXSizFourSymBol.otf', name='STIXSizeFourSym', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXGeneral.otf', name='STIXGeneral', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Telugu MN.ttc', name='Telugu MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/SFNS.ttf', name='System Font', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Marion.ttc', name='Marion', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansSoraSompeng-Regular.ttf', name='Noto Sans Sora Sompeng', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/LucidaGrande.ttc', name='Lucida Grande', style='normal', variant='normal', weight=500, stretch='normal', size='scalable')) = 2.872272727272727\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Avenir Next.ttc', name='Avenir Next', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Times New Roman Italic.ttf', name='Times New Roman', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial Narrow Bold.ttf', name='Arial Narrow', style='normal', variant='normal', weight=700, stretch='condensed', size='scalable')) = 10.535\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Bodoni 72 Smallcaps Book.ttf', name='Bodoni 72 Smallcaps', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Farah.ttc', name='Farah', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Palatino.ttc', name='Palatino', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansBuhid-Regular.ttf', name='Noto Sans Buhid', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansSundanese-Regular.ttf', name='Noto Sans Sundanese', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Futura.ttc', name='Futura', style='normal', variant='normal', weight=500, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Damascus.ttc', name='Damascus', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansOldPersian-Regular.ttf', name='Noto Sans Old Persian', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial Narrow.ttf', name='Arial Narrow', style='normal', variant='normal', weight=400, stretch='condensed', size='scalable')) = 10.25\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ角ゴシック W6.ttc', name='Hiragino Sans', style='normal', variant='normal', weight=600, stretch='normal', size='scalable')) = 10.24\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ角ゴシック W9.ttc', name='Hiragino Sans', style='normal', variant='normal', weight=900, stretch='normal', size='scalable')) = 10.525\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/KohinoorTelugu.ttc', name='Kohinoor Telugu', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMeeteiMayek-Regular.ttf', name='Noto Sans Meetei Mayek', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansTaiViet-Regular.ttf', name='Noto Sans Tai Viet', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/SFNSMono.ttf', name='.SF NS Mono', style='normal', variant='normal', weight=295, stretch='normal', size='scalable')) = 10.14975\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ丸ゴ ProN W4.ttc', name='Hiragino Maru Gothic Pro', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXNonUni.otf', name='STIXNonUnicode', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXSizTwoSymReg.otf', name='STIXSizeTwoSym', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial Bold Italic.ttf', name='Arial', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 7.698636363636363\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Webdings.ttf', name='Webdings', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansSyriac-Regular.ttf', name='Noto Sans Syriac', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial Rounded Bold.ttf', name='Arial Rounded MT Bold', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Didot.ttc', name='Didot', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ角ゴシック W5.ttc', name='Hiragino Sans', style='normal', variant='normal', weight=500, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Optima.ttc', name='Optima', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/AlBayan.ttc', name='Al Bayan', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/NotoSansArmenian.ttc', name='Noto Sans Armenian', style='normal', variant='normal', weight=900, stretch='normal', size='scalable')) = 10.525\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/InaiMathi-MN.ttc', name='InaiMathi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Hiragino Sans GB.ttc', name='Hiragino Sans GB', style='normal', variant='normal', weight=300, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ArialHB.ttc', name='Arial Hebrew', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/DecoTypeNaskh.ttc', name='DecoType Naskh', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Avenir Next Condensed.ttc', name='Avenir Next Condensed', style='normal', variant='normal', weight=700, stretch='condensed', size='scalable')) = 10.535\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Tamil MN.ttc', name='Tamil MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/SFCompact.ttf', name='.SF Compact', style='normal', variant='normal', weight=1000, stretch='normal', size='scalable')) = 10.62\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Kohinoor.ttc', name='Kohinoor Devanagari', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansEgyptianHieroglyphs-Regular.ttf', name='Noto Sans Egyptian Hieroglyphs', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Noteworthy.ttc', name='Noteworthy', style='normal', variant='normal', weight=300, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/PTSerif.ttc', name='PT Serif', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Phosphate.ttc', name='Phosphate', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Gurmukhi.ttf', name='Gurmukhi MT', style='normal', variant='normal', weight=500, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansBatak-Regular.ttf', name='Noto Sans Batak', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Seravek.ttc', name='Seravek', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Courier New Bold Italic.ttf', name='Courier New', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 11.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXGeneralItalic.otf', name='STIXGeneral', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansLinearB-Regular.ttf', name='Noto Sans Linear B', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Khmer MN.ttc', name='Khmer MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ角ゴシック W2.ttc', name='Hiragino Sans', style='normal', variant='normal', weight=250, stretch='normal', size='scalable')) = 10.1925\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Georgia Bold Italic.ttf', name='Georgia', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 11.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Krungthep.ttf', name='Krungthep', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Apple Braille Outline 8 Dot.ttf', name='Apple Braille', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansAdlam-Regular.ttf', name='Noto Sans Adlam', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansOldNorthArabian-Regular.ttf', name='Noto Sans Old North Arabian', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Sathu.ttf', name='Sathu', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Copperplate.ttc', name='Copperplate', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansHanunoo-Regular.ttf', name='Noto Sans Hanunoo', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMarchen-Regular.ttf', name='Noto Sans Marchen', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansHatran-Regular.ttf', name='Noto Sans Hatran', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Courier New Bold.ttf', name='Courier New', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/NotoSerifMyanmar.ttc', name='Noto Serif Myanmar', style='normal', variant='normal', weight=900, stretch='normal', size='scalable')) = 10.525\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Mishafi Gold.ttf', name='Mishafi Gold', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansDuployan-Regular.ttf', name='Noto Sans Duployan', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Trebuchet MS Bold Italic.ttf', name='Trebuchet MS', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 11.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansBhaiksuki-Regular.ttf', name='Noto Sans Bhaiksuki', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansKhudawadi-Regular.ttf', name='Noto Sans Khudawadi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXIntUpDReg.otf', name='STIXIntegralsUpD', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Chalkduster.ttf', name='Chalkduster', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Savoye LET.ttc', name='Savoye LET', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Farisi.ttf', name='Farisi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial Italic.ttf', name='Arial', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 7.413636363636363\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansGothic-Regular.ttf', name='Noto Sans Gothic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Wingdings 3.ttf', name='Wingdings 3', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSerifAhom-Regular.ttf', name='Noto Serif Ahom', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSerifBalinese-Regular.ttf', name='Noto Serif Balinese', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansBrahmi-Regular.ttf', name='Noto Sans Brahmi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansOsage-Regular.ttf', name='Noto Sans Osage', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/SignPainter.ttc', name='SignPainter', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansCaucasianAlbanian-Regular.ttf', name='Noto Sans Caucasian Albanian', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Kefa.ttc', name='Kefa', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Kokonor.ttf', name='Kokonor', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXSizTwoSymBol.otf', name='STIXSizeTwoSym', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXVarBol.otf', name='STIXVariants', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansNabataean-Regular.ttf', name='Noto Sans Nabataean', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXIntSmReg.otf', name='STIXIntegralsSm', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansSylotiNagri-Regular.ttf', name='Noto Sans Syloti Nagri', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansNewa-Regular.ttf', name='Noto Sans Newa', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMiao-Regular.ttf', name='Noto Sans Miao', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXIntUpReg.otf', name='STIXIntegralsUp', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Hoefler Text Ornaments.ttf', name='Hoefler Text', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansRejang-Regular.ttf', name='Noto Sans Rejang', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/ChalkboardSE.ttc', name='Chalkboard SE', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/DIN Alternate Bold.ttf', name='DIN Alternate', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Lao MN.ttc', name='Lao MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansTaiLe-Regular.ttf', name='Noto Sans Tai Le', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Raanana.ttc', name='Raanana', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/MuktaMahee.ttc', name='Mukta Mahee', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansGlagolitic-Regular.ttf', name='Noto Sans Glagolitic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/KohinoorGujarati.ttc', name='Kohinoor Gujarati', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Keyboard.ttf', name='.Keyboard', style='normal', variant='normal', weight=100, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Apple Braille.ttf', name='Apple Braille', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Georgia Bold.ttf', name='Georgia', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/PTSerifCaption.ttc', name='PT Serif Caption', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Apple Chancery.ttf', name='Apple Chancery', style='normal', variant='normal', weight=0, stretch='normal', size='scalable')) = 10.43\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Georgia.ttf', name='Georgia', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansLycian-Regular.ttf', name='Noto Sans Lycian', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansKayahLi-Regular.ttf', name='Noto Sans Kayah Li', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Telugu Sangam MN.ttc', name='Telugu Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ角ゴシック W4.ttc', name='Hiragino Sans', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Andale Mono.ttf', name='Andale Mono', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansLepcha-Regular.ttf', name='Noto Sans Lepcha', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Al Nile.ttc', name='Al Nile', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXSizThreeSymBol.otf', name='STIXSizeThreeSym', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Galvji.ttc', name='Galvji', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansOldHungarian-Regular.ttf', name='Noto Sans Old Hungarian', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansPalmyrene-Regular.ttf', name='Noto Sans Palmyrene', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Menlo.ttc', name='Menlo', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Athelas.ttc', name='Athelas', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Comic Sans MS.ttf', name='Comic Sans MS', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Shree714.ttc', name='Shree Devanagari 714', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Tamil Sangam MN.ttc', name='Tamil Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Academy Engraved LET Fonts.ttf', name='Academy Engraved LET', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Sana.ttc', name='Sana', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Helvetica.ttc', name='Helvetica', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 7.322727272727273\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXGeneralBol.otf', name='STIXGeneral', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Apple Braille Pinpoint 8 Dot.ttf', name='Apple Braille', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/DIN Condensed Bold.ttf', name='DIN Condensed', style='normal', variant='normal', weight=700, stretch='condensed', size='scalable')) = 10.535\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/NotoNastaliq.ttc', name='Noto Nastaliq Urdu', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ角ゴシック W0.ttc', name='Hiragino Sans', style='normal', variant='normal', weight=100, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansOsmanya-Regular.ttf', name='Noto Sans Osmanya', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Iowan Old Style.ttc', name='Iowan Old Style', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansCham-Regular.ttf', name='Noto Sans Cham', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMahajani-Regular.ttf', name='Noto Sans Mahajani', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/KufiStandardGK.ttc', name='KufiStandardGK', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/SnellRoundhand.ttc', name='Snell Roundhand', style='normal', variant='normal', weight=500, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Bangla MN.ttc', name='Bangla MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/AquaKana.ttc', name='.Aqua Kana', style='normal', variant='normal', weight=300, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/SFCompactRounded.ttf', name='.SF Compact Rounded', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/STHeiti Medium.ttc', name='Heiti TC', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Times New Roman Bold.ttf', name='Times New Roman', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Kannada Sangam MN.ttc', name='Kannada Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Bangla Sangam MN.ttc', name='Bangla Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/PTSans.ttc', name='PT Sans', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ角ゴシック W8.ttc', name='Hiragino Sans', style='normal', variant='normal', weight=800, stretch='normal', size='scalable')) = 10.43\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Cochin.ttc', name='Cochin', style='normal', variant='normal', weight=500, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Gurmukhi Sangam MN.ttc', name='Gurmukhi Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Monaco.ttf', name='Monaco', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXNonUniBol.otf', name='STIXNonUnicode', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Malayalam MN.ttc', name='Malayalam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansOldTurkic-Regular.ttf', name='Noto Sans Old Turkic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/SFNSMonoItalic.ttf', name='.SF NS Mono', style='italic', variant='normal', weight=295, stretch='normal', size='scalable')) = 11.14975\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansCoptic-Regular.ttf', name='Noto Sans Coptic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansImperialAramaic-Regular.ttf', name='Noto Sans Imperial Aramaic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Oriya MN.ttc', name='Oriya MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Kannada MN.ttc', name='Kannada MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Lao Sangam MN.ttf', name='Lao Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXSizOneSymBol.otf', name='STIXSizeOneSym', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansElbasan-Regular.ttf', name='Noto Sans Elbasan', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial Narrow Bold Italic.ttf', name='Arial Narrow', style='italic', variant='normal', weight=700, stretch='condensed', size='scalable')) = 11.535\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansChakma-Regular.ttf', name='Noto Sans Chakma', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXVar.otf', name='STIXVariants', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansLinearA-Regular.ttf', name='Noto Sans Linear A', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansBamum-Regular.ttf', name='Noto Sans Bamum', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansKhojki-Regular.ttf', name='Noto Sans Khojki', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansSharada-Regular.ttf', name='Noto Sans Sharada', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansGunjalaGondi-Regular.otf', name='Noto Sans Gunjala Gondi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/STHeiti Light.ttc', name='Heiti TC', style='normal', variant='normal', weight=300, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMro-Regular.ttf', name='Noto Sans Mro', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Avenir.ttc', name='Avenir', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansJavanese-Regular.otf', name='Noto Sans Javanese', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Microsoft Sans Serif.ttf', name='Microsoft Sans Serif', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/SFCompactItalic.ttf', name='.SF Compact', style='italic', variant='normal', weight=1000, stretch='normal', size='scalable')) = 11.62\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansSaurashtra-Regular.ttf', name='Noto Sans Saurashtra', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Herculanum.ttf', name='Herculanum', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Baghdad.ttc', name='Baghdad', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/NotoSansOriya.ttc', name='Noto Sans Oriya', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansKharoshthi-Regular.ttf', name='Noto Sans Kharoshthi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ角ゴシック W7.ttc', name='Hiragino Sans', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXGeneralBolIta.otf', name='STIXGeneral', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 11.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/KohinoorBangla.ttc', name='Kohinoor Bangla', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Impact.ttf', name='Impact', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ明朝 ProN.ttc', name='Hiragino Mincho ProN', style='normal', variant='normal', weight=300, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial.ttf', name='Arial', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 6.413636363636363\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Apple Braille Outline 6 Dot.ttf', name='Apple Braille', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansNKo-Regular.ttf', name='Noto Sans NKo', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/GillSans.ttc', name='Gill Sans', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Bodoni 72 OS.ttc', name='Bodoni 72 Oldstyle', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Verdana Italic.ttf', name='Verdana', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 4.6863636363636365\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Hoefler Text.ttc', name='Hoefler Text', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansPahawhHmong-Regular.ttf', name='Noto Sans Pahawh Hmong', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Trebuchet MS Bold.ttf', name='Trebuchet MS', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: Matching sans\\-serif:style=normal:variant=normal:weight=normal:stretch=normal:size=10.0 to DejaVu Sans ('/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSans.ttf') with score of 0.050000.\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x3305b5a90>"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG:matplotlib.font_manager:findfont: Matching sans\\-serif:style=normal:variant=normal:weight=normal:stretch=normal:size=10.0.\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/cmb10.ttf', name='cmb10', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXSizOneSymReg.ttf', name='STIXSizeOneSym', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXGeneralItalic.ttf', name='STIXGeneral', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXSizThreeSymReg.ttf', name='STIXSizeThreeSym', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/cmsy10.ttf', name='cmsy10', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSansMono-Oblique.ttf', name='DejaVu Sans Mono', style='oblique', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXGeneralBolIta.ttf', name='STIXGeneral', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 11.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXSizTwoSymReg.ttf', name='STIXSizeTwoSym', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSansMono-BoldOblique.ttf', name='DejaVu Sans Mono', style='oblique', variant='normal', weight=700, stretch='normal', size='scalable')) = 11.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXGeneralBol.ttf', name='STIXGeneral', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/cmtt10.ttf', name='cmtt10', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSansDisplay.ttf', name='DejaVu Sans Display', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXGeneral.ttf', name='STIXGeneral', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXSizOneSymBol.ttf', name='STIXSizeOneSym', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/cmss10.ttf', name='cmss10', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXSizFourSymReg.ttf', name='STIXSizeFourSym', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/cmr10.ttf', name='cmr10', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSerif-Italic.ttf', name='DejaVu Serif', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSans-Oblique.ttf', name='DejaVu Sans', style='oblique', variant='normal', weight=400, stretch='normal', size='scalable')) = 1.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXSizTwoSymBol.ttf', name='STIXSizeTwoSym', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXSizFourSymBol.ttf', name='STIXSizeFourSym', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSans-BoldOblique.ttf', name='DejaVu Sans', style='oblique', variant='normal', weight=700, stretch='normal', size='scalable')) = 1.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSerif-Bold.ttf', name='DejaVu Serif', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSerif-BoldItalic.ttf', name='DejaVu Serif', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 11.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSans-Bold.ttf', name='DejaVu Sans', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 0.33499999999999996\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/cmex10.ttf', name='cmex10', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSerif.ttf', name='DejaVu Serif', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSansMono.ttf', name='DejaVu Sans Mono', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXNonUni.ttf', name='STIXNonUnicode', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXNonUniBolIta.ttf', name='STIXNonUnicode', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 11.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSansMono-Bold.ttf', name='DejaVu Sans Mono', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXNonUniBol.ttf', name='STIXNonUnicode', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/cmmi10.ttf', name='cmmi10', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXSizThreeSymBol.ttf', name='STIXSizeThreeSym', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSans.ttf', name='DejaVu Sans', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 0.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXSizFiveSymReg.ttf', name='STIXSizeFiveSym', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/STIXNonUniIta.ttf', name='STIXNonUnicode', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSerifDisplay.ttf', name='DejaVu Serif Display', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/SuperClarendon.ttc', name='Superclarendon', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Zapfino.ttf', name='Zapfino', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansWarangCiti-Regular.ttf', name='Noto Sans Warang Citi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Gujarati Sangam MN.ttc', name='Gujarati Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMendeKikakui-Regular.ttf', name='Noto Sans Mende Kikakui', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Mshtakan.ttc', name='Mshtakan', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Tahoma.ttf', name='Tahoma', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Myanmar Sangam MN.ttc', name='Myanmar Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXIntUpSmReg.otf', name='STIXIntegralsUpSm', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/NotoSansKannada.ttc', name='Noto Sans Kannada', style='normal', variant='normal', weight=900, stretch='normal', size='scalable')) = 10.525\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansNewTaiLue-Regular.ttf', name='Noto Sans New Tai Lue', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial Black.ttf', name='Arial Black', style='normal', variant='normal', weight=900, stretch='normal', size='scalable')) = 10.525\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansLimbu-Regular.ttf', name='Noto Sans Limbu', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansOldSouthArabian-Regular.ttf', name='Noto Sans Old South Arabian', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Wingdings.ttf', name='Wingdings', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansTagalog-Regular.ttf', name='Noto Sans Tagalog', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansInscriptionalParthian-Regular.ttf', name='Noto Sans Inscriptional Parthian', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Verdana.ttf', name='Verdana', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 3.6863636363636365\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial Narrow Italic.ttf', name='Arial Narrow', style='italic', variant='normal', weight=400, stretch='condensed', size='scalable')) = 11.25\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXSizFourSymReg.otf', name='STIXSizeFourSym', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Luminari.ttf', name='Luminari', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/EuphemiaCAS.ttc', name='Euphemia UCAS', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Gurmukhi MN.ttc', name='Gurmukhi MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/AppleSDGothicNeo.ttc', name='Apple SD Gothic Neo', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Wingdings 2.ttf', name='Wingdings 2', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansInscriptionalPahlavi-Regular.ttf', name='Noto Sans Inscriptional Pahlavi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/PlantagenetCherokee.ttf', name='Plantagenet Cherokee', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansYi-Regular.ttf', name='Noto Sans Yi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansOldPermic-Regular.ttf', name='Noto Sans Old Permic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansTaiTham-Regular.ttf', name='Noto Sans Tai Tham', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/PingFang.ttc', name='PingFang HK', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansTifinagh-Regular.ttf', name='Noto Sans Tifinagh', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMultani-Regular.ttf', name='Noto Sans Multani', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Skia.ttf', name='Skia', style='normal', variant='normal', weight=5, stretch='normal', size='scalable')) = 10.42525\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/SFArabic.ttf', name='.SF Arabic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Malayalam Sangam MN.ttc', name='Malayalam Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXIntDReg.otf', name='STIXIntegralsD', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansWancho-Regular.ttf', name='Noto Sans Wancho', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Papyrus.ttc', name='Papyrus', style='normal', variant='normal', weight=400, stretch='condensed', size='scalable')) = 10.25\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Bodoni 72.ttc', name='Bodoni 72', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/DevanagariMT.ttc', name='Devanagari MT', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansBuginese-Regular.ttf', name='Noto Sans Buginese', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Oriya Sangam MN.ttc', name='Oriya Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Trattatello.ttf', name='Trattatello', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Mishafi.ttf', name='Mishafi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/GujaratiMT.ttc', name='Gujarati MT', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Courier New Italic.ttf', name='Courier New', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXIntUpDBol.otf', name='STIXIntegralsUpD', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Verdana Bold Italic.ttf', name='Verdana', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 4.971363636363637\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXIntUpSmBol.otf', name='STIXIntegralsUpSm', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Geneva.ttf', name='Geneva', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 4.595454545454545\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial Bold.ttf', name='Arial', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 6.698636363636363\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/AppleMyungjo.ttf', name='AppleMyungjo', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/SukhumvitSet.ttc', name='Sukhumvit Set', style='normal', variant='normal', weight=250, stretch='normal', size='scalable')) = 10.1925\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMeroitic-Regular.ttf', name='Noto Sans Meroitic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Tahoma Bold.ttf', name='Tahoma', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Sinhala MN.ttc', name='Sinhala MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Kailasa.ttc', name='Kailasa', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansCypriot-Regular.ttf', name='Noto Sans Cypriot', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansCuneiform-Regular.ttf', name='Noto Sans Cuneiform', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Times New Roman.ttf', name='Times New Roman', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Courier New.ttf', name='Courier New', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/PartyLET-plain.ttf', name='Party LET', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Ayuthaya.ttf', name='Ayuthaya', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/HelveticaNeue.ttc', name='Helvetica Neue', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ角ゴシック W1.ttc', name='Hiragino Sans', style='normal', variant='normal', weight=200, stretch='normal', size='scalable')) = 10.24\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansThaana-Regular.ttf', name='Noto Sans Thaana', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSerifYezidi-Regular.otf', name='Noto Serif Yezidi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansPsalterPahlavi-Regular.ttf', name='Noto Sans Psalter Pahlavi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Times.ttc', name='Times', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansUgaritic-Regular.ttf', name='Noto Sans Ugaritic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Apple Symbols.ttf', name='Apple Symbols', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansManichaean-Regular.ttf', name='Noto Sans Manichaean', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Chalkboard.ttc', name='Chalkboard', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Sinhala Sangam MN.ttc', name='Sinhala Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Courier.ttc', name='Courier', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Khmer Sangam MN.ttf', name='Khmer Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Diwan Kufi.ttc', name='Diwan Kufi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansKaithi-Regular.ttf', name='Noto Sans Kaithi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansModi-Regular.ttf', name='Noto Sans Modi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Symbol.ttf', name='Symbol', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansTagbanwa-Regular.ttf', name='Noto Sans Tagbanwa', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/PTMono.ttc', name='PT Mono', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Bodoni Ornaments.ttf', name='Bodoni Ornaments', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Silom.ttf', name='Silom', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NewPeninimMT.ttc', name='New Peninim MT', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXSizThreeSymReg.otf', name='STIXSizeThreeSym', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/Library/Fonts/Arial Unicode.ttf', name='Arial Unicode MS', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansCarian-Regular.ttf', name='Noto Sans Carian', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Charter.ttc', name='Charter', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial Unicode.ttf', name='Arial Unicode MS', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansTirhuta-Regular.ttf', name='Noto Sans Tirhuta', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Times New Roman Bold Italic.ttf', name='Times New Roman', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 11.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Bradley Hand Bold.ttf', name='Bradley Hand', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Georgia Italic.ttf', name='Georgia', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Comic Sans MS Bold.ttf', name='Comic Sans MS', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Apple Braille Pinpoint 6 Dot.ttf', name='Apple Braille', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/SFNSItalic.ttf', name='System Font', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Nadeem.ttc', name='Nadeem', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/AppleGothic.ttf', name='AppleGothic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXIntDBol.otf', name='STIXIntegralsD', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Brush Script.ttf', name='Brush Script MT', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Al Tarikh.ttc', name='Al Tarikh', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Muna.ttc', name='Muna', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXNonUniBolIta.otf', name='STIXNonUnicode', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 11.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Beirut.ttc', name='Beirut', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansLydian-Regular.ttf', name='Noto Sans Lydian', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Trebuchet MS Italic.ttf', name='Trebuchet MS', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/SFNSRounded.ttf', name='.SF NS Rounded', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXNonUniIta.otf', name='STIXNonUnicode', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/MarkerFelt.ttc', name='Marker Felt', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/AmericanTypewriter.ttc', name='American Typewriter', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Corsiva.ttc', name='Corsiva Hebrew', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMasaramGondi-Regular.otf', name='Noto Sans Masaram Gondi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXIntSmBol.otf', name='STIXIntegralsSm', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansSiddham-Regular.ttf', name='Noto Sans Siddham', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Songti.ttc', name='Songti SC', style='normal', variant='normal', weight=900, stretch='normal', size='scalable')) = 10.525\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Verdana Bold.ttf', name='Verdana', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 3.9713636363636367\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansPauCinHau-Regular.ttf', name='Noto Sans Pau Cin Hau', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Waseem.ttc', name='Waseem', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Rockwell.ttc', name='Rockwell', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansBassaVah-Regular.ttf', name='Noto Sans Bassa Vah', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/NotoSansMyanmar.ttc', name='Noto Sans Myanmar', style='normal', variant='normal', weight=900, stretch='normal', size='scalable')) = 10.525\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/NewYork.ttf', name='.New York', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXSizFiveSymReg.otf', name='STIXSizeFiveSym', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/BigCaslon.ttf', name='Big Caslon', style='normal', variant='normal', weight=500, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Baskerville.ttc', name='Baskerville', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ZapfDingbats.ttf', name='Zapf Dingbats', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXIntUpBol.otf', name='STIXIntegralsUp', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansOlChiki-Regular.ttf', name='Noto Sans Ol Chiki', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansHanifiRohingya-Regular.ttf', name='Noto Sans Hanifi Rohingya', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansSamaritan-Regular.ttf', name='Noto Sans Samaritan', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Myanmar MN.ttc', name='Myanmar MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/ITFDevanagari.ttc', name='ITF Devanagari', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMandaic-Regular.ttf', name='Noto Sans Mandaic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansTakri-Regular.ttf', name='Noto Sans Takri', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/GeezaPro.ttc', name='Geeza Pro', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Thonburi.ttc', name='Thonburi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansPhagsPa-Regular.ttf', name='Noto Sans PhagsPa', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansOldItalic-Regular.ttf', name='Noto Sans Old Italic', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXSizOneSymReg.otf', name='STIXSizeOneSym', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansLisu-Regular.ttf', name='Noto Sans Lisu', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansPhoenician-Regular.ttf', name='Noto Sans Phoenician', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/NewYorkItalic.ttf', name='.New York', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansAvestan-Regular.ttf', name='Noto Sans Avestan', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Diwan Thuluth.ttf', name='Diwan Thuluth', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Trebuchet MS.ttf', name='Trebuchet MS', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMongolian-Regular.ttf', name='Noto Sans Mongolian', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansVai-Regular.ttf', name='Noto Sans Vai', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Devanagari Sangam MN.ttc', name='Devanagari Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ角ゴシック W3.ttc', name='Hiragino Sans', style='normal', variant='normal', weight=300, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXSizFourSymBol.otf', name='STIXSizeFourSym', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXGeneral.otf', name='STIXGeneral', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Telugu MN.ttc', name='Telugu MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/SFNS.ttf', name='System Font', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Marion.ttc', name='Marion', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansSoraSompeng-Regular.ttf', name='Noto Sans Sora Sompeng', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/LucidaGrande.ttc', name='Lucida Grande', style='normal', variant='normal', weight=500, stretch='normal', size='scalable')) = 2.872272727272727\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Avenir Next.ttc', name='Avenir Next', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Times New Roman Italic.ttf', name='Times New Roman', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial Narrow Bold.ttf', name='Arial Narrow', style='normal', variant='normal', weight=700, stretch='condensed', size='scalable')) = 10.535\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Bodoni 72 Smallcaps Book.ttf', name='Bodoni 72 Smallcaps', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Farah.ttc', name='Farah', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Palatino.ttc', name='Palatino', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansBuhid-Regular.ttf', name='Noto Sans Buhid', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansSundanese-Regular.ttf', name='Noto Sans Sundanese', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Futura.ttc', name='Futura', style='normal', variant='normal', weight=500, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Damascus.ttc', name='Damascus', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansOldPersian-Regular.ttf', name='Noto Sans Old Persian', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial Narrow.ttf', name='Arial Narrow', style='normal', variant='normal', weight=400, stretch='condensed', size='scalable')) = 10.25\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ角ゴシック W6.ttc', name='Hiragino Sans', style='normal', variant='normal', weight=600, stretch='normal', size='scalable')) = 10.24\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ角ゴシック W9.ttc', name='Hiragino Sans', style='normal', variant='normal', weight=900, stretch='normal', size='scalable')) = 10.525\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/KohinoorTelugu.ttc', name='Kohinoor Telugu', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMeeteiMayek-Regular.ttf', name='Noto Sans Meetei Mayek', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansTaiViet-Regular.ttf', name='Noto Sans Tai Viet', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/SFNSMono.ttf', name='.SF NS Mono', style='normal', variant='normal', weight=295, stretch='normal', size='scalable')) = 10.14975\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ丸ゴ ProN W4.ttc', name='Hiragino Maru Gothic Pro', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXNonUni.otf', name='STIXNonUnicode', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXSizTwoSymReg.otf', name='STIXSizeTwoSym', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial Bold Italic.ttf', name='Arial', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 7.698636363636363\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Webdings.ttf', name='Webdings', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansSyriac-Regular.ttf', name='Noto Sans Syriac', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial Rounded Bold.ttf', name='Arial Rounded MT Bold', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Didot.ttc', name='Didot', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ角ゴシック W5.ttc', name='Hiragino Sans', style='normal', variant='normal', weight=500, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Optima.ttc', name='Optima', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/AlBayan.ttc', name='Al Bayan', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/NotoSansArmenian.ttc', name='Noto Sans Armenian', style='normal', variant='normal', weight=900, stretch='normal', size='scalable')) = 10.525\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/InaiMathi-MN.ttc', name='InaiMathi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Hiragino Sans GB.ttc', name='Hiragino Sans GB', style='normal', variant='normal', weight=300, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ArialHB.ttc', name='Arial Hebrew', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/DecoTypeNaskh.ttc', name='DecoType Naskh', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Avenir Next Condensed.ttc', name='Avenir Next Condensed', style='normal', variant='normal', weight=700, stretch='condensed', size='scalable')) = 10.535\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Tamil MN.ttc', name='Tamil MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/SFCompact.ttf', name='.SF Compact', style='normal', variant='normal', weight=1000, stretch='normal', size='scalable')) = 10.62\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Kohinoor.ttc', name='Kohinoor Devanagari', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansEgyptianHieroglyphs-Regular.ttf', name='Noto Sans Egyptian Hieroglyphs', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Noteworthy.ttc', name='Noteworthy', style='normal', variant='normal', weight=300, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/PTSerif.ttc', name='PT Serif', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Phosphate.ttc', name='Phosphate', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Gurmukhi.ttf', name='Gurmukhi MT', style='normal', variant='normal', weight=500, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansBatak-Regular.ttf', name='Noto Sans Batak', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Seravek.ttc', name='Seravek', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Courier New Bold Italic.ttf', name='Courier New', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 11.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXGeneralItalic.otf', name='STIXGeneral', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 11.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansLinearB-Regular.ttf', name='Noto Sans Linear B', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Khmer MN.ttc', name='Khmer MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ角ゴシック W2.ttc', name='Hiragino Sans', style='normal', variant='normal', weight=250, stretch='normal', size='scalable')) = 10.1925\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Georgia Bold Italic.ttf', name='Georgia', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 11.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Krungthep.ttf', name='Krungthep', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Apple Braille Outline 8 Dot.ttf', name='Apple Braille', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansAdlam-Regular.ttf', name='Noto Sans Adlam', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansOldNorthArabian-Regular.ttf', name='Noto Sans Old North Arabian', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Sathu.ttf', name='Sathu', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Copperplate.ttc', name='Copperplate', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansHanunoo-Regular.ttf', name='Noto Sans Hanunoo', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMarchen-Regular.ttf', name='Noto Sans Marchen', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansHatran-Regular.ttf', name='Noto Sans Hatran', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Courier New Bold.ttf', name='Courier New', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/NotoSerifMyanmar.ttc', name='Noto Serif Myanmar', style='normal', variant='normal', weight=900, stretch='normal', size='scalable')) = 10.525\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Mishafi Gold.ttf', name='Mishafi Gold', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansDuployan-Regular.ttf', name='Noto Sans Duployan', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Trebuchet MS Bold Italic.ttf', name='Trebuchet MS', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 11.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansBhaiksuki-Regular.ttf', name='Noto Sans Bhaiksuki', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansKhudawadi-Regular.ttf', name='Noto Sans Khudawadi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXIntUpDReg.otf', name='STIXIntegralsUpD', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Chalkduster.ttf', name='Chalkduster', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Savoye LET.ttc', name='Savoye LET', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Farisi.ttf', name='Farisi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial Italic.ttf', name='Arial', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 7.413636363636363\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansGothic-Regular.ttf', name='Noto Sans Gothic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Wingdings 3.ttf', name='Wingdings 3', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSerifAhom-Regular.ttf', name='Noto Serif Ahom', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSerifBalinese-Regular.ttf', name='Noto Serif Balinese', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansBrahmi-Regular.ttf', name='Noto Sans Brahmi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansOsage-Regular.ttf', name='Noto Sans Osage', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/SignPainter.ttc', name='SignPainter', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansCaucasianAlbanian-Regular.ttf', name='Noto Sans Caucasian Albanian', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Kefa.ttc', name='Kefa', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Kokonor.ttf', name='Kokonor', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXSizTwoSymBol.otf', name='STIXSizeTwoSym', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXVarBol.otf', name='STIXVariants', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansNabataean-Regular.ttf', name='Noto Sans Nabataean', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXIntSmReg.otf', name='STIXIntegralsSm', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansSylotiNagri-Regular.ttf', name='Noto Sans Syloti Nagri', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansNewa-Regular.ttf', name='Noto Sans Newa', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMiao-Regular.ttf', name='Noto Sans Miao', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXIntUpReg.otf', name='STIXIntegralsUp', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Hoefler Text Ornaments.ttf', name='Hoefler Text', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansRejang-Regular.ttf', name='Noto Sans Rejang', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/ChalkboardSE.ttc', name='Chalkboard SE', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/DIN Alternate Bold.ttf', name='DIN Alternate', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Lao MN.ttc', name='Lao MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansTaiLe-Regular.ttf', name='Noto Sans Tai Le', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Raanana.ttc', name='Raanana', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/MuktaMahee.ttc', name='Mukta Mahee', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansGlagolitic-Regular.ttf', name='Noto Sans Glagolitic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/KohinoorGujarati.ttc', name='Kohinoor Gujarati', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Keyboard.ttf', name='.Keyboard', style='normal', variant='normal', weight=100, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Apple Braille.ttf', name='Apple Braille', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Georgia Bold.ttf', name='Georgia', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/PTSerifCaption.ttc', name='PT Serif Caption', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Apple Chancery.ttf', name='Apple Chancery', style='normal', variant='normal', weight=0, stretch='normal', size='scalable')) = 10.43\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Georgia.ttf', name='Georgia', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansLycian-Regular.ttf', name='Noto Sans Lycian', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansKayahLi-Regular.ttf', name='Noto Sans Kayah Li', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Telugu Sangam MN.ttc', name='Telugu Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ角ゴシック W4.ttc', name='Hiragino Sans', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Andale Mono.ttf', name='Andale Mono', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansLepcha-Regular.ttf', name='Noto Sans Lepcha', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Al Nile.ttc', name='Al Nile', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXSizThreeSymBol.otf', name='STIXSizeThreeSym', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Galvji.ttc', name='Galvji', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansOldHungarian-Regular.ttf', name='Noto Sans Old Hungarian', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansPalmyrene-Regular.ttf', name='Noto Sans Palmyrene', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Menlo.ttc', name='Menlo', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Athelas.ttc', name='Athelas', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Comic Sans MS.ttf', name='Comic Sans MS', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Shree714.ttc', name='Shree Devanagari 714', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Tamil Sangam MN.ttc', name='Tamil Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Academy Engraved LET Fonts.ttf', name='Academy Engraved LET', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Sana.ttc', name='Sana', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Helvetica.ttc', name='Helvetica', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 7.322727272727273\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXGeneralBol.otf', name='STIXGeneral', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Apple Braille Pinpoint 8 Dot.ttf', name='Apple Braille', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/DIN Condensed Bold.ttf', name='DIN Condensed', style='normal', variant='normal', weight=700, stretch='condensed', size='scalable')) = 10.535\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/NotoNastaliq.ttc', name='Noto Nastaliq Urdu', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ角ゴシック W0.ttc', name='Hiragino Sans', style='normal', variant='normal', weight=100, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansOsmanya-Regular.ttf', name='Noto Sans Osmanya', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Iowan Old Style.ttc', name='Iowan Old Style', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansCham-Regular.ttf', name='Noto Sans Cham', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMahajani-Regular.ttf', name='Noto Sans Mahajani', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/KufiStandardGK.ttc', name='KufiStandardGK', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/SnellRoundhand.ttc', name='Snell Roundhand', style='normal', variant='normal', weight=500, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Bangla MN.ttc', name='Bangla MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/AquaKana.ttc', name='.Aqua Kana', style='normal', variant='normal', weight=300, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/SFCompactRounded.ttf', name='.SF Compact Rounded', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/STHeiti Medium.ttc', name='Heiti TC', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Times New Roman Bold.ttf', name='Times New Roman', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Kannada Sangam MN.ttc', name='Kannada Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Bangla Sangam MN.ttc', name='Bangla Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/PTSans.ttc', name='PT Sans', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ角ゴシック W8.ttc', name='Hiragino Sans', style='normal', variant='normal', weight=800, stretch='normal', size='scalable')) = 10.43\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Cochin.ttc', name='Cochin', style='normal', variant='normal', weight=500, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Gurmukhi Sangam MN.ttc', name='Gurmukhi Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Monaco.ttf', name='Monaco', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXNonUniBol.otf', name='STIXNonUnicode', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Malayalam MN.ttc', name='Malayalam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansOldTurkic-Regular.ttf', name='Noto Sans Old Turkic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/SFNSMonoItalic.ttf', name='.SF NS Mono', style='italic', variant='normal', weight=295, stretch='normal', size='scalable')) = 11.14975\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansCoptic-Regular.ttf', name='Noto Sans Coptic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansImperialAramaic-Regular.ttf', name='Noto Sans Imperial Aramaic', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Oriya MN.ttc', name='Oriya MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Kannada MN.ttc', name='Kannada MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Lao Sangam MN.ttf', name='Lao Sangam MN', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXSizOneSymBol.otf', name='STIXSizeOneSym', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansElbasan-Regular.ttf', name='Noto Sans Elbasan', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial Narrow Bold Italic.ttf', name='Arial Narrow', style='italic', variant='normal', weight=700, stretch='condensed', size='scalable')) = 11.535\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansChakma-Regular.ttf', name='Noto Sans Chakma', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXVar.otf', name='STIXVariants', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansLinearA-Regular.ttf', name='Noto Sans Linear A', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansBamum-Regular.ttf', name='Noto Sans Bamum', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansKhojki-Regular.ttf', name='Noto Sans Khojki', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansSharada-Regular.ttf', name='Noto Sans Sharada', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansGunjalaGondi-Regular.otf', name='Noto Sans Gunjala Gondi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/STHeiti Light.ttc', name='Heiti TC', style='normal', variant='normal', weight=300, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansMro-Regular.ttf', name='Noto Sans Mro', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Avenir.ttc', name='Avenir', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansJavanese-Regular.otf', name='Noto Sans Javanese', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Microsoft Sans Serif.ttf', name='Microsoft Sans Serif', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/SFCompactItalic.ttf', name='.SF Compact', style='italic', variant='normal', weight=1000, stretch='normal', size='scalable')) = 11.62\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansSaurashtra-Regular.ttf', name='Noto Sans Saurashtra', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Herculanum.ttf', name='Herculanum', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Baghdad.ttc', name='Baghdad', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/NotoSansOriya.ttc', name='Noto Sans Oriya', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansKharoshthi-Regular.ttf', name='Noto Sans Kharoshthi', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ角ゴシック W7.ttc', name='Hiragino Sans', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/STIXGeneralBolIta.otf', name='STIXGeneral', style='italic', variant='normal', weight=700, stretch='normal', size='scalable')) = 11.335\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/KohinoorBangla.ttc', name='Kohinoor Bangla', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Impact.ttf', name='Impact', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/ヒラギノ明朝 ProN.ttc', name='Hiragino Mincho ProN', style='normal', variant='normal', weight=300, stretch='normal', size='scalable')) = 10.145\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Arial.ttf', name='Arial', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 6.413636363636363\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Apple Braille Outline 6 Dot.ttf', name='Apple Braille', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansNKo-Regular.ttf', name='Noto Sans NKo', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/GillSans.ttc', name='Gill Sans', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Bodoni 72 OS.ttc', name='Bodoni 72 Oldstyle', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Verdana Italic.ttf', name='Verdana', style='italic', variant='normal', weight=400, stretch='normal', size='scalable')) = 4.6863636363636365\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Hoefler Text.ttc', name='Hoefler Text', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/NotoSansPahawhHmong-Regular.ttf', name='Noto Sans Pahawh Hmong', style='normal', variant='normal', weight=400, stretch='normal', size='scalable')) = 10.05\n",
      "DEBUG:matplotlib.font_manager:findfont: score(FontEntry(fname='/System/Library/Fonts/Supplemental/Trebuchet MS Bold.ttf', name='Trebuchet MS', style='normal', variant='normal', weight=700, stretch='normal', size='scalable')) = 10.335\n",
      "DEBUG:matplotlib.font_manager:findfont: Matching sans\\-serif:style=normal:variant=normal:weight=normal:stretch=normal:size=10.0 to DejaVu Sans ('/Users/chen/miniconda3/lib/python3.8/site-packages/matplotlib/mpl-data/fonts/ttf/DejaVuSans.ttf') with score of 0.050000.\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.scatter(x_gt.flatten(), M_sol[0, i2_inds])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 2D SNL problem"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG:functions:Cluster assignments: [0 0 0 0 0]\n",
      "DEBUG:functions:Keeping 100.00% of sensor-sensor terms\n",
      "DEBUG:functions:Keeping 93.33% of sensor-anchor terms\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG:functions:Potential has 219 non-zero terms\n",
      "DEBUG:functions:Using 78 basis functions\n",
      "DEBUG:functions:Adding 0 hard-equality constraints\n",
      "DEBUG:functions:Sensors with hard-equality constraints: []\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "===============================================================================\n",
      "                                     CVXPY                                     \n",
      "                                     v1.2.0                                    \n",
      "===============================================================================\n",
      "(CVXPY) May 22 03:03:41 PM: Your problem has 7449 variables, 7 constraints, and 0 parameters.\n",
      "(CVXPY) May 22 03:03:41 PM: It is compliant with the following grammars: DCP, DQCP\n",
      "(CVXPY) May 22 03:03:41 PM: (If you need to solve this problem multiple times, but with different data, consider using parameters.)\n",
      "(CVXPY) May 22 03:03:41 PM: CVXPY will first compile your problem; then, it will invoke a numerical solver to obtain a solution.\n",
      "-------------------------------------------------------------------------------\n",
      "                                  Compilation                                  \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) May 22 03:03:41 PM: Compiling problem (target solver=MOSEK).\n",
      "(CVXPY) May 22 03:03:41 PM: Reduction chain: Dcp2Cone -> CvxAttr2Constr -> ConeMatrixStuffing -> MOSEK\n",
      "(CVXPY) May 22 03:03:41 PM: Applying reduction Dcp2Cone\n",
      "(CVXPY) May 22 03:03:41 PM: Applying reduction CvxAttr2Constr\n",
      "(CVXPY) May 22 03:03:41 PM: Applying reduction ConeMatrixStuffing\n",
      "(CVXPY) May 22 03:03:41 PM: Applying reduction MOSEK\n",
      "(CVXPY) May 22 03:03:42 PM: Finished problem compilation (took 1.067e+00 seconds).\n",
      "-------------------------------------------------------------------------------\n",
      "                                Numerical solver                               \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) May 22 03:03:42 PM: Invoking solver MOSEK  to obtain a solution.\n",
      "\n",
      "\n",
      "(CVXPY) May 22 03:03:43 PM: Problem\n",
      "(CVXPY) May 22 03:03:43 PM:   Name                   :                 \n",
      "(CVXPY) May 22 03:03:43 PM:   Objective sense        : maximize        \n",
      "(CVXPY) May 22 03:03:43 PM:   Type                   : CONIC (conic optimization problem)\n",
      "(CVXPY) May 22 03:03:43 PM:   Constraints            : 4446            \n",
      "(CVXPY) May 22 03:03:43 PM:   Affine conic cons.     : 0               \n",
      "(CVXPY) May 22 03:03:43 PM:   Disjunctive cons.      : 0               \n",
      "(CVXPY) May 22 03:03:43 PM:   Cones                  : 0               \n",
      "(CVXPY) May 22 03:03:43 PM:   Scalar variables       : 6089            \n",
      "(CVXPY) May 22 03:03:43 PM:   Matrix variables       : 1               \n",
      "(CVXPY) May 22 03:03:43 PM:   Integer variables      : 0               \n",
      "(CVXPY) May 22 03:03:43 PM: \n",
      "(CVXPY) May 22 03:03:43 PM: Optimizer started.\n",
      "(CVXPY) May 22 03:03:43 PM: Presolve started.\n",
      "(CVXPY) May 22 03:03:43 PM: Eliminator started.\n",
      "(CVXPY) May 22 03:03:43 PM: Freed constraints in eliminator : 1350\n",
      "(CVXPY) May 22 03:03:43 PM: Eliminator terminated.\n",
      "(CVXPY) May 22 03:03:43 PM: Linear dependency checker started.\n",
      "(CVXPY) May 22 03:03:43 PM: Linear dependency checker terminated.\n",
      "(CVXPY) May 22 03:03:43 PM: Eliminator started.\n",
      "(CVXPY) May 22 03:03:43 PM: Freed constraints in eliminator : 0\n",
      "(CVXPY) May 22 03:03:43 PM: Eliminator terminated.\n",
      "(CVXPY) May 22 03:03:43 PM: Eliminator - tries                  : 2                 time                   : 0.00            \n",
      "(CVXPY) May 22 03:03:43 PM: Lin. dep.  - tries                  : 1                 time                   : 0.00            \n",
      "(CVXPY) May 22 03:03:43 PM: Lin. dep.  - number                 : 0               \n",
      "(CVXPY) May 22 03:03:43 PM: Presolve terminated. Time: 0.01    \n",
      "(CVXPY) May 22 03:03:43 PM: GP based matrix reordering started.\n",
      "(CVXPY) May 22 03:03:43 PM: GP based matrix reordering terminated.\n",
      "(CVXPY) May 22 03:03:43 PM: Problem\n",
      "(CVXPY) May 22 03:03:43 PM:   Name                   :                 \n",
      "(CVXPY) May 22 03:03:43 PM:   Objective sense        : maximize        \n",
      "(CVXPY) May 22 03:03:43 PM:   Type                   : CONIC (conic optimization problem)\n",
      "(CVXPY) May 22 03:03:43 PM:   Constraints            : 4446            \n",
      "(CVXPY) May 22 03:03:43 PM:   Affine conic cons.     : 0               \n",
      "(CVXPY) May 22 03:03:43 PM:   Disjunctive cons.      : 0               \n",
      "(CVXPY) May 22 03:03:43 PM:   Cones                  : 0               \n",
      "(CVXPY) May 22 03:03:43 PM:   Scalar variables       : 6089            \n",
      "(CVXPY) May 22 03:03:43 PM:   Matrix variables       : 1               \n",
      "(CVXPY) May 22 03:03:43 PM:   Integer variables      : 0               \n",
      "(CVXPY) May 22 03:03:43 PM: \n",
      "(CVXPY) May 22 03:03:43 PM: Optimizer  - threads                : 10              \n",
      "(CVXPY) May 22 03:03:43 PM: Optimizer  - solved problem         : the primal      \n",
      "(CVXPY) May 22 03:03:43 PM: Optimizer  - Constraints            : 3081\n",
      "(CVXPY) May 22 03:03:43 PM: Optimizer  - Cones                  : 1\n",
      "(CVXPY) May 22 03:03:43 PM: Optimizer  - Scalar variables       : 1725              conic                  : 1725            \n",
      "(CVXPY) May 22 03:03:43 PM: Optimizer  - Semi-definite variables: 1                 scalarized             : 3081            \n",
      "(CVXPY) May 22 03:03:43 PM: Factor     - setup time             : 0.21              dense det. time        : 0.10            \n",
      "(CVXPY) May 22 03:03:43 PM: Factor     - ML order time          : 0.00              GP order time          : 0.03            \n",
      "(CVXPY) May 22 03:03:43 PM: Factor     - nonzeros before factor : 4.75e+06          after factor           : 4.75e+06        \n",
      "(CVXPY) May 22 03:03:43 PM: Factor     - dense dim.             : 0                 flops                  : 9.80e+09        \n",
      "(CVXPY) May 22 03:03:43 PM: ITE PFEAS    DFEAS    GFEAS    PRSTATUS   POBJ              DOBJ              MU       TIME  \n",
      "(CVXPY) May 22 03:03:43 PM: 0   7.4e+01  1.0e+00  1.0e+00  0.00e+00   3.333333333e-03   3.333333333e-03   1.0e+00  0.22  \n",
      "(CVXPY) May 22 03:03:43 PM: 1   5.1e+01  7.0e-01  8.2e-01  -9.60e-01  -2.783643191e-01  -6.882877062e-01  7.0e-01  0.30  \n",
      "(CVXPY) May 22 03:03:43 PM: 2   2.5e+01  3.3e-01  5.2e-01  -8.85e-01  -7.140633716e+00  -8.634942624e+00  3.3e-01  0.36  \n",
      "(CVXPY) May 22 03:03:43 PM: 3   2.0e+00  2.7e-02  5.1e-02  -5.94e-01  -1.867450094e+01  -2.205545438e+01  2.7e-02  0.45  \n",
      "(CVXPY) May 22 03:03:44 PM: 4   1.6e-01  2.2e-03  2.3e-04  9.72e-01   -6.991911114e-01  -6.934159332e-01  2.2e-03  0.57  \n",
      "(CVXPY) May 22 03:03:44 PM: 5   1.2e-02  1.6e-04  8.2e-06  1.04e+00   -1.284901510e-01  -1.298000856e-01  1.6e-04  0.65  \n",
      "(CVXPY) May 22 03:03:44 PM: 6   2.0e-03  2.7e-05  9.1e-07  1.05e+00   -1.658467635e-02  -1.755993950e-02  2.7e-05  0.72  \n",
      "(CVXPY) May 22 03:03:44 PM: 7   3.2e-04  4.4e-06  6.1e-08  1.06e+00   -7.614997060e-04  -9.292012352e-04  4.4e-06  0.79  \n",
      "(CVXPY) May 22 03:03:44 PM: 8   4.5e-05  6.1e-07  2.8e-09  1.04e+00   1.803144156e-03   1.786606475e-03   6.1e-07  0.87  \n",
      "(CVXPY) May 22 03:03:44 PM: 9   2.5e-05  3.4e-07  1.2e-09  1.03e+00   2.016221061e-03   2.005717431e-03   3.4e-07  0.93  \n",
      "(CVXPY) May 22 03:03:44 PM: 10  3.6e-06  4.9e-08  6.6e-11  9.81e-01   2.124117257e-03   2.122678555e-03   4.9e-08  1.02  \n",
      "(CVXPY) May 22 03:03:44 PM: 11  2.1e-06  2.8e-08  3.0e-11  1.08e+00   2.142758115e-03   2.141849574e-03   2.8e-08  1.08  \n",
      "(CVXPY) May 22 03:03:44 PM: 12  1.1e-06  1.5e-08  1.2e-11  1.08e+00   2.165877994e-03   2.165374606e-03   1.5e-08  1.14  \n",
      "(CVXPY) May 22 03:03:44 PM: 13  7.5e-08  1.3e-09  1.7e-13  1.03e+00   2.174623329e-03   2.174613140e-03   1.2e-09  1.22  \n",
      "(CVXPY) May 22 03:03:44 PM: 14  1.2e-08  4.1e-10  1.3e-14  1.00e+00   2.175802440e-03   2.175799321e-03   1.8e-10  1.31  \n",
      "(CVXPY) May 22 03:03:44 PM: Optimizer terminated. Time: 1.32    \n",
      "(CVXPY) May 22 03:03:44 PM: \n",
      "(CVXPY) May 22 03:03:44 PM: \n",
      "(CVXPY) May 22 03:03:44 PM: Interior-point solution summary\n",
      "(CVXPY) May 22 03:03:44 PM:   Problem status  : PRIMAL_AND_DUAL_FEASIBLE\n",
      "(CVXPY) May 22 03:03:44 PM:   Solution status : OPTIMAL\n",
      "(CVXPY) May 22 03:03:44 PM:   Primal.  obj: 2.1758024397e-03    nrm: 7e+01    Viol.  con: 8e-08    var: 0e+00    barvar: 0e+00  \n",
      "(CVXPY) May 22 03:03:44 PM:   Dual.    obj: 2.1757993214e-03    nrm: 1e+00    Viol.  con: 0e+00    var: 1e-09    barvar: 3e-09  \n",
      "-------------------------------------------------------------------------------\n",
      "                                    Summary                                    \n",
      "-------------------------------------------------------------------------------\n",
      "(CVXPY) May 22 03:03:44 PM: Problem status: optimal\n",
      "(CVXPY) May 22 03:03:44 PM: Optimal value: 2.176e-03\n",
      "(CVXPY) May 22 03:03:44 PM: Compilation took 1.067e+00 seconds\n",
      "(CVXPY) May 22 03:03:44 PM: Solver (including time spent in interface) took 1.869e+00 seconds\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "DEBUG:functions:Achieved optimal value: 0.0022\n"
     ]
    }
   ],
   "source": [
    "config = {\n",
    "    # fixed parameters\n",
    "    'n_sol_dims': 5,\n",
    "    'n_spatial_dims': 2,\n",
    "\n",
    "    'n_noise_dims': 1,\n",
    "    'n_clusters': 1,\n",
    "\n",
    "    # noise model\n",
    "    # linear: perturbs n ss and sa edges\n",
    "    # outlier: sets n ss and sa edges to Uniform [0, 2]\n",
    "    'seed': 42,\n",
    "    'noise_model': 'linear',\n",
    "    'eps': 0.100,\n",
    "    'n_perturb_per_ndim': 1,\n",
    "\n",
    "    'radius': 4.000,\n",
    "\n",
    "    'use_hard_eq': False,\n",
    "    'n_hard_eq_constr': 0,\n",
    "    'use_cluster_basis': False,\n",
    "\n",
    "    # CVXPY params\n",
    "    'verbose': True,\n",
    "}\n",
    "snl_problem = SNL(config)\n",
    "prob, M, y, mul2y, ind4, sol_time = snl_problem.solve()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Extract the sensor positions and compare them to the true positions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "M_sol = M.value"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "x_gt = snl_problem.x_gt\n",
    "a_true_np = snl_problem.a_true_np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[-0.25091976,  0.90142861],\n",
       "       [ 0.46398788,  0.19731697],\n",
       "       [-0.68796272, -0.68801096],\n",
       "       [-0.88383278,  0.73235229],\n",
       "       [ 0.20223002,  0.41614516]])"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_gt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "n_sol_dims = snl_problem.n_sol_dims\n",
    "n_spatial_dims = snl_problem.n_spatial_dims"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "# extract our solutions and check that they're reasonable\n",
    "M = M_sol\n",
    "ind2 = snl_problem.ind2\n",
    "\n",
    "mus = np.zeros((n_sol_dims, n_spatial_dims))\n",
    "stds = np.zeros((n_sol_dims, n_spatial_dims))\n",
    "for s_i in range(n_sol_dims):\n",
    "    for sd in range(n_spatial_dims):\n",
    "        k = s_i * n_spatial_dims + sd\n",
    "        inds_ex_k = np.array(list(set(np.arange(ind2.shape[1])).difference(set([k]))))\n",
    "\n",
    "        try:\n",
    "            i1 = np.where((ind2[:, k] == 1) & (ind2[:, inds_ex_k].sum(axis=1) == 0))[0][0]\n",
    "            i2 = np.where((ind2[:, k] == 2) & (ind2[:, inds_ex_k].sum(axis=1) == 0))[0][0]\n",
    "            mu = M[0, i1]\n",
    "            var = M[0, i2] - mu ** 2\n",
    "            if var < 0:\n",
    "                assert np.abs(var) <= 1e-6\n",
    "                var = 0\n",
    "            std = np.sqrt(var)\n",
    "        except:\n",
    "            print('Failed for sensor {} dim {}'.format(s_i, sd))\n",
    "            mu = 0.0\n",
    "            std = 0.0\n",
    "\n",
    "        mus[s_i, sd] = mu\n",
    "        stds[s_i, sd] = std\n",
    "stds = np.clip(stds, 1e-3, np.inf)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x342372fa0>"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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IiLCdJ3ff/+9NTEx0e7+y5cvW4OCgoxann32WdPnyElUVJTRf1RUlKljjxw5Yj148KD1yJEjBV4Xsvfrr79aq1SpYvyd3fgYNWpUpp/f48ePZ+mjVq1aVknWYcOGWT///HOrq6trln4yevvtt60uLi52z1mmTBnrwoULs6138+bNRrvNmzc7fG2OfucmTZpk7I+JibE2a9bMbj3BwcHW1NRUu+eZMWOG3dfj5eVlXbdunbVTp05WSdZOnTo5rDmn1+LokfF1Zvw7Cw8PtzZv3txh+5z+fbKx9zryU9+BAwes9913n93j2rZta42Pj8/T981qtVpfeOGFHGurVKmS3ePfeOONbH+mbQ+LxWJ97bXXsj0248/rxo0brUOGDLHbT7169axnzpzJtp/ly5cb/z84euzfvz/Lsampqdann37a4XHly5e3btiwIcfX8P3331vvv//+LMcPGzbMaP/+++87/P22Pa5cueLgby17/B8BFJz8vF8rDk65/KvNzJkz1b59e129elVBQUGaMGGCAgMDdfXqVS1dutRYWalBgwYaM2aM6f537dqlfv36KTk5WaVLl9YHH3yg69ev68CBA3aPqVmzZpalXqdOnaqhQ4eqf//+6tChg+rWrStvb+8sN6STpIYNG+b46SMkJSZKnp65f96JXLx4Ud27dzc+jRw6dKgeeughValSRUePHtXMmTM1a9Ys/fbbb7nqLzw8XF9//bX8/f01duxYtWrVSqmpqdq+fbvR5rPPPtOECRMkSVWqVNFLL72k9u3bKzU1VRs3btT06dOVkJCgkJAQVa5cWT169Cj4F36D/v3769ChQ3ruuecUHBysihUr6vDhw3rzzTd16NAhffvtt5o9e7Yef/zxLMd+8803Gjt2rKT0FdFeeukl49P6//73v3r33Xc1ZMgQValSJV817t+/X6dPn1a3bt0kSW+99Zb69OmTqU3VqlWzPfaxxx7T/v379cgjj+jBBx+Ur6+vTp48adz3piDkp75Ro0Zp165dGjZsmAYOHGjU9+6772rnzp0KCwvTW2+9pXfeecd0Xd99950++OADSVLTpk315JNPKiAgQOXLl9elS5cUERGhH3/8UTt37sz2+Ndee824Aeg999yjRx99VHfccYdKly6tw4cP65NPPtHOnTv1xhtvqHLlynr22Wft1vLaa69px44d6tu3rx555BHVqlVLZ8+e1aeffqq1a9fq6NGjeuGFF7RkyZJMx509e1bDhw9XcnKyqlatqmeeecYYWUpKStIff/yhbdu2aeXKldme9+WXX9ann34qSapTp45eeukltWzZUgkJCVqzZo0++eQTXbp0Sb169VJYWJiaNWtm9zW89NJL2rdvn3r37q2QkBDjNVy+fFmStG/fPo0dO1ZpaWmqU6eOnnnmGTVv3lwVK1ZUfHy8IiMjtXnzZmO0EwByrbiTTH6tWbPGWq5cObufrjRo0MAaGRmZ7bE5jUhk/HQ0t4/58+dn6cf2aWFOj3vvvdcaHR1dwN+hdDfViMSZM1brd99ZrUePZn7+6NH05+18eugsnnvuOePvasaMGVn2p6SkWPv06ZPpZ8fRiIQk65133mm9ePFituc7d+6c1dPT0yrJ6ufnZz158mSWNr/88ovVy8vLKslao0YNa3Jycqb9hTEiUbp06Wz7io2NtVarVs0qydq0adMs+69du2atXr268YnuwYMHs7TZv39/pn838joiYbVarcePH3f4+59Rxn9zJFnnzp3rsL2j71VGjkZW8lPfV199laVNUlKStUmTJsaIwfXr1x32mZ2HH37YKslaq1Yth5+Ax8bGZnkuLCzM+GT91Vdfzfa41NRU60MPPWSVZC1btmyWn/2MP6+SrG+99VaWPtLS0oyRYldXV+u5c+cy7Z87d67DEQebq1evZhmR3rdvn/EamjRpku3v5vfff2+0adu2bZb9N76GiRMn2q1h4sSJVil9JC4mJsZuu7i4OIejfPaUuP8jACfmbCMSTjtHwiY4OFj79u3TCy+8oAYNGsjT01M+Pj5q3bq1pk2bpr1796pevXrFWuOMGTM0depU9enTR40aNVLlypXl6uqqcuXKqVGjRho2bJh++OEHbdmyRTVq1CjWWku8mBhpzx4pLU06eFA6diz9+WPH0r9OS0vfHxNTvHXmUVJSkhYuXCgpfXnhf/3rX1nalCpVSl988UWmGzPm5NNPP7V7U8T58+cb17u/99572S6T3KJFC40fP15S+tLEq1atyvW58+rZZ5/N9o7TFStW1PDhwyWlf9J66dKlTPtXrVqlM2fOSJImTpyY7WptTZo00SuvvFLwRZtw33336dFHHy3WGhzp37+/HnrooSzPlylTxlh4IjY2NtMiEbkV87/fz5YtWzq8v0/FihWz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JpIbkZGRSklJkaura4FcCoKCMWLECM2dO1c1a9bMdl4DABQFp/w/IjEx+w+e7D0PFJH8vF8rDoxIAE7o6tWrxvr67dq1K+ZqAMDJ3OSj2kBRIUgAJdCxY8fsLk2ampqqJ5980limcdiwYUVZGgAAgCTJtbgLAJDVm2++qbCwMA0aNEh33XWXqlatqqtXr2rfvn2aPXu2fvnlF0lSly5d1LNnz2KuFgAA3IoIEkAJdejQIU2aNMnu/vbt22vZsmVOc+diAABwcyFIACXQ+PHj1aBBA/3444/6888/df78eV2/fl2VKlVS69at9eCDD2rQoEHZrgYDAABQFAgSQAnUsGFDTZgwQRMmTCjuUgAAALLFx5kAAAAATCNIAAAAADCNIAEAAADANIIEAAAAANMIEgAAAABMI0gAAAAAMI0gAQAAAMA0ggQAAAAA0wgSAAAAAEwjSAAAAAAwjSABAAAAwDSCBAAAAADTCBIAAAAATCNIACgUISEhslgsql27dnGXAgAACgFBAgAAAIBpBAkAAAAAphEkAAAAAJhGkAAAAABgGkECAAAAgGkECaCEOnDggN566y1169ZNNWvWVJkyZeTt7a369etr2LBh2rVrl91jJ0+eLIvFIovFIklKSkrS9OnT1bJlS5UtW1Zly5ZV27Zt9cknnyglJSXHWpKTkzVr1iz17NlTNWrUUJkyZVS1alW1atVKzzzzjLZv3y6r1eqwj7i4OL322mu644475OXlJR8fH917771atGhRrr4f+/fv16hRo1S/fn15enqqbNmyuuOOO/TCCy/oxIkTdo87ceKE8b1YsGCBJGnlypXq0aOH/Pz85Orqqs6dO2c65siRI3r22WfVpEkTeXt7y83NTX5+fmrevLkeffRRLVu2TNeuXctV3QAA3LSsuCVERUVZJVklWaOiokwde+TIEevBgwetR44cKaTqcKPNmzcbf1+OHi+//HK2x0+aNMloExMTY23WrJndPoKDg62pqal2a9m7d6+1Tp06OdZy/PjxTMcNGzbMKslaq1Yt66FDh6y1a9e2e+zTTz/t8Pvx9ttvW11cXOweX6ZMGevChQuzPfb48eNGu3nz5lkffvjhLMd36tTJaL98+XKrm5tbjq93//79DmsGbhX8HwEUnPy8XysOrgUXSQAUlJSUFHl5ealnz56677771KhRI5UrV07nzp3T77//ro8++kh//vmnpk6dqgYNGmj48OF2++rfv78OHTqk5557TsHBwapYsaIOHz6sN998U4cOHdK3336r2bNn6/HHH89y7MGDB9WxY0fFx8dLkvr166dBgwbp9ttvV2pqqg4fPqwff/xR//d//2f3/ImJierdu7diY2P16quv6v7775e3t7f27t2r119/XdHR0fr0008VHBysbt26ZTn+s88+04QJEyRJVapU0UsvvaT27dsrNTVVGzdu1PTp05WQkKCQkBBVrlxZPXr0sFvLhx9+qH379qljx4568skn1aBBA8XFxRkjGmfPntXw4cOVnJysqlWr6plnnlG7du1UuXJlJSUl6Y8//tC2bdu0cuVKu+cAAOCWUdxJBkWDEQnncv78eevFixft7r927Zq1a9euxif+KSkpmfZnHJEoXbq0dfPmzVn6iI2NtVarVs0qydq0adNsz9OiRQurJKuLi4t1yZIlduu5cOGCNTExMdNzthEJSVYfHx/rgQMHshwXGRlpdXd3t0qy9u7dO8v+c+fOWT09Pa2SrH5+ftaTJ09mafPLL79Yvby8rJKsNWrUsCYnJ2fan3FEQpL1kUcesaalpWX7OubOnZurEYerV69meb3ArYr/I4CC42wjEsyRgNOyWqWICOnHH9P/zOESfadSuXJl+fj42N3v5uam6dOnS5L+/PNP/frrr3bbPvvss1nmAEhSxYoVjZGMffv26dKlS5n2r1+/Xnv37jX6GDRokN1zVKpUSR4eHnb3v/HGG7rjjjuyPF+vXj317dtXkrR9+/Ys++fPn6/ExERJ0nvvvSd/f/8sbVq0aKHx48dLkk6dOqVVq1bZrcPHx0effPKJMXfkRjExMZKkChUqqEmTJnb7cXd3d/h6AQC4FRAk4JTi4qRevaSAACkoKP3PXr3Sn78ZXbt2TSdPntTBgwd14MABHThwINPk5t9++83usUOHDrW7r1WrVsb28ePHM+1bu3atsf3CCy/kpWxJksVi0ZAhQ3Ks4eLFi4q74S9w48aNktIDwAMPPGC3jxEjRmQ5JjvBwcEqW7as3f3Vq1c3alm9erXddgAAQGKOBJyO1SoNHSqtW5f5+XXr0p/P8P7XqSUkJOijjz7S0qVL9fvvvys1NdVu2wsXLtjd16hRI7v7KlasaGxfuXIl0z7baMRtt92mWrVq5bbsLCpXrqxKlSrl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GT300EM6efJklmNatGhhbE+ZMkW//fab6fPu379f69evN75+6623tH///kyPp556ytifkpKiXr16GRO3g4KC9H//93/avXu3Vq5cqfvvv18//PCDMQE8v3x9fTV37lxJ6atLPf3005n2Jycna8iQIUpKSpKnp6cWLVrEZGoAQJEiSAAoNlu2bFHr1q31yCOPqE2bNsbowpgxYzR//nytX79eDRs21Pjx4zN9It+pUyc1bdpUknThwgW1aNFCnTt31ltvvaUNGzYoLi4ux3M3adJEDRo0ML6uUaOGmjRpkulRtWpVY//nn3+uvXv3SkqfG7J+/Xr17dtXrVq1Ur9+/fTjjz/q0UcfVXh4eEF8ayRJvXv3NuahfP3111q6dKmx75VXXjEC1AcffJDptQAAUBQIEgCKxR9//KEuXbooNjZW3377rVauXKmaNWsa+4cNG6bDhw9r6NChmjZtmp577jljn4uLi7755htjfoTVatXWrVs1ceJEdevWTRUrVlTTpk310ksv6ciRIwVS7+effy5Jqlatmj744INs28ycOVNVqlQpkPPZfPDBB2rYsKEk6cknn9TJkye1efNmvffee5Iyhw0AAIoSQQJAsbj99tu1fPlyHTx4MNulXyWpYsWKmjNnjrZt22Ys92pTr149/frrr5o6darq1q2baZ/VatX+/fv17rvvqnHjxhozZkyWm9aZcfr0aWO0ZODAgXbve+Ht7a2BAwfm+TzZyXjZUlxcnIYOHaphw4bJarXK19dXc+bMKdDzAQCQWyz/CpRAFoslxzZ//vmnw3Y33qk5ISFBx48ft9u+sG+Olp0HHnggV+06dOiQ7fNeXl566aWX9NJLL+nw4cPasWOHfv31V+3atUu7d+9WWlqaUlNT9f777ys2Nta4D4VZGe8O3aZNG4dt27Ztq08//TRP57GnVatWeuONNzR+/PhMKzjNnz+/wEdAAADILYIEcIsIDw9XYGCg3f0Z71LtjBo2bGhcAiRJp06d0uTJk41P7BcuXKgRI0bYDSWOXLx40djOOG8iO9WqVTPdf26MGzdO8+fPNy7VGjFihLp3714o5wIAIDcIEkAJlPET8ButXr1ar776qvz8/DKtOnSjjPMNnElBBZoaNWpo9uzZio+PNyYpr1ixIk9BImNNOY0WFVYg++GHHzLN9wgNDdXVq1fl4eFRKOcDACAn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NgoICCiQfh9//HGj361bt6p9+/a5PrZmzZoFUgMAAACQG4UaJFxdXQtktaTq1atn+rpmzZr6+eeflZCQoLi4OIef9tsmZlepUqXA5kcsWrRIqampknI/yTo3GjdubGyfOnWqwPoFAAAAClqhj0g4Wp41rxo3bmxMdI6IiFC7du2ybZeSkqJjx45JUoGNGkjSV199JUkqXbq0Bg8eXGD9Wq3WAusLAAAAKExOeR+JDh06GNtbt26122737t3GpU1mLhNy5Ndff9W+ffskST179lSlSpUKpF9JOnjwoLHt5+dXYP0CAAAABc0pg0Tnzp1Vvnx5SdLChQvtfpKfcZJ2v379CuTcGSdZDxs2rED6tPniiy+MbUd37AYAAACKm1MGCTc3Nz333HOS0u9YPWPGjCxtdu7cqblz50pKf1Pepk2bLG1OnDhhrAzVuXPnHM+bmpqqJUuWSJIqVaqknj175qreXbt2ObwhnNVq1auvvqpNmzZJkpo1a1ZgIygAAABAYXDKVZsk6cUXX9SyZct05MgRjRs3TkePHtWgQYPk4eGhzZs36+2331ZKSoo8PDz04YcfFsg5169fr5iYGEnS4MGDVbp06Vwd98MPP2jq1Knq3r27unbtqsaNG8vHx0fXrl3Tvn37jBvSSZKnp6dmz57NPSQAAABQojltkChbtqzWrl2rHj16KDIyUrNmzdKsWbMytSlXrpwWLVqk5s2bF8g5zd47IqNr165p9erVWr16td02t912mxYvXpzt6AkAAABQkjhtkJCkevXqae/evfr000+1YsUKHT16VMnJyfL391ePHj30/PPPq1atWgVyrsuXL2vNmjWS0leiMvNmf/jw4apWrZp27typffv26dy5c4qNjZWrq6sqV66sli1bKjg4WEOGDDFutgcAAACUZBYra47eEqKjo+Xv7y8p/d4a3MAOAACgZHG292tOOdkaAAAAQPEiSAAAAAAwjSABAAAAwDSCBAAAAADTCBIAAAAATCNIAAAAADCNIAEAAADANIIEAAAAANMIEgAAAABMI0gAAAAAMI0gAQAAAMA0ggQAAAAA0wgSAAAAAEwjSAAAAAAwjSABAAAAwDSCBAAAAADTCBIAAAAATCNIAAAAADCNIAEAAADANIIEAAAAANMIEgAAAABMI0gAAAAAMI0gAQAAAMA0ggQAAAAA0wgSAAAAAEwj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",
      "text/plain": [
       "<Figure size 800x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot 2D points\n",
    "fig, ax = plt.subplots(figsize=(4, 4), dpi=200)\n",
    "ax.scatter(x_gt[:, 0], x_gt[:, 1], c='red', marker='x', s=10.0, alpha=0.3, label='ground-truth sensors')\n",
    "ax.scatter(a_true_np[:, 0], a_true_np[:, 1], c='blue', marker='o', s=3.0, label='anchors')\n",
    "ax.scatter(mus[:, 0], mus[:, 1], c='black', marker='x', s=3.0, label='E[x]')\n",
    "\n",
    "# draw a box around each mu with dx = stds[s_i, 0], dy = stds[s_i, 1]\n",
    "for s_i in range(len(x_gt)):\n",
    "    x1 = mus[s_i, 0] - stds[s_i, 0]\n",
    "    x2 = mus[s_i, 0] + stds[s_i, 0]\n",
    "    y1 = mus[s_i, 1] - stds[s_i, 1]\n",
    "    y2 = mus[s_i, 1] + stds[s_i, 1]\n",
    "    if s_i == 0:\n",
    "        rect = patches.Rectangle((x1, y1), x2 - x1, y2 - y1, linewidth=1, edgecolor='black', facecolor='none', alpha=1.0, label='+- 1*Std[x]')\n",
    "    else:\n",
    "        rect = patches.Rectangle((x1, y1), x2 - x1, y2 - y1, linewidth=1, edgecolor='black', facecolor='none', alpha=1.0)\n",
    "    ax.add_patch(rect)\n",
    "\n",
    "plt.xlim([-1, 1])\n",
    "plt.ylim([-1, 1])\n",
    "plt.legend(loc='best')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "python-3.8-base",
   "language": "python",
   "name": "python-3.8-base"
  },
  "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.8.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
