{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "b13b00e6",
   "metadata": {},
   "source": [
    "## Experiments on the ACAS Xu benchmarks\n",
    "\n",
    "The networks (in .nnet format) and properties are taken from https://github.com/guykatzz/ReluplexCav2017/tree/master/nnet \n",
    "(also available at onnx format with properties at https://github.com/stanleybak/vnncomp2021/tree/main/benchmarks/acasxu) \n",
    "\n",
    "Convert in Julia file by jupyter nbconvert --to script ACASXu.ipynb"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "79a4b13f",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "WARNING: import of Base.rand into Main conflicts with an existing identifier; ignored.\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "propagate_gaussians_multhread (generic function with 1 method)"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "include(\"../src/DSI.jl\")\n",
    "include(\"../src/Zono_utils.jl\")\n",
    "include(\"../src/PZono.jl\")\n",
    "include(\"../src/DSZ.jl\")\n",
    "include(\"../src/parametrics.jl\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "c6cc4229",
   "metadata": {},
   "outputs": [],
   "source": [
    "using PyPlot"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4fcd622c",
   "metadata": {},
   "source": [
    "## Specifying input ranges, networks and properties"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "037dd1c5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5-element Vector{Interval{Float64}}:\n",
       "    [-0.303532, -0.298552]\n",
       "    [-0.0095493, 0.0095493]\n",
       " [0, 0]\n",
       "     [0.318181, 0.5]\n",
       "     [0.0833333, 0.166667]"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# from https://github.com/stanleybak/vnncomp2021/blob/main/benchmarks/acasxu/generate.py\n",
    "\n",
    "init_lb_prop_1_2 = [55947.691, -pi, -pi, 1145, 0]\n",
    "init_ub_prop_1_2 = [60760, pi, pi, 1200, 60]\n",
    "acas_input_1_2 = interval.(init_lb_prop_1_2,init_ub_prop_1_2)\n",
    "\n",
    "init_lb_prop_3 = [1500, -0.06, 3.1, 980, 960]\n",
    "init_ub_prop_3 = [1800, 0.06, pi, 1200, 1200]\n",
    "acas_input_3 = interval.(init_lb_prop_3,init_ub_prop_3)\n",
    "    \n",
    "init_lb_prop_4 = [1500, -0.06, 0, 1000, 700]\n",
    "init_ub_prop_4 = [1800, 0.06, 0, 1200, 800]\n",
    "acas_input_4 = interval.(init_lb_prop_4,init_ub_prop_4)\n",
    "\n",
    "init_lb_prop_5 = [250, 0.2, -3.141592, 100, 0]\n",
    "init_ub_prop_5 = [400, 0.4, -3.141592 + 0.005, 400, 400]\n",
    "acas_input_5 = interval.(init_lb_prop_5,init_ub_prop_5)\n",
    "\n",
    "init_lb_prop_61 = [12000, 0.7, -3.141592, 100, 0]\n",
    "init_ub_prop_61 = [62000, 3.141592, -3.141592 + 0.005, 1200, 1200]\n",
    "acas_input_61 = interval.(init_lb_prop_61,init_ub_prop_61)\n",
    "\n",
    "init_lb_prop_62 = [12000, -3.141592, -3.141592, 100, 0]\n",
    "init_ub_prop_62 = [62000, -0.7, -3.141592 + 0.005, 1200, 1200]\n",
    "acas_input_62 = interval.(init_lb_prop_62,init_ub_prop_62)\n",
    "\n",
    "init_lb_prop_7 = [0, -3.141592, -3.141592, 100, 0]\n",
    "init_ub_prop_7 = [60760, 3.141592, 3.141592, 1200, 1200]\n",
    "acas_input_7 = interval.(init_lb_prop_7,init_ub_prop_7)\n",
    "\n",
    "init_lb_prop_8 = [0, -3.141592, -0.1, 600, 600]\n",
    "init_ub_prop_8 = [60760, -0.75*3.141592, 0.1, 1200, 1200]\n",
    "acas_input_8 = interval.(init_lb_prop_8,init_ub_prop_8)\n",
    "\n",
    "init_lb_prop_9 = [2000, -0.4, -3.141592, 100, 0]\n",
    "init_ub_prop_9 = [7000, -0.14, -3.141592 + 0.01, 150, 150]\n",
    "acas_input_9 = interval.(init_lb_prop_9,init_ub_prop_9)\n",
    "\n",
    "#output labels = ['Clear of Conflict (COC)', 'Weak Left', 'Weak Right', 'Strong Left', 'Strong Right']\n",
    "\n",
    "\n",
    "function get_spec(prop::Int64)\n",
    "    if (prop == 2)\n",
    "        desc = \"Unsafe if COC is maximal\"\n",
    "        # Unsafe if y1 > y2 and y1 > y3 and y1 > y4 and y1 > y5\n",
    "        mat = [[-1. 1. 0. 0. 0.]\n",
    "               [-1. 0. 1. 0. 0.]\n",
    "               [-1. 0. 0. 1. 0.]\n",
    "               [-1. 0. 0. 0. 1.]]\n",
    "        rhs = [0., 0., 0., 0.]\n",
    "    elseif (prop == 3) || (prop == 4)\n",
    "        desc = \"Unsafe if COC is minimal\"\n",
    "        mat = [[1. -1. 0. 0. 0.]\n",
    "               [1. 0. -1. 0. 0.]\n",
    "               [1. 0. 0. -1. 0.]\n",
    "               [1. 0. 0. 0. -1.]]\n",
    "        rhs = [0., 0., 0., 0.]\n",
    "    end\n",
    "\n",
    "    return (desc, mat, rhs)\n",
    "end\n",
    "\n",
    "mat_spec_2 = get_spec(2)[2]\n",
    "rhs_spec_2 = get_spec(2)[3]\n",
    "mat_spec_3_4 = get_spec(3)[2]\n",
    "rhs_spec_3_4 = get_spec(3)[3]\n",
    "\n",
    "mat_essai_1 = [[-1. 1. 0. 0. 0.]\n",
    "[0. 0. 0. 0. 0.]\n",
    "[0. 0. 0. 0. 0.]\n",
    "[0. 0. 0. 0. 0.]]\n",
    "\n",
    "mat_essai_2 = [[0. 0. 0. 0. 0.]\n",
    "[-1. 0. 1. 0. 0.]\n",
    "[0. 0. 0. 0. 0.]\n",
    "[0. 0. 0. 0. 0.]]\n",
    "\n",
    "mat_essai_3 = [[0. 0. 0. 0. 0.]\n",
    "[0. 0. 0. 0. 0.]\n",
    "[-1. 0. 0. 1. 0.]\n",
    "[0. 0. 0. 0. 0.]]\n",
    "\n",
    "mat_essai_4 = [[0. 0. 0. 0. 0.]\n",
    "[0. 0. 0. 0. 0.]\n",
    "[0. 0. 0. 0. 0.]\n",
    "[-1. 0. 0. 0. 1.]]\n",
    "\n",
    "\n",
    "acas_nnet_1_2 = read_nnet(\"./ACASXU_networks/ACASXU_run2a_1_2_batch_2000.nnet\", last_layer_activation = Id());\n",
    "acas_nnet_1_3 = read_nnet(\"./ACASXU_networks/ACASXU_run2a_1_3_batch_2000.nnet\", last_layer_activation = Id());\n",
    "acas_nnet_1_4 = read_nnet(\"./ACASXU_networks/ACASXU_run2a_1_4_batch_2000.nnet\", last_layer_activation = Id());\n",
    "acas_nnet_1_5 = read_nnet(\"./ACASXU_networks/ACASXU_run2a_1_5_batch_2000.nnet\", last_layer_activation = Id());\n",
    "acas_nnet_1_6 = read_nnet(\"./ACASXU_networks/ACASXU_run2a_1_6_batch_2000.nnet\", last_layer_activation = Id());\n",
    "acas_nnet_2_2 = read_nnet(\"./ACASXU_networks/ACASXU_run2a_2_2_batch_2000.nnet\", last_layer_activation = Id());\n",
    "acas_nnet_2_9 = read_nnet(\"./ACASXU_networks/ACASXU_run2a_2_9_batch_2000.nnet\", last_layer_activation = Id());\n",
    "acas_nnet_3_1 = read_nnet(\"./ACASXU_networks/ACASXU_run2a_3_1_batch_2000.nnet\", last_layer_activation = Id());\n",
    "acas_nnet_3_6 = read_nnet(\"./ACASXU_networks/ACASXU_run2a_3_6_batch_2000.nnet\", last_layer_activation = Id());\n",
    "acas_nnet_3_7 = read_nnet(\"./ACASXU_networks/ACASXU_run2a_3_7_batch_2000.nnet\", last_layer_activation = Id());\n",
    "acas_nnet_4_1 = read_nnet(\"./ACASXU_networks/ACASXU_run2a_4_1_batch_2000.nnet\", last_layer_activation = Id());\n",
    "acas_nnet_4_7 = read_nnet(\"./ACASXU_networks/ACASXU_run2a_4_7_batch_2000.nnet\", last_layer_activation = Id());\n",
    "acas_nnet_5_3 = read_nnet(\"./ACASXU_networks/ACASXU_run2a_5_3_batch_2000.nnet\", last_layer_activation = Id());\n",
    "acas_nnet_1_7 = read_nnet(\"./ACASXU_networks/ACASXU_run2a_1_7_batch_2000.nnet\", last_layer_activation = Id());\n",
    "acas_nnet_1_9 = read_nnet(\"./ACASXU_networks/ACASXU_run2a_1_9_batch_2000.nnet\", last_layer_activation = Id());\n",
    "\n",
    "\n",
    "# Prop 2: x0 >= 0.6\n",
    "# x0 <= 0.6798577687\n",
    "# x1 >= -0.5\n",
    "# x1 <= 0.5\n",
    "# x2 >= -0.5\n",
    "# x2 <= 0.5\n",
    "# x3 >= 0.45\n",
    "# x3 <= 0.5\n",
    "# x4 >= -0.5\n",
    "# x4 <= -0.45\n",
    "# +y0 -y1 >= 0\n",
    "# +y0 -y2 >= 0\n",
    "# +y0 -y3 >= 0\n",
    "# +y0 -y4 >= 0\n",
    "\n",
    "init_lb_prop_1_2 = [0.6, -0.5, -0.5, 0.45, -0.5]\n",
    "init_ub_prop_1_2 = [0.6798577687, 0.5, 0.5, 0.5, -0.45]\n",
    "acas_input_1_2 = interval.(init_lb_prop_1_2,init_ub_prop_1_2)\n",
    "\n",
    "# Prop 3:\n",
    "# x0 >= -0.3035311561\n",
    "# x0 <= -0.2985528119\n",
    "# x1 >= -0.0095492966\n",
    "# x1 <= 0.0095492966\n",
    "# x2 >= 0.4933803236\n",
    "# x2 <= 0.5\n",
    "# x3 >= 0.3\n",
    "# x3 <= 0.5\n",
    "# x4 >= 0.3\n",
    "# x4 <= 0.5\n",
    "# +y0 -y1 <= 0\n",
    "# +y0 -y2 <= 0\n",
    "# +y0 -y3 <= 0\n",
    "# +y0 -y4 <= 0\n",
    "\n",
    "init_lb_prop_3 = [-0.3035311561, -0.0095492966, 0.4933803236, 0.3, 0.3]\n",
    "init_ub_prop_3 = [-0.2985528119, 0.0095492966, 0.5, 0.5, 0.5]\n",
    "acas_input_3 = interval.(init_lb_prop_3,init_ub_prop_3)\n",
    "\n",
    "# Prop4:\n",
    "# x0 >= -0.3035311561\n",
    "# x0 <= -0.2985528119\n",
    "# x1 >= -0.0095492966\n",
    "# x1 <= 0.0095492966\n",
    "# x2 >= 0\n",
    "# x2 <= 0\n",
    "# x3 >= 0.3181818182\n",
    "# x3 <= 0.5\n",
    "# x4 >= 0.0833333333\n",
    "# x4 <= 0.1666666667\n",
    "# +y0 -y1 <= 0\n",
    "# +y0 -y2 <= 0\n",
    "# +y0 -y3 <= 0\n",
    "# +y0 -y4 <= 0\n",
    "\n",
    "init_lb_prop_4 = [-0.3035311561, -0.0095492966, 0.0, 0.3181818182, 0.0833333333]\n",
    "init_ub_prop_4 = [-0.2985528119, 0.0095492966,0.0, 0.5, 0.1666666667]\n",
    "acas_input_4 = interval.(init_lb_prop_4,init_ub_prop_4)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a1d29b9c",
   "metadata": {},
   "source": [
    "## DSZ Analysis"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "cf334067",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5-element Vector{pbox}:\n",
       " Pbox: \t  ~ normal ( range=[0.098799, 1.1811], mean=[0.13993, 1.1399], var=0.00017715)\n",
       " Pbox: \t  ~ normal ( range=[-1.015, 1.015], mean=[-0.5, 0.5], var=0.027778)\n",
       " Pbox: \t  ~ normal ( range=[-1.015, 1.015], mean=[-0.5, 0.5], var=0.027778)\n",
       " Pbox: \t  ~ normal ( range=[-0.050752, 1.0008], mean=[-0.025, 0.975], var=6.9444e-5)\n",
       " Pbox: \t  ~ normal ( range=[-1.0008, 0.050752], mean=[-0.975, 0.025], var=6.9444e-5)"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "means_inputs = (init_ub_prop_1_2 .+ init_lb_prop_1_2) ./ 2\n",
    "std_inputs = (init_ub_prop_1_2 .- means_inputs) ./ 3\n",
    "input_boxes_desc = [([means_inputs[i] - 0.5, means_inputs[i] + 0.5], std_inputs[i]) for i in 1:5]\n",
    "input_boxes = [normal(interval(input_boxes_desc[i][1][1], input_boxes_desc[i][1][2]), input_boxes_desc[i][2]) for i in 1:5]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "e43df83f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "5-element Vector{Vector{Any}}:\n",
       " [[0.11505185752639391, 0.14014528678818738, 0.12290875795520713, 0.1284870900219245, 0.1326269051504597, 0.1349688295366952, 0.12541624349377017, 0.1381670728663365, 0.13544009680103064, 0.14593135917337996  …  0.10404225485853455, 0.1115855554908771, 0.14131270019310388, 0.12501741423821167, 0.1455315211680621, 0.13830331694912734, 0.12068615209567599, 0.1553621243302381, 0.15367443962304722, 0.12417866477517686], [0.23979531725408806, 0.24731310516213212, 0.24698312592291918, 0.23363848725311737, 0.25137168491513256, 0.21452528653097347, 0.2315289573361718, 0.2419963304126277, 0.2441133129935694, 0.25810069118357437  …  0.25391722931030863, 0.24479355836885786, 0.24709471079245132, 0.24429780602021806, 0.22941612623769303, 0.23103162841497535, 0.21555755675371033, 0.2270365351144389, 0.2548126208954919, 0.2551907477269805], [0.34243710841291625, 0.33965416123162706, 0.33629640251793597, 0.32305308501073066, 0.34074606304463206, 0.3680354291244681, 0.3619254340567812, 0.3347655572870377, 0.3242997418828376, 0.3056673079304435  …  0.33958623264039645, 0.34332850704127166, 0.36210643707899975, 0.34499113043179336, 0.3110829702156143, 0.33991221361198426, 0.3406742263204415, 0.35458621742842644, 0.33182456686275846, 0.3465760593744299], [0.47321425368851333, 0.4248800142983283, 0.4196624670956151, 0.4354996785136582, 0.4448233311069186, 0.42936406999883137, 0.46768224442024425, 0.44743381761612994, 0.4516120155089647, 0.447469666683696  …  0.483595945983201, 0.4415878999119062, 0.4412532490264078, 0.46718624772789713, 0.4174670585780479, 0.4299681395669736, 0.42231445972077175, 0.4265941923328402, 0.43160984600957203, 0.452961208807988], [0.5450593751038858, 0.5399602350070738, 0.5557185412260461, 0.5218654774334761, 0.5188258122224256, 0.5355578703995261, 0.5692929495744746, 0.5438223902347753, 0.5315086254486625, 0.5339047022005009  …  0.5552958739862179, 0.529496024505629, 0.5385180465084625, 0.5202141667501694, 0.5486937442224499, 0.5419539094795816, 0.5495054590330819, 0.540083201159417, 0.5378200110794216, 0.5371059873973586], [0.6788323243648573, 0.6429339939980155, 0.6485572942561361, 0.6239423080214003, 0.6387917627347736, 0.6530871357122938, 0.6678303711313432, 0.6274263253605129, 0.6246008719576647, 0.6262153191588379  …  0.6424703338167104, 0.6579277572836469, 0.6208560119862896, 0.6496601493859646, 0.639855379862505, 0.6341897029843698, 0.6473473493114564, 0.628885370781586, 0.6205367110094969, 0.6317944119387209], [0.7319218959256484, 0.7096846493335792, 0.72159911502632, 0.7376938886562657, 0.7492331950243917, 0.744692725475496, 0.7523341716918146, 0.7269839176370277, 0.7286203357333202, 0.724845619937235  …  0.7233049436571699, 0.7549800808338833, 0.7555620878165797, 0.7327058728388782, 0.7238050311819673, 0.7401538089200724, 0.7385970802311971, 0.7285149438744912, 0.7411810065030087, 0.7277114687185051], [0.8383059681729462, 0.8379985124761904, 0.8214039281816978, 0.8331412256768055, 0.8148291971390156, 0.8424450312466729, 0.8551935649573007, 0.860834921069326, 0.802792046179012, 0.8468002586055874  …  0.8308720350172668, 0.8417118961923663, 0.8286502231233173, 0.8477865279688995, 0.8281125609342919, 0.8659098221973466, 0.8530702028828258, 0.8485189269287015, 0.8549813157832963, 0.8285516535280412], [0.9264573117640754, 0.9336456212976377, 0.9356330051614627, 0.948176016091318, 0.9075341281461835, 0.9382901163245861, 0.9620382400936821, 0.9411793648777682, 0.9427029123274769, 0.9451542244249121  …  0.9364528131564706, 0.9473600977536599, 0.9369386559721424, 0.9418176568104853, 0.9279443072662671, 0.9310419485524501, 0.922815684065659, 0.944478938509835, 0.9231863029854765, 0.9562280408115315], [1.0401331703801062, 1.0199892612631714, 1.062695762102928, 1.0119790698819957, 1.0441293914675882, 1.0403877875828, 1.0451004280159557, 1.0443358474842763, 1.0301183322429806, 1.0230595077990567  …  1.0454724588210276, 1.031852998740883, 1.0470401980254305, 1.039624432167307, 1.0329257310824176, 1.0313006058666883, 1.0239293397220561, 1.0435132837225105, 1.0339503802021761, 1.0335028653123444], [1.1296422934006811, 1.1287234640101549, 1.1559849751263973, 1.1602541415667482, 1.1520164852157813, 1.127153614782075, 1.135498650753067, 1.137908491213411, 1.1105685873868187, 1.1196798691728729  …  1.1450604274817529, 1.1515072874817385, 1.15190397458066, 1.1688170959275215, 1.1703475284089746, 1.0850377895296897, 1.1038761077221757, 1.1383669971329975, 1.1686791424869043, 1.1385332786469702]]\n",
       " [[-0.6170942485869271, -0.21217767683253103, -0.941536774877612, -0.6391361725884972, -0.46908172096017764, -0.5708175882593979, -0.4615982022381346, -0.616530799877749, -0.5828081385227202, -0.1202240290610967  …  -0.5667915280066387, -0.4039260630369826, -0.5190279087856818, -0.5527202214043452, -0.4430279579343185, -0.1587168620965885, -0.21883897547237582, -0.2919815197255875, -0.2670255777754677, -0.6631920422744669], [-0.4748806436397606, -0.41506501081348857, -0.2151038067113576, -0.514749488524835, -0.30139546251924204, -0.2149001751932697, -0.4014563604513862, -0.23235348877557377, -0.5139672506602564, -0.6245595489440428  …  -0.48522756670909434, -0.43876455655145763, -0.20617556801084058, -0.20653796210117023, -0.370975690317114, -0.43830040871684056, -0.4330998764019525, -0.5115633605568272, -0.12118083801666896, 0.11763041727139609], [-0.6067807031898348, -0.030304760919834358, -0.5024620131987544, -0.45054979624423797, -0.34430448254725143, -0.050036541962244975, -0.04991586117776025, -0.5760059770143908, -0.2504004898961233, -0.19522908850193182  …  0.0002632144282322964, -0.5214300645433392, -0.23733581062783912, -0.18089508458555648, -0.6787850726397812, -0.02717537405406463, -0.5310920211334246, -0.10498265308164163, -0.12616848283217144, -0.34518658653831397], [-0.27478022591693224, -0.27247312275180974, -0.17084940497924772, -0.46142735535809537, -0.5173300566294827, -0.19953057550746, -0.20455298330287888, -0.3782588356538914, -0.2805584561023321, -0.12207521054608768  …  -0.17641018161818336, -0.16939409371301067, -0.18896824482522004, -0.40601031835520446, -0.37271036558213516, -0.3426604884632385, -0.2912385511074234, -0.18131649540986614, -0.1969548495201737, -0.2625248675506184], [-0.08262006202989083, -0.10642925745339155, 0.1331511714700392, -0.2158213427701333, -0.16103956115066906, -0.1365168265806561, -0.24239666868914095, -0.24218641796248008, -0.1346040357222375, -0.32369708813707143  …  0.10685275895213149, -0.22581157717151568, 0.06001281321672485, -0.09923763390499103, 0.05194989573930983, -0.035939237601172826, -0.07746021843111936, -0.14402190185008984, -0.2252519432927631, -0.054988017014567056], [-0.23353978890206742, -0.13512064021715256, -0.16181227925677694, -0.15030593394017328, -0.11995206760531785, -0.11111043337293525, -0.10924912090983536, -0.1295675375857641, -0.11279355944221911, 0.028757133910949147  …  0.08989941755935979, 0.1353679084923481, 0.14106593293229394, -0.048975279234467664, -0.07891042739737536, 0.03683922505049465, -0.1710862978551854, -0.13970955750467268, 0.14330585505579455, 0.01809127430390331], [-0.09442595168365345, 0.18639261974622223, 0.33967455580174055, 0.15206073881271323, 0.01914984624141983, 0.07097444278084306, 0.35227683332476545, 0.07983078563131946, 0.12447883965724645, 0.015245496172136686  …  0.27450370176531746, -0.35619190881203555, 0.021128683428491987, 0.28220683502791055, -0.2399867879390918, -0.007307859296780215, -0.00722552303084646, 0.21396060708652428, -0.025415100853659976, 0.05641175467912697], [0.016202830672988937, 0.1566569315970937, 0.17712776267955496, 0.04426254468829611, 0.12840274730433426, 0.03673558706445948, 0.2696716742353897, 0.12285189300493915, -0.003020742795476028, -0.08030703283738226  …  0.3412905496339207, 0.03828489965693513, 0.1590786595573497, 0.04718464481492656, 0.035411643216988746, 0.27887155492352556, 0.42602353873877574, 0.03199263522110719, 0.0881800861973551, 0.2576311794880256], [0.279629788389592, 0.6652349226970116, 0.4126489248328953, 0.210376348646365, -0.02272823285456843, 0.251409690534526, 0.3345827667849323, 0.10982509961371646, -0.044452874818196764, -0.08307577694082219  …  0.17758563634260677, 0.27567279505090647, 0.510156235313776, 0.17666477114073678, 0.13176883494631542, 0.38322883382469275, 0.38298967076443535, 0.31756401572830517, 0.19925393826925158, 0.005653133133089662], [0.3616928486852631, 0.4807953184511132, 0.31243659872109636, 0.5707520992236129, 0.4173713603096025, 0.5875251454942432, 0.5684770574725808, 0.6517495301754178, 0.432290374180168, 0.31667239905582084  …  0.6267727866183413, 0.46883599631871686, 0.4907609875047815, 0.4882265734123813, 0.3255675049819488, 0.46114596320534235, 0.5566650591569029, 0.3917097008693259, 0.38921769630274533, 0.4842552220460578], [0.47945069466087153, 0.389076404222279, 0.6552500756432713, 0.6559696566064632, 0.6769406340689142, 0.3143851631085803, 0.674133191489734, 0.20034351865547156, 0.6367523816106178, 0.23162302844813026  …  0.523910906515012, 0.549294473671715, 0.537628540319677, 0.7684719975863722, 0.31587600275934347, 0.358828889004473, 0.5582088575505687, 0.4741706017720751, 0.41196732006182746, 0.5088749741141237]]\n",
       " [[-0.34396055045720386, -0.24612046405465246, -0.5351097169907677, -0.6212976479968921, -0.4765688617170126, -0.6791012329070392, -0.5624840369462599, -0.5831064787488462, -0.4332111266875017, -0.5553694206252888  …  -0.3976305517653031, -0.5388964997997465, -0.40595465607112025, -0.689778805664433, -0.44380946464264603, -0.38478794575162345, -0.6219694908421524, -0.42763318470965545, -0.6324126331079855, -0.6082705121238033], [-0.4079731830732809, -0.420131757321645, -0.2515514369864785, -0.4086232317058871, -0.36174126362971054, -0.3540957151323749, -0.5956964810217807, -0.4737193215374349, -0.605197735634474, -0.09764567459953168  …  -0.4488644776725017, -0.6437082569800385, -0.1822740471924315, -0.6166234956714475, -0.3032745139845836, -0.5991884293831027, -0.4977127429351529, -0.2508288675842509, -0.5129804824794476, -0.31733565164887023], [-0.1558926028318301, -0.49853549817332504, -0.02495968448435881, -0.317823012522399, -0.2456826396550481, -0.4129156152564687, -0.43868639519741576, -0.47534666771164863, -0.25873258605810895, -0.6311279596014343  …  -0.3966081979930243, -0.5507864332019342, -0.2740192088231077, -0.38908147845940605, -0.4986543994704256, -0.2918261148440944, -0.27185684788911635, 0.08373797643342025, -0.7189797776520673, -0.1739552520802285], [-0.4844381772115958, -0.18074011547897573, -0.26292614176180756, -0.1489546780377328, -0.10921272042960332, -0.1028285481849615, -0.12641877164486373, -0.020723464461031044, -0.1110375848043392, -0.1946773557163327  …  -0.15137552566332135, -0.28654938466998486, -0.03523419885176157, -0.4140336076832905, -0.31576192395162794, -0.3317050923151258, -0.08155257322817178, -0.1311919722342065, -0.15849647614917936, -0.33132671421781956], [0.05732060404885513, -0.1660757338086923, -0.1425433269816372, -0.3981348708860192, 0.07829919064802274, 0.22102340161391207, -0.23263888821746503, -0.6215476187587491, 0.21250076505876306, -0.02295381075266351  …  -0.10142868611492323, -0.1692810927235461, -0.10098301653596192, -0.11967742322846175, -0.48532779254871405, -0.046494381535149995, -0.2783457428626825, -0.1858183622094366, -0.38151855042852056, -0.09587078715938549], [-0.09665104740295839, -0.07490092877998832, 0.18101957621334558, 0.12781116654695857, 0.08579456215760141, -0.07952019302148564, 0.14984147289301936, -0.2584056471199362, -0.06759301363014959, -0.05786232210972635  …  -0.23048008781793572, -0.11295091621176115, -0.18986529054052992, 0.01195617684733847, -0.1348115216460866, 0.20533839976093596, -0.3042617328083145, 0.038549032834354166, 0.08232633936529908, 0.08279978307883012], [0.24199348454963052, 0.2642321251742004, 0.32181772928485697, 0.20711788745295742, -0.0066816983086045575, 0.26075808508172066, 0.2841207283303129, 0.11205565582430603, 0.1949752258746155, 0.2184279747305717  …  0.4377166179333109, 0.19534750543240922, -0.12077795087846949, -0.08357299824284029, -0.10576263774585924, 0.0556885923122872, 0.08547517862827003, 0.06463399232499491, 0.2266739516848801, 0.01917544058130534], [0.550723828888112, 0.004853194792187017, 0.31485124741542964, 0.0827347460068573, 0.2499934642737755, 0.2414338504154863, 0.2661585174670681, 0.03163995619626319, -0.1337463096589973, 0.27967343772316955  …  0.26951987368641916, 0.4199443697727598, 0.21345063391819466, 0.42971910887238357, 0.11417240360573276, 0.34473698376395023, 0.2784249216600945, -0.0733057256849997, -0.22485996618519455, 0.2676517080947632], [0.08747441979388894, 0.3906998850916469, 0.33055105584752953, -0.05473941696483148, 0.3650502559908651, 0.4057027405394895, 0.4884954456682563, 0.03051913036536807, 0.11112655048681146, 0.2857037642327413  …  0.29357563209755566, 0.1182634092405582, 0.5634250284385456, 0.3301298147261558, 0.17508593192764388, 0.42617491643438404, 0.3037694632669069, 0.05770055147125287, 0.24756283857733732, 0.292727576424092], [0.35663366582156886, 0.4042567504149646, 0.31565137224369966, 0.3625933004190503, 0.4847788811143502, 0.3903329529667553, 0.4855245445700769, -0.018033657585000654, 0.5475890667141525, 0.1894245440872569  …  0.44248378090600277, 0.425782664831286, 0.48801329547589645, 0.6291890630028575, -0.11050737641681675, 0.5202400194933411, 0.17383679321217102, 0.20611559112654615, 0.105215412981413, 0.2400184151494411], [0.47375728506517994, 0.795631042258003, 0.4577731686021177, 0.8411784093615121, 0.68744505055264, 0.5255853693891072, 0.35772912141077556, 0.6785556793254208, 0.5374781232577343, 0.4106209931973918  …  0.5673900538816439, 0.6168378292846132, 0.44301663746911857, 0.5661453561555013, 0.6239928032152475, 0.43869993413729874, 0.5027922803574644, 0.39161078906861285, 0.434178030716771, 0.525932451674361]]\n",
       " [[-0.033410996999107906, -0.02234836234550456, -0.019514163333470884, -0.04202700763670047, -0.027833954262010404, -0.025799765171716834, -0.022456037870827002, -0.02575956349663158, -0.030594580673700675, -0.039837766780337854  …  -0.033785088526265314, -0.008783062304051067, -0.026745450508145755, -0.021878280164390734, -0.02349903320792296, -0.031161477794296878, -0.022081083638270157, -0.018571015318076256, -0.0337757826852214, -0.027537009632975916], [0.07394559296772298, 0.0671503228661901, 0.06359358643764829, 0.07749818264657399, 0.07489041967327803, 0.08436150331221202, 0.08614457718840156, 0.07997100639699183, 0.08632230470196639, 0.06785396201318568  …  0.08965948889698251, 0.0624263710295725, 0.06320046852384899, 0.0750907494398244, 0.07141702809500722, 0.0746691714431479, 0.07956111616317704, 0.08288902275273363, 0.07480489662102328, 0.09505584897008519], [0.15811152408303894, 0.1609214921703419, 0.17050542136966676, 0.1805747911071575, 0.1709952085970345, 0.17874244656678928, 0.17703173262249622, 0.15952766887669756, 0.16463752451264227, 0.1960318910208673  …  0.17183963186024115, 0.17371906256467842, 0.17076602411462227, 0.17770373627666924, 0.17487928487678017, 0.17775992011484143, 0.1777856672407974, 0.18364846753694428, 0.1866331373605906, 0.1719212824049424], [0.2720420566666574, 0.283885775580299, 0.2842870868699313, 0.2881425367588383, 0.28608517261423366, 0.2766919532071079, 0.2869640679557128, 0.25695955083050664, 0.26634718414229647, 0.27375798343653623  …  0.2719152969327822, 0.2630836241842298, 0.27451793724707757, 0.29552424858825577, 0.27429686150536337, 0.2859285767173639, 0.28389548810634224, 0.27610444086057195, 0.2618711884234898, 0.2683655737560775], [0.36904367538781563, 0.3674906029502423, 0.37373315009069086, 0.39040401978922257, 0.3698140819532555, 0.36975590843355516, 0.3704673964258168, 0.37561151869257925, 0.3621477920536594, 0.3641865421539104  …  0.36260139398391766, 0.38549694017062464, 0.3881685847707449, 0.3772806237777145, 0.39204131682138277, 0.3805814145392519, 0.37225787786527076, 0.3783627727478518, 0.37522795707682277, 0.3812120986960215], [0.4897420046044421, 0.47362714016725005, 0.469930083429383, 0.4813190939445447, 0.47569467815785327, 0.4619594399596256, 0.4692470175868013, 0.4655497280254595, 0.4825224076337372, 0.4748557957180716  …  0.4749708092367732, 0.4730492414590526, 0.4839113031431135, 0.46322380437041794, 0.47505028296455176, 0.45470194154739474, 0.47647033380993725, 0.4818152597500854, 0.4801333530121582, 0.4698667204104775], [0.5708628483803463, 0.5674333849722613, 0.5715906384748033, 0.5860454345135275, 0.5860659018311511, 0.6001389837820582, 0.567655247153013, 0.5821571853744753, 0.5625134853599534, 0.5819297368954207  …  0.5730979426064331, 0.5823758372036669, 0.5664387932115403, 0.5802045970691183, 0.5724681096828359, 0.5714098640301719, 0.5884154720475054, 0.5931062080025521, 0.5734202707385154, 0.5737296620525472], [0.6768015970070451, 0.6830131812356691, 0.6684577514489312, 0.6678776654409017, 0.6676468499985719, 0.6593322800878341, 0.6659823719572506, 0.6805561565680095, 0.6699509675995982, 0.6751347623315013  …  0.6701136033233341, 0.6765592221472839, 0.6841435125640462, 0.6794921045815012, 0.67310749544371, 0.6615539626351542, 0.6774191916566692, 0.6758865696031003, 0.6767301716678873, 0.6786331334359795], [0.7697541259348298, 0.783817570598018, 0.7796778787178649, 0.7787292472025868, 0.7728891515164337, 0.7760928660297031, 0.7818937580083801, 0.7660823969372346, 0.7787350585603744, 0.7839876586341266  …  0.7709922363479867, 0.7850571049177222, 0.7689277998855422, 0.7781071898713843, 0.774112581942151, 0.7744135496335195, 0.7752545618168452, 0.7575242821229226, 0.781715559400082, 0.7671501125542864], [0.8743188882960322, 0.8724127021445724, 0.8702365483729566, 0.8738235702335067, 0.8672434426350589, 0.8715625395979937, 0.8727950758143025, 0.8709876770293266, 0.8604297633893716, 0.8717692485490196  …  0.8687164642240873, 0.8754272397763926, 0.8659203572691048, 0.8697916070974953, 0.8741538630809652, 0.8943052803384169, 0.8886276364195936, 0.872391187312299, 0.8722257725286934, 0.892346341359336], [0.9849099748542521, 0.9764605739349015, 0.9696295638953321, 0.9880996221952062, 0.9792855280403001, 0.9857945711015071, 0.9794968541535397, 0.9913660798667752, 0.9657811790144459, 0.962424991635319  …  0.9710154564825745, 0.9642887807698663, 0.970801659017272, 0.9822631106131887, 0.9818574364396069, 0.9710852055550904, 0.9720773356206498, 0.9674326704140268, 0.9816590445116258, 0.9792768941971051]]\n",
       " [[-0.976095676292169, -0.9787005342100913, -0.9735463567195605, -0.9895434574349713, -0.9790217994830682, -0.9676069659952582, -0.9724679816250026, -0.974494590295727, -0.9877181626307023, -0.9911574551906751  …  -0.9828410912764931, -0.9725476820509367, -0.9682240663842129, -0.983772835417764, -0.9619419660562444, -0.9594544179736804, -0.9538959725840312, -0.9860062113952945, -0.9698114595456785, -0.9762034452713914], [-0.872575372148383, -0.8825718014784285, -0.8816390173162917, -0.879705895924679, -0.8881504889607248, -0.8781717985609214, -0.8753181441126441, -0.872173080390452, -0.8639315148712121, -0.858097608105948  …  -0.8735874837775727, -0.8779994342000261, -0.869107246307334, -0.8769564891399175, -0.8684693122677061, -0.8794767838656563, -0.88221457640318, -0.8672938479071435, -0.8733590878399347, -0.8935094617555054], [-0.7850731730026077, -0.781809410162896, -0.7664250077054177, -0.7851733938560614, -0.7764375399009573, -0.7686783739723432, -0.77740582017287, -0.7814677359340905, -0.7720272562121842, -0.7692859267413393  …  -0.763146110276315, -0.7732212853251315, -0.7731724881756781, -0.7734820176571144, -0.7771028442032064, -0.7759775858880733, -0.7835044444585528, -0.7870901327114455, -0.7756904974368756, -0.7663597220703263], [-0.678362321655326, -0.6796651825658232, -0.6770059196395244, -0.6796317896710087, -0.6676209235680424, -0.6709823385937842, -0.6837560912077336, -0.6745270492905868, -0.6930794227609423, -0.6810842878617163  …  -0.6758664459162398, -0.6575632316921425, -0.6887696769375387, -0.6799808593497434, -0.6958337176099015, -0.6735019857238538, -0.6798907104611771, -0.6709835300242531, -0.6597297220978232, -0.6740798466023437], [-0.5747236414215798, -0.5725937121783694, -0.5796604441910307, -0.5750103516864271, -0.5731660028250497, -0.5800686662851575, -0.585634005986326, -0.5631587179924089, -0.5696750844626959, -0.5672127082901909  …  -0.5820736105255082, -0.5807886893644736, -0.5743902879322069, -0.5838708503363089, -0.5746436594760014, -0.5849262103784136, -0.5771069519837309, -0.5732860064619265, -0.5679940170348342, -0.5880845238624106], [-0.46459898835811947, -0.48204936784642305, -0.4693997432080349, -0.48569411758296693, -0.47587867273650714, -0.4750675620652381, -0.4796436549987606, -0.48733997159606535, -0.48988963814555025, -0.4741898835237881  …  -0.4600181413652459, -0.4752009343149607, -0.4785334150337456, -0.4776608582370367, -0.4853862840886315, -0.4835166884614643, -0.47938153852549126, -0.4779590706220619, -0.4942402436548235, -0.4840510574211145], [-0.38231560399282505, -0.37131681596253535, -0.37409639371253645, -0.37366734192109496, -0.3708365221062963, -0.3677961318290226, -0.3713815631225924, -0.39142630099109793, -0.36909668102289594, -0.35855884885306333  …  -0.3918402847250276, -0.3821316119249407, -0.37046633605522006, -0.3916899126894408, -0.3682700271935831, -0.36854249306916076, -0.37280254331468304, -0.38930007578258086, -0.3629638305021762, -0.37986525218874173], [-0.27316887866251155, -0.27524802561533035, -0.2684639583590044, -0.269068812389537, -0.2720249190593762, -0.2747055833328829, -0.2744388775595196, -0.26024418886421175, -0.2806588820287331, -0.2776754254486989  …  -0.2689467118377186, -0.28110002565868425, -0.28331340164706986, -0.30071630036305214, -0.2695219792374285, -0.2610704439456137, -0.2703251989245418, -0.2825628292077377, -0.2666054825392044, -0.266803877766289], [-0.17571121570145118, -0.18388039259104053, -0.1634355859507262, -0.19320356626433938, -0.16963611089945912, -0.17725632758206541, -0.16402826060007825, -0.18234261699063012, -0.18442911655660746, -0.17234583422253769  …  -0.1680861696462157, -0.18189109696332012, -0.18314359369750158, -0.17267774876356737, -0.1700216574053531, -0.16799575718935544, -0.1688601458072943, -0.1826095050327165, -0.1702653304930754, -0.17390616788310018], [-0.08232521071262203, -0.0722095343751198, -0.07848373242304843, -0.0787366873016707, -0.0825532845299104, -0.07033636408729908, -0.07150039012897962, -0.08566780361609966, -0.06809779907431636, -0.08293756615362208  …  -0.07689709900197562, -0.06677634657747447, -0.0826531470213845, -0.08476377396426822, -0.06726384262255158, -0.07666280022635552, -0.07530637272128365, -0.08313818327816991, -0.08016030423208467, -0.06130026304804867], [0.023451606761685576, 0.04744068777528581, 0.024500353918021234, 0.010652833071614794, 0.03986602960771131, 0.025576477709061428, 0.03358168545199695, 0.04623470394011266, 0.024021867665596715, 0.037117641274679605  …  0.02914451648326291, 0.02794726661545302, 0.021114958672765013, 0.015276882827497217, 0.034656501915581055, 0.0311471426145729, 0.032236281847730586, 0.02781118031144507, 0.01182692102756546, 0.023367612081334838]]"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "psamplespoint1 = gaussian_samples(input_boxes_desc, 200, 0.01)\n",
    "psamplespoint2 = gaussian_samples(input_boxes_desc, 200, 0.02)\n",
    "psamplespoint5 = gaussian_samples(input_boxes_desc, 200, 0.05)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "955652c4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(5,)\n",
      "(51,)\n",
      "(200,)\n"
     ]
    }
   ],
   "source": [
    "println(size(psamplespoint1))\n",
    "println(size(psamplespoint1[1]))\n",
    "println(size(psamplespoint1[1][1]))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2cb08346-3474-4012-bd80-89a72068205a",
   "metadata": {},
   "source": [
    "## This is inefficient, we don't run this yet!!"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "a02fe39f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "161051\n",
      "1000 3.9233598709106445\n",
      "7.824841022491455\n",
      "11.640527963638306\n",
      "15.568771839141846\n"
     ]
    },
    {
     "ename": "LoadError",
     "evalue": "InterruptException:",
     "output_type": "error",
     "traceback": [
      "InterruptException:",
      "",
      "Stacktrace:",
      " [1] _generic_matvecmul!(C::Vector{Any}, tA::Char, A::Matrix{Float64}, B::Vector{Any}, _add::LinearAlgebra.MulAddMul{true, true, Bool, Bool})",
      "   @ LinearAlgebra /opt/homebrew/Cellar/julia/1.11.2_1/share/julia/stdlib/v1.11/LinearAlgebra/src/matmul.jl:852",
      " [2] generic_matvecmul!",
      "   @ /opt/homebrew/Cellar/julia/1.11.2_1/share/julia/stdlib/v1.11/LinearAlgebra/src/matmul.jl:787 [inlined]",
      " [3] _mul!",
      "   @ /opt/homebrew/Cellar/julia/1.11.2_1/share/julia/stdlib/v1.11/LinearAlgebra/src/matmul.jl:73 [inlined]",
      " [4] mul!",
      "   @ /opt/homebrew/Cellar/julia/1.11.2_1/share/julia/stdlib/v1.11/LinearAlgebra/src/matmul.jl:70 [inlined]",
      " [5] mul!",
      "   @ /opt/homebrew/Cellar/julia/1.11.2_1/share/julia/stdlib/v1.11/LinearAlgebra/src/matmul.jl:253 [inlined]",
      " [6] *",
      "   @ /opt/homebrew/Cellar/julia/1.11.2_1/share/julia/stdlib/v1.11/LinearAlgebra/src/matmul.jl:60 [inlined]",
      " [7] affine_map(layer::Layer{ReLU, Float64}, x::Vector{Any})",
      "   @ NeuralVerification ~/.julia/packages/NeuralVerification/DpyyR/src/utils/util.jl:352",
      " [8] compute_output(nnet::Network, input::Vector{Any})",
      "   @ NeuralVerification ~/.julia/packages/NeuralVerification/DpyyR/src/utils/util.jl:128",
      " [9] propagate_gaussians_performance(psamples::Vector{Vector{Any}}, network::Network, num_samples::Int64)",
      "   @ Main ~/DSZAnalysisThessi/src/parametrics.jl:95"
     ]
    }
   ],
   "source": [
    "outpspoint5 = propagate_gaussians_performance(psamplespoint5, acas_nnet_1_6, 200)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "7787408c",
   "metadata": {},
   "outputs": [],
   "source": [
    "pz = pbox_approximate_nnet(acas_nnet_1_6, input_boxes, true)\n",
    "network_name = \"acas_xu_1_6\"\n",
    "num_samples = 200\n",
    "\n",
    "for i in 1:1#length(outps[1][1])\n",
    "    #ProbabilityBoundsAnalysis.plot(pz[i])\n",
    "    # Create a new figure\n",
    "    fig = figure()\n",
    "    fig = figure(figsize=(6, 4))\n",
    "    for j in 1:length(outps)\n",
    "        data = [outps[j][k][i] for k in 1:num_samples]\n",
    "        cdf = empirical_cdf(data)\n",
    "        plot(cdf[1], cdf[2], marker=\"o\", linestyle=\"-\")\n",
    "    end\n",
    "    filename = string(\"../pictures/empirical_cdfs_propagation_\",network_name,\"_\", i, \".png\")  # Proper string concatenation\n",
    "    PyPlot.savefig(filename)\n",
    "end\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "4ddc734f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1 2\n",
      "2 1\n",
      "3 3\n",
      "4 7\n"
     ]
    }
   ],
   "source": [
    "a = [2,1,3,7]\n",
    "for (idx, elem) in enumerate(a)\n",
    "    println(idx,\" \" ,elem)\n",
    "end"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fdb1eb3a-11fb-4b10-b0b7-ab4e08000c33",
   "metadata": {},
   "source": [
    "## Setup multithreaded env "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "74a14907-3644-4651-9237-396c15391965",
   "metadata": {},
   "source": [
    "(Restart needed afterwards)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ca2eaa6e-abad-42ce-b90a-a8074f550ad0",
   "metadata": {},
   "outputs": [],
   "source": [
    "using IJulia\n",
    "installkernel(\"Julia (11 threads)\", env=Dict(\"JULIA_NUM_THREADS\"=>\"11\"))\n",
    "Threads.nthreads()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d09f25e4-c944-4d2f-a2cd-5baf50b19f5e",
   "metadata": {},
   "source": [
    "check if it works:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "d993e70b-a9e0-410c-942a-87392964f3d1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "16"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Threads.nthreads()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b41d7bdf-5326-4ae1-bd46-65057e10eb1a",
   "metadata": {},
   "source": [
    "## This is what we can run!"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "c9d743ef",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total combinations to process: 161051\n",
      "Time: 0.7843995849291484 minutes\n",
      "Processed 161051 combinations\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "161051-element Vector{Vector{Vector{Float64}}}:\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [0.007923473803639749, -0.09232976862930542, 0.025048943858231216, -0.08614913044076929, 0.08351253157016407], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.01863868096937849, -0.019379301011543896, -0.01941377559018462, -0.019309047752778894, -0.019341046906688537], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0114413069268783, -0.02433013684918964, -0.00761948285599671, -0.027705095135379762, -0.0010327256561135714], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0202109618883751, -0.01916933003041699, -0.019163009293958897, -0.018890924099635373, -0.01868827913570978], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.014572269006938508, -0.01965286322669033, -0.017437870438804893, -0.0205574139055109, -0.016557795280928753], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.02023533842188116, -0.019167645696911893, -0.019179753432383945, -0.018861925386985313, -0.01864061917795569], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.014607677786511043, -0.01974647910992003, -0.01793253551766127, -0.02040946131717195, -0.017261773969962917], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.02028374048921854, -0.019128435877870782, -0.019171460620416365, -0.01876271753796565, -0.018532799434583084], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.014471680243216038, -0.01988947997279396, -0.017887834883970378, -0.020504318965993286, -0.017312794368978653], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.020130834541980662, -0.019326837070025714, -0.019373107261645876, -0.01919067648342194, -0.019248717330809642], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.013730650146015256, -0.02240525276320975, -0.01244042844275263, -0.02514610665558379, -0.011202432186127221], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.012393149431942986, -0.025797744734122253, -0.004241971990659513, -0.03089692018914264, -0.0011490806100574145], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.009093266854019021, -0.030183306690053285, 0.007096203717121562, -0.03792727697174007, 0.013159024891864927], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0053262937989650115, -0.03589862233417941, 0.018394523945520058, -0.04763031324163658, 0.026165871996746713], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.005486421107095466, -0.058261237082183594, 0.028515087649138602, -0.08606495031988988, 0.041557418586452954], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.005015357511094307, -0.09509625558437346, 0.04165267537665536, -0.1427043304600066, 0.06718379071086718], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.014132066211839794, -0.01960106940119467, -0.019691965804992138, -0.019547409664656745, -0.01970817611228434], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0190256132753521, -0.01939889372356262, -0.019462336171297556, -0.019329295452942357, -0.01940116233801732], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.016493377019362043, -0.01947459880803369, -0.01950187486029129, -0.019538881853045496, -0.01953381346118311], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.006892716131844782, -0.016871795042853487, -0.01961772366647971, -0.017227573540542423, -0.017954241615778768], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.018771360552608883, -0.019348761763195145, -0.019359802615221355, -0.019280577672696725, -0.01927456974973183], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.01429098389186515, -0.01944484774137649, -0.018016424259773626, -0.01978532373875462, -0.017328884369442295], [-0.014289546580866591, -0.019385053877653338, -0.017382070402999328, -0.019880858591116057, -0.016353345619717446], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.011764249850218733, -0.019671093816165757, -0.019726839216234696, -0.01974594678525366, -0.019831520359841245], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0202193865962501, -0.019382576830903095, -0.019541855259510996, -0.019168545822854842, -0.019239938220568832], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.001600365131955172, -0.01811357515246304, -0.01990094013634663, -0.02053592163827308, -0.01862748460425912], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.020239780128906665, -0.01911304054452147, -0.019088072366273048, -0.01878359914908484, -0.01848766773317575], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.014439441110974418, -0.019527277860830947, -0.018523016308284065, -0.019828354334753145, -0.018090525689764745], [-0.014474531142499188, -0.019544052086099644, -0.01806478386193402, -0.02003900696990389, -0.01741258363193325], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " ⋮\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.020018978390954324, -0.01826634388838857, -0.01772388408011481, -0.017873373581568024, -0.017148356836838234], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]\n",
       " [[-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]  …  [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343], [-0.0201359, -0.0193657, -0.019445, -0.0192374, -0.019343]]"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "outpspoint5 = propagate_gaussians_multhread(psamplespoint5, acas_nnet_1_6, 200)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d0545f1a-35e3-4893-80a1-95d6884ecf68",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total combinations to process: 11881376"
     ]
    }
   ],
   "source": [
    "outpspoint2 = propagate_gaussians_multhread(psamplespoint2, acas_nnet_1_6, 10)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e4afec2b",
   "metadata": {},
   "source": [
    "### Property 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "2238b2a0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "vect_nb_focal_elem for Property 2 = [5, 80, 50, 6, 5]:\n"
     ]
    }
   ],
   "source": [
    "# Defining the number of focal element for each component of the input vector for Property 2\n",
    "vect_nb_focal_elem = [5, 80, 50, 6, 5]\n",
    "println(\"vect_nb_focal_elem for Property 2 = \",vect_nb_focal_elem,\":\")\n",
    "# the true flag in init_pbox_Normal means truncating the focal elements to restrict the range to [lb,ub]\n",
    "acas_inputpbox_1_2 = init_pbox_Normal(init_lb_prop_1_2,init_ub_prop_1_2,vect_nb_focal_elem,true)\n",
    "plot(acas_inputpbox_1_2[4])\n",
    "PyPlot.savefig(\"../pictures/acasxu4.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "c35db142",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " 23.620334 seconds (203.86 M allocations: 53.091 GiB, 31.38% gc time, 1.43% compilation time)\n",
      "Property 2, net-1-6 : [0, 0.0199884]\n"
     ]
    },
    {
     "ename": "InterruptException",
     "evalue": "InterruptException:",
     "output_type": "error",
     "traceback": [
      "InterruptException:\n",
      "\n",
      "Stacktrace:\n",
      "  [1] copy\n",
      "    @ ./array.jl:350 [inlined]\n",
      "  [2] #47\n",
      "    @ ./none:0 [inlined]\n",
      "  [3] iterate\n",
      "    @ ./generator.jl:48 [inlined]\n",
      "  [4] collect_to!(dest::Vector{Vector{Float64}}, itr::Base.Generator{Tuple{Symbol, Symbol}, LazySets.var\"#47#48\"{Zonotope{Float64, Vector{Float64}, Matrix{Float64}}}}, offs::Int64, st::Int64)\n",
      "    @ Base ./array.jl:849\n",
      "  [5] collect_to_with_first!\n",
      "    @ ./array.jl:827 [inlined]\n",
      "  [6] collect\n",
      "    @ ./array.jl:801 [inlined]\n",
      "  [7] copy\n",
      "    @ ~/.julia/packages/LazySets/qUfTe/src/Interfaces/LazySet.jl:520 [inlined]\n",
      "  [8] translate(X::Zonotope{Float64, Vector{Float64}, Matrix{Float64}}, v::Vector{Float64})\n",
      "    @ LazySets ~/.julia/packages/LazySets/qUfTe/src/Interfaces/LazySet.jl:470\n",
      "  [9] #affine_map#46\n",
      "    @ ~/.julia/packages/LazySets/qUfTe/src/Interfaces/LazySet.jl:481 [inlined]\n",
      " [10] affine_map(M::Matrix{Float64}, X::Zonotope{Float64, Vector{Float64}, Matrix{Float64}}, v::Vector{Float64})\n",
      "    @ LazySets ~/.julia/packages/LazySets/qUfTe/src/Interfaces/LazySet.jl:480\n",
      " [11] zono_approximate_nnet(nnet::Network, input::Hyperrectangle{Float64, Vector{Float64}, Vector{Float64}})\n",
      "    @ Main ~/DSZAnalysisThessi/src/Zono_utils.jl:25\n",
      " [12] dsz_approximate_nnet_and_condition_nostorage(nnet::Network, input::Vector{pbox}, mat_spec::Matrix{Float64}, rhs_spec::Vector{Float64}, print_pbox::Bool)\n",
      "    @ Main ~/DSZAnalysisThessi/src/DSZ.jl:265\n",
      " [13] dsz_approximate_nnet_and_condition_nostorage\n",
      "    @ ~/DSZAnalysisThessi/src/DSZ.jl:233 [inlined]\n",
      " [14] macro expansion\n",
      "    @ ./timing.jl:581 [inlined]\n",
      " [15] top-level scope\n",
      "    @ ~/DSZAnalysisThessi/examples/jl_notebook_cell_df34fa98e69747e1a8f8a730347b8e2f_X10sZmlsZQ==.jl:6"
     ]
    }
   ],
   "source": [
    "\n",
    "@time vec_proba = dsz_approximate_nnet_and_condition_nostorage(acas_nnet_1_6, acas_inputpbox_1_2, mat_spec_2,rhs_spec_2) \n",
    "println(\"Property 2, net-1-6 : \", vec_proba[length(vec_proba)])\n",
    "\n",
    "\n",
    "@time vec_proba = dsz_approximate_nnet_and_condition_nostorage(acas_nnet_2_2, acas_inputpbox_1_2, mat_spec_2,rhs_spec_2)\n",
    "println(\"Property 2, net-2-2 : \", vec_proba[length(vec_proba)])\n",
    "\n",
    "\n",
    "@time vec_proba = dsz_approximate_nnet_and_condition_nostorage(acas_nnet_2_9, acas_inputpbox_1_2, mat_spec_2,rhs_spec_2) \n",
    "println(\"Property 2, net-2-9 : \", vec_proba[length(vec_proba)])\n",
    "\n",
    "\n",
    "@time vec_proba = dsz_approximate_nnet_and_condition_nostorage(acas_nnet_3_1, acas_inputpbox_1_2, mat_spec_2,rhs_spec_2) \n",
    "println(\"Property 2, net-3-1 : \", vec_proba[length(vec_proba)])\n",
    "\n",
    "\n",
    "@time vec_proba = dsz_approximate_nnet_and_condition_nostorage(acas_nnet_3_6, acas_inputpbox_1_2, mat_spec_2,rhs_spec_2) \n",
    "println(\"Property 2, net-3-6 : \", vec_proba[length(vec_proba)])\n",
    "\n",
    "\n",
    "@time vec_proba = dsz_approximate_nnet_and_condition_nostorage(acas_nnet_3_7, acas_inputpbox_1_2, mat_spec_2,rhs_spec_2)\n",
    "println(\"Property 2, net-3-7 : \", vec_proba[length(vec_proba)])\n",
    "\n",
    "\n",
    "@time vec_proba = dsz_approximate_nnet_and_condition_nostorage(acas_nnet_4_1, acas_inputpbox_1_2, mat_spec_2,rhs_spec_2)\n",
    "println(\"Property 2, net-4-1 : \", vec_proba[length(vec_proba)])\n",
    "\n",
    "\n",
    "@time vec_proba = dsz_approximate_nnet_and_condition_nostorage(acas_nnet_4_7, acas_inputpbox_1_2, mat_spec_2,rhs_spec_2)\n",
    "println(\"Property 2, net-4-7 : \", vec_proba[length(vec_proba)])\n",
    "\n",
    "\n",
    "@time vec_proba = dsz_approximate_nnet_and_condition_nostorage(acas_nnet_5_3, acas_inputpbox_1_2, mat_spec_2,rhs_spec_2)\n",
    "println(\"Property 2, net-5-3 : \", vec_proba[length(vec_proba)])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6256e8f2",
   "metadata": {},
   "source": [
    "### Properties 3 and 4"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d00be161",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Defining the number of focal element for each component of the input vector for Properties 3 and 4\n",
    "vect_nb_focal_elem = [5, 20, 1, 6, 5]\n",
    "println(\"vect_nb_focal_elem for Properties 3 and 4 = \",vect_nb_focal_elem,\":\")\n",
    "acas_inputpbox_3 = init_pbox_Normal(init_lb_prop_3,init_ub_prop_3,vect_nb_focal_elem,true)\n",
    "\n",
    "\n",
    "@time vec_proba = dsz_approximate_nnet_and_condition_nostorage(acas_nnet_1_7, acas_inputpbox_3, mat_spec_3_4,rhs_spec_3_4) \n",
    "println(\"Property 3, net-1-7 : \", vec_proba[length(vec_proba)])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f80687b5",
   "metadata": {},
   "outputs": [],
   "source": [
    "#vect_nb_focal_elem = [5, 20, 1, 6, 5] \n",
    "acas_inputpbox_4 = init_pbox_Normal(init_lb_prop_4,init_ub_prop_4,vect_nb_focal_elem,true)\n",
    "\n",
    "\n",
    "@time vec_proba = dsz_approximate_nnet_and_condition_nostorage(acas_nnet_1_9, acas_inputpbox_4, mat_spec_3_4,rhs_spec_3_4) \n",
    "println(\"Property 4, net-1-9 : \", vec_proba[length(vec_proba)])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "fc4306d1",
   "metadata": {},
   "source": [
    "### Heuristic refinement/optimization of focal element "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3c2bb42b",
   "metadata": {},
   "outputs": [],
   "source": [
    "#@time dsz_focal_refinement(acas_nnet_1_6,init_lb_prop_1_2,init_ub_prop_1_2, mat_spec_2,rhs_spec_2 , true, 0.05)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Julia (16 threads) 1.11.2",
   "language": "julia",
   "name": "julia-_16-threads_-1.11"
  },
  "language_info": {
   "file_extension": ".jl",
   "mimetype": "application/julia",
   "name": "julia",
   "version": "1.11.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
