Skip to content

Instantly share code, notes, and snippets.

@lccambiaghi
Created December 11, 2018 21:38
Show Gist options
  • Save lccambiaghi/58e83770a163eac66f9c53e3cf8a7bef to your computer and use it in GitHub Desktop.
Save lccambiaghi/58e83770a163eac66f9c53e3cf8a7bef to your computer and use it in GitHub Desktop.
Display the source blob
Display the rendered blob
Raw
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
{
"cells": [
{
"cell_type": "code",
"execution_count": 115,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"The autoreload extension is already loaded. To reload it, use:\n",
" %reload_ext autoreload\n",
"/data/home/lca153/udf_deep_learning\n"
]
}
],
"source": [
"%load_ext autoreload\n",
"%autoreload 2\n",
"%cd '/home/lca153/udf_deep_learning/'"
]
},
{
"cell_type": "code",
"execution_count": 116,
"metadata": {},
"outputs": [],
"source": [
"import pandas as pd\n",
"import numpy as np\n",
"from datetime import timedelta\n",
"\n",
"from scripts.arx_preprocessor import Preprocessor\n",
"from scripts.arx import ARX\n",
"\n",
"from folium import Map, CircleMarker, PolyLine, FeatureGroup, LayerControl\n",
"from folium.plugins import FeatureGroupSubGroup"
]
},
{
"cell_type": "code",
"execution_count": 3,
"metadata": {},
"outputs": [],
"source": [
"paths = {'bookings_df_path': 'data/focus_full.feather',\n",
" 'holidays_df_path': 'data/holidays_matrix.h5',\n",
" 'seasonal_df_path': 'data/seasonal_matrix.h5'}\n",
"pp_pars = paths.copy()\n",
"\n",
"ar_order = 4\n",
"n_dfus = 20\n",
"horizon = pp_pars['forecast_horizon'] = 4\n",
"\n",
"pp = Preprocessor(**pp_pars)\n",
"varx = ARX(pp, lags_order=ar_order)\n",
"x, Y = varx.get_X_Y()\n",
"top = list(pp.Y.mean().sort_values(ascending=False).index)[:n_dfus]\n",
"\n",
"test_weeks = 52\n",
"start_test = x.index[-1] - timedelta(weeks=test_weeks + 1)\n",
"Y_test = Y[start_test:]"
]
},
{
"cell_type": "code",
"execution_count": 4,
"metadata": {},
"outputs": [],
"source": [
"# start with coeff_df: id=DFU, coef=coef\n",
"enet_h4 = np.load('results/enet_ev/r95_h4.npy').item()\n",
"enet_h4 = pd.DataFrame(enet_h4)\n",
"top = list(enet_h4.transpose().index)\n",
"enet_h4_coefs = enet_h4.transpose()['coef']"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# Coefficients data"
]
},
{
"cell_type": "code",
"execution_count": 178,
"metadata": {},
"outputs": [],
"source": [
"i = 6\n",
"dfu_id = top[i]"
]
},
{
"cell_type": "code",
"execution_count": 179,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>coef</th>\n",
" <th>abs_coef</th>\n",
" <th>lopfi</th>\n",
" <th>dipla</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>CNYAT_GBFXS_PP_DRY _40_-1</th>\n",
" <td>3.667393</td>\n",
" <td>3.667393</td>\n",
" <td>CNYAT</td>\n",
" <td>GBFXS</td>\n",
" </tr>\n",
" <tr>\n",
" <th>CNYAT_NLROT_PP_DRY _40_-1</th>\n",
" <td>0.610678</td>\n",
" <td>0.610678</td>\n",
" <td>CNYAT</td>\n",
" <td>NLROT</td>\n",
" </tr>\n",
" <tr>\n",
" <th>CNYAT_GBFXS_PP_DRY _40_-3</th>\n",
" <td>0.343879</td>\n",
" <td>0.343879</td>\n",
" <td>CNYAT</td>\n",
" <td>GBFXS</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" coef abs_coef lopfi dipla\n",
"CNYAT_GBFXS_PP_DRY _40_-1 3.667393 3.667393 CNYAT GBFXS\n",
"CNYAT_NLROT_PP_DRY _40_-1 0.610678 0.610678 CNYAT NLROT\n",
"CNYAT_GBFXS_PP_DRY _40_-3 0.343879 0.343879 CNYAT GBFXS"
]
},
"execution_count": 179,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"en_coefs = enet_h4_coefs[i]\n",
"en_selected = np.nonzero(en_coefs)[0]\n",
"en_coefs_df = pd.DataFrame(data=en_coefs[en_selected],index=x.columns[en_selected], columns=['coef'])\n",
"en_coefs_df['abs_coef'] = np.abs(en_coefs_df['coef'])\n",
"en_coefs_df = en_coefs_df.sort_values(by='abs_coef', ascending=False).head(3)\n",
"\n",
"# From the ID, extract port of origin and port of destination\n",
"en_coefs_df['lopfi'] = list(map(lambda s: s.split('_')[0], en_coefs_df.index))\n",
"en_coefs_df['dipla'] = list(map(lambda s: s.split('_')[1], en_coefs_df.index))\n",
"en_coefs_df"
]
},
{
"cell_type": "code",
"execution_count": 180,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>lon</th>\n",
" <th>lat</th>\n",
" </tr>\n",
" <tr>\n",
" <th>port</th>\n",
" <th></th>\n",
" <th></th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>AEAMN</th>\n",
" <td>55.421800</td>\n",
" <td>25.390600</td>\n",
" </tr>\n",
" <tr>\n",
" <th>AEAUH</th>\n",
" <td>54.359300</td>\n",
" <td>24.453100</td>\n",
" </tr>\n",
" <tr>\n",
" <th>AEDXB</th>\n",
" <td>55.399333</td>\n",
" <td>25.166666</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" lon lat\n",
"port \n",
"AEAMN 55.421800 25.390600\n",
"AEAUH 54.359300 24.453100\n",
"AEDXB 55.399333 25.166666"
]
},
"execution_count": 180,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"# join with ports and get lat and lon\n",
"ports = pd.read_csv('data/ports.csv', header=None)\n",
"ports.columns = ['port', 'lon', 'lat']\n",
"ports.set_index('port', inplace=True); ports.head(3)"
]
},
{
"cell_type": "code",
"execution_count": 181,
"metadata": {},
"outputs": [],
"source": [
"en_coefs_df = en_coefs_df.join(ports, on='lopfi')\n",
"en_coefs_df.rename(columns={\"lon\": \"lopfi_lon\", \"lat\": \"lopfi_lat\"}, inplace=True)\n",
"en_coefs_df = en_coefs_df.join(ports, on='dipla')\n",
"en_coefs_df.rename(columns={\"lon\": \"dipla_lon\", \"lat\": \"dipla_lat\"}, inplace=True)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# Map"
]
},
{
"cell_type": "code",
"execution_count": 182,
"metadata": {},
"outputs": [],
"source": [
"dfu_lopfi = dfu_id.split('_')[0]\n",
"dfu_dipla = dfu_id.split('_')[1]\n",
"\n",
"dfu_lopfi_lat = ports.loc[dfu_lopfi]['lat']\n",
"dfu_lopfi_lon = ports.loc[dfu_lopfi]['lon']\n",
"\n",
"dfu_dipla_lat = ports.loc[dfu_dipla]['lat']\n",
"dfu_dipla_lon = ports.loc[dfu_dipla]['lon']"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"m = folium.Map(location=[30, 0],\n",
" zoom_start=2, tiles=\"CartoDB dark_matter\")\n",
"\n",
"lopfi = folium.CircleMarker(location=[dfu_lopfi_lat, dfu_lopfi_lon],\n",
" popup=f'LOPFI:{dfu_lopfi}', color='red', fill=True).add_to(m)\n",
"dipla = folium.CircleMarker(location=[dfu_dipla_lat, dfu_dipla_lon], \n",
" popup=f'DIPLA:{dfu_dipla}', color='red', fill=True).add_to(m)\n",
"m"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# Add coefficients edges"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"scrolled": false
},
"outputs": [],
"source": [
"colors = ['blue', 'lightblue', 'gray']\n",
"\n",
"for coef_id, row in en_coefs_df.iterrows():\n",
" i = en_coefs_df.index.get_loc(coef_id)\n",
" color = colors[i]\n",
" \n",
" lopfi_lat, lopfi_lon = row['lopfi_lat'], row['lopfi_lon']\n",
" dipla_lat, dipla_lon = row['dipla_lat'], row['dipla_lon']\n",
" \n",
" if row.lopfi != dfu_lopfi:\n",
" lopfi = folium.CircleMarker(location=[lopfi_lat, lopfi_lon],\n",
" popup=f'LOPFI:{row.lopfi}', color=color, fill=True).add_to(m)\n",
" if row.dipla != dfu_dipla:\n",
" dipla = folium.CircleMarker(location=[dipla_lat, dipla_lon],\n",
" popup=f'LOPFI:{row.dipla}', color=color, fill=True).add_to(m)\n",
" \n",
" coef_line = PolyLine([[lopfi_lat, lopfi_lon],[dipla_lat, dipla_lon]], \n",
" popup=f'id:{coef_id}, coef:{row.coef}',\n",
" weight=row['coef'], color = color).add_to(m)\n",
"\n",
"m"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# Coefficients group"
]
},
{
"cell_type": "code",
"execution_count": 185,
"metadata": {},
"outputs": [],
"source": [
"m = Map(location=[30, 0],\n",
" zoom_start=2, tiles=\"CartoDB dark_matter\")\n",
"\n",
"lopfi = CircleMarker(location=[dfu_lopfi_lat, dfu_lopfi_lon],\n",
" popup=f'LOPFI:{dfu_lopfi}', color='red', fill=True).add_to(m)\n",
"dipla = CircleMarker(location=[dfu_dipla_lat, dfu_dipla_lon], \n",
" popup=f'DIPLA:{dfu_dipla}', color='red', fill=True).add_to(m)\n",
"\n",
"enet_group = FeatureGroup(name='ElasticNet coefficients')\n",
"m.add_child(enet_group)\n",
"for coef_id, row in en_coefs_df.iterrows():\n",
" subgroup = FeatureGroupSubGroup(enet_group, coef_id)\n",
" m.add_child(subgroup)\n",
" \n",
" i = en_coefs_df.index.get_loc(coef_id)\n",
" color = colors[i]\n",
" \n",
" lopfi_lat, lopfi_lon = row['lopfi_lat'], row['lopfi_lon']\n",
" dipla_lat, dipla_lon = row['dipla_lat'], row['dipla_lon']\n",
" \n",
" if row.lopfi != dfu_lopfi:\n",
" lopfi = folium.CircleMarker(location=[lopfi_lat, lopfi_lon],\n",
" popup=f'LOPFI:{row.lopfi}', color=color, fill=True).add_to(subgroup)\n",
" if row.dipla != dfu_dipla:\n",
" dipla = folium.CircleMarker(location=[dipla_lat, dipla_lon],\n",
" popup=f'LOPFI:{row.dipla}', color=color, fill=True).add_to(subgroup)\n",
" \n",
" coef_line = PolyLine([[lopfi_lat, lopfi_lon],[dipla_lat, dipla_lon]],\n",
" popup=f'id:{coef_id}, coef:{row.coef}',\n",
" weight=row['coef'], color = color).add_to(subgroup)"
]
},
{
"cell_type": "code",
"execution_count": 186,
"metadata": {},
"outputs": [],
"source": [
"# start with coeff_df: id=DFU, coef=coef\n",
"sgl_h4 = np.load('results/glasso_ev/r95_h4.npy').item()\n",
"sgl_h4 = pd.DataFrame(sgl_h4)\n",
"top = list(sgl_h4.transpose().index)\n",
"sgl_h4_coefs = sgl_h4.transpose()['coef']\n",
"\n",
"sgl_coefs = sgl_h4_coefs[i]\n",
"sgl_coefs = sgl_coefs[:-1]\n",
"sgl_selected = np.nonzero(sgl_coefs)[0]\n",
"sgl_coefs_df = pd.DataFrame(data=sgl_coefs[sgl_selected],index=x.columns[sgl_selected], columns=['coef'])\n",
"sgl_coefs_df['abs_coef'] = np.abs(sgl_coefs_df['coef'])\n",
"sgl_coefs_df = sgl_coefs_df.sort_values(by='abs_coef', ascending=False).head(3)\n",
"\n",
"# From the ID, extract port of origin and port of destination\n",
"sgl_coefs_df['lopfi'] = list(map(lambda s: s.split('_')[0], sgl_coefs_df.index))\n",
"sgl_coefs_df['dipla'] = list(map(lambda s: s.split('_')[1], sgl_coefs_df.index))\n",
"\n",
"sgl_coefs_df = sgl_coefs_df.join(ports, on='lopfi')\n",
"sgl_coefs_df.rename(columns={\"lon\": \"lopfi_lon\", \"lat\": \"lopfi_lat\"}, inplace=True)\n",
"sgl_coefs_df = sgl_coefs_df.join(ports, on='dipla')\n",
"sgl_coefs_df.rename(columns={\"lon\": \"dipla_lon\", \"lat\": \"dipla_lat\"}, inplace=True)"
]
},
{
"cell_type": "code",
"execution_count": 187,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div style=\"width:100%;\"><div style=\"position:relative;width:100%;height:0;padding-bottom:60%;\"><iframe src=\"data:text/html;charset=utf-8;base64,<!DOCTYPE html>
<head>    
    <meta http-equiv="content-type" content="text/html; charset=UTF-8" />
    <script>L_PREFER_CANVAS=false; L_NO_TOUCH=false; L_DISABLE_3D=false;</script>
    <script src="https://cdn.jsdelivr.net/npm/leaflet@1.3.4/dist/leaflet.js"></script>
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/js/bootstrap.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/Leaflet.awesome-markers/2.0.2/leaflet.awesome-markers.js"></script>
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/leaflet@1.3.4/dist/leaflet.css"/>
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap.min.css"/>
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap-theme.min.css"/>
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.6.3/css/font-awesome.min.css"/>
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/Leaflet.awesome-markers/2.0.2/leaflet.awesome-markers.css"/>
    <link rel="stylesheet" href="https://rawcdn.githack.com/python-visualization/folium/master/folium/templates/leaflet.awesome.rotate.css"/>
    <style>html, body {width: 100%;height: 100%;margin: 0;padding: 0;}</style>
    <style>#map {position:absolute;top:0;bottom:0;right:0;left:0;}</style>
    
    <meta name="viewport" content="width=device-width,
        initial-scale=1.0, maximum-scale=1.0, user-scalable=no" />
    <style>#map_ab046ca2c40847c2a71e87be100aa058 {
        position: relative;
        width: 100.0%;
        height: 100.0%;
        left: 0.0%;
        top: 0.0%;
        }
    </style>
    <script src="https://unpkg.com/leaflet.featuregroup.subgroup@1.0.2/dist/leaflet.featuregroup.subgroup.js"></script>
