{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "49abd003-313a-4f6d-afa3-b5fb6089a5df",
   "metadata": {},
   "source": [
    "# Load data, baselines, and codes for plotting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "da242218-78e6-4a5f-8b6f-424f50e117c3",
   "metadata": {},
   "outputs": [],
   "source": [
    "using JLD2\n",
    "using LinearAlgebra\n",
    "using Plots\n",
    "using StatsPlots\n",
    "using Colors\n",
    "using DataFrames\n",
    "include(\"../methods/IgTensors/decomp.jl\")\n",
    "include(\"../methods/IgTensors/get_msk.jl\");\n",
    "include(\"../methods/IgTensors/LBTC.jl\");\n",
    "\n",
    "# include baselines\n",
    "include(\"../methods/TC/PTRC_RW.jl\")\n",
    "include(\"../methods/TC/HaLRTC.jl\")\n",
    "include(\"../methods/TC/SiLRTC.jl\")\n",
    "include(\"../methods/TC/SiLRTCTT.jl\")\n",
    "\n",
    "# Plot setting\n",
    "pyplot()\n",
    "iter_max    = 20;\n",
    "miss_alpha  = 0.1;\n",
    "miss_color  = :red;\n",
    "mc = :transparent\n",
    "mc_shape = :circle\n",
    "plt_size    = (1400,400);\n",
    "\n",
    "# get average \n",
    "ma(vs,n) = [sum(@view vs[i:(i+n-1)])/n for i in 1:(length(vs)-(n-1))]\n",
    "\n",
    "# load data\n",
    "T = load(\"../../data/traffic/PeMS/MainlineVDS716331/MainlineVDS716331.jld2\")[\"T\"];\n",
    "actu_sumT = sum(T);\n",
    "\n",
    "tfsize = 16\n",
    "lfsize = 16\n",
    "a = 1\n",
    "function get_time_pred(Tm, Tgt, day_start, day_end, label, a; lc1, lc2, title=\"\", lane_idx=1, legend_pos=:bottomleft)\n",
    "    tgt = vec( vcat( [Tgt[q,:,:,lane_idx] for q = day_start:day_end]... )' )\n",
    "    tm  = vec( vcat( [Tm[q,:,:,lane_idx]  for q = day_start:day_end]... )' )\n",
    "    len_days = day_end - day_start + 1\n",
    "    day2min = 1440\n",
    "    n_x  = 288\n",
    "    cnt  = 2\n",
    "    #xaxis= (\"Day\", (0,+Inf), ([0:n_x:n_x*len_days;],[1:1:len_days+1;]))\n",
    "    \n",
    "    interval_days = 3\n",
    "    xaxis= (\"Day\", (0,+Inf), ([0:interval_days*n_x:n_x*len_days;],[day_start:interval_days:len_days+day_start;]))\n",
    "    yaxis= (\"Spped (mph)\", (0,90))\n",
    "    \n",
    "    p = plot(legend=legend_pos, xaxis=xaxis, yaxis=yaxis, tickfontsize=tfsize, legendfontsize=lfsize)\n",
    "    plot!(p, tgt, label=\"GT\", lc=lc1)\n",
    "    plot!(p, tm, label=label, lc=lc2, title=title*\" Lane $lane_idx\")\n",
    "    return p\n",
    "end\n",
    "\n",
    "function get_miss_fit(Tgt, T, W)\n",
    "    Wc = 1 .- W\n",
    "    rmse = norm(T .* Wc - Tgt .* Wc) / norm(Tgt .* Wc)\n",
    "    return 1 - round(rmse,digits=3)\n",
    "end\n",
    "\n",
    "function plot_missing_area(p, miss_min_interval;  color=:red, alpha=0.2, size=(600,400))\n",
    "    plot!(p, size=plt_size, xlim=(0,1000))\n",
    "    vspan!(p, miss_min_interval, color = :red, alpha = 0.1, labels=false)\n",
    "end\n",
    "\n",
    "function shift_miss_min_interval(miss_min_interval, day_start)\n",
    "    shift_val = 12*24*(day_start-1)\n",
    "    for l = 1:4\n",
    "        n_miss_in_l = size( miss_min_interval[l] )[1]\n",
    "        for n = 1:n_miss_in_l\n",
    "            miss_min_interval[l][n] .-= shift_val\n",
    "        end\n",
    "    end\n",
    "    miss_min_interval\n",
    "end\n",
    "\n",
    "# color config\n",
    "lc_GT = :seagreen\n",
    "lc_m1 = :purple4\n",
    "lc_m2 = :orangered\n",
    "lc_m3 = :midnightblue;"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "51b9f975-dafa-4238-a7e7-89fba82e2c7d",
   "metadata": {},
   "source": [
    "# Add missing values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7f4a1462-e1e5-45a9-95c3-82bc0c5238d1",
   "metadata": {},
   "outputs": [],
   "source": [
    "function missing_generater(T)\n",
    "    W = ones( size(T)... )\n",
    "    n_days, n_hours, n_min, n_lane = size(T)\n",
    "    miss_min_interval = [ [] for l=1:n_lane ]\n",
    "    \n",
    "    min_len_missing = 100\n",
    "    max_len_missing = 600\n",
    "    \n",
    "    min_intval = 400\n",
    "    max_intval = 800\n",
    "    \n",
    "    max_n_missing = 50\n",
    "    sizeWvec = n_days*n_hours*n_min\n",
    "    for l in 1:n_lane\n",
    "        i = 1\n",
    "        m_e_pre = 0\n",
    "        while(i < max_n_missing)\n",
    "            m_s = m_e_pre + rand([min_intval:max_intval;])\n",
    "            m_e = m_s + rand([min_len_missing:max_len_missing;])\n",
    "            i += 1\n",
    "            if m_e > sizeWvec\n",
    "                break\n",
    "            else\n",
    "                push!(miss_min_interval[l], [m_s, m_e])\n",
    "                for tm = m_s:m_e\n",
    "                    idx = f(tm, n_hours, n_min)\n",
    "                    W[idx..., l] = 0\n",
    "                end\n",
    "            end\n",
    "            m_e_pre = m_e\n",
    "        end\n",
    "    end\n",
    "    return W, miss_min_interval\n",
    "end\n",
    "\n",
    "function f(m, n_hours, n_min)\n",
    "    m = m - 1\n",
    "    d = div(m, n_hours*n_min)\n",
    "    h = div(rem(m, n_hours*n_min), n_min)\n",
    "    m = rem(rem(m, n_hours*n_min), n_min)\n",
    "    return d+1, h+1, m+1\n",
    "end\n",
    "\n",
    "W, miss_min_interval = missing_generater(T)\n",
    "T_miss = deepcopy( T );\n",
    "idx_missing = findall( W .== 0 );\n",
    "T_miss[ idx_missing ] .= rand(Normal(50,10), length(idx_missing));\n",
    "\n",
    "# observe ratio\n",
    "ol = sum(W) / prod(size(W));\n",
    "# missing ratio\n",
    "ml = round( 1 - sum(W) / prod(size(W)), digits=3 );"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c305fa43-ab28-44e7-9596-54b301a85096",
   "metadata": {},
   "source": [
    "## Save tensor with missing values\n",
    "Warning : Data will be overwritten."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9f7c68ad-4401-462a-8a9b-c735eea1f74e",
   "metadata": {},
   "outputs": [],
   "source": [
    "#fstr = Int( round(ml*100,digits=0) )\n",
    "#input_tensor = \"data/traffic/preprocess/mr$fstr.jld2\"\n",
    "#save(input_tensor, \"GT\", T, \"miss\", T_miss, \"weight\", W, \"miss_interval\", miss_min_interval, \"mr\", ml)\n",
    "#println(\"$input_tensor has been saved.\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3aefd1fc-32b9-45cc-9e71-e7b8b7c85619",
   "metadata": {},
   "source": [
    "## Load tensor with missing values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "47ae22ff-ff72-4e00-897e-6aaf9ea9d0f3",
   "metadata": {},
   "outputs": [],
   "source": [
    " fstr = 9 # scenario 1\n",
    "# fstr = 27 # scenario 2\n",
    "# fstr = 34 # scenario 3\n",
    "\n",
    "input_tensor = \"data/traffic/preprocess/mr$fstr.jld2\"\n",
    "println(\"$input_tensor has been loaded.\")\n",
    "\n",
    "T = load(input_tensor, \"GT\");\n",
    "T_miss = load(input_tensor, \"miss\");\n",
    "miss_min_interval = load(input_tensor, \"miss_interval\")\n",
    "W  = load(input_tensor, \"weight\");\n",
    "ml = load(input_tensor, \"mr\");"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "873be584-44d9-48b1-87b9-5098d727f6fe",
   "metadata": {},
   "source": [
    "## Plot GT."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8618e7af-19b3-47c3-ac35-4b6f2f387614",
   "metadata": {},
   "outputs": [],
   "source": [
    "# show missing pos.\n",
    "day_start = 1\n",
    "day_end = 28\n",
    "ps = []\n",
    "for lane_idx = 1:4\n",
    "    p = get_time_pred(T, T, day_start,day_end, \"\",a, lc1=lc_GT, lc2=lc_GT, title=\"\", lane_idx=lane_idx)\n",
    "    p = plot_missing_area(p, miss_min_interval[lane_idx], color=miss_color, alpha=miss_alpha, size=plt_size)\n",
    "    push!(ps,p)\n",
    "end\n",
    "plot(ps..., layout=(2,2), size=(1800,600), plot_title=\"\\n Missing rate $ml\", legend=false)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "04005b65-032c-4684-81e4-06c197e34d82",
   "metadata": {},
   "source": [
    "# Run proposal"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a4f84bac-3664-4050-8762-dfe460429b6f",
   "metadata": {},
   "outputs": [],
   "source": [
    "function run_and_save_LBTC(T_miss, W, intracts, save_name, Tgt, mr, miss_interval; tol=1.0e-4, tmax=160, get_sol=false)\n",
    "    T_pred = LBTC!(deepcopy(T_miss), W, intracts, verbose_MBA=false, tol=tol, tmax=tmax);\n",
    "    fit_score = get_miss_fit(Tgt, T_pred, W)\n",
    "    fstr = Int( round(mr*100,digits=0) )\n",
    "    save_name = \"results/mr$fstr/$save_name.jld2\"\n",
    "    save(save_name,\"result\", T_pred, \"score\", fit_score, \"intracts\", intracts, \"miss_interval\", miss_interval)\n",
    "    println(\"$save_name has been saved\")\n",
    "    if get_sol\n",
    "        return T_pred\n",
    "    end\n",
    "end\n",
    "\n",
    "function plt_result(load_name, gt_file; day_start=1, day_end=28, plt_lanes=[1,2,3,4], img_size=(1800,600), title=\"\", label=\"lname\", legend_pos=:bottomleft)\n",
    "    load_dir = \"results/$gt_file/$load_name.jld2\"\n",
    "    T_pred = load(load_dir)[\"result\"]\n",
    "    fit_score = load(load_dir)[\"score\"]\n",
    "    miss_min_interval = load(load_dir)[\"miss_interval\"]\n",
    "    \n",
    "    gt_file = \"data/traffic/preprocess/$gt_file.jld2\"\n",
    "    T = load(gt_file)[\"GT\"]\n",
    "    \n",
    "    if label == \"lname\"\n",
    "        label == load_name\n",
    "    end\n",
    "\n",
    "    plts = Dict{Int, Plots.Plot}( l => plot() for l in plt_lanes )\n",
    "    miss_min_interval = shift_miss_min_interval(miss_min_interval, day_start)\n",
    "    for lane_idx in plt_lanes\n",
    "        p = get_time_pred(T_pred, T, day_start, day_end, label, a, lc1=lc_GT, lc2=lc_m3, title=\"\", lane_idx=lane_idx, legend_pos=legend_pos)\n",
    "        p = plot_missing_area(p, miss_min_interval[lane_idx], color=miss_color, alpha=miss_alpha, size=plt_size)\n",
    "        plts[lane_idx] = p\n",
    "    end\n",
    "    ln = length(plt_lanes)\n",
    "    if ln == 4\n",
    "        layout = (2,2)\n",
    "    else\n",
    "        layout = (ln,1)\n",
    "    end\n",
    "    layout = (ln,1)\n",
    "    plot( [ plts[l] for l in plt_lanes ]..., layout=layout, size=img_size, plot_title=title)\n",
    "end"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "212c3799-7cf0-4022-8144-5f63fba67652",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "tol = 1.0e-5\n",
    "tmax = 200\n",
    "\n",
    "day_start = 9\n",
    "day_end = 20\n",
    "plt_lanes = [1]\n",
    "img_size = (700,300)\n",
    "\n",
    "intracts = [[1,1,1,1],[1,0,1,1,1,0], [1,0,0,0], [0]]\n",
    "run_and_save_LBTC(T_miss, W, intracts, \"2p101110_3p1000\", T, ml, miss_min_interval, tol=tol)\n",
    "\n",
    "pt = plt_result(\"2p101110_3p1000\",\"mr$fstr\", day_start=day_start, day_end=day_end, plt_lanes=plt_lanes, img_size=img_size, \n",
    "            label=\"Proposal\", legend_pos=:outerright)\n",
    "savefig(pt, \"results/mr$fstr/2p101110_3p1000.pdf\");"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0706349c-2a36-4da0-9dff-6ddc1888e1ef",
   "metadata": {},
   "outputs": [],
   "source": [
    "if fstr == 9\n",
    "    s = 1\n",
    "elseif fstr == 27\n",
    "    s = 2\n",
    "elseif fstr == 34\n",
    "    s = 3\n",
    "end\n",
    "\n",
    "pt = plt_result(\"2p101110_3p1000\",\"mr$fstr\", title=\"Scenario $s\", label=\"Proposal\", legend_pos=:outerright,img_size=(1800,800))\n",
    "savefig(pt, \"results/mr$fstr/2p101110_3p1000.pdf\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1bcf6c4d-7752-485f-92fa-1afec1b848a4",
   "metadata": {},
   "source": [
    "### Experiment in Section C.2 ###"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9621137e-d2ed-455b-84eb-cac37e98ec64",
   "metadata": {},
   "outputs": [],
   "source": [
    "# plot config\n",
    "\n",
    "day_start = 1\n",
    "day_end = 28\n",
    "plt_lanes = [1,2,3,4]\n",
    "img_size = (1800,800)\n",
    "\n",
    "# Run with Interaction A\n",
    "\n",
    "J = size(T_miss)\n",
    "intracts = [[1,1,1,1],[1,0,1,1,1,0], [0,0,0,1], [0]]\n",
    "run_and_save_LBTC(T_miss, W, intracts, \"2p101110_3p0001\", T, ml, miss_min_interval, tol=tol)\n",
    "pt = plt_result(\"2p101110_3p0001\",\"mr$fstr\", day_start=day_start, day_end=day_end, plt_lanes=plt_lanes, img_size=img_size, \n",
    "            label=\"Intraction A\", legend_pos=:outerright)\n",
    "savefig(pt, \"results/mr$fstr/A.pdf\");"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2cf52444-595c-4a5a-8786-62a8e4832cf9",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Run with Interaction B\n",
    "intracts = [[1,1,1,1],[0,1,1,1,0,1], [0,0,1,0], [0]]\n",
    "run_and_save_LBTC(T_miss, W, intracts, \"2p011101_3p0010\", T, ml, miss_min_interval, tol=tol)\n",
    "pt = plt_result(\"2p011101_3p0010\",\"mr$fstr\", day_start=day_start, day_end=day_end, plt_lanes=plt_lanes, img_size=img_size, \n",
    "    label=\"Intraction B\", legend_pos=:outerright)\n",
    "savefig(pt, \"results/mr$fstr/B.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2ab16a83-9e56-4f92-a1b9-3310005f1eac",
   "metadata": {
    "scrolled": true,
    "tags": []
   },
   "outputs": [],
   "source": [
    "intracts = [[1,1,1,1],[0,1,1,1,0,1], [0,0,1,0], [0]]\n",
    "#@show get_n_params_from_intracts(intracts, J)\n",
    "\n",
    "scores = Dict( ab => Dict(x => [] for x in [9,27,34]) for ab in [\"A\",\"B\"] )\n",
    "for ab in [\"A\",\"B\"]\n",
    "    if ab == \"B\"\n",
    "        intracts = [[1,1,1,1],[0,1,1,1,0,1], [0,0,1,0], [0]]\n",
    "        intracts_str = \"2p011101_3p0010\"\n",
    "    else\n",
    "        intracts = [[1,1,1,1],[1,0,1,1,1,0], [0,0,0,1], [0]]\n",
    "        intracts_str = \"2p101110_3p0001\"\n",
    "    end\n",
    "    for fstr in [9,27,34]\n",
    "        input_tensor = \"data/traffic/preprocess/mr$fstr.jld2\"\n",
    "        println(\"$input_tensor has been loaded.\")\n",
    "\n",
    "        T = load(input_tensor, \"GT\");\n",
    "        T_miss = load(input_tensor, \"miss\");\n",
    "        miss_min_interval = load(input_tensor, \"miss_interval\")\n",
    "        W  = load(input_tensor, \"weight\");\n",
    "        ml = load(input_tensor, \"mr\");\n",
    "        for k = 1:10\n",
    "            T_pred = run_and_save_LBTC(T_miss, W, intracts, intracts_str, T, ml, miss_min_interval, tol=tol, get_sol=true)\n",
    "            score = get_miss_fit(T, T_pred, W)\n",
    "            @show score\n",
    "            push!(scores[ab][fstr], score)\n",
    "        end\n",
    "    end\n",
    "end\n",
    "\n",
    "pt = plt_result(\"2p011101_3p0010\",\"mr$fstr\", day_start=day_start, day_end=day_end, plt_lanes=plt_lanes, img_size=img_size, \n",
    "    label=\"Intraction B\", legend_pos=:outerright)\n",
    "savefig(pt, \"results/mr$fstr/B.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "68cd6f21-8742-47bf-90d2-b3a17e3407ea",
   "metadata": {},
   "outputs": [],
   "source": [
    "AB = \"A\"\n",
    "for AB in [\"A\",\"B\"]\n",
    "    # scenario 1\n",
    "    @show mean(scores[AB][9])\n",
    "    @show std(scores[AB][9])\n",
    "    # scenario 2\n",
    "    @show mean(scores[AB][27])\n",
    "    @show std(scores[AB][27])\n",
    "    # scenario 3\n",
    "    @show mean(scores[AB][34])\n",
    "    @show std(scores[AB][34])\n",
    "end"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "160f2776-b74e-46a2-8930-248f11ed0f85",
   "metadata": {},
   "source": [
    "# Baselines"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c9d35f31-b642-4f56-8f4d-34b257015437",
   "metadata": {},
   "outputs": [],
   "source": [
    "function plot_baseline(reconv, T, day_start, day_end, method_label, title, plt_lanes, score, mr, miss_min_interval; a=1)\n",
    "    plts = Dict{Int, Plots.Plot}( l => plot() for l in plt_lanes )\n",
    "    for lane_idx in plt_lanes\n",
    "        p = get_time_pred(reconv, T, day_start,day_end, method_label, a, lc1=lc_GT, lc2=lc_m3, title=title, lane_idx=lane_idx)\n",
    "        p = plot_missing_area(p, miss_min_interval[lane_idx], color=miss_color, alpha=miss_alpha, size=plt_size)\n",
    "        plts[lane_idx] = p\n",
    "    end\n",
    "    \n",
    "    n_plt = length(plt_lanes)\n",
    "    if n_plt == 4\n",
    "        layout = (2,2) \n",
    "    else\n",
    "        layout = (n_plt,1) \n",
    "    end\n",
    "    plot( [ plts[l] for l=1:n_plt ]..., layout=layout, size=(1800,600), plot_title=\"\\n Fit $score mr $mr\")\n",
    "end"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "33cc5544-df18-4f70-aa61-c8ac9ca7d51b",
   "metadata": {},
   "source": [
    "### HaLRTC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7cbf9a6c-f926-4c49-b36c-66fd7d2c5509",
   "metadata": {
    "scrolled": true,
    "tags": []
   },
   "outputs": [],
   "source": [
    "rhos = [1.0e-5, 1.0e-4, 1.0e-3, 1.0e-2, 1.0e-1, 1.0, 1.0e+1, 1.0e+2]\n",
    "miss_fits = []\n",
    "for rho in rhos\n",
    "    reconv_HaLRTC = HaLRTC(deepcopy(T_miss), W, rho=rho, verbose_inv=50, verbose=false, tol=1.0e-5, iter_max=1500);\n",
    "    miss_fit = get_miss_fit(T, reconv_HaLRTC, W)\n",
    "    push!(miss_fits, miss_fit)\n",
    "end\n",
    "best_rho = rhos[argmax(miss_fits)]\n",
    "best_miss_fit = maximum(miss_fits)\n",
    "@show miss_fits, best_rho\n",
    "\n",
    "plot(rhos, miss_fits, xaxis=:log,  legend=false, frame=:box,   size=(400,400),\n",
    "    ylim=(0,1), xlim=(minimum(rhos), maximum(rhos)), xlabel=\"ρ\",   ylabel=\"Fit\", ms=10, lc=:red, \n",
    "    msc=:red,   mc=mc, shape=mc_shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "73a6d341-c0d1-4fd3-8c77-9393141c673b",
   "metadata": {},
   "outputs": [],
   "source": [
    "lane_idx = [1,2,3,4]\n",
    "day_start = 1;\n",
    "day_end = 28;\n",
    "reconv_HaLRTC = HaLRTC(deepcopy(T_miss), W, rho=best_rho, verbose_inv=5, verbose=false);\n",
    "plot_baseline(reconv_HaLRTC, T, day_start, day_end, \"HaLRTC ρ=$best_rho\", \"\", lane_idx, best_miss_fit, ml, miss_min_interval; a=1)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "08f785a9-cf60-496d-89ce-5ef4c888bcf0",
   "metadata": {},
   "source": [
    "### SiLRTC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "eb22a2aa-e8dd-4e4e-b976-faac6f921696",
   "metadata": {},
   "outputs": [],
   "source": [
    "taus = [1.0e-2,1.0e-1,1.0e0,1.0e1,1.0e2,1.0e3,1.0e4]\n",
    "miss_fits = []\n",
    "best_tau  = 0\n",
    "for tau in taus\n",
    "    reconv_SiLRTC = SiLRTC(deepcopy(T_miss), W, tau=tau,  iter_max=2000,  verbose=true, verbose_inv=1500, tol=1.0e-5);\n",
    "    miss_fit = get_miss_fit(T, reconv_SiLRTC, W)\n",
    "    push!(miss_fits, miss_fit)\n",
    "end\n",
    "@show miss_fits\n",
    "best_tau = taus[argmax(miss_fits)]\n",
    "best_miss_fit = maximum(miss_fits)\n",
    "plot(taus, miss_fits, xaxis=:log, legend=false, frame=:box, size=(400,400),\n",
    "    ylim=(0,1), xlim=(minimum(taus), maximum(taus)), xlabel=\"τ\", ylabel=\"Fit\", ms=10, lc=:red, \n",
    "    msc=:red,   mc=mc, shape=mc_shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a3d0399a-d32b-4a69-b5ca-775b45ec15b5",
   "metadata": {},
   "outputs": [],
   "source": [
    "lane_idx = [1,2,3,4]\n",
    "reconv_SiLRTC = SiLRTC(deepcopy(T_miss), W, tau=best_tau,  iter_max=200,  verbose=false, verbose_inv=1, tol=1.0e-5);\n",
    "#p = get_time_pred(reconv_SiLRTC, T, day_start,day_end, \"SiLRTC τ=$best_tau\",a, lc1=lc_GT, lc2=lc_m3,title=\"Fit $best_miss_fit\", lane_idx=lane_idx)\n",
    "#p = plot_missing_area(p, miss_min_interval[lane_idx], color=miss_color, alpha=miss_alpha, size=plt_size)\n",
    "plot_baseline(reconv_SiLRTC, T, day_start, day_end, \"SiLRTC τ=$best_tau\", \"\", lane_idx, best_miss_fit, ml, miss_min_interval; a=1)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d767ed84-2fa1-4ddd-816a-93fe769441dd",
   "metadata": {},
   "source": [
    "### SiLRTC_TT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b5ef32d8-bc13-4f5e-9ea5-47a6519cdcad",
   "metadata": {},
   "outputs": [],
   "source": [
    "fvs = [0.001, 0.01, 0.025, 0.1, 0.25, 1]\n",
    "miss_fits = []\n",
    "best_tau  = 0\n",
    "\n",
    "for fv in fvs\n",
    "    reconv_SiLRTCTT   = SiLRTCTT!(deepcopy(T_miss), W, f=fv, iter_max=1500,  verbose=true, verbose_inv=100, tol=1.0e-5);\n",
    "    miss_fit = get_miss_fit(T, reconv_SiLRTCTT, W)\n",
    "    push!(miss_fits, miss_fit)\n",
    "    @show (fv, miss_fit)\n",
    "end\n",
    "best_fv = fvs[argmax(miss_fits)]\n",
    "best_miss_fit = maximum(miss_fits)\n",
    "plot(fvs, miss_fits, xaxis=:log, legend=false, frame=:box, size=(400,400),\n",
    "    ylim=(0,1), xlim=(minimum(fvs), maximum(fvs)), xlabel=\"f\", ylabel=\"Fit\", ms=10, lc=:red, \n",
    "    msc=:red,   mc=mc, shape=mc_shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7e29781d-f210-4b15-a7aa-32282b081f16",
   "metadata": {},
   "outputs": [],
   "source": [
    "lane_idx = [1,2,3,4]\n",
    "reconv_SiLRTCTT = SiLRTCTT!(deepcopy(T_miss), W, f=best_fv,  iter_max=500,  verbose=false, verbose_inv=10, tol=1.0e-5);\n",
    "plot_baseline(reconv_SiLRTCTT, T, day_start, day_end, \"SiLRTCTT f=$best_fv\", \"\", lane_idx, best_miss_fit, ml, miss_min_interval; a=1)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5c996e94-9e89-4251-91e7-7f097ffb2dd2",
   "metadata": {},
   "source": [
    "### PTRC_RW"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7f15084d-42e9-43e8-845a-d447d8e7a882",
   "metadata": {},
   "outputs": [],
   "source": [
    "Rs = [1,2,3,4,5,6]; alpha = [0.25,0.25,0.25,0.25]; d = 2;\n",
    "miss_fits = []\n",
    "D  = ndims(T_miss)\n",
    "for r in Rs\n",
    "    R = [r,r,r,r]\n",
    "    reconv_PTRCRW = PTRCRW!(deepcopy(T_miss), W, R, alpha, d, verbose=true, tol=1.0e-5, verbose_inval=1000, iter_max=1500);\n",
    "    miss_fit = get_miss_fit(T, reconv_PTRCRW, W)\n",
    "    push!(miss_fits, miss_fit)\n",
    "end\n",
    "best_r = Rs[argmax(miss_fits)]\n",
    "best_miss_fit = maximum(miss_fits)\n",
    "@show miss_fits\n",
    "plot(Rs, miss_fits, legend=false, frame=:box, size=(400,400),\n",
    "    ylim=(0,1), xlim=(minimum(Rs), maximum(Rs)), xlabel=\"Rank\", ylabel=\"Fit\", ms=10, lc=:red, \n",
    "    msc=:red,   mc=mc, shape=mc_shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a76d9554-e5dd-41ee-8fe4-b5262f9cf471",
   "metadata": {},
   "outputs": [],
   "source": [
    "best_R = [best_r for i = 1:4 ]\n",
    "reconv_PTRCRW = PTRCRW!(deepcopy(T_miss), W, best_R, alpha, d, verbose=false, tol=1.0e-5, verbose_inval=1);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a4a3194e-e24e-4828-8806-4d4185de6f94",
   "metadata": {},
   "outputs": [],
   "source": [
    "lane_idx = [1,2,3,4]\n",
    "plot_baseline(reconv_PTRCRW, T, day_start, day_end, \"PTRCRW r=$best_R\", \"\", lane_idx, best_miss_fit, ml, miss_min_interval; a=1)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Julia (8 threads) 1.8.5",
   "language": "julia",
   "name": "julia-_8-threads_-1.8"
  },
  "language_info": {
   "file_extension": ".jl",
   "mimetype": "application/julia",
   "name": "julia",
   "version": "1.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
