{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "c6339f5c-22a6-4b4e-a15d-b74f2c881b7d",
   "metadata": {},
   "outputs": [],
   "source": [
    "using Plots\n",
    "using Random\n",
    "using Distributions\n",
    "using LinearAlgebra\n",
    "include(\"pogm_restart.jl\") # issues adding MIRT so will use julia file instead\n",
    "rng = Random.seed!(0)\n",
    "N = 100\n",
    "D = 100\n",
    "d = 10\n",
    "σ1 = 1\n",
    "σ2 = 30\n",
    "goodpts = 11\n",
    "X = zeros(D,N)\n",
    "Y = zeros(D,N)\n",
    "Π = vec(zeros(N,1))\n",
    "U1 = svd(rand(D,N)).U[:,1:d]\n",
    "for k = 1:N\n",
    "    X[:,k] = U1*U1'*rand(Uniform(-100,100),D)\n",
    "end\n",
    "for j=1:N\n",
    "        if (j<= goodpts)\n",
    "            Y[:,j] = X[:,j] + rand(Normal(0,σ1),D)\n",
    "            Π[j] = σ1^2\n",
    "        else\n",
    "            Y[:,j] = X[:,j] + rand(Normal(0,σ2),D)\n",
    "            Π[j] = σ2^2\n",
    "        end\n",
    "end"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "516133cc-1792-4a19-aba7-4de1d0b13d1f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "HPCA_UNKNOWN_ADMM (generic function with 1 method)"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "function HPCA_UNKNOWN_ADMM(Y, λr, N, μ, ρ, U_init)\n",
    "    X = deepcopy(U_init*U_init'*Y)\n",
    "    Z = deepcopy(Y-X)\n",
    "    var = W_NO_GROUPS(Y,X)\n",
    "    Π = diagm(var.^-1)\n",
    "    Λ2 = sign.(Y)\n",
    "    Λ = deepcopy(Λ2 ./ (max(opnorm(Λ2), (1/λr)*norm(Λ2, Inf))))\n",
    "    normY = norm(Y,2)\n",
    "    count = 0\n",
    "    soft = (x,t) -> sign.(x) .* max.(abs.(x) .- t, 0)\n",
    "    function pssvt(x,t,N)\n",
    "        U,S,V = svd(x)\n",
    "        S[(N+1):end] = soft.(S[(N+1):end],t)\n",
    "        return U*diagm(S)*V'\n",
    "    end\n",
    "    while ((norm(Y-X-Z,2)/normY > 1e-6) || (count <100))\n",
    "        X = pssvt(Y-Z+(1/μ)*Λ, λr/μ,N)\n",
    "        Z = μ*(Y-X+(1/μ)*Λ)*inv(Π+μ*I)\n",
    "        Λ = Λ + μ*(Y-X-Z)\n",
    "        var = W_NO_GROUPS(Y,X)\n",
    "        Π = diagm(var.^-1)\n",
    "        μ = ρ*μ\n",
    "        count = count + 1\n",
    "    end\n",
    "    U = svd(X).U[:,1:N]   \n",
    "    return U, var\n",
    "end"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "ea2a8ac9-572f-4ac3-8e3f-5038e4856b51",
   "metadata": {},
   "outputs": [],
   "source": [
    "using HePPCAT\n",
    "heppCAT_nogroups = []\n",
    "for i = 1:N\n",
    "    push!(heppCAT_nogroups, Y[:,i])\n",
    "end\n",
    "U_PPCA = heppcat(heppCAT_nogroups,d,0).U;"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 137,
   "id": "4456c5a3-e121-48ce-a628-11f4203f51f9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "W_NO_GROUPS (generic function with 1 method)"
      ]
     },
     "execution_count": 137,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "function HPCA_APGD(Y, λr, w, N, ϵ, X0)\n",
    "    Π = w.^-1\n",
    "    Lf = maximum(Π)\n",
    "    Π = Diagonal(Π)\n",
    "    grad = K -> -1*(Y-K)*Π\n",
    "    soft = (x,t) -> sign.(x) .* max.(abs.(x) .- t, 0)\n",
    "    function pssvt(x,t,N)\n",
    "        U,S,V = svd(x)\n",
    "        S[(N+1):end] = soft.(S[(N+1):end],t)\n",
    "        return U*diagm(S)*V'\n",
    "    end\n",
    "    prox1 = (z,c) -> pssvt(z, c*λr, N)\n",
    "    K, _ = pogm_restart(X0, x -> 0, grad, Lf ; g_prox=prox1, eps=ϵ, mom=:fpgm, restart=:gr) # objective(x,Y-x,λr,w)\n",
    "    return K\n",
    "end\n",
    "function AltMin(Y, λr, N, ϵ)\n",
    "    Π = ones(size(Y)[2])\n",
    "    X = zeros(size(Y)) .+ 1\n",
    "    X0 = zeros(size(Y)) .+ 1e-6\n",
    "    while norm(X-X0, 2)/norm(X0,2) > 1e-6\n",
    "        X0 = X\n",
    "        X = HPCA_POGM(Y, λr, Π, N, ϵ, X)\n",
    "        Π = W_NO_GROUPS(Y, X)\n",
    "    end\n",
    "    return X, Π\n",
    "end\n",
    "function W_NO_GROUPS(Y, L)\n",
    "    d = size(Y)[1]\n",
    "    Π = diag((1/d)*(Y-L)'*(Y-L))\n",
    "    return max.(Π, 1e-9)\n",
    "end"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 150,
   "id": "d9ffe4b3-0753-41a1-8f52-e5afdf9c081e",
   "metadata": {},
   "outputs": [],
   "source": [
    "UTEST, VAR_ADMM = HPCA_UNKNOWN_ADMM(Y, 100, 10, 0.01, 1.005, U_PPCA);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 158,
   "id": "4317de9a-f26b-4405-b066-50e569029047",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n",
       "<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"600\" height=\"400\" viewBox=\"0 0 2400 1600\">\n",
       "<defs>\n",
       "  <clipPath id=\"clip190\">\n",
       "    <rect x=\"0\" y=\"0\" width=\"2400\" height=\"1600\"/>\n",
       "  </clipPath>\n",
       "</defs>\n",
       "<path clip-path=\"url(#clip190)\" d=\"\n",
       "M0 1600 L2400 1600 L2400 0 L0 0  Z\n",
       "  \" fill=\"#ffffff\" fill-rule=\"evenodd\" fill-opacity=\"1\"/>\n",
       "<defs>\n",
       "  <clipPath id=\"clip191\">\n",
       "    <rect x=\"480\" y=\"0\" width=\"1681\" height=\"1600\"/>\n",
       "  </clipPath>\n",
       "</defs>\n",
       "<path clip-path=\"url(#clip190)\" d=\"\n",
       "M199.283 1486.45 L2352.76 1486.45 L2352.76 47.2441 L199.283 47.2441  Z\n",
       "  \" fill=\"#ffffff\" fill-rule=\"evenodd\" fill-opacity=\"1\"/>\n",
       "<defs>\n",
       "  <clipPath id=\"clip192\">\n",
       "    <rect x=\"199\" y=\"47\" width=\"2154\" height=\"1440\"/>\n",
       "  </clipPath>\n",
       "</defs>\n",
       "<polyline clip-path=\"url(#clip192)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:2; stroke-opacity:0.1; fill:none\" points=\"\n",
       "  239.71,1486.45 239.71,47.2441 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip192)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:2; stroke-opacity:0.1; fill:none\" points=\"\n",
       "  752.734,1486.45 752.734,47.2441 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip192)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:2; stroke-opacity:0.1; fill:none\" points=\"\n",
       "  1265.76,1486.45 1265.76,47.2441 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip192)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:2; stroke-opacity:0.1; fill:none\" points=\"\n",
       "  1778.78,1486.45 1778.78,47.2441 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip192)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:2; stroke-opacity:0.1; fill:none\" points=\"\n",
       "  2291.81,1486.45 2291.81,47.2441 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip190)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:4; stroke-opacity:1; fill:none\" points=\"\n",
       "  199.283,1486.45 2352.76,1486.45 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip190)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:4; stroke-opacity:1; fill:none\" points=\"\n",
       "  239.71,1486.45 239.71,1467.55 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip190)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:4; stroke-opacity:1; fill:none\" points=\"\n",
       "  752.734,1486.45 752.734,1467.55 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip190)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:4; stroke-opacity:1; fill:none\" points=\"\n",
       "  1265.76,1486.45 1265.76,1467.55 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip190)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:4; stroke-opacity:1; fill:none\" points=\"\n",
       "  1778.78,1486.45 1778.78,1467.55 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip190)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:4; stroke-opacity:1; fill:none\" points=\"\n",
       "  2291.81,1486.45 2291.81,1467.55 \n",
       "  \"/>\n",
       "<path clip-path=\"url(#clip190)\" d=\"M239.71 1517.37 Q236.098 1517.37 234.27 1520.93 Q232.464 1524.47 232.464 1531.6 Q232.464 1538.71 234.27 1542.27 Q236.098 1545.82 239.71 1545.82 Q243.344 1545.82 245.149 1542.27 Q246.978 1538.71 246.978 1531.6 Q246.978 1524.47 245.149 1520.93 Q243.344 1517.37 239.71 1517.37 M239.71 1513.66 Q245.52 1513.66 248.575 1518.27 Q251.654 1522.85 251.654 1531.6 Q251.654 1540.33 248.575 1544.94 Q245.52 1549.52 239.71 1549.52 Q233.899 1549.52 230.821 1544.94 Q227.765 1540.33 227.765 1531.6 Q227.765 1522.85 230.821 1518.27 Q233.899 1513.66 239.71 1513.66 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M732.005 1544.91 L748.325 1544.91 L748.325 1548.85 L726.38 1548.85 L726.38 1544.91 Q729.042 1542.16 733.626 1537.53 Q738.232 1532.88 739.413 1531.53 Q741.658 1529.01 742.538 1527.27 Q743.44 1525.51 743.44 1523.82 Q743.44 1521.07 741.496 1519.33 Q739.575 1517.6 736.473 1517.6 Q734.274 1517.6 731.82 1518.36 Q729.39 1519.13 726.612 1520.68 L726.612 1515.95 Q729.436 1514.82 731.89 1514.24 Q734.343 1513.66 736.38 1513.66 Q741.751 1513.66 744.945 1516.35 Q748.139 1519.03 748.139 1523.52 Q748.139 1525.65 747.329 1527.57 Q746.542 1529.47 744.436 1532.07 Q743.857 1532.74 740.755 1535.95 Q737.653 1539.15 732.005 1544.91 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M758.186 1514.29 L776.542 1514.29 L776.542 1518.22 L762.468 1518.22 L762.468 1526.7 Q763.487 1526.35 764.505 1526.19 Q765.524 1526 766.542 1526 Q772.329 1526 775.709 1529.17 Q779.088 1532.34 779.088 1537.76 Q779.088 1543.34 775.616 1546.44 Q772.144 1549.52 765.825 1549.52 Q763.649 1549.52 761.38 1549.15 Q759.135 1548.78 756.727 1548.04 L756.727 1543.34 Q758.811 1544.47 761.033 1545.03 Q763.255 1545.58 765.732 1545.58 Q769.737 1545.58 772.074 1543.48 Q774.412 1541.37 774.412 1537.76 Q774.412 1534.15 772.074 1532.04 Q769.737 1529.94 765.732 1529.94 Q763.857 1529.94 761.982 1530.35 Q760.13 1530.77 758.186 1531.65 L758.186 1514.29 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M1240.46 1514.29 L1258.81 1514.29 L1258.81 1518.22 L1244.74 1518.22 L1244.74 1526.7 Q1245.76 1526.35 1246.78 1526.19 Q1247.8 1526 1248.81 1526 Q1254.6 1526 1257.98 1529.17 Q1261.36 1532.34 1261.36 1537.76 Q1261.36 1543.34 1257.89 1546.44 Q1254.42 1549.52 1248.1 1549.52 Q1245.92 1549.52 1243.65 1549.15 Q1241.41 1548.78 1239 1548.04 L1239 1543.34 Q1241.08 1544.47 1243.31 1545.03 Q1245.53 1545.58 1248 1545.58 Q1252.01 1545.58 1254.35 1543.48 Q1256.69 1541.37 1256.69 1537.76 Q1256.69 1534.15 1254.35 1532.04 Q1252.01 1529.94 1248 1529.94 Q1246.13 1529.94 1244.25 1530.35 Q1242.4 1530.77 1240.46 1531.65 L1240.46 1514.29 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M1280.57 1517.37 Q1276.96 1517.37 1275.13 1520.93 Q1273.33 1524.47 1273.33 1531.6 Q1273.33 1538.71 1275.13 1542.27 Q1276.96 1545.82 1280.57 1545.82 Q1284.21 1545.82 1286.01 1542.27 Q1287.84 1538.71 1287.84 1531.6 Q1287.84 1524.47 1286.01 1520.93 Q1284.21 1517.37 1280.57 1517.37 M1280.57 1513.66 Q1286.38 1513.66 1289.44 1518.27 Q1292.52 1522.85 1292.52 1531.6 Q1292.52 1540.33 1289.44 1544.94 Q1286.38 1549.52 1280.57 1549.52 Q1274.76 1549.52 1271.68 1544.94 Q1268.63 1540.33 1268.63 1531.6 Q1268.63 1522.85 1271.68 1518.27 Q1274.76 1513.66 1280.57 1513.66 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M1752.64 1514.29 L1774.86 1514.29 L1774.86 1516.28 L1762.31 1548.85 L1757.43 1548.85 L1769.24 1518.22 L1752.64 1518.22 L1752.64 1514.29 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M1784.03 1514.29 L1802.38 1514.29 L1802.38 1518.22 L1788.31 1518.22 L1788.31 1526.7 Q1789.33 1526.35 1790.35 1526.19 Q1791.36 1526 1792.38 1526 Q1798.17 1526 1801.55 1529.17 Q1804.93 1532.34 1804.93 1537.76 Q1804.93 1543.34 1801.46 1546.44 Q1797.99 1549.52 1791.67 1549.52 Q1789.49 1549.52 1787.22 1549.15 Q1784.98 1548.78 1782.57 1548.04 L1782.57 1543.34 Q1784.65 1544.47 1786.87 1545.03 Q1789.1 1545.58 1791.57 1545.58 Q1795.58 1545.58 1797.92 1543.48 Q1800.25 1541.37 1800.25 1537.76 Q1800.25 1534.15 1797.92 1532.04 Q1795.58 1529.94 1791.57 1529.94 Q1789.7 1529.94 1787.82 1530.35 Q1785.97 1530.77 1784.03 1531.65 L1784.03 1514.29 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M2251.42 1544.91 L2259.05 1544.91 L2259.05 1518.55 L2250.74 1520.21 L2250.74 1515.95 L2259.01 1514.29 L2263.68 1514.29 L2263.68 1544.91 L2271.32 1544.91 L2271.32 1548.85 L2251.42 1548.85 L2251.42 1544.91 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M2290.77 1517.37 Q2287.16 1517.37 2285.33 1520.93 Q2283.52 1524.47 2283.52 1531.6 Q2283.52 1538.71 2285.33 1542.27 Q2287.16 1545.82 2290.77 1545.82 Q2294.4 1545.82 2296.21 1542.27 Q2298.04 1538.71 2298.04 1531.6 Q2298.04 1524.47 2296.21 1520.93 Q2294.4 1517.37 2290.77 1517.37 M2290.77 1513.66 Q2296.58 1513.66 2299.63 1518.27 Q2302.71 1522.85 2302.71 1531.6 Q2302.71 1540.33 2299.63 1544.94 Q2296.58 1549.52 2290.77 1549.52 Q2284.96 1549.52 2281.88 1544.94 Q2278.82 1540.33 2278.82 1531.6 Q2278.82 1522.85 2281.88 1518.27 Q2284.96 1513.66 2290.77 1513.66 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M2320.93 1517.37 Q2317.32 1517.37 2315.49 1520.93 Q2313.68 1524.47 2313.68 1531.6 Q2313.68 1538.71 2315.49 1542.27 Q2317.32 1545.82 2320.93 1545.82 Q2324.56 1545.82 2326.37 1542.27 Q2328.2 1538.71 2328.2 1531.6 Q2328.2 1524.47 2326.37 1520.93 Q2324.56 1517.37 2320.93 1517.37 M2320.93 1513.66 Q2326.74 1513.66 2329.79 1518.27 Q2332.87 1522.85 2332.87 1531.6 Q2332.87 1540.33 2329.79 1544.94 Q2326.74 1549.52 2320.93 1549.52 Q2315.12 1549.52 2312.04 1544.94 Q2308.98 1540.33 2308.98 1531.6 Q2308.98 1522.85 2312.04 1518.27 Q2315.12 1513.66 2320.93 1513.66 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><polyline clip-path=\"url(#clip192)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:2; stroke-opacity:0.1; fill:none\" points=\"\n",
       "  199.283,1445.72 2352.76,1445.72 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip192)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:2; stroke-opacity:0.1; fill:none\" points=\"\n",
       "  199.283,1147.15 2352.76,1147.15 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip192)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:2; stroke-opacity:0.1; fill:none\" points=\"\n",
       "  199.283,848.584 2352.76,848.584 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip192)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:2; stroke-opacity:0.1; fill:none\" points=\"\n",
       "  199.283,550.018 2352.76,550.018 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip192)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:2; stroke-opacity:0.1; fill:none\" points=\"\n",
       "  199.283,251.453 2352.76,251.453 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip190)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:4; stroke-opacity:1; fill:none\" points=\"\n",
       "  199.283,1486.45 199.283,47.2441 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip190)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:4; stroke-opacity:1; fill:none\" points=\"\n",
       "  199.283,1445.72 218.181,1445.72 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip190)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:4; stroke-opacity:1; fill:none\" points=\"\n",
       "  199.283,1147.15 218.181,1147.15 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip190)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:4; stroke-opacity:1; fill:none\" points=\"\n",
       "  199.283,848.584 218.181,848.584 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip190)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:4; stroke-opacity:1; fill:none\" points=\"\n",
       "  199.283,550.018 218.181,550.018 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip190)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:4; stroke-opacity:1; fill:none\" points=\"\n",
       "  199.283,251.453 218.181,251.453 \n",
       "  \"/>\n",
       "<path clip-path=\"url(#clip190)\" d=\"M151.339 1431.51 Q147.728 1431.51 145.899 1435.08 Q144.093 1438.62 144.093 1445.75 Q144.093 1452.86 145.899 1456.42 Q147.728 1459.96 151.339 1459.96 Q154.973 1459.96 156.779 1456.42 Q158.607 1452.86 158.607 1445.75 Q158.607 1438.62 156.779 1435.08 Q154.973 1431.51 151.339 1431.51 M151.339 1427.81 Q157.149 1427.81 160.205 1432.42 Q163.283 1437 163.283 1445.75 Q163.283 1454.48 160.205 1459.08 Q157.149 1463.67 151.339 1463.67 Q145.529 1463.67 142.45 1459.08 Q139.394 1454.48 139.394 1445.75 Q139.394 1437 142.45 1432.42 Q145.529 1427.81 151.339 1427.81 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M85.0429 1160.49 L101.362 1160.49 L101.362 1164.43 L79.4179 1164.43 L79.4179 1160.49 Q82.0799 1157.74 86.6632 1153.11 Q91.2697 1148.46 92.4502 1147.12 Q94.6956 1144.59 95.5752 1142.86 Q96.478 1141.1 96.478 1139.41 Q96.478 1136.65 94.5336 1134.92 Q92.6123 1133.18 89.5104 1133.18 Q87.3114 1133.18 84.8577 1133.94 Q82.4271 1134.71 79.6494 1136.26 L79.6494 1131.54 Q82.4734 1130.4 84.9271 1129.82 Q87.3808 1129.24 89.4178 1129.24 Q94.7882 1129.24 97.9826 1131.93 Q101.177 1134.62 101.177 1139.11 Q101.177 1141.24 100.367 1143.16 Q99.5798 1145.06 97.4734 1147.65 Q96.8947 1148.32 93.7928 1151.54 Q90.691 1154.73 85.0429 1160.49 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M111.223 1129.87 L129.58 1129.87 L129.58 1133.81 L115.506 1133.81 L115.506 1142.28 Q116.524 1141.93 117.543 1141.77 Q118.561 1141.58 119.58 1141.58 Q125.367 1141.58 128.746 1144.75 Q132.126 1147.93 132.126 1153.34 Q132.126 1158.92 128.654 1162.02 Q125.182 1165.1 118.862 1165.1 Q116.686 1165.1 114.418 1164.73 Q112.172 1164.36 109.765 1163.62 L109.765 1158.92 Q111.848 1160.05 114.07 1160.61 Q116.293 1161.17 118.77 1161.17 Q122.774 1161.17 125.112 1159.06 Q127.45 1156.95 127.45 1153.34 Q127.45 1149.73 125.112 1147.62 Q122.774 1145.52 118.77 1145.52 Q116.895 1145.52 115.02 1145.93 Q113.168 1146.35 111.223 1147.23 L111.223 1129.87 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M151.339 1132.95 Q147.728 1132.95 145.899 1136.51 Q144.093 1140.06 144.093 1147.18 Q144.093 1154.29 145.899 1157.86 Q147.728 1161.4 151.339 1161.4 Q154.973 1161.4 156.779 1157.86 Q158.607 1154.29 158.607 1147.18 Q158.607 1140.06 156.779 1136.51 Q154.973 1132.95 151.339 1132.95 M151.339 1129.24 Q157.149 1129.24 160.205 1133.85 Q163.283 1138.43 163.283 1147.18 Q163.283 1155.91 160.205 1160.52 Q157.149 1165.1 151.339 1165.1 Q145.529 1165.1 142.45 1160.52 Q139.394 1155.91 139.394 1147.18 Q139.394 1138.43 142.45 1133.85 Q145.529 1129.24 151.339 1129.24 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M81.0614 831.304 L99.4178 831.304 L99.4178 835.239 L85.3438 835.239 L85.3438 843.711 Q86.3623 843.364 87.3808 843.202 Q88.3993 843.017 89.4178 843.017 Q95.2049 843.017 98.5845 846.188 Q101.964 849.36 101.964 854.776 Q101.964 860.355 98.4919 863.457 Q95.0197 866.535 88.7003 866.535 Q86.5243 866.535 84.2558 866.165 Q82.0105 865.795 79.6031 865.054 L79.6031 860.355 Q81.6864 861.489 83.9086 862.045 Q86.1308 862.6 88.6077 862.6 Q92.6123 862.6 94.9502 860.494 Q97.2882 858.387 97.2882 854.776 Q97.2882 851.165 94.9502 849.059 Q92.6123 846.952 88.6077 846.952 Q86.7327 846.952 84.8577 847.369 Q83.0058 847.786 81.0614 848.665 L81.0614 831.304 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M121.177 834.383 Q117.566 834.383 115.737 837.948 Q113.932 841.489 113.932 848.619 Q113.932 855.725 115.737 859.29 Q117.566 862.832 121.177 862.832 Q124.811 862.832 126.617 859.29 Q128.445 855.725 128.445 848.619 Q128.445 841.489 126.617 837.948 Q124.811 834.383 121.177 834.383 M121.177 830.679 Q126.987 830.679 130.043 835.286 Q133.121 839.869 133.121 848.619 Q133.121 857.346 130.043 861.952 Q126.987 866.535 121.177 866.535 Q115.367 866.535 112.288 861.952 Q109.233 857.346 109.233 848.619 Q109.233 839.869 112.288 835.286 Q115.367 830.679 121.177 830.679 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M151.339 834.383 Q147.728 834.383 145.899 837.948 Q144.093 841.489 144.093 848.619 Q144.093 855.725 145.899 859.29 Q147.728 862.832 151.339 862.832 Q154.973 862.832 156.779 859.29 Q158.607 855.725 158.607 848.619 Q158.607 841.489 156.779 837.948 Q154.973 834.383 151.339 834.383 M151.339 830.679 Q157.149 830.679 160.205 835.286 Q163.283 839.869 163.283 848.619 Q163.283 857.346 160.205 861.952 Q157.149 866.535 151.339 866.535 Q145.529 866.535 142.45 861.952 Q139.394 857.346 139.394 848.619 Q139.394 839.869 142.45 835.286 Q145.529 830.679 151.339 830.679 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M79.8346 532.738 L102.057 532.738 L102.057 534.729 L89.5104 567.298 L84.6262 567.298 L96.4317 536.674 L79.8346 536.674 L79.8346 532.738 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M111.223 532.738 L129.58 532.738 L129.58 536.674 L115.506 536.674 L115.506 545.146 Q116.524 544.799 117.543 544.636 Q118.561 544.451 119.58 544.451 Q125.367 544.451 128.746 547.623 Q132.126 550.794 132.126 556.21 Q132.126 561.789 128.654 564.891 Q125.182 567.97 118.862 567.97 Q116.686 567.97 114.418 567.599 Q112.172 567.229 109.765 566.488 L109.765 561.789 Q111.848 562.923 114.07 563.479 Q116.293 564.035 118.77 564.035 Q122.774 564.035 125.112 561.928 Q127.45 559.822 127.45 556.21 Q127.45 552.599 125.112 550.493 Q122.774 548.386 118.77 548.386 Q116.895 548.386 115.02 548.803 Q113.168 549.22 111.223 550.099 L111.223 532.738 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M151.339 535.817 Q147.728 535.817 145.899 539.382 Q144.093 542.924 144.093 550.053 Q144.093 557.16 145.899 560.724 Q147.728 564.266 151.339 564.266 Q154.973 564.266 156.779 560.724 Q158.607 557.16 158.607 550.053 Q158.607 542.924 156.779 539.382 Q154.973 535.817 151.339 535.817 M151.339 532.113 Q157.149 532.113 160.205 536.72 Q163.283 541.303 163.283 550.053 Q163.283 558.78 160.205 563.386 Q157.149 567.97 151.339 567.97 Q145.529 567.97 142.45 563.386 Q139.394 558.78 139.394 550.053 Q139.394 541.303 142.45 536.72 Q145.529 532.113 151.339 532.113 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M51.6634 264.797 L59.3023 264.797 L59.3023 238.432 L50.9921 240.099 L50.9921 235.839 L59.256 234.173 L63.9319 234.173 L63.9319 264.797 L71.5707 264.797 L71.5707 268.733 L51.6634 268.733 L51.6634 264.797 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M91.0151 237.251 Q87.404 237.251 85.5753 240.816 Q83.7697 244.358 83.7697 251.487 Q83.7697 258.594 85.5753 262.159 Q87.404 265.7 91.0151 265.7 Q94.6493 265.7 96.4548 262.159 Q98.2835 258.594 98.2835 251.487 Q98.2835 244.358 96.4548 240.816 Q94.6493 237.251 91.0151 237.251 M91.0151 233.548 Q96.8252 233.548 99.8808 238.154 Q102.959 242.737 102.959 251.487 Q102.959 260.214 99.8808 264.821 Q96.8252 269.404 91.0151 269.404 Q85.2049 269.404 82.1262 264.821 Q79.0707 260.214 79.0707 251.487 Q79.0707 242.737 82.1262 238.154 Q85.2049 233.548 91.0151 233.548 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M121.177 237.251 Q117.566 237.251 115.737 240.816 Q113.932 244.358 113.932 251.487 Q113.932 258.594 115.737 262.159 Q117.566 265.7 121.177 265.7 Q124.811 265.7 126.617 262.159 Q128.445 258.594 128.445 251.487 Q128.445 244.358 126.617 240.816 Q124.811 237.251 121.177 237.251 M121.177 233.548 Q126.987 233.548 130.043 238.154 Q133.121 242.737 133.121 251.487 Q133.121 260.214 130.043 264.821 Q126.987 269.404 121.177 269.404 Q115.367 269.404 112.288 264.821 Q109.233 260.214 109.233 251.487 Q109.233 242.737 112.288 238.154 Q115.367 233.548 121.177 233.548 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M151.339 237.251 Q147.728 237.251 145.899 240.816 Q144.093 244.358 144.093 251.487 Q144.093 258.594 145.899 262.159 Q147.728 265.7 151.339 265.7 Q154.973 265.7 156.779 262.159 Q158.607 258.594 158.607 251.487 Q158.607 244.358 156.779 240.816 Q154.973 237.251 151.339 237.251 M151.339 233.548 Q157.149 233.548 160.205 238.154 Q163.283 242.737 163.283 251.487 Q163.283 260.214 160.205 264.821 Q157.149 269.404 151.339 269.404 Q145.529 269.404 142.45 264.821 Q139.394 260.214 139.394 251.487 Q139.394 242.737 142.45 238.154 Q145.529 233.548 151.339 233.548 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><polyline clip-path=\"url(#clip192)\" style=\"stroke:#009af9; stroke-linecap:butt; stroke-linejoin:round; stroke-width:4; stroke-opacity:1; fill:none\" points=\"\n",
       "  260.231,1445.72 280.752,1445.72 301.273,1445.72 321.794,1445.72 342.314,1445.72 362.835,1445.71 383.356,1443.03 403.877,1445.72 424.398,1445.71 444.919,1445.71 \n",
       "  465.44,1438.08 485.961,541.588 506.482,732.668 527.003,484.961 547.524,537.891 568.045,87.9763 588.566,316.007 609.087,626.838 629.608,642.24 650.129,391.09 \n",
       "  670.65,504.298 691.171,221.419 711.692,204.295 732.213,639.954 752.734,281.356 773.255,521.385 793.776,544.658 814.297,564.671 834.818,396.201 855.339,662.533 \n",
       "  875.86,538.443 896.381,662.817 916.902,157.876 937.423,351.772 957.944,445.596 978.465,326.178 998.986,682.092 1019.51,540.842 1040.03,554.226 1060.55,577.011 \n",
       "  1081.07,212.897 1101.59,408.781 1122.11,518.708 1142.63,491.949 1163.15,535.069 1183.68,626.176 1204.2,316.922 1224.72,511.988 1245.24,519.636 1265.76,316.408 \n",
       "  1286.28,321.982 1306.8,588.477 1327.32,476.169 1347.84,552.89 1368.36,568.922 1388.88,545.341 1409.41,520.848 1429.93,532.301 1450.45,389.064 1470.97,364.05 \n",
       "  1491.49,467.754 1512.01,742.525 1532.53,686.527 1553.05,495.803 1573.57,428.959 1594.09,245.993 1614.62,298.414 1635.14,646.842 1655.66,512.245 1676.18,492.106 \n",
       "  1696.7,305.054 1717.22,504.78 1737.74,564.843 1758.26,465.059 1778.78,405.149 1799.3,328.381 1819.83,373.848 1840.35,467.444 1860.87,433.954 1881.39,472.162 \n",
       "  1901.91,423.667 1922.43,580.162 1942.95,589.947 1963.47,262.048 1983.99,381.349 2004.51,299.793 2025.04,420.924 2045.56,417.294 2066.08,492.237 2086.6,391.663 \n",
       "  2107.12,440.728 2127.64,560.412 2148.16,618.257 2168.68,243.961 2189.2,597.192 2209.72,519.911 2230.25,436.543 2250.77,372.865 2271.29,516.26 2291.81,431.262 \n",
       "  \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip192)\" style=\"stroke:#e26f46; stroke-linecap:butt; stroke-linejoin:round; stroke-width:4; stroke-opacity:1; fill:none\" points=\"\n",
       "  260.231,1445.72 280.752,1444.84 301.273,1445.72 321.794,1443 342.314,1445.72 362.835,1445.72 383.356,1445.72 403.877,1445.72 424.398,1445.72 444.919,1445.72 \n",
       "  465.44,1445.72 485.961,544.733 506.482,750.116 527.003,496.661 547.524,545.27 568.045,112.117 588.566,330.677 609.087,621.667 629.608,642.28 650.129,426.871 \n",
       "  670.65,504.61 691.171,223.518 711.692,207.142 732.213,632.241 752.734,284.764 773.255,531.274 793.776,561.173 814.297,554.266 834.818,388.983 855.339,620.531 \n",
       "  875.86,557.843 896.381,663.822 916.902,170.148 937.423,340.551 957.944,462.448 978.465,316.048 998.986,691.922 1019.51,544.124 1040.03,551.513 1060.55,599.089 \n",
       "  1081.07,226.385 1101.59,423.874 1122.11,540.015 1142.63,531.399 1163.15,551.163 1183.68,610.341 1204.2,321.732 1224.72,527.551 1245.24,535.178 1265.76,314.906 \n",
       "  1286.28,347.592 1306.8,575.553 1327.32,486.237 1347.84,531.395 1368.36,556.779 1388.88,545.691 1409.41,524.316 1429.93,562.182 1450.45,378.763 1470.97,370.491 \n",
       "  1491.49,449.894 1512.01,728.921 1532.53,683.782 1553.05,512.209 1573.57,414.444 1594.09,244.786 1614.62,299.075 1635.14,663.185 1655.66,514.811 1676.18,515.379 \n",
       "  1696.7,308.75 1717.22,506.007 1737.74,590.359 1758.26,481.261 1778.78,398.252 1799.3,328.881 1819.83,330.744 1840.35,461.928 1860.87,428.34 1881.39,486.279 \n",
       "  1901.91,484.992 1922.43,598.775 1942.95,595.769 1963.47,270.894 1983.99,390.106 2004.51,317.689 2025.04,411.386 2045.56,412.299 2066.08,493.387 2086.6,398.729 \n",
       "  2107.12,441.377 2127.64,580.024 2148.16,573.334 2168.68,302.482 2189.2,601.034 2209.72,510.438 2230.25,450.941 2250.77,376.24 2271.29,491.928 2291.81,427.068 \n",
       "  \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip192)\" style=\"stroke:#3da44d; stroke-linecap:butt; stroke-linejoin:round; stroke-width:4; stroke-opacity:1; fill:none\" points=\"\n",
       "  260.231,1444.52 280.752,1444.52 301.273,1444.52 321.794,1444.52 342.314,1444.52 362.835,1444.52 383.356,1444.52 403.877,1444.52 424.398,1444.52 444.919,1444.52 \n",
       "  465.44,1444.52 485.961,370.879 506.482,370.879 527.003,370.879 547.524,370.879 568.045,370.879 588.566,370.879 609.087,370.879 629.608,370.879 650.129,370.879 \n",
       "  670.65,370.879 691.171,370.879 711.692,370.879 732.213,370.879 752.734,370.879 773.255,370.879 793.776,370.879 814.297,370.879 834.818,370.879 855.339,370.879 \n",
       "  875.86,370.879 896.381,370.879 916.902,370.879 937.423,370.879 957.944,370.879 978.465,370.879 998.986,370.879 1019.51,370.879 1040.03,370.879 1060.55,370.879 \n",
       "  1081.07,370.879 1101.59,370.879 1122.11,370.879 1142.63,370.879 1163.15,370.879 1183.68,370.879 1204.2,370.879 1224.72,370.879 1245.24,370.879 1265.76,370.879 \n",
       "  1286.28,370.879 1306.8,370.879 1327.32,370.879 1347.84,370.879 1368.36,370.879 1388.88,370.879 1409.41,370.879 1429.93,370.879 1450.45,370.879 1470.97,370.879 \n",
       "  1491.49,370.879 1512.01,370.879 1532.53,370.879 1553.05,370.879 1573.57,370.879 1594.09,370.879 1614.62,370.879 1635.14,370.879 1655.66,370.879 1676.18,370.879 \n",
       "  1696.7,370.879 1717.22,370.879 1737.74,370.879 1758.26,370.879 1778.78,370.879 1799.3,370.879 1819.83,370.879 1840.35,370.879 1860.87,370.879 1881.39,370.879 \n",
       "  1901.91,370.879 1922.43,370.879 1942.95,370.879 1963.47,370.879 1983.99,370.879 2004.51,370.879 2025.04,370.879 2045.56,370.879 2066.08,370.879 2086.6,370.879 \n",
       "  2107.12,370.879 2127.64,370.879 2148.16,370.879 2168.68,370.879 2189.2,370.879 2209.72,370.879 2230.25,370.879 2250.77,370.879 2271.29,370.879 2291.81,370.879 \n",
       "  \n",
       "  \"/>\n",
       "<path clip-path=\"url(#clip190)\" d=\"\n",
       "M1895.96 302.578 L2280.97 302.578 L2280.97 95.2176 L1895.96 95.2176  Z\n",
       "  \" fill=\"#ffffff\" fill-rule=\"evenodd\" fill-opacity=\"1\"/>\n",
       "<polyline clip-path=\"url(#clip190)\" style=\"stroke:#000000; stroke-linecap:butt; stroke-linejoin:round; stroke-width:4; stroke-opacity:1; fill:none\" points=\"\n",
       "  1895.96,302.578 2280.97,302.578 2280.97,95.2176 1895.96,95.2176 1895.96,302.578 \n",
       "  \"/>\n",
       "<polyline clip-path=\"url(#clip190)\" style=\"stroke:#009af9; stroke-linecap:butt; stroke-linejoin:round; stroke-width:4; stroke-opacity:1; fill:none\" points=\"\n",
       "  1919.89,147.058 2063.45,147.058 \n",
       "  \"/>\n",
       "<path clip-path=\"url(#clip190)\" d=\"M2103.21 134.384 L2096.87 151.583 L2109.58 151.583 L2103.21 134.384 M2100.57 129.778 L2105.87 129.778 L2119.05 164.338 L2114.18 164.338 L2111.04 155.472 L2095.46 155.472 L2092.31 164.338 L2087.38 164.338 L2100.57 129.778 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M2128.77 133.62 L2128.77 146.606 L2134.65 146.606 Q2137.91 146.606 2139.69 144.916 Q2141.48 143.227 2141.48 140.102 Q2141.48 137 2139.69 135.31 Q2137.91 133.62 2134.65 133.62 L2128.77 133.62 M2124.09 129.778 L2134.65 129.778 Q2140.46 129.778 2143.42 132.416 Q2146.41 135.032 2146.41 140.102 Q2146.41 145.217 2143.42 147.833 Q2140.46 150.449 2134.65 150.449 L2128.77 150.449 L2128.77 164.338 L2124.09 164.338 L2124.09 129.778 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M2176.24 159.407 L2176.24 150.125 L2168.6 150.125 L2168.6 146.282 L2180.87 146.282 L2180.87 161.12 Q2178.17 163.041 2174.9 164.037 Q2171.64 165.009 2167.93 165.009 Q2159.83 165.009 2155.25 160.287 Q2150.69 155.541 2150.69 147.092 Q2150.69 138.62 2155.25 133.898 Q2159.83 129.153 2167.93 129.153 Q2171.31 129.153 2174.35 129.986 Q2177.4 130.819 2179.97 132.44 L2179.97 137.416 Q2177.38 135.217 2174.46 134.106 Q2171.54 132.995 2168.33 132.995 Q2161.98 132.995 2158.79 136.537 Q2155.62 140.078 2155.62 147.092 Q2155.62 154.083 2158.79 157.625 Q2161.98 161.166 2168.33 161.166 Q2170.8 161.166 2172.75 160.75 Q2174.69 160.31 2176.24 159.407 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M2194.09 133.62 L2194.09 160.495 L2199.74 160.495 Q2206.89 160.495 2210.2 157.254 Q2213.54 154.014 2213.54 147.023 Q2213.54 140.078 2210.2 136.861 Q2206.89 133.62 2199.74 133.62 L2194.09 133.62 M2189.42 129.778 L2199.02 129.778 Q2209.07 129.778 2213.77 133.967 Q2218.47 138.134 2218.47 147.023 Q2218.47 155.958 2213.74 160.148 Q2209.02 164.338 2199.02 164.338 L2189.42 164.338 L2189.42 129.778 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><polyline clip-path=\"url(#clip190)\" style=\"stroke:#e26f46; stroke-linecap:butt; stroke-linejoin:round; stroke-width:4; stroke-opacity:1; fill:none\" points=\"\n",
       "  1919.89,198.898 2063.45,198.898 \n",
       "  \"/>\n",
       "<path clip-path=\"url(#clip190)\" d=\"M2103.21 186.224 L2096.87 203.423 L2109.58 203.423 L2103.21 186.224 M2100.57 181.618 L2105.87 181.618 L2119.05 216.178 L2114.18 216.178 L2111.04 207.312 L2095.46 207.312 L2092.31 216.178 L2087.38 216.178 L2100.57 181.618 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M2128.77 185.46 L2128.77 212.335 L2134.42 212.335 Q2141.57 212.335 2144.88 209.094 Q2148.21 205.854 2148.21 198.863 Q2148.21 191.918 2144.88 188.701 Q2141.57 185.46 2134.42 185.46 L2128.77 185.46 M2124.09 181.618 L2133.7 181.618 Q2143.74 181.618 2148.44 185.807 Q2153.14 189.974 2153.14 198.863 Q2153.14 207.798 2148.42 211.988 Q2143.7 216.178 2133.7 216.178 L2124.09 216.178 L2124.09 181.618 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M2160.6 181.618 L2167.56 181.618 L2176.38 205.136 L2185.25 181.618 L2192.22 181.618 L2192.22 216.178 L2187.66 216.178 L2187.66 185.83 L2178.74 209.534 L2174.04 209.534 L2165.13 185.83 L2165.13 216.178 L2160.6 216.178 L2160.6 181.618 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M2201.5 181.618 L2208.47 181.618 L2217.29 205.136 L2226.15 181.618 L2233.12 181.618 L2233.12 216.178 L2228.56 216.178 L2228.56 185.83 L2219.65 209.534 L2214.95 209.534 L2206.04 185.83 L2206.04 216.178 L2201.5 216.178 L2201.5 181.618 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><polyline clip-path=\"url(#clip190)\" style=\"stroke:#3da44d; stroke-linecap:butt; stroke-linejoin:round; stroke-width:4; stroke-opacity:1; fill:none\" points=\"\n",
       "  1919.89,250.738 2063.45,250.738 \n",
       "  \"/>\n",
       "<path clip-path=\"url(#clip190)\" d=\"M2087.38 233.458 L2116.61 233.458 L2116.61 237.393 L2104.35 237.393 L2104.35 268.018 L2099.65 268.018 L2099.65 237.393 L2087.38 237.393 L2087.38 233.458 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M2137.52 251.814 Q2139.02 252.323 2140.43 253.99 Q2141.87 255.657 2143.3 258.573 L2148.05 268.018 L2143.03 268.018 L2138.61 259.152 Q2136.89 255.68 2135.27 254.545 Q2133.67 253.411 2130.9 253.411 L2125.8 253.411 L2125.8 268.018 L2121.13 268.018 L2121.13 233.458 L2131.68 233.458 Q2137.61 233.458 2140.53 235.934 Q2143.44 238.411 2143.44 243.411 Q2143.44 246.675 2141.92 248.828 Q2140.41 250.981 2137.52 251.814 M2125.8 237.3 L2125.8 249.569 L2131.68 249.569 Q2135.06 249.569 2136.78 248.018 Q2138.51 246.444 2138.51 243.411 Q2138.51 240.379 2136.78 238.851 Q2135.06 237.3 2131.68 237.3 L2125.8 237.3 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M2153.54 233.458 L2158.23 233.458 L2158.23 254.453 Q2158.23 260.008 2160.25 262.462 Q2162.26 264.893 2166.78 264.893 Q2171.27 264.893 2173.28 262.462 Q2175.29 260.008 2175.29 254.453 L2175.29 233.458 L2179.99 233.458 L2179.99 255.032 Q2179.99 261.791 2176.64 265.24 Q2173.3 268.689 2166.78 268.689 Q2160.23 268.689 2156.87 265.24 Q2153.54 261.791 2153.54 255.032 L2153.54 233.458 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /><path clip-path=\"url(#clip190)\" d=\"M2188.77 233.458 L2210.62 233.458 L2210.62 237.393 L2193.44 237.393 L2193.44 247.624 L2209.9 247.624 L2209.9 251.559 L2193.44 251.559 L2193.44 264.082 L2211.04 264.082 L2211.04 268.018 L2188.77 268.018 L2188.77 233.458 Z\" fill=\"#000000\" fill-rule=\"evenodd\" fill-opacity=\"1\" /></svg>\n"
      ]
     },
     "execution_count": 158,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X_HPCA, VTEST = AltMin(Y, 100, 10, 1e-3);\n",
    "plot(VTEST, label=\"APGD\")\n",
    "plot!(VAR_ADMM, label=\"ADMM\")\n",
    "plot!(Π, label=\"TRUE\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 157,
   "id": "5eb5da2c-0592-49ae-8791-fdf80a4a879d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  6.874914 seconds (100.65 k allocations: 2.884 GiB, 1.93% gc time)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "([-20.379597698056614 18.717997882916265 … -47.10610052280907 -4.973421475324903; -7.2133008472028175 14.553317670313156 … -51.64308057643732 1.1373961366773826; … ; 13.761893464887882 6.425622801346693 … 51.601533267603536 25.59389853723345; 4.999529341730698 -16.630622253651445 … -9.977410613548956 2.7220295714220994], [1.0e-9, 1.0e-9, 1.0e-9, 1.0e-9, 0.4355674783471102, 0.2760574883834456, 3.383076489662483, 0.0031071003342823867, 0.0033896920013734328, 0.5516743359024637  …  819.9167271218474, 727.4100840446564, 532.9537592884075, 963.7056157658996, 614.6713893088614, 809.1531724242678, 816.1443008431035, 851.4730809893933, 770.2837725248198, 859.0636146563717])"
      ]
     },
     "execution_count": 157,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "@time begin\n",
    "  AltMin(Y, 100, 10, 0.2e-2)\n",
    "end"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 108,
   "id": "df3511d2-269f-4a84-88fc-0a3128db22a3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  7.821692 seconds (205.54 k allocations: 3.179 GiB, 1.90% gc time, 1.52% compilation time)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "([-0.12463269599305948 0.03956105310329805 … 0.008253979428597402 -0.01623898237303816; -0.07555503279065834 -0.01315808748845751 … -0.13373453224163107 -0.004559337308998601; … ; 0.0260386236547617 -0.1743476697556499 … 0.018890865222680863 0.3239491485466074; -0.01844492220754795 0.11485636363052462 … 0.12686349872495786 -0.03385782321803714], [1.0e-9, 0.729394249341736, 3.9597569816479694e-8, 2.274518423181442, 2.4033164596381178e-8, 1.1469825495143014e-8, 3.15106465256252e-9, 9.892536770263568e-9, 1.5134296021751067e-9, 3.890131760378128e-9  …  840.9697037347228, 724.8747880695781, 730.4772155560432, 957.2711297047358, 707.2826065208686, 783.1422155200677, 832.9611587509395, 895.5106688001619, 798.6413855336118, 852.9507055481245])"
      ]
     },
     "execution_count": 108,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "@time begin\n",
    "  HPCA_UNKNOWN_ADMM(Y, 100, 10, 0.01, 1.005, U_PPCA)\n",
    "end"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8a194551-492f-457f-b53f-1f292a42aa1b",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Julia (31 threads) 1.9.0",
   "language": "julia",
   "name": "julia-_31-threads_-1.9"
  },
  "language_info": {
   "file_extension": ".jl",
   "mimetype": "application/julia",
   "name": "julia",
   "version": "1.9.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