</head>
<body>    
    
    <div class="folium-map" id="map_ab046ca2c40847c2a71e87be100aa058" ></div>
</body>
<script>    
    
    
        var bounds = null;
    

    var map_ab046ca2c40847c2a71e87be100aa058 = L.map(
        'map_ab046ca2c40847c2a71e87be100aa058', {
        center: [30, 0],
        zoom: 2,
        maxBounds: bounds,
        layers: [],
        worldCopyJump: false,
        crs: L.CRS.EPSG3857,
        zoomControl: true,
        });

    
    
    var tile_layer_80e57ecaf3f44a59ab783de6406404a3 = L.tileLayer(
        'https://cartodb-basemaps-{s}.global.ssl.fastly.net/dark_all/{z}/{x}/{y}.png',
        {
        "attribution": null,
        "detectRetina": false,
        "maxNativeZoom": 18,
        "maxZoom": 18,
        "minZoom": 0,
        "noWrap": false,
        "opacity": 1,
        "subdomains": "abc",
        "tms": false
}).addTo(map_ab046ca2c40847c2a71e87be100aa058);
    
            var circle_marker_d3c2d4aea85e4d669da90bca43f6ab4a = L.circleMarker(
                [22.58333, 114.266671],
                {
  "bubblingMouseEvents": true,
  "color": "red",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "red",
  "fillOpacity": 0.2,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 10,
  "stroke": true,
  "weight": 3
}
                )
                .addTo(map_ab046ca2c40847c2a71e87be100aa058);
            
    
            var popup_02b53134a2784c1c856e69724f9fc4ed = L.popup({maxWidth: '300'
            
            });

            
                var html_67f414439b0b48ee9f6358023aa32339 = $(`<div id="html_67f414439b0b48ee9f6358023aa32339" style="width: 100.0%; height: 100.0%;">LOPFI:CNYAT</div>`)[0];
                popup_02b53134a2784c1c856e69724f9fc4ed.setContent(html_67f414439b0b48ee9f6358023aa32339);
            

            circle_marker_d3c2d4aea85e4d669da90bca43f6ab4a.bindPopup(popup_02b53134a2784c1c856e69724f9fc4ed)
            ;

            
        
    
            var circle_marker_d22d0ba71d61428aa08123e4b51c9359 = L.circleMarker(
                [51.91667, 4.5],
                {
  "bubblingMouseEvents": true,
  "color": "red",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "red",
  "fillOpacity": 0.2,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 10,
  "stroke": true,
  "weight": 3
}
                )
                .addTo(map_ab046ca2c40847c2a71e87be100aa058);
            
    
            var popup_6744eb8b25f54473a8f2e1bf23eb73f0 = L.popup({maxWidth: '300'
            
            });

            
                var html_3b7e8cee60ec48b8b86e3aa7ecbfd87d = $(`<div id="html_3b7e8cee60ec48b8b86e3aa7ecbfd87d" style="width: 100.0%; height: 100.0%;">DIPLA:NLROT</div>`)[0];
                popup_6744eb8b25f54473a8f2e1bf23eb73f0.setContent(html_3b7e8cee60ec48b8b86e3aa7ecbfd87d);
            

            circle_marker_d22d0ba71d61428aa08123e4b51c9359.bindPopup(popup_6744eb8b25f54473a8f2e1bf23eb73f0)
            ;

            
        
    
            var feature_group_fdd366fb1b97402095f27c281ee1256b = L.featureGroup(
                ).addTo(map_ab046ca2c40847c2a71e87be100aa058);
        
    
            var feature_group_sub_group_ba4000d759c74be3a8f3a4008487b380 = L.featureGroup.subGroup(feature_group_fdd366fb1b97402095f27c281ee1256b);
            feature_group_sub_group_ba4000d759c74be3a8f3a4008487b380.addTo(map_ab046ca2c40847c2a71e87be100aa058);
            
    
            var circle_marker_95e3b26ae0344fc08cab4cff43097a25 = L.circleMarker(
                [51.9531, 1.35],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "blue",
  "fillOpacity": 0.2,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 10,
  "stroke": true,
  "weight": 3
}
                )
                .addTo(feature_group_sub_group_ba4000d759c74be3a8f3a4008487b380);
            
    
            var popup_7f7b812e3cca4012bf71a05f9d771180 = L.popup({maxWidth: '300'
            
            });

            
                var html_b6291d31eaba45f59d8fe04da2a0f3bc = $(`<div id="html_b6291d31eaba45f59d8fe04da2a0f3bc" style="width: 100.0%; height: 100.0%;">LOPFI:GBFXS</div>`)[0];
                popup_7f7b812e3cca4012bf71a05f9d771180.setContent(html_b6291d31eaba45f59d8fe04da2a0f3bc);
            

            circle_marker_95e3b26ae0344fc08cab4cff43097a25.bindPopup(popup_7f7b812e3cca4012bf71a05f9d771180)
            ;

            
        
    
                var poly_line_fc270afbd79e44bfaba71ea09b42b77b = L.polyline(
                    [[22.58333, 114.266671], [51.9531, 1.35]],
                    {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": false,
  "fillColor": "blue",
  "fillOpacity": 0.2,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "noClip": false,
  "opacity": 1.0,
  "smoothFactor": 1.0,
  "stroke": true,
  "weight": 3.6673931962206026
}
                    )
                    .addTo(feature_group_sub_group_ba4000d759c74be3a8f3a4008487b380);
            
    
            var popup_8f362bc6a1af4cb196fe259ba09c842f = L.popup({maxWidth: '300'
            
            });

            
                var html_57c1c767139e477e981f2818d7da6860 = $(`<div id="html_57c1c767139e477e981f2818d7da6860" style="width: 100.0%; height: 100.0%;">id:CNYAT_GBFXS_PP_DRY _40_-1, coef:3.6673931962206026</div>`)[0];
                popup_8f362bc6a1af4cb196fe259ba09c842f.setContent(html_57c1c767139e477e981f2818d7da6860);
            

            poly_line_fc270afbd79e44bfaba71ea09b42b77b.bindPopup(popup_8f362bc6a1af4cb196fe259ba09c842f)
            ;

            
        
    
            var feature_group_sub_group_1951ecc956b94b68940ad5938d11bf8b = L.featureGroup.subGroup(feature_group_fdd366fb1b97402095f27c281ee1256b);
            feature_group_sub_group_1951ecc956b94b68940ad5938d11bf8b.addTo(map_ab046ca2c40847c2a71e87be100aa058);
            
    
                var poly_line_92cedf20e3c148a0b23d8f02eebf8978 = L.polyline(
                    [[22.58333, 114.266671], [51.91667, 4.5]],
                    {
  "bubblingMouseEvents": true,
  "color": "lightblue",
  "dashArray": null,
  "dashOffset": null,
  "fill": false,
  "fillColor": "lightblue",
  "fillOpacity": 0.2,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "noClip": false,
  "opacity": 1.0,
  "smoothFactor": 1.0,
  "stroke": true,
  "weight": 0.6106783203231637
}
                    )
                    .addTo(feature_group_sub_group_1951ecc956b94b68940ad5938d11bf8b);
            
    
            var popup_69159e2fc5ec42f589d1bbb408db66d1 = L.popup({maxWidth: '300'
            
            });

            
                var html_b3476968ee31409aaa9013fc9452c073 = $(`<div id="html_b3476968ee31409aaa9013fc9452c073" style="width: 100.0%; height: 100.0%;">id:CNYAT_NLROT_PP_DRY _40_-1, coef:0.6106783203231637</div>`)[0];
                popup_69159e2fc5ec42f589d1bbb408db66d1.setContent(html_b3476968ee31409aaa9013fc9452c073);
            

            poly_line_92cedf20e3c148a0b23d8f02eebf8978.bindPopup(popup_69159e2fc5ec42f589d1bbb408db66d1)
            ;

            
        
    
            var feature_group_sub_group_f931b545bac24d12a2e4c2eb14bed724 = L.featureGroup.subGroup(feature_group_fdd366fb1b97402095f27c281ee1256b);
            feature_group_sub_group_f931b545bac24d12a2e4c2eb14bed724.addTo(map_ab046ca2c40847c2a71e87be100aa058);
            
    
            var circle_marker_df44f1ed511b4a85bb98179128b07911 = L.circleMarker(
                [51.9531, 1.35],
                {
  "bubblingMouseEvents": true,
  "color": "gray",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "gray",
  "fillOpacity": 0.2,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 10,
  "stroke": true,
  "weight": 3
}
                )
                .addTo(feature_group_sub_group_f931b545bac24d12a2e4c2eb14bed724);
            
    
            var popup_e3a7c3c781d44e41bd13b73d051c0dae = L.popup({maxWidth: '300'
            
            });

            
                var html_e5daa0df44814a4abda105da500eea47 = $(`<div id="html_e5daa0df44814a4abda105da500eea47" style="width: 100.0%; height: 100.0%;">LOPFI:GBFXS</div>`)[0];
                popup_e3a7c3c781d44e41bd13b73d051c0dae.setContent(html_e5daa0df44814a4abda105da500eea47);
            

            circle_marker_df44f1ed511b4a85bb98179128b07911.bindPopup(popup_e3a7c3c781d44e41bd13b73d051c0dae)
            ;

            
        
    
                var poly_line_ba2f9393943c442ba8cb99968e957fc5 = L.polyline(
                    [[22.58333, 114.266671], [51.9531, 1.35]],
                    {
  "bubblingMouseEvents": true,
  "color": "gray",
  "dashArray": null,
  "dashOffset": null,
  "fill": false,
  "fillColor": "gray",
  "fillOpacity": 0.2,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "noClip": false,
  "opacity": 1.0,
  "smoothFactor": 1.0,
  "stroke": true,
  "weight": 0.3438793839549973
}
                    )
                    .addTo(feature_group_sub_group_f931b545bac24d12a2e4c2eb14bed724);
            
    
            var popup_dea039f41901420aa1416c561049a602 = L.popup({maxWidth: '300'
            
            });

            
                var html_464ba8e8705b4a23833f4beb471e17d9 = $(`<div id="html_464ba8e8705b4a23833f4beb471e17d9" style="width: 100.0%; height: 100.0%;">id:CNYAT_GBFXS_PP_DRY _40_-3, coef:0.3438793839549973</div>`)[0];
                popup_dea039f41901420aa1416c561049a602.setContent(html_464ba8e8705b4a23833f4beb471e17d9);
            

            poly_line_ba2f9393943c442ba8cb99968e957fc5.bindPopup(popup_dea039f41901420aa1416c561049a602)
            ;

            
        
    
            var feature_group_26d710eb0d20414cbce20bd6657ec552 = L.featureGroup(
                ).addTo(map_ab046ca2c40847c2a71e87be100aa058);
        
    
            var feature_group_sub_group_8fbbfb0ce39a4c248e1f67197e12454b = L.featureGroup.subGroup(feature_group_26d710eb0d20414cbce20bd6657ec552);
            feature_group_sub_group_8fbbfb0ce39a4c248e1f67197e12454b.addTo(map_ab046ca2c40847c2a71e87be100aa058);
            
    
            var circle_marker_33b1e89c224148a98993cd9aeeff8954 = L.circleMarker(
                [34.0522, -118.2428],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "blue",
  "fillOpacity": 0.2,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 10,
  "stroke": true,
  "weight": 3
}
                )
                .addTo(feature_group_sub_group_8fbbfb0ce39a4c248e1f67197e12454b);
            
    
            var popup_81bce69dd8af43b7a2261a51c9d93122 = L.popup({maxWidth: '300'
            
            });

            
                var html_389e38d2ac044effaca1195fc9d3e36f = $(`<div id="html_389e38d2ac044effaca1195fc9d3e36f" style="width: 100.0%; height: 100.0%;">LOPFI:USLSA</div>`)[0];
                popup_81bce69dd8af43b7a2261a51c9d93122.setContent(html_389e38d2ac044effaca1195fc9d3e36f);
            

            circle_marker_33b1e89c224148a98993cd9aeeff8954.bindPopup(popup_81bce69dd8af43b7a2261a51c9d93122)
            ;

            
        
    
            var circle_marker_c20c7d1c2c9b42bdb3d1c5b95c00164c = L.circleMarker(
                [22.76, 113.572],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "blue",
  "fillOpacity": 0.2,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 10,
  "stroke": true,
  "weight": 3
}
                )
                .addTo(feature_group_sub_group_8fbbfb0ce39a4c248e1f67197e12454b);
            
    
            var popup_2b5fa4f8f2584f22a0478678c2c12e6b = L.popup({maxWidth: '300'
            
            });

            
                var html_967b272e5fb04a54a973f6a88175d63c = $(`<div id="html_967b272e5fb04a54a973f6a88175d63c" style="width: 100.0%; height: 100.0%;">LOPFI:CNNAN</div>`)[0];
                popup_2b5fa4f8f2584f22a0478678c2c12e6b.setContent(html_967b272e5fb04a54a973f6a88175d63c);
            

            circle_marker_c20c7d1c2c9b42bdb3d1c5b95c00164c.bindPopup(popup_2b5fa4f8f2584f22a0478678c2c12e6b)
            ;

            
        
    
                var poly_line_62e2d86d75ff4d7e9428e8fdbd161a72 = L.polyline(
                    [[34.0522, -118.2428], [22.76, 113.572]],
                    {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": false,
  "fillColor": "blue",
  "fillOpacity": 0.2,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "noClip": false,
  "opacity": 1.0,
  "smoothFactor": 1.0,
  "stroke": true,
  "weight": 3.1517324352615566
}
                    )
                    .addTo(feature_group_sub_group_8fbbfb0ce39a4c248e1f67197e12454b);
            
    
            var popup_56343a9efc09496fa83ed6f96b2a5d2f = L.popup({maxWidth: '300'
            
            });

            
                var html_7cedcd5ca5074fb492443f59cf7cfbe3 = $(`<div id="html_7cedcd5ca5074fb492443f59cf7cfbe3" style="width: 100.0%; height: 100.0%;">id:USLSA_CNNAN_IP_DRY _40_-2, coef:3.1517324352615566</div>`)[0];
                popup_56343a9efc09496fa83ed6f96b2a5d2f.setContent(html_7cedcd5ca5074fb492443f59cf7cfbe3);
            

            poly_line_62e2d86d75ff4d7e9428e8fdbd161a72.bindPopup(popup_56343a9efc09496fa83ed6f96b2a5d2f)
            ;

            
        
    
            var feature_group_sub_group_177671299c014c15aa8e164784cbfeeb = L.featureGroup.subGroup(feature_group_26d710eb0d20414cbce20bd6657ec552);
            feature_group_sub_group_177671299c014c15aa8e164784cbfeeb.addTo(map_ab046ca2c40847c2a71e87be100aa058);
            
    
            var circle_marker_f707d06c0eb9403a92fffb363cd997c2 = L.circleMarker(
                [51.9531, 1.35],
                {
  "bubblingMouseEvents": true,
  "color": "lightblue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "lightblue",
  "fillOpacity": 0.2,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 10,
  "stroke": true,
  "weight": 3
}
                )
                .addTo(feature_group_sub_group_177671299c014c15aa8e164784cbfeeb);
            
    
            var popup_36065f9958e040f6b5ce8cba8b7deb40 = L.popup({maxWidth: '300'
            
            });

            
                var html_263c88ff7c484c008ea2bcfb51f91705 = $(`<div id="html_263c88ff7c484c008ea2bcfb51f91705" style="width: 100.0%; height: 100.0%;">LOPFI:GBFXS</div>`)[0];
                popup_36065f9958e040f6b5ce8cba8b7deb40.setContent(html_263c88ff7c484c008ea2bcfb51f91705);
            

            circle_marker_f707d06c0eb9403a92fffb363cd997c2.bindPopup(popup_36065f9958e040f6b5ce8cba8b7deb40)
            ;

            
        
    
                var poly_line_fa4c150f4cb0498ebe00e1f9921beb2e = L.polyline(
                    [[22.58333, 114.266671], [51.9531, 1.35]],
                    {
  "bubblingMouseEvents": true,
  "color": "lightblue",
  "dashArray": null,
  "dashOffset": null,
  "fill": false,
  "fillColor": "lightblue",
  "fillOpacity": 0.2,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "noClip": false,
  "opacity": 1.0,
  "smoothFactor": 1.0,
  "stroke": true,
  "weight": 2.887996729145287
}
                    )
                    .addTo(feature_group_sub_group_177671299c014c15aa8e164784cbfeeb);
            
    
            var popup_b3e7284347c74d61abe4c0875272f0ec = L.popup({maxWidth: '300'
            
            });

            
                var html_9e7b2d3e843a49c98b47e586cf2d7f21 = $(`<div id="html_9e7b2d3e843a49c98b47e586cf2d7f21" style="width: 100.0%; height: 100.0%;">id:CNYAT_GBFXS_PP_DRY _40_-1, coef:2.887996729145287</div>`)[0];
                popup_b3e7284347c74d61abe4c0875272f0ec.setContent(html_9e7b2d3e843a49c98b47e586cf2d7f21);
            

            poly_line_fa4c150f4cb0498ebe00e1f9921beb2e.bindPopup(popup_b3e7284347c74d61abe4c0875272f0ec)
            ;

            
        
    
            var feature_group_sub_group_b07c349615754bbda97f22f4ee849963 = L.featureGroup.subGroup(feature_group_26d710eb0d20414cbce20bd6657ec552);
            feature_group_sub_group_b07c349615754bbda97f22f4ee849963.addTo(map_ab046ca2c40847c2a71e87be100aa058);
            
    
            var circle_marker_15b4c2e5069b45d6a7286ed6ec1a8b7f = L.circleMarker(
                [29.875, 121.5468],
                {
  "bubblingMouseEvents": true,
  "color": "gray",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "gray",
  "fillOpacity": 0.2,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 10,
  "stroke": true,
  "weight": 3
}
                )
                .addTo(feature_group_sub_group_b07c349615754bbda97f22f4ee849963);
            
    
            var popup_8e98b354af094168938c5c60dbf9a01e = L.popup({maxWidth: '300'
            
            });

            
                var html_9b67b3bc02f441cbbb06a9dbee94cb61 = $(`<div id="html_9b67b3bc02f441cbbb06a9dbee94cb61" style="width: 100.0%; height: 100.0%;">LOPFI:CNNPO</div>`)[0];
                popup_8e98b354af094168938c5c60dbf9a01e.setContent(html_9b67b3bc02f441cbbb06a9dbee94cb61);
            

            circle_marker_15b4c2e5069b45d6a7286ed6ec1a8b7f.bindPopup(popup_8e98b354af094168938c5c60dbf9a01e)
            ;

            
        
    
            var circle_marker_3c5a065b857249f59f4a07586d217ac2 = L.circleMarker(
                [51.9531, 1.35],
                {
  "bubblingMouseEvents": true,
  "color": "gray",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "gray",
  "fillOpacity": 0.2,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 10,
  "stroke": true,
  "weight": 3
}
                )
                .addTo(feature_group_sub_group_b07c349615754bbda97f22f4ee849963);
            
    
            var popup_f4398e63ada849c7a9150be7c1a030e2 = L.popup({maxWidth: '300'
            
            });

            
                var html_f12d16eb39c84cb1a885bceb9eb3b64d = $(`<div id="html_f12d16eb39c84cb1a885bceb9eb3b64d" style="width: 100.0%; height: 100.0%;">LOPFI:GBFXS</div>`)[0];
                popup_f4398e63ada849c7a9150be7c1a030e2.setContent(html_f12d16eb39c84cb1a885bceb9eb3b64d);
            

            circle_marker_3c5a065b857249f59f4a07586d217ac2.bindPopup(popup_f4398e63ada849c7a9150be7c1a030e2)
            ;

            
        
    
                var poly_line_118fa4bec07f4e38b4e642d773be73c8 = L.polyline(
                    [[29.875, 121.5468], [51.9531, 1.35]],
                    {
  "bubblingMouseEvents": true,
  "color": "gray",
  "dashArray": null,
  "dashOffset": null,
  "fill": false,
  "fillColor": "gray",
  "fillOpacity": 0.2,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "noClip": false,
  "opacity": 1.0,
  "smoothFactor": 1.0,
  "stroke": true,
  "weight": -2.5792875872761263
}
                    )
                    .addTo(feature_group_sub_group_b07c349615754bbda97f22f4ee849963);
            
    
            var popup_16703222ddf54359b6b61b9374e31a64 = L.popup({maxWidth: '300'
            
            });

            
                var html_e087e6ad07294bad9ddfbb166932a2a1 = $(`<div id="html_e087e6ad07294bad9ddfbb166932a2a1" style="width: 100.0%; height: 100.0%;">id:CNNPO_GBFXS_PP_DRY _40_-3, coef:-2.5792875872761263</div>`)[0];
                popup_16703222ddf54359b6b61b9374e31a64.setContent(html_e087e6ad07294bad9ddfbb166932a2a1);
            

            poly_line_118fa4bec07f4e38b4e642d773be73c8.bindPopup(popup_16703222ddf54359b6b61b9374e31a64)
            ;

            
        
    
            var layer_control_4c1a18d5d24247ff92c6c67e77965086 = {
                base_layers : { "cartodbdark_matter" : tile_layer_80e57ecaf3f44a59ab783de6406404a3, },
                overlays : { "ElasticNet coefficients" : feature_group_fdd366fb1b97402095f27c281ee1256b,"CNYAT_GBFXS_PP_DRY _40_-1" : feature_group_sub_group_177671299c014c15aa8e164784cbfeeb,"CNYAT_NLROT_PP_DRY _40_-1" : feature_group_sub_group_1951ecc956b94b68940ad5938d11bf8b,"CNYAT_GBFXS_PP_DRY _40_-3" : feature_group_sub_group_f931b545bac24d12a2e4c2eb14bed724,"GroupLasso coefficients" : feature_group_26d710eb0d20414cbce20bd6657ec552,"USLSA_CNNAN_IP_DRY _40_-2" : feature_group_sub_group_8fbbfb0ce39a4c248e1f67197e12454b,"CNNPO_GBFXS_PP_DRY _40_-3" : feature_group_sub_group_b07c349615754bbda97f22f4ee849963, }
                };
            L.control.layers(
                layer_control_4c1a18d5d24247ff92c6c67e77965086.base_layers,
                layer_control_4c1a18d5d24247ff92c6c67e77965086.overlays,
                {position: 'topright',
                 collapsed: true,
                 autoZIndex: true
                }).addTo(map_ab046ca2c40847c2a71e87be100aa058);
            
        
</script>\" style=\"position:absolute;width:100%;height:100%;left:0;top:0;border:none !important;\" allowfullscreen webkitallowfullscreen mozallowfullscreen></iframe></div></div>"
],
"text/plain": [
"<folium.folium.Map at 0x7f4041308278>"
]
},
"execution_count": 187,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"sgl_group = FeatureGroup(name='GroupLasso coefficients')\n",
"m.add_child(sgl_group)\n",
"for coef_id, row in sgl_coefs_df.iterrows():\n",
" subgroup = FeatureGroupSubGroup(sgl_group, coef_id)\n",
" m.add_child(subgroup)\n",
" \n",
" i = sgl_coefs_df.index.get_loc(coef_id)\n",
" color = colors[i]\n",
" \n",
" lopfi_lat, lopfi_lon = row['lopfi_lat'], row['lopfi_lon']\n",
" dipla_lat, dipla_lon = row['dipla_lat'], row['dipla_lon']\n",
" \n",
" if row.lopfi != dfu_lopfi:\n",
" lopfi = folium.CircleMarker(location=[lopfi_lat, lopfi_lon],\n",
" popup=f'LOPFI:{row.lopfi}', color=color, fill=True).add_to(subgroup)\n",
" if row.dipla != dfu_dipla:\n",
" dipla = folium.CircleMarker(location=[dipla_lat, dipla_lon],\n",
" popup=f'LOPFI:{row.dipla}', color=color, fill=True).add_to(subgroup)\n",
" \n",
" coef_line = PolyLine([[lopfi_lat, lopfi_lon],[dipla_lat, dipla_lon]],\n",
" popup=f'id:{coef_id}, coef:{row.coef}',\n",
" weight=row['coef'], color = color).add_to(subgroup)\n",
" \n",
"LayerControl().add_to(m)\n",
"m"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": []
}
],
"metadata": {
"kernelspec": {
"display_name": "Python [conda env:py36]",
"language": "python",
"name": "conda-env-py36-py"
},
"language_info": {
"codemirror_mode": {
"name": "ipython",
"version": 3
},
"file_extension": ".py",
"mimetype": "text/x-python",
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
"version": "3.6.6"
}
},
"nbformat": 4,
"nbformat_minor": 2
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment