Skip to content

Instantly share code, notes, and snippets.

@golobor
Created June 22, 2020 20:26
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save golobor/b69a75a7264b30cbe146021e2ac65d8d to your computer and use it in GitHub Desktop.
Save golobor/b69a75a7264b30cbe146021e2ac65d8d to your computer and use it in GitHub Desktop.
Bottle Brush P(s) theory for Gibcus et at 2018
Display the source blob
Display the rendered blob
Raw
{
"cells": [
{
"cell_type": "markdown",
"metadata": {
"toc": "true"
},
"source": [
"# Table of Contents\n",
" <p><div class=\"lev1\"><a href=\"#Bottle-brush-with-RW-angular-loop-orientation\"><span class=\"toc-item-num\">1&nbsp;&nbsp;</span>Bottle brush with RW angular loop orientation</a></div><div class=\"lev2\"><a href=\"#No-drift\"><span class=\"toc-item-num\">1.1&nbsp;&nbsp;</span>No drift</a></div><div class=\"lev2\"><a href=\"#With-drift\"><span class=\"toc-item-num\">1.2&nbsp;&nbsp;</span>With drift</a></div><div class=\"lev1\"><a href=\"#Bottle-brush-with-OU-angular-loop-orientation-(approximate)\"><span class=\"toc-item-num\">2&nbsp;&nbsp;</span>Bottle brush with OU angular loop orientation (approximate)</a></div><div class=\"lev1\"><a href=\"#Experimental\"><span class=\"toc-item-num\">3&nbsp;&nbsp;</span>Experimental</a></div><div class=\"lev1\"><a href=\"#Bottle-brush-with-random-angular-loop-orientation\"><span class=\"toc-item-num\">4&nbsp;&nbsp;</span>Bottle brush with random angular loop orientation</a></div>"
]
},
{
"cell_type": "code",
"execution_count": 1,
"metadata": {
"ExecuteTime": {
"end_time": "2020-06-22T20:20:39.452901Z",
"start_time": "2020-06-22T20:20:36.333899Z"
}
},
"outputs": [],
"source": [
"#import glob, os, sys, shelve, itertools\n",
"#from collections import OrderedDict\n",
"import matplotlib.pyplot as plt\n",
"\n",
"%matplotlib notebook\n",
"%config InlineBackend.figure_format = 'svg'\n",
"\n",
"import numpy as np\n",
"from ipywidgets.widgets.interaction import interact\n",
"import ipywidgets.widgets as widgets\n",
"\n",
"import scipy\n",
"import scipy.stats as st\n",
"\n",
"# from matplotlib import gridspec\n",
"# from mirnylib import plotting\n",
"\n",
"# import seaborn as sns\n",
"# sns.set_style('white')\n",
"# sns.set_palette('deep')\n",
"# sns.set_context('talk')\n",
"\n"
]
},
{
"cell_type": "code",
"execution_count": 2,
"metadata": {
"ExecuteTime": {
"end_time": "2020-06-22T20:20:39.460179Z",
"start_time": "2020-06-22T20:20:39.455595Z"
}
},
"outputs": [],
"source": [
"MIN_LOG10_S = -1\n",
"MAX_LOG10_S = 4\n",
"GLUE_AT = 2\n",
"EXP_LOOP_SIZE = 80000\n",
"IN_LOOP_SLOPE = -1.0"
]
},
{
"cell_type": "code",
"execution_count": 4,
"metadata": {
"ExecuteTime": {
"end_time": "2020-06-22T20:20:47.694519Z",
"start_time": "2020-06-22T20:20:47.672684Z"
}
},
"outputs": [],
"source": [
"# REFSC_7m = smcviz.scalings['WT-20151009-7m-R1']\n",
"\n",
"REFSC_7m = np.array([[ 1.06010000e+03, 1.18810000e+03, 1.33210000e+03,\n",
" 1.49310000e+03, 1.67360000e+03, 1.87610000e+03,\n",
" 2.10310000e+03, 2.35760000e+03, 2.64310000e+03,\n",
" 2.96310000e+03, 3.32160000e+03, 3.72310000e+03,\n",
" 4.17310000e+03, 4.67810000e+03, 5.24410000e+03,\n",
" 5.87860000e+03, 6.58960000e+03, 7.38660000e+03,\n",
" 8.28010000e+03, 9.28160000e+03, 1.04046000e+04,\n",
" 1.16631000e+04, 1.30736000e+04, 1.46551000e+04,\n",
" 1.64276000e+04, 1.84146000e+04, 2.06421000e+04,\n",
" 2.31386000e+04, 2.59371000e+04, 2.90741000e+04,\n",
" 3.25911000e+04, 3.65331000e+04, 4.09516000e+04,\n",
" 4.59051000e+04, 5.14576000e+04, 5.76816000e+04,\n",
" 6.46581000e+04, 7.24786000e+04, 8.12451000e+04,\n",
" 9.10716000e+04, 1.02087100e+05, 1.14434600e+05,\n",
" 1.28275600e+05, 1.43791100e+05, 1.61182600e+05,\n",
" 1.80677600e+05, 2.02531100e+05, 2.27027600e+05,\n",
" 2.54486600e+05, 2.85267100e+05, 3.19770600e+05,\n",
" 3.58447600e+05, 4.01802600e+05, 4.50401100e+05,\n",
" 5.04877600e+05, 5.65943600e+05, 6.34395600e+05,\n",
" 7.11126600e+05, 7.97138100e+05, 8.93553100e+05,\n",
" 1.00162960e+06, 1.12277810e+06, 1.25858010e+06,\n",
" 1.41080710e+06, 1.58144610e+06, 1.77272410e+06,\n",
" 1.98713760e+06, 2.22748460e+06, 2.49690160e+06,\n",
" 2.79890560e+06, 3.13743760e+06, 3.51691460e+06,\n",
" 3.94229010e+06, 4.41911560e+06, 4.95361410e+06,\n",
" 5.55276110e+06, 6.22437510e+06, 6.97722160e+06,\n",
" 7.82112610e+06, 8.76710210e+06, 9.82749510e+06,\n",
" 1.10161446e+07, 1.23485626e+07, 1.38421381e+07,\n",
" 1.55163641e+07, 1.73930901e+07, 1.94968086e+07,\n",
" 2.18549741e+07, 2.44983631e+07, 2.74614741e+07,\n",
" 3.07829776e+07, 3.45062216e+07, 3.86797966e+07,\n",
" 4.33581716e+07, 4.86024026e+07, 5.44809301e+07,\n",
" 6.10704741e+07, 6.84570326e+07, 7.67370056e+07,\n",
" 8.60184526e+07, 9.64225031e+07, 1.08084938e+08,\n",
" 1.21157961e+08, 1.35812184e+08, 1.52238855e+08,\n",
" 1.70652355e+08, 1.91292994e+08, 2.14430146e+08,\n",
" 2.40365768e+08, 2.69438340e+08, 3.02027280e+08,\n",
" 3.38557897e+08, 3.79506943e+08, 4.25408832e+08,\n",
" 4.76862619e+08, 5.34539812e+08, 5.99193141e+08,\n",
" 6.71666379e+08, 7.52905356e+08, 8.43970300e+08,\n",
" 9.46049675e+08],\n",
" [ 1.36025607e-05, 1.34046188e-05, 1.36574460e-05,\n",
" 1.32345444e-05, 1.29639579e-05, 1.25128973e-05,\n",
" 1.19243258e-05, 1.13629686e-05, 1.05735869e-05,\n",
" 9.77219368e-06, 8.84240339e-06, 8.06609568e-06,\n",
" 7.14465216e-06, 6.31499827e-06, 5.51226795e-06,\n",
" 4.76879398e-06, 4.18247063e-06, 3.59360570e-06,\n",
" 3.13764287e-06, 2.75338562e-06, 2.45340402e-06,\n",
" 2.18181840e-06, 1.94339264e-06, 1.77000763e-06,\n",
" 1.60003804e-06, 1.45911904e-06, 1.34797427e-06,\n",
" 1.22491760e-06, 1.13661127e-06, 1.05464027e-06,\n",
" 9.74862144e-07, 9.07692404e-07, 8.52651873e-07,\n",
" 7.98028535e-07, 7.45706359e-07, 7.00864258e-07,\n",
" 6.58708816e-07, 6.24673757e-07, 5.86377722e-07,\n",
" 5.54947671e-07, 5.26503076e-07, 4.98313350e-07,\n",
" 4.72124666e-07, 4.45941670e-07, 4.24237778e-07,\n",
" 3.99209011e-07, 3.77865371e-07, 3.54132789e-07,\n",
" 3.35382423e-07, 3.13948076e-07, 2.94289478e-07,\n",
" 2.74606656e-07, 2.58023724e-07, 2.39221238e-07,\n",
" 2.22871782e-07, 2.06780001e-07, 1.91610943e-07,\n",
" 1.77610080e-07, 1.64602895e-07, 1.52824997e-07,\n",
" 1.41911209e-07, 1.31598674e-07, 1.21713280e-07,\n",
" 1.12660971e-07, 1.03716735e-07, 9.49234670e-08,\n",
" 8.53526672e-08, 7.54735421e-08, 6.50218799e-08,\n",
" 5.39394069e-08, 4.37518502e-08, 3.52473806e-08,\n",
" 2.90136753e-08, 2.41306659e-08, 2.01100335e-08,\n",
" 1.69164445e-08, 1.45610547e-08, 1.27782927e-08,\n",
" 1.15661752e-08, 1.05925240e-08, 9.75479526e-09,\n",
" 8.97489348e-09, 8.23350430e-09, 7.44221577e-09,\n",
" 6.66177792e-09, 5.95105691e-09, 5.34956968e-09,\n",
" 4.80811488e-09, 4.37376310e-09, 3.93143736e-09,\n",
" 3.59289091e-09, 3.28204473e-09, 3.05535485e-09,\n",
" 2.87612295e-09, 2.73886018e-09, 2.63728473e-09,\n",
" 2.57426311e-09, 2.50288251e-09, 2.38974135e-09,\n",
" 2.27761691e-09, 2.12083309e-09, 1.95334581e-09,\n",
" 1.75004353e-09, np.nan, np.nan,\n",
" np.nan, np.nan, np.nan,\n",
" np.nan, np.nan, np.nan,\n",
" np.nan, np.nan, np.nan,\n",
" np.nan, np.nan, np.nan,\n",
" np.nan, np.nan, np.nan,\n",
" np.nan]])"
]
},
{
"cell_type": "code",
"execution_count": 5,
"metadata": {
"ExecuteTime": {
"end_time": "2020-06-22T20:20:48.870549Z",
"start_time": "2020-06-22T20:20:48.849338Z"
}
},
"outputs": [],
"source": [
"# REFSC_10m = smcviz.scalings['WT-92Pphase-10m-R1']\n",
"\n",
"REFSC_10m =np.array([[ 1.06010000e+03, 1.18810000e+03, 1.33210000e+03,\n",
" 1.49310000e+03, 1.67360000e+03, 1.87610000e+03,\n",
" 2.10310000e+03, 2.35760000e+03, 2.64310000e+03,\n",
" 2.96310000e+03, 3.32160000e+03, 3.72310000e+03,\n",
" 4.17310000e+03, 4.67810000e+03, 5.24410000e+03,\n",
" 5.87860000e+03, 6.58960000e+03, 7.38660000e+03,\n",
" 8.28010000e+03, 9.28160000e+03, 1.04046000e+04,\n",
" 1.16631000e+04, 1.30736000e+04, 1.46551000e+04,\n",
" 1.64276000e+04, 1.84146000e+04, 2.06421000e+04,\n",
" 2.31386000e+04, 2.59371000e+04, 2.90741000e+04,\n",
" 3.25911000e+04, 3.65331000e+04, 4.09516000e+04,\n",
" 4.59051000e+04, 5.14576000e+04, 5.76816000e+04,\n",
" 6.46581000e+04, 7.24786000e+04, 8.12451000e+04,\n",
" 9.10716000e+04, 1.02087100e+05, 1.14434600e+05,\n",
" 1.28275600e+05, 1.43791100e+05, 1.61182600e+05,\n",
" 1.80677600e+05, 2.02531100e+05, 2.27027600e+05,\n",
" 2.54486600e+05, 2.85267100e+05, 3.19770600e+05,\n",
" 3.58447600e+05, 4.01802600e+05, 4.50401100e+05,\n",
" 5.04877600e+05, 5.65943600e+05, 6.34395600e+05,\n",
" 7.11126600e+05, 7.97138100e+05, 8.93553100e+05,\n",
" 1.00162960e+06, 1.12277810e+06, 1.25858010e+06,\n",
" 1.41080710e+06, 1.58144610e+06, 1.77272410e+06,\n",
" 1.98713760e+06, 2.22748460e+06, 2.49690160e+06,\n",
" 2.79890560e+06, 3.13743760e+06, 3.51691460e+06,\n",
" 3.94229010e+06, 4.41911560e+06, 4.95361410e+06,\n",
" 5.55276110e+06, 6.22437510e+06, 6.97722160e+06,\n",
" 7.82112610e+06, 8.76710210e+06, 9.82749510e+06,\n",
" 1.10161446e+07, 1.23485626e+07, 1.38421381e+07,\n",
" 1.55163641e+07, 1.73930901e+07, 1.94968086e+07,\n",
" 2.18549741e+07, 2.44983631e+07, 2.74614741e+07,\n",
" 3.07829776e+07, 3.45062216e+07, 3.86797966e+07,\n",
" 4.33581716e+07, 4.86024026e+07, 5.44809301e+07,\n",
" 6.10704741e+07, 6.84570326e+07, 7.67370056e+07,\n",
" 8.60184526e+07, 9.64225031e+07, 1.08084938e+08,\n",
" 1.21157961e+08, 1.35812184e+08, 1.52238855e+08,\n",
" 1.70652355e+08, 1.91292994e+08, 2.14430146e+08,\n",
" 2.40365768e+08, 2.69438340e+08, 3.02027280e+08,\n",
" 3.38557897e+08, 3.79506943e+08, 4.25408832e+08,\n",
" 4.76862619e+08, 5.34539812e+08, 5.99193141e+08,\n",
" 6.71666379e+08, 7.52905356e+08, 8.43970300e+08,\n",
" 9.46049675e+08],\n",
" [ 5.12401928e-06, 5.21053010e-06, 5.43670420e-06,\n",
" 5.51432327e-06, 5.80338727e-06, 5.74049234e-06,\n",
" 5.81727055e-06, 5.86260055e-06, 5.73426592e-06,\n",
" 5.67409064e-06, 5.51083511e-06, 5.34948672e-06,\n",
" 5.15669658e-06, 4.94856413e-06, 4.69226356e-06,\n",
" 4.42405745e-06, 4.17199337e-06, 3.90491288e-06,\n",
" 3.61900127e-06, 3.39410568e-06, 3.12408496e-06,\n",
" 2.89812736e-06, 2.69193214e-06, 2.45217645e-06,\n",
" 2.27232962e-06, 2.09816377e-06, 1.93096590e-06,\n",
" 1.78977445e-06, 1.64921804e-06, 1.52646390e-06,\n",
" 1.41841330e-06, 1.32360411e-06, 1.22847270e-06,\n",
" 1.15095084e-06, 1.08174275e-06, 1.01408849e-06,\n",
" 9.55430430e-07, 8.98691236e-07, 8.58129012e-07,\n",
" 8.08875083e-07, 7.64637589e-07, 7.31114664e-07,\n",
" 6.92200849e-07, 6.60665470e-07, 6.31291407e-07,\n",
" 5.97896042e-07, 5.68835030e-07, 5.42300591e-07,\n",
" 5.15300288e-07, 4.88965839e-07, 4.61142954e-07,\n",
" 4.36771896e-07, 4.13572974e-07, 3.90778564e-07,\n",
" 3.69347980e-07, 3.48814164e-07, 3.28971645e-07,\n",
" 3.11824481e-07, 2.93789418e-07, 2.76521240e-07,\n",
" 2.59964798e-07, 2.43863255e-07, 2.27076162e-07,\n",
" 2.08273698e-07, 1.87344523e-07, 1.63703500e-07,\n",
" 1.37869309e-07, 1.11120277e-07, 8.64569185e-08,\n",
" 6.59059683e-08, 4.95332916e-08, 3.70433346e-08,\n",
" 2.74404981e-08, 2.04434070e-08, 1.54896441e-08,\n",
" 1.21378868e-08, 9.97291256e-09, 8.51308568e-09,\n",
" 7.41821013e-09, 6.61411826e-09, 5.95786854e-09,\n",
" 5.33640193e-09, 4.72705901e-09, 4.18209989e-09,\n",
" 3.59923398e-09, 3.03972761e-09, 2.54110466e-09,\n",
" 2.11420249e-09, 1.73818067e-09, 1.44410727e-09,\n",
" 1.16081550e-09, 9.36761032e-10, 7.76385942e-10,\n",
" 6.58526750e-10, 5.62581388e-10, 4.95524509e-10,\n",
" 4.62136925e-10, 4.14579522e-10, 4.02640302e-10,\n",
" 3.91300897e-10, 3.52900340e-10, 3.59177371e-10,\n",
" 4.74865558e-10, np.nan, np.nan,\n",
" np.nan, np.nan, np.nan,\n",
" np.nan, np.nan, np.nan,\n",
" np.nan, np.nan, np.nan,\n",
" np.nan, np.nan, np.nan,\n",
" np.nan, np.nan, np.nan,\n",
" np.nan]])"
]
},
{
"cell_type": "code",
"execution_count": 6,
"metadata": {
"ExecuteTime": {
"end_time": "2020-06-22T20:20:50.001895Z",
"start_time": "2020-06-22T20:20:49.980182Z"
}
},
"outputs": [],
"source": [
"# REFSC_30m = smcviz.scalings['WT-20150609-30m-R1']\n",
"\n",
"REFSC_30m = (\n",
" np.array([1060.0999999999999, 1188.0999999999999, 1332.0999999999999, 1493.0999999999999, 1673.5999999999999, 1876.0999999999999, 2103.0999999999999, 2357.5999999999999, 2643.0999999999999, 2963.0999999999999, 3321.5999999999999, 3723.0999999999999, 4173.1000000000004, 4678.1000000000004, 5244.1000000000004, 5878.6000000000004, 6589.6000000000004, 7386.6000000000004, 8280.1000000000004, 9281.6000000000004, 10404.6, 11663.1, 13073.6, 14655.1, 16427.599999999999, 18414.599999999999, 20642.099999999999, 23138.599999999999, 25937.099999999999, 29074.099999999999, 32591.099999999999, 36533.099999999999, 40951.599999999999, 45905.099999999999, 51457.599999999999, 57681.599999999999, 64658.100000000006, 72478.600000000006, 81245.100000000006, 91071.600000000006, 102087.10000000001, 114434.60000000001, 128275.60000000001, 143791.10000000001, 161182.60000000001, 180677.60000000001, 202531.10000000001, 227027.60000000001, 254486.59999999998, 285267.09999999998, 319770.59999999998, 358447.59999999998, 401802.59999999998, 450401.09999999998, 504877.59999999998, 565943.59999999998, 634395.59999999998, 711126.59999999998, 797138.09999999998, 893553.09999999998, 1001629.6000000001, 1122778.1000000001, 1258580.1000000001, 1410807.1000000001, 1581446.1000000001, 1772724.1000000001, 1987137.6000000001, 2227484.6000000001, 2496901.6000000001, 2798905.6000000001, 3137437.6000000001, 3516914.6000000001, 3942290.1000000001, 4419115.5999999996, 4953614.0999999996, 5552761.0999999996, 6224375.0999999996, 6977221.5999999996, 7821126.0999999996, 8767102.0999999996, 9827495.0999999996, 11016144.6, 12348562.6, 13842138.1, 15516364.1, 17393090.100000001, 19496808.600000001, 21854974.100000001, 24498363.100000001, 27461474.100000001, 30782977.600000001, 34506221.600000001, 38679796.600000001, 43358171.600000001, 48602402.600000001, 54480930.100000001, 61070474.100000001, 68457032.599999994, 76737005.599999994, 86018452.599999994, 96422503.099999994, 108084938.09999999, 121157961.09999999, 135812184.09999999, 152238855.09999999, 170652355.09999999, 191292993.59999999, 214430145.59999999, 240365768.09999999, 269438340.10000002, 302027280.10000002, 338557897.10000002, 379506942.60000002, 425408832.10000002, 476862618.60000002, 534539811.60000002, 599193140.60000002, 671666379.10000002, 752905356.10000002, 843970299.60000002, 946049674.60000002]),\n",
" np.array([23.675955871271874, 23.236626555421729, 23.066863635884847, 22.154452714571342, 21.467480284981807, 20.487367494245994, 19.160454706435878, 17.949003170166357, 16.415234568857386, 14.890233181524469, 13.327493418288194, 11.976836612759442, 10.512942407898162, 9.1349005029935775, 7.9085956321347277, 6.7569424618369842, 5.8690989848720863, 5.0640546842705909, 4.4052025303940123, 3.8904891247104438, 3.4631642433279706, 3.1253142884925431, 2.8047821378746551, 2.5578439264424477, 2.3630871716158621, 2.1790466537117612, 2.0246085517256325, 1.8838032175167119, 1.76475211641389, 1.6462896440262906, 1.5525393513441721, 1.4588544928495353, 1.3721372555187086, 1.3008301278520282, 1.2287831641991491, 1.1669889062227117, 1.1058944331413405, 1.0500554482960165, 1.0, 0.9626059154858434, 0.91474919296378132, 0.87982050546965485, 0.84226404486894413, 0.8089168077811949, 0.7769503867285813, 0.74647710200195516, 0.71588134711832496, 0.68697410529290193, 0.65871989693983068, 0.62731464238829537, 0.60027613270236702, 0.57514705963705059, 0.54615107057834789, 0.51976930440691971, 0.49090114734707713, 0.46307744679980578, 0.43447665458306117, 0.40687844130045864, 0.37938086283748018, 0.35114034378259634, 0.32291674469674325, 0.29463998972017813, 0.26751258897884228, 0.23995520669188192, 0.21396083423648307, 0.19011344601583471, 0.16718835632995099, 0.14709446687242295, 0.13021253723330545, 0.1160188918882349, 0.10670497929090897, 0.10111587113542761, 0.099641938724001289, 0.10259190796296001, 0.10912502769018932, 0.11637930652079441, 0.11998296048899362, 0.11298928603359318, 0.094577549712040562, 0.069578032765169537, 0.048057204280106222, 0.035223246097696274, 0.029000513382554206, 0.024373415309400931, 0.019243673691066811, 0.01462752889253496, 0.011302196219838108, 0.0091482940278357575, 0.0074610556191346883, 0.0061577877928047694, 0.0052151024960781353, 0.0044258888621608412, 0.0038571980326946318, 0.0033870834338773342, 0.0030387264655687874, 0.002745753811241077, 0.002526358711246568, 0.0023551346707166173, 0.002179804846088893, 0.0019746189904878185, 0.0017948425263511838, 0.0015583471819714605, 0.0012250967415409282, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan])\n",
")"
]
},
{
"cell_type": "code",
"execution_count": 7,
"metadata": {
"ExecuteTime": {
"end_time": "2020-06-22T20:20:50.683058Z",
"start_time": "2020-06-22T20:20:50.662665Z"
}
},
"outputs": [],
"source": [
"REFSC_60m = np.array([\n",
" [1.06010000e+03, 1.18810000e+03, 1.33210000e+03, 1.49310000e+03, 1.67360000e+03, 1.87610000e+03, 2.10310000e+03, 2.35760000e+03, 2.64310000e+03, 2.96310000e+03, 3.32160000e+03, 3.72310000e+03, 4.17310000e+03, 4.67810000e+03, 5.24410000e+03, 5.87860000e+03, 6.58960000e+03, 7.38660000e+03, 8.28010000e+03, 9.28160000e+03, 1.04046000e+04, 1.16631000e+04, 1.30736000e+04, 1.46551000e+04, 1.64276000e+04, 1.84146000e+04, 2.06421000e+04, 2.31386000e+04, 2.59371000e+04, 2.90741000e+04, 3.25911000e+04, 3.65331000e+04, 4.09516000e+04, 4.59051000e+04, 5.14576000e+04, 5.76816000e+04, 6.46581000e+04, 7.24786000e+04, 8.12451000e+04, 9.10716000e+04, 1.02087100e+05, 1.14434600e+05, 1.28275600e+05, 1.43791100e+05, 1.61182600e+05, 1.80677600e+05, 2.02531100e+05, 2.27027600e+05, 2.54486600e+05, 2.85267100e+05, 3.19770600e+05, 3.58447600e+05, 4.01802600e+05, 4.50401100e+05, 5.04877600e+05, 5.65943600e+05, 6.34395600e+05, 7.11126600e+05, 7.97138100e+05, 8.93553100e+05, 1.00162960e+06, 1.12277810e+06, 1.25858010e+06, 1.41080710e+06, 1.58144610e+06, 1.77272410e+06, 1.98713760e+06, 2.22748460e+06, 2.49690160e+06, 2.79890560e+06, 3.13743760e+06, 3.51691460e+06, 3.94229010e+06, 4.41911560e+06, 4.95361410e+06, 5.55276110e+06, 6.22437510e+06, 6.97722160e+06, 7.82112610e+06, 8.76710210e+06, 9.82749510e+06, 1.10161446e+07, 1.23485626e+07, 1.38421381e+07, 1.55163641e+07, 1.73930901e+07, 1.94968086e+07, 2.18549741e+07, 2.44983631e+07, 2.74614741e+07, 3.07829776e+07, 3.45062216e+07, 3.86797966e+07, 4.33581716e+07, 4.86024026e+07, 5.44809301e+07, 6.10704741e+07, 6.84570326e+07, 7.67370056e+07, 8.60184526e+07, 9.64225031e+07, 1.08084938e+08, 1.21157961e+08, 1.35812184e+08, 1.52238855e+08, 1.70652355e+08, 1.91292994e+08, 2.14430146e+08, 2.40365768e+08, 2.69438340e+08, 3.02027280e+08, 3.38557897e+08, 3.79506943e+08, 4.25408832e+08, 4.76862619e+08, 5.34539812e+08, 5.99193141e+08, 6.71666379e+08, 7.52905356e+08, 8.43970300e+08, 9.46049675e+08],\n",
" [1.11674528e-05, 1.10282684e-05, 1.09980203e-05, 1.06884880e-05, 1.03712325e-05, 9.95821573e-06, 9.47413900e-06, 8.87913543e-06, 8.21672193e-06, 7.45318538e-06, 6.82834626e-06, 6.14048613e-06, 5.37048964e-06, 4.71935343e-06, 4.06989925e-06, 3.51089326e-06, 3.02076909e-06, 2.57435245e-06, 2.21909132e-06, 1.91879215e-06, 1.68308009e-06, 1.46757533e-06, 1.30174005e-06, 1.17126648e-06, 1.04734768e-06, 9.51688382e-07, 8.62266245e-07, 7.93401224e-07, 7.25596116e-07, 6.76413802e-07, 6.24958572e-07, 5.84692670e-07, 5.43564296e-07, 5.05236306e-07, 4.71761588e-07, 4.41920715e-07, 4.15568895e-07, 3.92503100e-07, 3.70347541e-07, 3.50564659e-07, 3.33628688e-07, 3.17393189e-07, 3.03657569e-07, 2.90687400e-07, 2.78146055e-07, 2.66326586e-07, 2.55340097e-07, 2.45048634e-07, 2.35155466e-07, 2.25754918e-07, 2.15531712e-07, 2.06851814e-07, 1.97710816e-07, 1.89624627e-07, 1.80552323e-07, 1.71415055e-07, 1.62620001e-07, 1.53768791e-07, 1.44083593e-07, 1.35276642e-07, 1.26636339e-07, 1.17637592e-07, 1.08375348e-07, 9.94187099e-08, 9.04282429e-08, 8.17490821e-08, 7.35160607e-08, 6.52278835e-08, 5.76475407e-08, 5.06953599e-08, 4.44968908e-08, 3.94321523e-08, 3.47959158e-08, 3.12136029e-08, 2.85296416e-08, 2.67930020e-08, 2.59793418e-08, 2.59996532e-08, 2.65096650e-08, 2.68270629e-08, 2.62755234e-08, 2.43076446e-08, 2.07729648e-08, 1.64369050e-08, 1.22358304e-08, 8.92005709e-09, 6.91674313e-09, 5.68891892e-09, 4.89137781e-09, 4.16687997e-09, 3.59501755e-09, 3.15501512e-09, 2.85019840e-09, 2.60398008e-09, 2.42504006e-09, 2.27515440e-09, 2.16693084e-09, 2.04621298e-09, 1.86925166e-09, 1.73855477e-09, 1.57095274e-09, 1.31108423e-09, 9.11974699e-10, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan, np.nan]])"
]
},
{
"cell_type": "code",
"execution_count": 8,
"metadata": {
"ExecuteTime": {
"end_time": "2020-06-22T20:20:51.553533Z",
"start_time": "2020-06-22T20:20:51.533565Z"
}
},
"outputs": [],
"source": [
"def prepare_canvas(refsc = REFSC_10m, \n",
" exp_loop_size=EXP_LOOP_SIZE):\n",
" \n",
" fig, ax = plt.subplots(1,2, figsize=(8,3.5))\n",
" plt.subplots_adjust(bottom=0.15, wspace=0.3)\n",
" ln1 = ax[0].plot([], [], label='test')\n",
"\n",
" ax[0].set_xlim(MIN_LOG10_S,MAX_LOG10_S)\n",
" ax[0].set_ylim(-3,1)\n",
" ax[0].set_xticks(np.arange(MIN_LOG10_S,MAX_LOG10_S+0.01))\n",
" ax[0].axvline(0.0, ls='--', c='gray',lw=0.5)\n",
" ax[0].set_aspect(1.0)\n",
" ax[0].set_xlabel('log10 separation/avg loop length')\n",
" ax[0].set_ylabel('log10 contact frequency')\n",
"\n",
" if refsc is not None:\n",
" x = refsc[0] / exp_loop_size\n",
" y = refsc[1]\n",
" y /= y[np.argmin(np.abs(np.log10(x/GLUE_AT)))]\n",
"\n",
" ax[0].plot(\n",
" np.log10(x),\n",
" np.log10(y)\n",
" )\n",
" \n",
" ax[1].plot(\n",
" np.log10(x[1:]*x[:-1]),\n",
" np.diff(np.log10(y)) / np.diff(np.log10(x))\n",
" )\n",
" else:\n",
" ax[0].plot(\n",
" [],\n",
" []\n",
" )\n",
" ax[1].plot(\n",
" [],\n",
" []\n",
" )\n",
" \n",
" \n",
" ln2 = ax[1].plot([], [], label='test')\n",
" ax[1].set_xlim(MIN_LOG10_S,MAX_LOG10_S)\n",
" ax[1].set_ylim(-3,1)\n",
" ax[1].set_aspect(1.0)\n",
" ax[1].axvline(0.0, ls='--', c='gray',lw=0.5)\n",
" ax[1].axhline(0.0, ls='--', c='gray',lw=0.5)\n",
" ax[1].axhline(-0.5, ls='--', c='gray',lw=0.5)\n",
" ax[1].axhline(-1.0, ls='--', c='gray',lw=0.5)\n",
" ax[1].axhline(-1.5, ls='--', c='gray',lw=0.5)\n",
" ax[1].set_xlabel('log10 separation/avg loop length')\n",
" ax[1].set_ylabel('log-log derivative')\n",
" \n",
" return fig, ax"
]
},
{
"cell_type": "code",
"execution_count": 9,
"metadata": {
"ExecuteTime": {
"end_time": "2020-06-22T20:20:54.004699Z",
"start_time": "2020-06-22T20:20:53.625861Z"
}
},
"outputs": [
{
"data": {
"application/javascript": [
"/* Put everything inside the global mpl namespace */\n",
"window.mpl = {};\n",
"\n",
"\n",
"mpl.get_websocket_type = function() {\n",
" if (typeof(WebSocket) !== 'undefined') {\n",
" return WebSocket;\n",
" } else if (typeof(MozWebSocket) !== 'undefined') {\n",
" return MozWebSocket;\n",
" } else {\n",
" alert('Your browser does not have WebSocket support. ' +\n",
" 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
" 'Firefox 4 and 5 are also supported but you ' +\n",
" 'have to enable WebSockets in about:config.');\n",
" };\n",
"}\n",
"\n",
"mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
" this.id = figure_id;\n",
"\n",
" this.ws = websocket;\n",
"\n",
" this.supports_binary = (this.ws.binaryType != undefined);\n",
"\n",
" if (!this.supports_binary) {\n",
" var warnings = document.getElementById(\"mpl-warnings\");\n",
" if (warnings) {\n",
" warnings.style.display = 'block';\n",
" warnings.textContent = (\n",
" \"This browser does not support binary websocket messages. \" +\n",
" \"Performance may be slow.\");\n",
" }\n",
" }\n",
"\n",
" this.imageObj = new Image();\n",
"\n",
" this.context = undefined;\n",
" this.message = undefined;\n",
" this.canvas = undefined;\n",
" this.rubberband_canvas = undefined;\n",
" this.rubberband_context = undefined;\n",
" this.format_dropdown = undefined;\n",
"\n",
" this.image_mode = 'full';\n",
"\n",
" this.root = $('<div/>');\n",
" this._root_extra_style(this.root)\n",
" this.root.attr('style', 'display: inline-block');\n",
"\n",
" $(parent_element).append(this.root);\n",
"\n",
" this._init_header(this);\n",
" this._init_canvas(this);\n",
" this._init_toolbar(this);\n",
"\n",
" var fig = this;\n",
"\n",
" this.waiting = false;\n",
"\n",
" this.ws.onopen = function () {\n",
" fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
" fig.send_message(\"send_image_mode\", {});\n",
" if (mpl.ratio != 1) {\n",
" fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
" }\n",
" fig.send_message(\"refresh\", {});\n",
" }\n",
"\n",
" this.imageObj.onload = function() {\n",
" if (fig.image_mode == 'full') {\n",
" // Full images could contain transparency (where diff images\n",
" // almost always do), so we need to clear the canvas so that\n",
" // there is no ghosting.\n",
" fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
" }\n",
" fig.context.drawImage(fig.imageObj, 0, 0);\n",
" };\n",
"\n",
" this.imageObj.onunload = function() {\n",
" fig.ws.close();\n",
" }\n",
"\n",
" this.ws.onmessage = this._make_on_message_function(this);\n",
"\n",
" this.ondownload = ondownload;\n",
"}\n",
"\n",
"mpl.figure.prototype._init_header = function() {\n",
" var titlebar = $(\n",
" '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
" 'ui-helper-clearfix\"/>');\n",
" var titletext = $(\n",
" '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
" 'text-align: center; padding: 3px;\"/>');\n",
" titlebar.append(titletext)\n",
" this.root.append(titlebar);\n",
" this.header = titletext[0];\n",
"}\n",
"\n",
"\n",
"\n",
"mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
"\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
"\n",
"}\n",
"\n",
"mpl.figure.prototype._init_canvas = function() {\n",
" var fig = this;\n",
"\n",
" var canvas_div = $('<div/>');\n",
"\n",
" canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
"\n",
" function canvas_keyboard_event(event) {\n",
" return fig.key_event(event, event['data']);\n",
" }\n",
"\n",
" canvas_div.keydown('key_press', canvas_keyboard_event);\n",
" canvas_div.keyup('key_release', canvas_keyboard_event);\n",
" this.canvas_div = canvas_div\n",
" this._canvas_extra_style(canvas_div)\n",
" this.root.append(canvas_div);\n",
"\n",
" var canvas = $('<canvas/>');\n",
" canvas.addClass('mpl-canvas');\n",
" canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
"\n",
" this.canvas = canvas[0];\n",
" this.context = canvas[0].getContext(\"2d\");\n",
"\n",
" var backingStore = this.context.backingStorePixelRatio ||\n",
"\tthis.context.webkitBackingStorePixelRatio ||\n",
"\tthis.context.mozBackingStorePixelRatio ||\n",
"\tthis.context.msBackingStorePixelRatio ||\n",
"\tthis.context.oBackingStorePixelRatio ||\n",
"\tthis.context.backingStorePixelRatio || 1;\n",
"\n",
" mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
"\n",
" var rubberband = $('<canvas/>');\n",
" rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
"\n",
" var pass_mouse_events = true;\n",
"\n",
" canvas_div.resizable({\n",
" start: function(event, ui) {\n",
" pass_mouse_events = false;\n",
" },\n",
" resize: function(event, ui) {\n",
" fig.request_resize(ui.size.width, ui.size.height);\n",
" },\n",
" stop: function(event, ui) {\n",
" pass_mouse_events = true;\n",
" fig.request_resize(ui.size.width, ui.size.height);\n",
" },\n",
" });\n",
"\n",
" function mouse_event_fn(event) {\n",
" if (pass_mouse_events)\n",
" return fig.mouse_event(event, event['data']);\n",
" }\n",
"\n",
" rubberband.mousedown('button_press', mouse_event_fn);\n",
" rubberband.mouseup('button_release', mouse_event_fn);\n",
" // Throttle sequential mouse events to 1 every 20ms.\n",
" rubberband.mousemove('motion_notify', mouse_event_fn);\n",
"\n",
" rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
" rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
"\n",
" canvas_div.on(\"wheel\", function (event) {\n",
" event = event.originalEvent;\n",
" event['data'] = 'scroll'\n",
" if (event.deltaY < 0) {\n",
" event.step = 1;\n",
" } else {\n",
" event.step = -1;\n",
" }\n",
" mouse_event_fn(event);\n",
" });\n",
"\n",
" canvas_div.append(canvas);\n",
" canvas_div.append(rubberband);\n",
"\n",
" this.rubberband = rubberband;\n",
" this.rubberband_canvas = rubberband[0];\n",
" this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
" this.rubberband_context.strokeStyle = \"#000000\";\n",
"\n",
" this._resize_canvas = function(width, height) {\n",
" // Keep the size of the canvas, canvas container, and rubber band\n",
" // canvas in synch.\n",
" canvas_div.css('width', width)\n",
" canvas_div.css('height', height)\n",
"\n",
" canvas.attr('width', width * mpl.ratio);\n",
" canvas.attr('height', height * mpl.ratio);\n",
" canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
"\n",
" rubberband.attr('width', width);\n",
" rubberband.attr('height', height);\n",
" }\n",
"\n",
" // Set the figure to an initial 600x600px, this will subsequently be updated\n",
" // upon first draw.\n",
" this._resize_canvas(600, 600);\n",
"\n",
" // Disable right mouse context menu.\n",
" $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
" return false;\n",
" });\n",
"\n",
" function set_focus () {\n",
" canvas.focus();\n",
" canvas_div.focus();\n",
" }\n",
"\n",
" window.setTimeout(set_focus, 100);\n",
"}\n",
"\n",
"mpl.figure.prototype._init_toolbar = function() {\n",
" var fig = this;\n",
"\n",
" var nav_element = $('<div/>');\n",
" nav_element.attr('style', 'width: 100%');\n",
" this.root.append(nav_element);\n",
"\n",
" // Define a callback function for later on.\n",
" function toolbar_event(event) {\n",
" return fig.toolbar_button_onclick(event['data']);\n",
" }\n",
" function toolbar_mouse_event(event) {\n",
" return fig.toolbar_button_onmouseover(event['data']);\n",
" }\n",
"\n",
" for(var toolbar_ind in mpl.toolbar_items) {\n",
" var name = mpl.toolbar_items[toolbar_ind][0];\n",
" var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
" var image = mpl.toolbar_items[toolbar_ind][2];\n",
" var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
"\n",
" if (!name) {\n",
" // put a spacer in here.\n",
" continue;\n",
" }\n",
" var button = $('<button/>');\n",
" button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
" 'ui-button-icon-only');\n",
" button.attr('role', 'button');\n",
" button.attr('aria-disabled', 'false');\n",
" button.click(method_name, toolbar_event);\n",
" button.mouseover(tooltip, toolbar_mouse_event);\n",
"\n",
" var icon_img = $('<span/>');\n",
" icon_img.addClass('ui-button-icon-primary ui-icon');\n",
" icon_img.addClass(image);\n",
" icon_img.addClass('ui-corner-all');\n",
"\n",
" var tooltip_span = $('<span/>');\n",
" tooltip_span.addClass('ui-button-text');\n",
" tooltip_span.html(tooltip);\n",
"\n",
" button.append(icon_img);\n",
" button.append(tooltip_span);\n",
"\n",
" nav_element.append(button);\n",
" }\n",
"\n",
" var fmt_picker_span = $('<span/>');\n",
"\n",
" var fmt_picker = $('<select/>');\n",
" fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
" fmt_picker_span.append(fmt_picker);\n",
" nav_element.append(fmt_picker_span);\n",
" this.format_dropdown = fmt_picker[0];\n",
"\n",
" for (var ind in mpl.extensions) {\n",
" var fmt = mpl.extensions[ind];\n",
" var option = $(\n",
" '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
" fmt_picker.append(option);\n",
" }\n",
"\n",
" // Add hover states to the ui-buttons\n",
" $( \".ui-button\" ).hover(\n",
" function() { $(this).addClass(\"ui-state-hover\");},\n",
" function() { $(this).removeClass(\"ui-state-hover\");}\n",
" );\n",
"\n",
" var status_bar = $('<span class=\"mpl-message\"/>');\n",
" nav_element.append(status_bar);\n",
" this.message = status_bar[0];\n",
"}\n",
"\n",
"mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
" // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
" // which will in turn request a refresh of the image.\n",
" this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
"}\n",
"\n",
"mpl.figure.prototype.send_message = function(type, properties) {\n",
" properties['type'] = type;\n",
" properties['figure_id'] = this.id;\n",
" this.ws.send(JSON.stringify(properties));\n",
"}\n",
"\n",
"mpl.figure.prototype.send_draw_message = function() {\n",
" if (!this.waiting) {\n",
" this.waiting = true;\n",
" this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
" }\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype.handle_save = function(fig, msg) {\n",
" var format_dropdown = fig.format_dropdown;\n",
" var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
" fig.ondownload(fig, format);\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
" var size = msg['size'];\n",
" if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
" fig._resize_canvas(size[0], size[1]);\n",
" fig.send_message(\"refresh\", {});\n",
" };\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
" var x0 = msg['x0'] / mpl.ratio;\n",
" var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
" var x1 = msg['x1'] / mpl.ratio;\n",
" var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
" x0 = Math.floor(x0) + 0.5;\n",
" y0 = Math.floor(y0) + 0.5;\n",
" x1 = Math.floor(x1) + 0.5;\n",
" y1 = Math.floor(y1) + 0.5;\n",
" var min_x = Math.min(x0, x1);\n",
" var min_y = Math.min(y0, y1);\n",
" var width = Math.abs(x1 - x0);\n",
" var height = Math.abs(y1 - y0);\n",
"\n",
" fig.rubberband_context.clearRect(\n",
" 0, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\n",
"\n",
" fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
" // Updates the figure title.\n",
" fig.header.textContent = msg['label'];\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
" var cursor = msg['cursor'];\n",
" switch(cursor)\n",
" {\n",
" case 0:\n",
" cursor = 'pointer';\n",
" break;\n",
" case 1:\n",
" cursor = 'default';\n",
" break;\n",
" case 2:\n",
" cursor = 'crosshair';\n",
" break;\n",
" case 3:\n",
" cursor = 'move';\n",
" break;\n",
" }\n",
" fig.rubberband_canvas.style.cursor = cursor;\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_message = function(fig, msg) {\n",
" fig.message.textContent = msg['message'];\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
" // Request the server to send over a new figure.\n",
" fig.send_draw_message();\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
" fig.image_mode = msg['mode'];\n",
"}\n",
"\n",
"mpl.figure.prototype.updated_canvas_event = function() {\n",
" // Called whenever the canvas gets updated.\n",
" this.send_message(\"ack\", {});\n",
"}\n",
"\n",
"// A function to construct a web socket function for onmessage handling.\n",
"// Called in the figure constructor.\n",
"mpl.figure.prototype._make_on_message_function = function(fig) {\n",
" return function socket_on_message(evt) {\n",
" if (evt.data instanceof Blob) {\n",
" /* FIXME: We get \"Resource interpreted as Image but\n",
" * transferred with MIME type text/plain:\" errors on\n",
" * Chrome. But how to set the MIME type? It doesn't seem\n",
" * to be part of the websocket stream */\n",
" evt.data.type = \"image/png\";\n",
"\n",
" /* Free the memory for the previous frames */\n",
" if (fig.imageObj.src) {\n",
" (window.URL || window.webkitURL).revokeObjectURL(\n",
" fig.imageObj.src);\n",
" }\n",
"\n",
" fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
" evt.data);\n",
" fig.updated_canvas_event();\n",
" fig.waiting = false;\n",
" return;\n",
" }\n",
" else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
" fig.imageObj.src = evt.data;\n",
" fig.updated_canvas_event();\n",
" fig.waiting = false;\n",
" return;\n",
" }\n",
"\n",
" var msg = JSON.parse(evt.data);\n",
" var msg_type = msg['type'];\n",
"\n",
" // Call the \"handle_{type}\" callback, which takes\n",
" // the figure and JSON message as its only arguments.\n",
" try {\n",
" var callback = fig[\"handle_\" + msg_type];\n",
" } catch (e) {\n",
" console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
" return;\n",
" }\n",
"\n",
" if (callback) {\n",
" try {\n",
" // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
" callback(fig, msg);\n",
" } catch (e) {\n",
" console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
" }\n",
" }\n",
" };\n",
"}\n",
"\n",
"// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
"mpl.findpos = function(e) {\n",
" //this section is from http://www.quirksmode.org/js/events_properties.html\n",
" var targ;\n",
" if (!e)\n",
" e = window.event;\n",
" if (e.target)\n",
" targ = e.target;\n",
" else if (e.srcElement)\n",
" targ = e.srcElement;\n",
" if (targ.nodeType == 3) // defeat Safari bug\n",
" targ = targ.parentNode;\n",
"\n",
" // jQuery normalizes the pageX and pageY\n",
" // pageX,Y are the mouse positions relative to the document\n",
" // offset() returns the position of the element relative to the document\n",
" var x = e.pageX - $(targ).offset().left;\n",
" var y = e.pageY - $(targ).offset().top;\n",
"\n",
" return {\"x\": x, \"y\": y};\n",
"};\n",
"\n",
"/*\n",
" * return a copy of an object with only non-object keys\n",
" * we need this to avoid circular references\n",
" * http://stackoverflow.com/a/24161582/3208463\n",
" */\n",
"function simpleKeys (original) {\n",
" return Object.keys(original).reduce(function (obj, key) {\n",
" if (typeof original[key] !== 'object')\n",
" obj[key] = original[key]\n",
" return obj;\n",
" }, {});\n",
"}\n",
"\n",
"mpl.figure.prototype.mouse_event = function(event, name) {\n",
" var canvas_pos = mpl.findpos(event)\n",
"\n",
" if (name === 'button_press')\n",
" {\n",
" this.canvas.focus();\n",
" this.canvas_div.focus();\n",
" }\n",
"\n",
" var x = canvas_pos.x * mpl.ratio;\n",
" var y = canvas_pos.y * mpl.ratio;\n",
"\n",
" this.send_message(name, {x: x, y: y, button: event.button,\n",
" step: event.step,\n",
" guiEvent: simpleKeys(event)});\n",
"\n",
" /* This prevents the web browser from automatically changing to\n",
" * the text insertion cursor when the button is pressed. We want\n",
" * to control all of the cursor setting manually through the\n",
" * 'cursor' event from matplotlib */\n",
" event.preventDefault();\n",
" return false;\n",
"}\n",
"\n",
"mpl.figure.prototype._key_event_extra = function(event, name) {\n",
" // Handle any extra behaviour associated with a key event\n",
"}\n",
"\n",
"mpl.figure.prototype.key_event = function(event, name) {\n",
"\n",
" // Prevent repeat events\n",
" if (name == 'key_press')\n",
" {\n",
" if (event.which === this._key)\n",
" return;\n",
" else\n",
" this._key = event.which;\n",
" }\n",
" if (name == 'key_release')\n",
" this._key = null;\n",
"\n",
" var value = '';\n",
" if (event.ctrlKey && event.which != 17)\n",
" value += \"ctrl+\";\n",
" if (event.altKey && event.which != 18)\n",
" value += \"alt+\";\n",
" if (event.shiftKey && event.which != 16)\n",
" value += \"shift+\";\n",
"\n",
" value += 'k';\n",
" value += event.which.toString();\n",
"\n",
" this._key_event_extra(event, name);\n",
"\n",
" this.send_message(name, {key: value,\n",
" guiEvent: simpleKeys(event)});\n",
" return false;\n",
"}\n",
"\n",
"mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
" if (name == 'download') {\n",
" this.handle_save(this, null);\n",
" } else {\n",
" this.send_message(\"toolbar_button\", {name: name});\n",
" }\n",
"};\n",
"\n",
"mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
" this.message.textContent = tooltip;\n",
"};\n",
"mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
"\n",
"mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
"\n",
"mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
" // Create a \"websocket\"-like object which calls the given IPython comm\n",
" // object with the appropriate methods. Currently this is a non binary\n",
" // socket, so there is still some room for performance tuning.\n",
" var ws = {};\n",
"\n",
" ws.close = function() {\n",
" comm.close()\n",
" };\n",
" ws.send = function(m) {\n",
" //console.log('sending', m);\n",
" comm.send(m);\n",
" };\n",
" // Register the callback with on_msg.\n",
" comm.on_msg(function(msg) {\n",
" //console.log('receiving', msg['content']['data'], msg);\n",
" // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
" ws.onmessage(msg['content']['data'])\n",
" });\n",
" return ws;\n",
"}\n",
"\n",
"mpl.mpl_figure_comm = function(comm, msg) {\n",
" // This is the function which gets called when the mpl process\n",
" // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
"\n",
" var id = msg.content.data.id;\n",
" // Get hold of the div created by the display call when the Comm\n",
" // socket was opened in Python.\n",
" var element = $(\"#\" + id);\n",
" var ws_proxy = comm_websocket_adapter(comm)\n",
"\n",
" function ondownload(figure, format) {\n",
" window.open(figure.imageObj.src);\n",
" }\n",
"\n",
" var fig = new mpl.figure(id, ws_proxy,\n",
" ondownload,\n",
" element.get(0));\n",
"\n",
" // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
" // web socket which is closed, not our websocket->open comm proxy.\n",
" ws_proxy.onopen();\n",
"\n",
" fig.parent_element = element.get(0);\n",
" fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
" if (!fig.cell_info) {\n",
" console.error(\"Failed to find cell for figure\", id, fig);\n",
" return;\n",
" }\n",
"\n",
" var output_index = fig.cell_info[2]\n",
" var cell = fig.cell_info[0];\n",
"\n",
"};\n",
"\n",
"mpl.figure.prototype.handle_close = function(fig, msg) {\n",
" var width = fig.canvas.width/mpl.ratio\n",
" fig.root.unbind('remove')\n",
"\n",
" // Update the output cell to use the data from the current canvas.\n",
" fig.push_to_output();\n",
" var dataURL = fig.canvas.toDataURL();\n",
" // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
" // the notebook keyboard shortcuts fail.\n",
" IPython.keyboard_manager.enable()\n",
" $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
" fig.close_ws(fig, msg);\n",
"}\n",
"\n",
"mpl.figure.prototype.close_ws = function(fig, msg){\n",
" fig.send_message('closing', msg);\n",
" // fig.ws.close()\n",
"}\n",
"\n",
"mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
" // Turn the data on the canvas into data in the output cell.\n",
" var width = this.canvas.width/mpl.ratio\n",
" var dataURL = this.canvas.toDataURL();\n",
" this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
"}\n",
"\n",
"mpl.figure.prototype.updated_canvas_event = function() {\n",
" // Tell IPython that the notebook contents must change.\n",
" IPython.notebook.set_dirty(true);\n",
" this.send_message(\"ack\", {});\n",
" var fig = this;\n",
" // Wait a second, then push the new image to the DOM so\n",
" // that it is saved nicely (might be nice to debounce this).\n",
" setTimeout(function () { fig.push_to_output() }, 1000);\n",
"}\n",
"\n",
"mpl.figure.prototype._init_toolbar = function() {\n",
" var fig = this;\n",
"\n",
" var nav_element = $('<div/>');\n",
" nav_element.attr('style', 'width: 100%');\n",
" this.root.append(nav_element);\n",
"\n",
" // Define a callback function for later on.\n",
" function toolbar_event(event) {\n",
" return fig.toolbar_button_onclick(event['data']);\n",
" }\n",
" function toolbar_mouse_event(event) {\n",
" return fig.toolbar_button_onmouseover(event['data']);\n",
" }\n",
"\n",
" for(var toolbar_ind in mpl.toolbar_items){\n",
" var name = mpl.toolbar_items[toolbar_ind][0];\n",
" var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
" var image = mpl.toolbar_items[toolbar_ind][2];\n",
" var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
"\n",
" if (!name) { continue; };\n",
"\n",
" var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
" button.click(method_name, toolbar_event);\n",
" button.mouseover(tooltip, toolbar_mouse_event);\n",
" nav_element.append(button);\n",
" }\n",
"\n",
" // Add the status bar.\n",
" var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
" nav_element.append(status_bar);\n",
" this.message = status_bar[0];\n",
"\n",
" // Add the close button to the window.\n",
" var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
" var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
" button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
" button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
" buttongrp.append(button);\n",
" var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
" titlebar.prepend(buttongrp);\n",
"}\n",
"\n",
"mpl.figure.prototype._root_extra_style = function(el){\n",
" var fig = this\n",
" el.on(\"remove\", function(){\n",
"\tfig.close_ws(fig, {});\n",
" });\n",
"}\n",
"\n",
"mpl.figure.prototype._canvas_extra_style = function(el){\n",
" // this is important to make the div 'focusable\n",
" el.attr('tabindex', 0)\n",
" // reach out to IPython and tell the keyboard manager to turn it's self\n",
" // off when our div gets focus\n",
"\n",
" // location in version 3\n",
" if (IPython.notebook.keyboard_manager) {\n",
" IPython.notebook.keyboard_manager.register_events(el);\n",
" }\n",
" else {\n",
" // location in version 2\n",
" IPython.keyboard_manager.register_events(el);\n",
" }\n",
"\n",
"}\n",
"\n",
"mpl.figure.prototype._key_event_extra = function(event, name) {\n",
" var manager = IPython.notebook.keyboard_manager;\n",
" if (!manager)\n",
" manager = IPython.keyboard_manager;\n",
"\n",
" // Check for shift+enter\n",
" if (event.shiftKey && event.which == 13) {\n",
" this.canvas_div.blur();\n",
" event.shiftKey = false;\n",
" // Send a \"J\" for go to next cell\n",
" event.which = 74;\n",
" event.keyCode = 74;\n",
" manager.command_mode();\n",
" manager.handle_keydown(event);\n",
" }\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_save = function(fig, msg) {\n",
" fig.ondownload(fig, null);\n",
"}\n",
"\n",
"\n",
"mpl.find_output_cell = function(html_output) {\n",
" // Return the cell and output element which can be found *uniquely* in the notebook.\n",
" // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
" // IPython event is triggered only after the cells have been serialised, which for\n",
" // our purposes (turning an active figure into a static one), is too late.\n",
" var cells = IPython.notebook.get_cells();\n",
" var ncells = cells.length;\n",
" for (var i=0; i<ncells; i++) {\n",
" var cell = cells[i];\n",
" if (cell.cell_type === 'code'){\n",
" for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
" var data = cell.output_area.outputs[j];\n",
" if (data.data) {\n",
" // IPython >= 3 moved mimebundle to data attribute of output\n",
" data = data.data;\n",
" }\n",
" if (data['text/html'] == html_output) {\n",
" return [cell, data, j];\n",
" }\n",
" }\n",
" }\n",
" }\n",
"}\n",
"\n",
"// Register the function which deals with the matplotlib target/channel.\n",
"// The kernel may be null if the page has been refreshed.\n",
"if (IPython.notebook.kernel != null) {\n",
" IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
"}\n"
],
"text/plain": [
"<IPython.core.display.Javascript object>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"text/html": [
"<img src=\"\" width=\"800\">"
],
"text/plain": [
"<IPython.core.display.HTML object>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"application/vnd.jupyter.widget-view+json": {
"model_id": "1aa87994300a4ea29a4596a7e00529da",
"version_major": 2,
"version_minor": 0
},
"text/plain": [
"interactive(children=(FloatSlider(value=1.6, description='log10(z_loop_spread/step)', layout=Layout(height='80…"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"fig, ax = prepare_canvas(REFSC_7m)\n",
"\n",
"def get_simple_bb_scaling(\n",
" z_loop_width_step_log10_ratio,\n",
" min_log10_s=MIN_LOG10_S, \n",
" max_log10_s=MAX_LOG10_S,\n",
" in_loop_slope=IN_LOOP_SLOPE):\n",
" \n",
" s = 10**np.linspace(MIN_LOG10_S,MAX_LOG10_S,1000)\n",
"\n",
" in_loop_scaling = s**(in_loop_slope)\n",
" \n",
" between_loop_scaling_z = (\n",
" st.norm.pdf(s, loc=0, scale=np.sqrt(2)*(10**z_loop_width_step_log10_ratio)) )\n",
" \n",
" between_loop_scaling = between_loop_scaling_z\n",
" \n",
" in_loop_scaling /= in_loop_scaling[np.argmin(np.abs(np.log10(s/GLUE_AT)))]\n",
" between_loop_scaling /= between_loop_scaling[np.argmin(np.abs(np.log10(s/GLUE_AT)))]\n",
"\n",
" cp = np.exp(-s) * in_loop_scaling + (1-np.exp(-s))* between_loop_scaling\n",
" \n",
" return s, cp\n",
"\n",
"def plot_interactive():\n",
" \n",
" def update_scalings(z_loop_width_step_log10_ratio):\n",
" s,cp = get_simple_bb_scaling(\n",
" z_loop_width_step_log10_ratio,\n",
" )\n",
" ax[0].lines[0].set_data(np.log10(s), np.log10(cp))\n",
"\n",
" ax[1].lines[0].set_data(\n",
" (np.log10(s)[1:] + np.log10(s)[:-1])/2,\n",
" np.diff(np.log10(cp)) / np.diff(np.log10(s))\n",
" )\n",
" \n",
" \n",
" widget_z_loop_width_step_log10_ratio = widgets.FloatSlider(\n",
" description='log10(z_loop_spread/step)',\n",
" layout=widgets.Layout(width='50%', height='80px'),\n",
" value=1.6,\n",
" min=-1, \n",
" max=4)\n",
" interact(update_scalings, z_loop_width_step_log10_ratio=widget_z_loop_width_step_log10_ratio)\n",
" \n",
"plot_interactive()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# Bottle brush with RW angular loop orientation"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## No drift"
]
},
{
"cell_type": "markdown",
"metadata": {
"ExecuteTime": {
"end_time": "2017-05-26T20:56:05.048759",
"start_time": "2017-05-26T20:56:05.029247"
}
},
"source": [
"A bottlebrush with angular correlations of loops.\n",
"- Below the loop size the scaling is calculated as s^-3/2.\n",
"- Above the loop size, contact probability is the probability for two particles to have the same z-component and same angle.\n",
" - The probability of an overlap in z is calculated as in (1).\n",
" - The angular orientations of loops perform a RW, the probability of an overlap == the return probability.\n",
" - The 2nd slider sets $log10 (RW\\_step\\_in\\_radians / 2 \\pi ) $\n",
"\n"
]
},
{
"cell_type": "code",
"execution_count": 16,
"metadata": {
"ExecuteTime": {
"end_time": "2019-04-25T15:22:19.110110Z",
"start_time": "2019-04-25T15:22:19.101796Z"
}
},
"outputs": [],
"source": [
"%matplotlib notebook"
]
},
{
"cell_type": "code",
"execution_count": 11,
"metadata": {
"ExecuteTime": {
"end_time": "2020-06-22T20:21:51.263905Z",
"start_time": "2020-06-22T20:21:51.115571Z"
}
},
"outputs": [
{
"data": {
"application/javascript": [
"/* Put everything inside the global mpl namespace */\n",
"window.mpl = {};\n",
"\n",
"\n",
"mpl.get_websocket_type = function() {\n",
" if (typeof(WebSocket) !== 'undefined') {\n",
" return WebSocket;\n",
" } else if (typeof(MozWebSocket) !== 'undefined') {\n",
" return MozWebSocket;\n",
" } else {\n",
" alert('Your browser does not have WebSocket support. ' +\n",
" 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
" 'Firefox 4 and 5 are also supported but you ' +\n",
" 'have to enable WebSockets in about:config.');\n",
" };\n",
"}\n",
"\n",
"mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
" this.id = figure_id;\n",
"\n",
" this.ws = websocket;\n",
"\n",
" this.supports_binary = (this.ws.binaryType != undefined);\n",
"\n",
" if (!this.supports_binary) {\n",
" var warnings = document.getElementById(\"mpl-warnings\");\n",
" if (warnings) {\n",
" warnings.style.display = 'block';\n",
" warnings.textContent = (\n",
" \"This browser does not support binary websocket messages. \" +\n",
" \"Performance may be slow.\");\n",
" }\n",
" }\n",
"\n",
" this.imageObj = new Image();\n",
"\n",
" this.context = undefined;\n",
" this.message = undefined;\n",
" this.canvas = undefined;\n",
" this.rubberband_canvas = undefined;\n",
" this.rubberband_context = undefined;\n",
" this.format_dropdown = undefined;\n",
"\n",
" this.image_mode = 'full';\n",
"\n",
" this.root = $('<div/>');\n",
" this._root_extra_style(this.root)\n",
" this.root.attr('style', 'display: inline-block');\n",
"\n",
" $(parent_element).append(this.root);\n",
"\n",
" this._init_header(this);\n",
" this._init_canvas(this);\n",
" this._init_toolbar(this);\n",
"\n",
" var fig = this;\n",
"\n",
" this.waiting = false;\n",
"\n",
" this.ws.onopen = function () {\n",
" fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
" fig.send_message(\"send_image_mode\", {});\n",
" if (mpl.ratio != 1) {\n",
" fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
" }\n",
" fig.send_message(\"refresh\", {});\n",
" }\n",
"\n",
" this.imageObj.onload = function() {\n",
" if (fig.image_mode == 'full') {\n",
" // Full images could contain transparency (where diff images\n",
" // almost always do), so we need to clear the canvas so that\n",
" // there is no ghosting.\n",
" fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
" }\n",
" fig.context.drawImage(fig.imageObj, 0, 0);\n",
" };\n",
"\n",
" this.imageObj.onunload = function() {\n",
" fig.ws.close();\n",
" }\n",
"\n",
" this.ws.onmessage = this._make_on_message_function(this);\n",
"\n",
" this.ondownload = ondownload;\n",
"}\n",
"\n",
"mpl.figure.prototype._init_header = function() {\n",
" var titlebar = $(\n",
" '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
" 'ui-helper-clearfix\"/>');\n",
" var titletext = $(\n",
" '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
" 'text-align: center; padding: 3px;\"/>');\n",
" titlebar.append(titletext)\n",
" this.root.append(titlebar);\n",
" this.header = titletext[0];\n",
"}\n",
"\n",
"\n",
"\n",
"mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
"\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
"\n",
"}\n",
"\n",
"mpl.figure.prototype._init_canvas = function() {\n",
" var fig = this;\n",
"\n",
" var canvas_div = $('<div/>');\n",
"\n",
" canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
"\n",
" function canvas_keyboard_event(event) {\n",
" return fig.key_event(event, event['data']);\n",
" }\n",
"\n",
" canvas_div.keydown('key_press', canvas_keyboard_event);\n",
" canvas_div.keyup('key_release', canvas_keyboard_event);\n",
" this.canvas_div = canvas_div\n",
" this._canvas_extra_style(canvas_div)\n",
" this.root.append(canvas_div);\n",
"\n",
" var canvas = $('<canvas/>');\n",
" canvas.addClass('mpl-canvas');\n",
" canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
"\n",
" this.canvas = canvas[0];\n",
" this.context = canvas[0].getContext(\"2d\");\n",
"\n",
" var backingStore = this.context.backingStorePixelRatio ||\n",
"\tthis.context.webkitBackingStorePixelRatio ||\n",
"\tthis.context.mozBackingStorePixelRatio ||\n",
"\tthis.context.msBackingStorePixelRatio ||\n",
"\tthis.context.oBackingStorePixelRatio ||\n",
"\tthis.context.backingStorePixelRatio || 1;\n",
"\n",
" mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
"\n",
" var rubberband = $('<canvas/>');\n",
" rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
"\n",
" var pass_mouse_events = true;\n",
"\n",
" canvas_div.resizable({\n",
" start: function(event, ui) {\n",
" pass_mouse_events = false;\n",
" },\n",
" resize: function(event, ui) {\n",
" fig.request_resize(ui.size.width, ui.size.height);\n",
" },\n",
" stop: function(event, ui) {\n",
" pass_mouse_events = true;\n",
" fig.request_resize(ui.size.width, ui.size.height);\n",
" },\n",
" });\n",
"\n",
" function mouse_event_fn(event) {\n",
" if (pass_mouse_events)\n",
" return fig.mouse_event(event, event['data']);\n",
" }\n",
"\n",
" rubberband.mousedown('button_press', mouse_event_fn);\n",
" rubberband.mouseup('button_release', mouse_event_fn);\n",
" // Throttle sequential mouse events to 1 every 20ms.\n",
" rubberband.mousemove('motion_notify', mouse_event_fn);\n",
"\n",
" rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
" rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
"\n",
" canvas_div.on(\"wheel\", function (event) {\n",
" event = event.originalEvent;\n",
" event['data'] = 'scroll'\n",
" if (event.deltaY < 0) {\n",
" event.step = 1;\n",
" } else {\n",
" event.step = -1;\n",
" }\n",
" mouse_event_fn(event);\n",
" });\n",
"\n",
" canvas_div.append(canvas);\n",
" canvas_div.append(rubberband);\n",
"\n",
" this.rubberband = rubberband;\n",
" this.rubberband_canvas = rubberband[0];\n",
" this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
" this.rubberband_context.strokeStyle = \"#000000\";\n",
"\n",
" this._resize_canvas = function(width, height) {\n",
" // Keep the size of the canvas, canvas container, and rubber band\n",
" // canvas in synch.\n",
" canvas_div.css('width', width)\n",
" canvas_div.css('height', height)\n",
"\n",
" canvas.attr('width', width * mpl.ratio);\n",
" canvas.attr('height', height * mpl.ratio);\n",
" canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
"\n",
" rubberband.attr('width', width);\n",
" rubberband.attr('height', height);\n",
" }\n",
"\n",
" // Set the figure to an initial 600x600px, this will subsequently be updated\n",
" // upon first draw.\n",
" this._resize_canvas(600, 600);\n",
"\n",
" // Disable right mouse context menu.\n",
" $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
" return false;\n",
" });\n",
"\n",
" function set_focus () {\n",
" canvas.focus();\n",
" canvas_div.focus();\n",
" }\n",
"\n",
" window.setTimeout(set_focus, 100);\n",
"}\n",
"\n",
"mpl.figure.prototype._init_toolbar = function() {\n",
" var fig = this;\n",
"\n",
" var nav_element = $('<div/>');\n",
" nav_element.attr('style', 'width: 100%');\n",
" this.root.append(nav_element);\n",
"\n",
" // Define a callback function for later on.\n",
" function toolbar_event(event) {\n",
" return fig.toolbar_button_onclick(event['data']);\n",
" }\n",
" function toolbar_mouse_event(event) {\n",
" return fig.toolbar_button_onmouseover(event['data']);\n",
" }\n",
"\n",
" for(var toolbar_ind in mpl.toolbar_items) {\n",
" var name = mpl.toolbar_items[toolbar_ind][0];\n",
" var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
" var image = mpl.toolbar_items[toolbar_ind][2];\n",
" var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
"\n",
" if (!name) {\n",
" // put a spacer in here.\n",
" continue;\n",
" }\n",
" var button = $('<button/>');\n",
" button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
" 'ui-button-icon-only');\n",
" button.attr('role', 'button');\n",
" button.attr('aria-disabled', 'false');\n",
" button.click(method_name, toolbar_event);\n",
" button.mouseover(tooltip, toolbar_mouse_event);\n",
"\n",
" var icon_img = $('<span/>');\n",
" icon_img.addClass('ui-button-icon-primary ui-icon');\n",
" icon_img.addClass(image);\n",
" icon_img.addClass('ui-corner-all');\n",
"\n",
" var tooltip_span = $('<span/>');\n",
" tooltip_span.addClass('ui-button-text');\n",
" tooltip_span.html(tooltip);\n",
"\n",
" button.append(icon_img);\n",
" button.append(tooltip_span);\n",
"\n",
" nav_element.append(button);\n",
" }\n",
"\n",
" var fmt_picker_span = $('<span/>');\n",
"\n",
" var fmt_picker = $('<select/>');\n",
" fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
" fmt_picker_span.append(fmt_picker);\n",
" nav_element.append(fmt_picker_span);\n",
" this.format_dropdown = fmt_picker[0];\n",
"\n",
" for (var ind in mpl.extensions) {\n",
" var fmt = mpl.extensions[ind];\n",
" var option = $(\n",
" '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
" fmt_picker.append(option);\n",
" }\n",
"\n",
" // Add hover states to the ui-buttons\n",
" $( \".ui-button\" ).hover(\n",
" function() { $(this).addClass(\"ui-state-hover\");},\n",
" function() { $(this).removeClass(\"ui-state-hover\");}\n",
" );\n",
"\n",
" var status_bar = $('<span class=\"mpl-message\"/>');\n",
" nav_element.append(status_bar);\n",
" this.message = status_bar[0];\n",
"}\n",
"\n",
"mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
" // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
" // which will in turn request a refresh of the image.\n",
" this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
"}\n",
"\n",
"mpl.figure.prototype.send_message = function(type, properties) {\n",
" properties['type'] = type;\n",
" properties['figure_id'] = this.id;\n",
" this.ws.send(JSON.stringify(properties));\n",
"}\n",
"\n",
"mpl.figure.prototype.send_draw_message = function() {\n",
" if (!this.waiting) {\n",
" this.waiting = true;\n",
" this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
" }\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype.handle_save = function(fig, msg) {\n",
" var format_dropdown = fig.format_dropdown;\n",
" var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
" fig.ondownload(fig, format);\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
" var size = msg['size'];\n",
" if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
" fig._resize_canvas(size[0], size[1]);\n",
" fig.send_message(\"refresh\", {});\n",
" };\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
" var x0 = msg['x0'] / mpl.ratio;\n",
" var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
" var x1 = msg['x1'] / mpl.ratio;\n",
" var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
" x0 = Math.floor(x0) + 0.5;\n",
" y0 = Math.floor(y0) + 0.5;\n",
" x1 = Math.floor(x1) + 0.5;\n",
" y1 = Math.floor(y1) + 0.5;\n",
" var min_x = Math.min(x0, x1);\n",
" var min_y = Math.min(y0, y1);\n",
" var width = Math.abs(x1 - x0);\n",
" var height = Math.abs(y1 - y0);\n",
"\n",
" fig.rubberband_context.clearRect(\n",
" 0, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\n",
"\n",
" fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
" // Updates the figure title.\n",
" fig.header.textContent = msg['label'];\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
" var cursor = msg['cursor'];\n",
" switch(cursor)\n",
" {\n",
" case 0:\n",
" cursor = 'pointer';\n",
" break;\n",
" case 1:\n",
" cursor = 'default';\n",
" break;\n",
" case 2:\n",
" cursor = 'crosshair';\n",
" break;\n",
" case 3:\n",
" cursor = 'move';\n",
" break;\n",
" }\n",
" fig.rubberband_canvas.style.cursor = cursor;\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_message = function(fig, msg) {\n",
" fig.message.textContent = msg['message'];\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
" // Request the server to send over a new figure.\n",
" fig.send_draw_message();\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
" fig.image_mode = msg['mode'];\n",
"}\n",
"\n",
"mpl.figure.prototype.updated_canvas_event = function() {\n",
" // Called whenever the canvas gets updated.\n",
" this.send_message(\"ack\", {});\n",
"}\n",
"\n",
"// A function to construct a web socket function for onmessage handling.\n",
"// Called in the figure constructor.\n",
"mpl.figure.prototype._make_on_message_function = function(fig) {\n",
" return function socket_on_message(evt) {\n",
" if (evt.data instanceof Blob) {\n",
" /* FIXME: We get \"Resource interpreted as Image but\n",
" * transferred with MIME type text/plain:\" errors on\n",
" * Chrome. But how to set the MIME type? It doesn't seem\n",
" * to be part of the websocket stream */\n",
" evt.data.type = \"image/png\";\n",
"\n",
" /* Free the memory for the previous frames */\n",
" if (fig.imageObj.src) {\n",
" (window.URL || window.webkitURL).revokeObjectURL(\n",
" fig.imageObj.src);\n",
" }\n",
"\n",
" fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
" evt.data);\n",
" fig.updated_canvas_event();\n",
" fig.waiting = false;\n",
" return;\n",
" }\n",
" else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
" fig.imageObj.src = evt.data;\n",
" fig.updated_canvas_event();\n",
" fig.waiting = false;\n",
" return;\n",
" }\n",
"\n",
" var msg = JSON.parse(evt.data);\n",
" var msg_type = msg['type'];\n",
"\n",
" // Call the \"handle_{type}\" callback, which takes\n",
" // the figure and JSON message as its only arguments.\n",
" try {\n",
" var callback = fig[\"handle_\" + msg_type];\n",
" } catch (e) {\n",
" console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
" return;\n",
" }\n",
"\n",
" if (callback) {\n",
" try {\n",
" // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
" callback(fig, msg);\n",
" } catch (e) {\n",
" console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
" }\n",
" }\n",
" };\n",
"}\n",
"\n",
"// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
"mpl.findpos = function(e) {\n",
" //this section is from http://www.quirksmode.org/js/events_properties.html\n",
" var targ;\n",
" if (!e)\n",
" e = window.event;\n",
" if (e.target)\n",
" targ = e.target;\n",
" else if (e.srcElement)\n",
" targ = e.srcElement;\n",
" if (targ.nodeType == 3) // defeat Safari bug\n",
" targ = targ.parentNode;\n",
"\n",
" // jQuery normalizes the pageX and pageY\n",
" // pageX,Y are the mouse positions relative to the document\n",
" // offset() returns the position of the element relative to the document\n",
" var x = e.pageX - $(targ).offset().left;\n",
" var y = e.pageY - $(targ).offset().top;\n",
"\n",
" return {\"x\": x, \"y\": y};\n",
"};\n",
"\n",
"/*\n",
" * return a copy of an object with only non-object keys\n",
" * we need this to avoid circular references\n",
" * http://stackoverflow.com/a/24161582/3208463\n",
" */\n",
"function simpleKeys (original) {\n",
" return Object.keys(original).reduce(function (obj, key) {\n",
" if (typeof original[key] !== 'object')\n",
" obj[key] = original[key]\n",
" return obj;\n",
" }, {});\n",
"}\n",
"\n",
"mpl.figure.prototype.mouse_event = function(event, name) {\n",
" var canvas_pos = mpl.findpos(event)\n",
"\n",
" if (name === 'button_press')\n",
" {\n",
" this.canvas.focus();\n",
" this.canvas_div.focus();\n",
" }\n",
"\n",
" var x = canvas_pos.x * mpl.ratio;\n",
" var y = canvas_pos.y * mpl.ratio;\n",
"\n",
" this.send_message(name, {x: x, y: y, button: event.button,\n",
" step: event.step,\n",
" guiEvent: simpleKeys(event)});\n",
"\n",
" /* This prevents the web browser from automatically changing to\n",
" * the text insertion cursor when the button is pressed. We want\n",
" * to control all of the cursor setting manually through the\n",
" * 'cursor' event from matplotlib */\n",
" event.preventDefault();\n",
" return false;\n",
"}\n",
"\n",
"mpl.figure.prototype._key_event_extra = function(event, name) {\n",
" // Handle any extra behaviour associated with a key event\n",
"}\n",
"\n",
"mpl.figure.prototype.key_event = function(event, name) {\n",
"\n",
" // Prevent repeat events\n",
" if (name == 'key_press')\n",
" {\n",
" if (event.which === this._key)\n",
" return;\n",
" else\n",
" this._key = event.which;\n",
" }\n",
" if (name == 'key_release')\n",
" this._key = null;\n",
"\n",
" var value = '';\n",
" if (event.ctrlKey && event.which != 17)\n",
" value += \"ctrl+\";\n",
" if (event.altKey && event.which != 18)\n",
" value += \"alt+\";\n",
" if (event.shiftKey && event.which != 16)\n",
" value += \"shift+\";\n",
"\n",
" value += 'k';\n",
" value += event.which.toString();\n",
"\n",
" this._key_event_extra(event, name);\n",
"\n",
" this.send_message(name, {key: value,\n",
" guiEvent: simpleKeys(event)});\n",
" return false;\n",
"}\n",
"\n",
"mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
" if (name == 'download') {\n",
" this.handle_save(this, null);\n",
" } else {\n",
" this.send_message(\"toolbar_button\", {name: name});\n",
" }\n",
"};\n",
"\n",
"mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
" this.message.textContent = tooltip;\n",
"};\n",
"mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
"\n",
"mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
"\n",
"mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
" // Create a \"websocket\"-like object which calls the given IPython comm\n",
" // object with the appropriate methods. Currently this is a non binary\n",
" // socket, so there is still some room for performance tuning.\n",
" var ws = {};\n",
"\n",
" ws.close = function() {\n",
" comm.close()\n",
" };\n",
" ws.send = function(m) {\n",
" //console.log('sending', m);\n",
" comm.send(m);\n",
" };\n",
" // Register the callback with on_msg.\n",
" comm.on_msg(function(msg) {\n",
" //console.log('receiving', msg['content']['data'], msg);\n",
" // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
" ws.onmessage(msg['content']['data'])\n",
" });\n",
" return ws;\n",
"}\n",
"\n",
"mpl.mpl_figure_comm = function(comm, msg) {\n",
" // This is the function which gets called when the mpl process\n",
" // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
"\n",
" var id = msg.content.data.id;\n",
" // Get hold of the div created by the display call when the Comm\n",
" // socket was opened in Python.\n",
" var element = $(\"#\" + id);\n",
" var ws_proxy = comm_websocket_adapter(comm)\n",
"\n",
" function ondownload(figure, format) {\n",
" window.open(figure.imageObj.src);\n",
" }\n",
"\n",
" var fig = new mpl.figure(id, ws_proxy,\n",
" ondownload,\n",
" element.get(0));\n",
"\n",
" // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
" // web socket which is closed, not our websocket->open comm proxy.\n",
" ws_proxy.onopen();\n",
"\n",
" fig.parent_element = element.get(0);\n",
" fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
" if (!fig.cell_info) {\n",
" console.error(\"Failed to find cell for figure\", id, fig);\n",
" return;\n",
" }\n",
"\n",
" var output_index = fig.cell_info[2]\n",
" var cell = fig.cell_info[0];\n",
"\n",
"};\n",
"\n",
"mpl.figure.prototype.handle_close = function(fig, msg) {\n",
" var width = fig.canvas.width/mpl.ratio\n",
" fig.root.unbind('remove')\n",
"\n",
" // Update the output cell to use the data from the current canvas.\n",
" fig.push_to_output();\n",
" var dataURL = fig.canvas.toDataURL();\n",
" // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
" // the notebook keyboard shortcuts fail.\n",
" IPython.keyboard_manager.enable()\n",
" $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
" fig.close_ws(fig, msg);\n",
"}\n",
"\n",
"mpl.figure.prototype.close_ws = function(fig, msg){\n",
" fig.send_message('closing', msg);\n",
" // fig.ws.close()\n",
"}\n",
"\n",
"mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
" // Turn the data on the canvas into data in the output cell.\n",
" var width = this.canvas.width/mpl.ratio\n",
" var dataURL = this.canvas.toDataURL();\n",
" this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
"}\n",
"\n",
"mpl.figure.prototype.updated_canvas_event = function() {\n",
" // Tell IPython that the notebook contents must change.\n",
" IPython.notebook.set_dirty(true);\n",
" this.send_message(\"ack\", {});\n",
" var fig = this;\n",
" // Wait a second, then push the new image to the DOM so\n",
" // that it is saved nicely (might be nice to debounce this).\n",
" setTimeout(function () { fig.push_to_output() }, 1000);\n",
"}\n",
"\n",
"mpl.figure.prototype._init_toolbar = function() {\n",
" var fig = this;\n",
"\n",
" var nav_element = $('<div/>');\n",
" nav_element.attr('style', 'width: 100%');\n",
" this.root.append(nav_element);\n",
"\n",
" // Define a callback function for later on.\n",
" function toolbar_event(event) {\n",
" return fig.toolbar_button_onclick(event['data']);\n",
" }\n",
" function toolbar_mouse_event(event) {\n",
" return fig.toolbar_button_onmouseover(event['data']);\n",
" }\n",
"\n",
" for(var toolbar_ind in mpl.toolbar_items){\n",
" var name = mpl.toolbar_items[toolbar_ind][0];\n",
" var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
" var image = mpl.toolbar_items[toolbar_ind][2];\n",
" var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
"\n",
" if (!name) { continue; };\n",
"\n",
" var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
" button.click(method_name, toolbar_event);\n",
" button.mouseover(tooltip, toolbar_mouse_event);\n",
" nav_element.append(button);\n",
" }\n",
"\n",
" // Add the status bar.\n",
" var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
" nav_element.append(status_bar);\n",
" this.message = status_bar[0];\n",
"\n",
" // Add the close button to the window.\n",
" var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
" var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
" button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
" button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
" buttongrp.append(button);\n",
" var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
" titlebar.prepend(buttongrp);\n",
"}\n",
"\n",
"mpl.figure.prototype._root_extra_style = function(el){\n",
" var fig = this\n",
" el.on(\"remove\", function(){\n",
"\tfig.close_ws(fig, {});\n",
" });\n",
"}\n",
"\n",
"mpl.figure.prototype._canvas_extra_style = function(el){\n",
" // this is important to make the div 'focusable\n",
" el.attr('tabindex', 0)\n",
" // reach out to IPython and tell the keyboard manager to turn it's self\n",
" // off when our div gets focus\n",
"\n",
" // location in version 3\n",
" if (IPython.notebook.keyboard_manager) {\n",
" IPython.notebook.keyboard_manager.register_events(el);\n",
" }\n",
" else {\n",
" // location in version 2\n",
" IPython.keyboard_manager.register_events(el);\n",
" }\n",
"\n",
"}\n",
"\n",
"mpl.figure.prototype._key_event_extra = function(event, name) {\n",
" var manager = IPython.notebook.keyboard_manager;\n",
" if (!manager)\n",
" manager = IPython.keyboard_manager;\n",
"\n",
" // Check for shift+enter\n",
" if (event.shiftKey && event.which == 13) {\n",
" this.canvas_div.blur();\n",
" event.shiftKey = false;\n",
" // Send a \"J\" for go to next cell\n",
" event.which = 74;\n",
" event.keyCode = 74;\n",
" manager.command_mode();\n",
" manager.handle_keydown(event);\n",
" }\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_save = function(fig, msg) {\n",
" fig.ondownload(fig, null);\n",
"}\n",
"\n",
"\n",
"mpl.find_output_cell = function(html_output) {\n",
" // Return the cell and output element which can be found *uniquely* in the notebook.\n",
" // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
" // IPython event is triggered only after the cells have been serialised, which for\n",
" // our purposes (turning an active figure into a static one), is too late.\n",
" var cells = IPython.notebook.get_cells();\n",
" var ncells = cells.length;\n",
" for (var i=0; i<ncells; i++) {\n",
" var cell = cells[i];\n",
" if (cell.cell_type === 'code'){\n",
" for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
" var data = cell.output_area.outputs[j];\n",
" if (data.data) {\n",
" // IPython >= 3 moved mimebundle to data attribute of output\n",
" data = data.data;\n",
" }\n",
" if (data['text/html'] == html_output) {\n",
" return [cell, data, j];\n",
" }\n",
" }\n",
" }\n",
" }\n",
"}\n",
"\n",
"// Register the function which deals with the matplotlib target/channel.\n",
"// The kernel may be null if the page has been refreshed.\n",
"if (IPython.notebook.kernel != null) {\n",
" IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
"}\n"
],
"text/plain": [
"<IPython.core.display.Javascript object>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"text/html": [
"<img src=\"\" width=\"800\">"
],
"text/plain": [
"<IPython.core.display.HTML object>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"application/vnd.jupyter.widget-view+json": {
"model_id": "2480274491754c0f9285f535ad21f69e",
"version_major": 2,
"version_minor": 0
},
"text/plain": [
"interactive(children=(FloatSlider(value=1.4, description='log10(z_loop_spread/step)', layout=Layout(height='80…"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"fig, ax =prepare_canvas(REFSC_60m,80000)\n",
"#fig, ax =prepare_canvas(REFSC_7m,60000)\n",
"\n",
"def get_simple_bb_scaling(\n",
" z_loop_width_step_log10_ratio,\n",
" ang_rw_step,\n",
" ang_loop_spread,\n",
" min_log10_s=MIN_LOG10_S, \n",
" max_log10_s=MAX_LOG10_S):\n",
" \n",
" s = 10**np.linspace(MIN_LOG10_S,MAX_LOG10_S,1000)\n",
"\n",
" in_loop_scaling = s**(-3/2)\n",
"\n",
" between_loop_scaling_z = (\n",
" st.norm.pdf(s, loc=0, scale=np.sqrt(2)*(10**z_loop_width_step_log10_ratio)) )\n",
" \n",
" between_loop_scaling_ang = np.vstack(\n",
" st.norm.pdf(x , loc=0, scale=np.sqrt(2*ang_loop_spread**2+s*(ang_rw_step**2)))\n",
" for x in 2*np.pi*np.arange(-100,100+0.1)\n",
" ).sum(axis=0)\n",
"\n",
" between_loop_scaling = between_loop_scaling_z * between_loop_scaling_ang\n",
" \n",
" in_loop_scaling /= in_loop_scaling[np.argmin(np.abs(np.log10(s/GLUE_AT)))]\n",
" between_loop_scaling /= between_loop_scaling[np.argmin(np.abs(np.log10(s/GLUE_AT)))]\n",
"\n",
" cp = np.exp(-s) * in_loop_scaling + (1-np.exp(-s)) * between_loop_scaling\n",
"\n",
" return s, cp\n",
"\n",
"def plot_interactive():\n",
" \n",
" def update_scalings(z_loop_width_step_log10_ratio,ang_rw_step,ang_loop_spread):\n",
" ang_rw_step = 2 * np.pi * (10**ang_rw_step)\n",
" ang_loop_spread = 2 * np.pi * (10**ang_loop_spread)\n",
" s,cp = get_simple_bb_scaling(\n",
" z_loop_width_step_log10_ratio,\n",
" ang_rw_step,\n",
" ang_loop_spread\n",
" )\n",
" ax[0].lines[0].set_data(np.log10(s), np.log10(cp))\n",
"\n",
" ax[1].lines[0].set_data(\n",
" (np.log10(s)[1:] + np.log10(s)[:-1])/2,\n",
" np.diff(np.log10(cp)) / np.diff(np.log10(s))\n",
" )\n",
" \n",
" \n",
" widget_z_loop_width_step_log10_ratio = widgets.FloatSlider(\n",
" description='log10(z_loop_spread/step)',\n",
" layout=widgets.Layout(width='50%', height='80px'),\n",
" value=1.4, #WT-7m 6kb\n",
" #value=1.4,\n",
" min=-4, \n",
" max=4)\n",
" widget_ang_rw_step = widgets.FloatSlider(\n",
" description='log10 (ang_rw_step / 2 Pi)',\n",
" layout=widgets.Layout(width='50%', height='80px'),\n",
" value=-1.1, #WT-7m 6kb\n",
" #value=-1.1,\n",
" min=-4, \n",
" max=0)\n",
" widget_ang_loop_spread = widgets.FloatSlider(\n",
" description='log10 (ang_loop_spread / 2 Pi)',\n",
" layout=widgets.Layout(width='50%', height='80px'),\n",
" value=-1.7, #WT-7m 60kb\n",
" #value=-1.3,\n",
" min=-4, \n",
" max=0)\n",
" interact(\n",
" update_scalings, \n",
" z_loop_width_step_log10_ratio=widget_z_loop_width_step_log10_ratio,\n",
" ang_rw_step=widget_ang_rw_step,\n",
" ang_loop_spread=widget_ang_loop_spread\n",
" )\n",
" ax[0].set_ylim(-1.5,1.5)\n",
" ax[0].set_xlim(-1,3)\n",
" #plt.savefig(f'{FIG_FOLDER}/coarse_grained_RW_scaling_7m_60kb.svg')\n",
" \n",
"plot_interactive()"
]
},
{
"cell_type": "markdown",
"metadata": {
"ExecuteTime": {
"end_time": "2017-05-26T13:24:03.332250",
"start_time": "2017-05-26T13:24:03.324858"
}
},
"source": [
"## With drift"
]
},
{
"cell_type": "markdown",
"metadata": {
"ExecuteTime": {
"end_time": "2017-05-26T21:05:23.418338",
"start_time": "2017-05-26T21:05:23.408531"
}
},
"source": [
"A bottlebrush with angular correlations and drift of loops.\n",
"- Same as (2), but with a drift component.\n",
" - The 3rd slider sets $log10 (angular\\_drift\\_per\\_loop\\_in\\_radians / 2 \\pi ) $. The inverse of this number is the period of the spiral in loops.\n",
"\n"
]
},
{
"cell_type": "code",
"execution_count": 12,
"metadata": {
"ExecuteTime": {
"end_time": "2020-06-22T20:22:20.198828Z",
"start_time": "2020-06-22T20:22:20.003370Z"
},
"scrolled": false
},
"outputs": [
{
"data": {
"application/javascript": [
"/* Put everything inside the global mpl namespace */\n",
"window.mpl = {};\n",
"\n",
"\n",
"mpl.get_websocket_type = function() {\n",
" if (typeof(WebSocket) !== 'undefined') {\n",
" return WebSocket;\n",
" } else if (typeof(MozWebSocket) !== 'undefined') {\n",
" return MozWebSocket;\n",
" } else {\n",
" alert('Your browser does not have WebSocket support. ' +\n",
" 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
" 'Firefox 4 and 5 are also supported but you ' +\n",
" 'have to enable WebSockets in about:config.');\n",
" };\n",
"}\n",
"\n",
"mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
" this.id = figure_id;\n",
"\n",
" this.ws = websocket;\n",
"\n",
" this.supports_binary = (this.ws.binaryType != undefined);\n",
"\n",
" if (!this.supports_binary) {\n",
" var warnings = document.getElementById(\"mpl-warnings\");\n",
" if (warnings) {\n",
" warnings.style.display = 'block';\n",
" warnings.textContent = (\n",
" \"This browser does not support binary websocket messages. \" +\n",
" \"Performance may be slow.\");\n",
" }\n",
" }\n",
"\n",
" this.imageObj = new Image();\n",
"\n",
" this.context = undefined;\n",
" this.message = undefined;\n",
" this.canvas = undefined;\n",
" this.rubberband_canvas = undefined;\n",
" this.rubberband_context = undefined;\n",
" this.format_dropdown = undefined;\n",
"\n",
" this.image_mode = 'full';\n",
"\n",
" this.root = $('<div/>');\n",
" this._root_extra_style(this.root)\n",
" this.root.attr('style', 'display: inline-block');\n",
"\n",
" $(parent_element).append(this.root);\n",
"\n",
" this._init_header(this);\n",
" this._init_canvas(this);\n",
" this._init_toolbar(this);\n",
"\n",
" var fig = this;\n",
"\n",
" this.waiting = false;\n",
"\n",
" this.ws.onopen = function () {\n",
" fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
" fig.send_message(\"send_image_mode\", {});\n",
" if (mpl.ratio != 1) {\n",
" fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
" }\n",
" fig.send_message(\"refresh\", {});\n",
" }\n",
"\n",
" this.imageObj.onload = function() {\n",
" if (fig.image_mode == 'full') {\n",
" // Full images could contain transparency (where diff images\n",
" // almost always do), so we need to clear the canvas so that\n",
" // there is no ghosting.\n",
" fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
" }\n",
" fig.context.drawImage(fig.imageObj, 0, 0);\n",
" };\n",
"\n",
" this.imageObj.onunload = function() {\n",
" fig.ws.close();\n",
" }\n",
"\n",
" this.ws.onmessage = this._make_on_message_function(this);\n",
"\n",
" this.ondownload = ondownload;\n",
"}\n",
"\n",
"mpl.figure.prototype._init_header = function() {\n",
" var titlebar = $(\n",
" '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
" 'ui-helper-clearfix\"/>');\n",
" var titletext = $(\n",
" '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
" 'text-align: center; padding: 3px;\"/>');\n",
" titlebar.append(titletext)\n",
" this.root.append(titlebar);\n",
" this.header = titletext[0];\n",
"}\n",
"\n",
"\n",
"\n",
"mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
"\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
"\n",
"}\n",
"\n",
"mpl.figure.prototype._init_canvas = function() {\n",
" var fig = this;\n",
"\n",
" var canvas_div = $('<div/>');\n",
"\n",
" canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
"\n",
" function canvas_keyboard_event(event) {\n",
" return fig.key_event(event, event['data']);\n",
" }\n",
"\n",
" canvas_div.keydown('key_press', canvas_keyboard_event);\n",
" canvas_div.keyup('key_release', canvas_keyboard_event);\n",
" this.canvas_div = canvas_div\n",
" this._canvas_extra_style(canvas_div)\n",
" this.root.append(canvas_div);\n",
"\n",
" var canvas = $('<canvas/>');\n",
" canvas.addClass('mpl-canvas');\n",
" canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
"\n",
" this.canvas = canvas[0];\n",
" this.context = canvas[0].getContext(\"2d\");\n",
"\n",
" var backingStore = this.context.backingStorePixelRatio ||\n",
"\tthis.context.webkitBackingStorePixelRatio ||\n",
"\tthis.context.mozBackingStorePixelRatio ||\n",
"\tthis.context.msBackingStorePixelRatio ||\n",
"\tthis.context.oBackingStorePixelRatio ||\n",
"\tthis.context.backingStorePixelRatio || 1;\n",
"\n",
" mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
"\n",
" var rubberband = $('<canvas/>');\n",
" rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
"\n",
" var pass_mouse_events = true;\n",
"\n",
" canvas_div.resizable({\n",
" start: function(event, ui) {\n",
" pass_mouse_events = false;\n",
" },\n",
" resize: function(event, ui) {\n",
" fig.request_resize(ui.size.width, ui.size.height);\n",
" },\n",
" stop: function(event, ui) {\n",
" pass_mouse_events = true;\n",
" fig.request_resize(ui.size.width, ui.size.height);\n",
" },\n",
" });\n",
"\n",
" function mouse_event_fn(event) {\n",
" if (pass_mouse_events)\n",
" return fig.mouse_event(event, event['data']);\n",
" }\n",
"\n",
" rubberband.mousedown('button_press', mouse_event_fn);\n",
" rubberband.mouseup('button_release', mouse_event_fn);\n",
" // Throttle sequential mouse events to 1 every 20ms.\n",
" rubberband.mousemove('motion_notify', mouse_event_fn);\n",
"\n",
" rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
" rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
"\n",
" canvas_div.on(\"wheel\", function (event) {\n",
" event = event.originalEvent;\n",
" event['data'] = 'scroll'\n",
" if (event.deltaY < 0) {\n",
" event.step = 1;\n",
" } else {\n",
" event.step = -1;\n",
" }\n",
" mouse_event_fn(event);\n",
" });\n",
"\n",
" canvas_div.append(canvas);\n",
" canvas_div.append(rubberband);\n",
"\n",
" this.rubberband = rubberband;\n",
" this.rubberband_canvas = rubberband[0];\n",
" this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
" this.rubberband_context.strokeStyle = \"#000000\";\n",
"\n",
" this._resize_canvas = function(width, height) {\n",
" // Keep the size of the canvas, canvas container, and rubber band\n",
" // canvas in synch.\n",
" canvas_div.css('width', width)\n",
" canvas_div.css('height', height)\n",
"\n",
" canvas.attr('width', width * mpl.ratio);\n",
" canvas.attr('height', height * mpl.ratio);\n",
" canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
"\n",
" rubberband.attr('width', width);\n",
" rubberband.attr('height', height);\n",
" }\n",
"\n",
" // Set the figure to an initial 600x600px, this will subsequently be updated\n",
" // upon first draw.\n",
" this._resize_canvas(600, 600);\n",
"\n",
" // Disable right mouse context menu.\n",
" $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
" return false;\n",
" });\n",
"\n",
" function set_focus () {\n",
" canvas.focus();\n",
" canvas_div.focus();\n",
" }\n",
"\n",
" window.setTimeout(set_focus, 100);\n",
"}\n",
"\n",
"mpl.figure.prototype._init_toolbar = function() {\n",
" var fig = this;\n",
"\n",
" var nav_element = $('<div/>');\n",
" nav_element.attr('style', 'width: 100%');\n",
" this.root.append(nav_element);\n",
"\n",
" // Define a callback function for later on.\n",
" function toolbar_event(event) {\n",
" return fig.toolbar_button_onclick(event['data']);\n",
" }\n",
" function toolbar_mouse_event(event) {\n",
" return fig.toolbar_button_onmouseover(event['data']);\n",
" }\n",
"\n",
" for(var toolbar_ind in mpl.toolbar_items) {\n",
" var name = mpl.toolbar_items[toolbar_ind][0];\n",
" var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
" var image = mpl.toolbar_items[toolbar_ind][2];\n",
" var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
"\n",
" if (!name) {\n",
" // put a spacer in here.\n",
" continue;\n",
" }\n",
" var button = $('<button/>');\n",
" button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
" 'ui-button-icon-only');\n",
" button.attr('role', 'button');\n",
" button.attr('aria-disabled', 'false');\n",
" button.click(method_name, toolbar_event);\n",
" button.mouseover(tooltip, toolbar_mouse_event);\n",
"\n",
" var icon_img = $('<span/>');\n",
" icon_img.addClass('ui-button-icon-primary ui-icon');\n",
" icon_img.addClass(image);\n",
" icon_img.addClass('ui-corner-all');\n",
"\n",
" var tooltip_span = $('<span/>');\n",
" tooltip_span.addClass('ui-button-text');\n",
" tooltip_span.html(tooltip);\n",
"\n",
" button.append(icon_img);\n",
" button.append(tooltip_span);\n",
"\n",
" nav_element.append(button);\n",
" }\n",
"\n",
" var fmt_picker_span = $('<span/>');\n",
"\n",
" var fmt_picker = $('<select/>');\n",
" fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
" fmt_picker_span.append(fmt_picker);\n",
" nav_element.append(fmt_picker_span);\n",
" this.format_dropdown = fmt_picker[0];\n",
"\n",
" for (var ind in mpl.extensions) {\n",
" var fmt = mpl.extensions[ind];\n",
" var option = $(\n",
" '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
" fmt_picker.append(option);\n",
" }\n",
"\n",
" // Add hover states to the ui-buttons\n",
" $( \".ui-button\" ).hover(\n",
" function() { $(this).addClass(\"ui-state-hover\");},\n",
" function() { $(this).removeClass(\"ui-state-hover\");}\n",
" );\n",
"\n",
" var status_bar = $('<span class=\"mpl-message\"/>');\n",
" nav_element.append(status_bar);\n",
" this.message = status_bar[0];\n",
"}\n",
"\n",
"mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
" // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
" // which will in turn request a refresh of the image.\n",
" this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
"}\n",
"\n",
"mpl.figure.prototype.send_message = function(type, properties) {\n",
" properties['type'] = type;\n",
" properties['figure_id'] = this.id;\n",
" this.ws.send(JSON.stringify(properties));\n",
"}\n",
"\n",
"mpl.figure.prototype.send_draw_message = function() {\n",
" if (!this.waiting) {\n",
" this.waiting = true;\n",
" this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
" }\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype.handle_save = function(fig, msg) {\n",
" var format_dropdown = fig.format_dropdown;\n",
" var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
" fig.ondownload(fig, format);\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
" var size = msg['size'];\n",
" if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
" fig._resize_canvas(size[0], size[1]);\n",
" fig.send_message(\"refresh\", {});\n",
" };\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
" var x0 = msg['x0'] / mpl.ratio;\n",
" var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
" var x1 = msg['x1'] / mpl.ratio;\n",
" var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
" x0 = Math.floor(x0) + 0.5;\n",
" y0 = Math.floor(y0) + 0.5;\n",
" x1 = Math.floor(x1) + 0.5;\n",
" y1 = Math.floor(y1) + 0.5;\n",
" var min_x = Math.min(x0, x1);\n",
" var min_y = Math.min(y0, y1);\n",
" var width = Math.abs(x1 - x0);\n",
" var height = Math.abs(y1 - y0);\n",
"\n",
" fig.rubberband_context.clearRect(\n",
" 0, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\n",
"\n",
" fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
" // Updates the figure title.\n",
" fig.header.textContent = msg['label'];\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
" var cursor = msg['cursor'];\n",
" switch(cursor)\n",
" {\n",
" case 0:\n",
" cursor = 'pointer';\n",
" break;\n",
" case 1:\n",
" cursor = 'default';\n",
" break;\n",
" case 2:\n",
" cursor = 'crosshair';\n",
" break;\n",
" case 3:\n",
" cursor = 'move';\n",
" break;\n",
" }\n",
" fig.rubberband_canvas.style.cursor = cursor;\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_message = function(fig, msg) {\n",
" fig.message.textContent = msg['message'];\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
" // Request the server to send over a new figure.\n",
" fig.send_draw_message();\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
" fig.image_mode = msg['mode'];\n",
"}\n",
"\n",
"mpl.figure.prototype.updated_canvas_event = function() {\n",
" // Called whenever the canvas gets updated.\n",
" this.send_message(\"ack\", {});\n",
"}\n",
"\n",
"// A function to construct a web socket function for onmessage handling.\n",
"// Called in the figure constructor.\n",
"mpl.figure.prototype._make_on_message_function = function(fig) {\n",
" return function socket_on_message(evt) {\n",
" if (evt.data instanceof Blob) {\n",
" /* FIXME: We get \"Resource interpreted as Image but\n",
" * transferred with MIME type text/plain:\" errors on\n",
" * Chrome. But how to set the MIME type? It doesn't seem\n",
" * to be part of the websocket stream */\n",
" evt.data.type = \"image/png\";\n",
"\n",
" /* Free the memory for the previous frames */\n",
" if (fig.imageObj.src) {\n",
" (window.URL || window.webkitURL).revokeObjectURL(\n",
" fig.imageObj.src);\n",
" }\n",
"\n",
" fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
" evt.data);\n",
" fig.updated_canvas_event();\n",
" fig.waiting = false;\n",
" return;\n",
" }\n",
" else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
" fig.imageObj.src = evt.data;\n",
" fig.updated_canvas_event();\n",
" fig.waiting = false;\n",
" return;\n",
" }\n",
"\n",
" var msg = JSON.parse(evt.data);\n",
" var msg_type = msg['type'];\n",
"\n",
" // Call the \"handle_{type}\" callback, which takes\n",
" // the figure and JSON message as its only arguments.\n",
" try {\n",
" var callback = fig[\"handle_\" + msg_type];\n",
" } catch (e) {\n",
" console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
" return;\n",
" }\n",
"\n",
" if (callback) {\n",
" try {\n",
" // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
" callback(fig, msg);\n",
" } catch (e) {\n",
" console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
" }\n",
" }\n",
" };\n",
"}\n",
"\n",
"// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
"mpl.findpos = function(e) {\n",
" //this section is from http://www.quirksmode.org/js/events_properties.html\n",
" var targ;\n",
" if (!e)\n",
" e = window.event;\n",
" if (e.target)\n",
" targ = e.target;\n",
" else if (e.srcElement)\n",
" targ = e.srcElement;\n",
" if (targ.nodeType == 3) // defeat Safari bug\n",
" targ = targ.parentNode;\n",
"\n",
" // jQuery normalizes the pageX and pageY\n",
" // pageX,Y are the mouse positions relative to the document\n",
" // offset() returns the position of the element relative to the document\n",
" var x = e.pageX - $(targ).offset().left;\n",
" var y = e.pageY - $(targ).offset().top;\n",
"\n",
" return {\"x\": x, \"y\": y};\n",
"};\n",
"\n",
"/*\n",
" * return a copy of an object with only non-object keys\n",
" * we need this to avoid circular references\n",
" * http://stackoverflow.com/a/24161582/3208463\n",
" */\n",
"function simpleKeys (original) {\n",
" return Object.keys(original).reduce(function (obj, key) {\n",
" if (typeof original[key] !== 'object')\n",
" obj[key] = original[key]\n",
" return obj;\n",
" }, {});\n",
"}\n",
"\n",
"mpl.figure.prototype.mouse_event = function(event, name) {\n",
" var canvas_pos = mpl.findpos(event)\n",
"\n",
" if (name === 'button_press')\n",
" {\n",
" this.canvas.focus();\n",
" this.canvas_div.focus();\n",
" }\n",
"\n",
" var x = canvas_pos.x * mpl.ratio;\n",
" var y = canvas_pos.y * mpl.ratio;\n",
"\n",
" this.send_message(name, {x: x, y: y, button: event.button,\n",
" step: event.step,\n",
" guiEvent: simpleKeys(event)});\n",
"\n",
" /* This prevents the web browser from automatically changing to\n",
" * the text insertion cursor when the button is pressed. We want\n",
" * to control all of the cursor setting manually through the\n",
" * 'cursor' event from matplotlib */\n",
" event.preventDefault();\n",
" return false;\n",
"}\n",
"\n",
"mpl.figure.prototype._key_event_extra = function(event, name) {\n",
" // Handle any extra behaviour associated with a key event\n",
"}\n",
"\n",
"mpl.figure.prototype.key_event = function(event, name) {\n",
"\n",
" // Prevent repeat events\n",
" if (name == 'key_press')\n",
" {\n",
" if (event.which === this._key)\n",
" return;\n",
" else\n",
" this._key = event.which;\n",
" }\n",
" if (name == 'key_release')\n",
" this._key = null;\n",
"\n",
" var value = '';\n",
" if (event.ctrlKey && event.which != 17)\n",
" value += \"ctrl+\";\n",
" if (event.altKey && event.which != 18)\n",
" value += \"alt+\";\n",
" if (event.shiftKey && event.which != 16)\n",
" value += \"shift+\";\n",
"\n",
" value += 'k';\n",
" value += event.which.toString();\n",
"\n",
" this._key_event_extra(event, name);\n",
"\n",
" this.send_message(name, {key: value,\n",
" guiEvent: simpleKeys(event)});\n",
" return false;\n",
"}\n",
"\n",
"mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
" if (name == 'download') {\n",
" this.handle_save(this, null);\n",
" } else {\n",
" this.send_message(\"toolbar_button\", {name: name});\n",
" }\n",
"};\n",
"\n",
"mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
" this.message.textContent = tooltip;\n",
"};\n",
"mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
"\n",
"mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
"\n",
"mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
" // Create a \"websocket\"-like object which calls the given IPython comm\n",
" // object with the appropriate methods. Currently this is a non binary\n",
" // socket, so there is still some room for performance tuning.\n",
" var ws = {};\n",
"\n",
" ws.close = function() {\n",
" comm.close()\n",
" };\n",
" ws.send = function(m) {\n",
" //console.log('sending', m);\n",
" comm.send(m);\n",
" };\n",
" // Register the callback with on_msg.\n",
" comm.on_msg(function(msg) {\n",
" //console.log('receiving', msg['content']['data'], msg);\n",
" // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
" ws.onmessage(msg['content']['data'])\n",
" });\n",
" return ws;\n",
"}\n",
"\n",
"mpl.mpl_figure_comm = function(comm, msg) {\n",
" // This is the function which gets called when the mpl process\n",
" // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
"\n",
" var id = msg.content.data.id;\n",
" // Get hold of the div created by the display call when the Comm\n",
" // socket was opened in Python.\n",
" var element = $(\"#\" + id);\n",
" var ws_proxy = comm_websocket_adapter(comm)\n",
"\n",
" function ondownload(figure, format) {\n",
" window.open(figure.imageObj.src);\n",
" }\n",
"\n",
" var fig = new mpl.figure(id, ws_proxy,\n",
" ondownload,\n",
" element.get(0));\n",
"\n",
" // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
" // web socket which is closed, not our websocket->open comm proxy.\n",
" ws_proxy.onopen();\n",
"\n",
" fig.parent_element = element.get(0);\n",
" fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
" if (!fig.cell_info) {\n",
" console.error(\"Failed to find cell for figure\", id, fig);\n",
" return;\n",
" }\n",
"\n",
" var output_index = fig.cell_info[2]\n",
" var cell = fig.cell_info[0];\n",
"\n",
"};\n",
"\n",
"mpl.figure.prototype.handle_close = function(fig, msg) {\n",
" var width = fig.canvas.width/mpl.ratio\n",
" fig.root.unbind('remove')\n",
"\n",
" // Update the output cell to use the data from the current canvas.\n",
" fig.push_to_output();\n",
" var dataURL = fig.canvas.toDataURL();\n",
" // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
" // the notebook keyboard shortcuts fail.\n",
" IPython.keyboard_manager.enable()\n",
" $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
" fig.close_ws(fig, msg);\n",
"}\n",
"\n",
"mpl.figure.prototype.close_ws = function(fig, msg){\n",
" fig.send_message('closing', msg);\n",
" // fig.ws.close()\n",
"}\n",
"\n",
"mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
" // Turn the data on the canvas into data in the output cell.\n",
" var width = this.canvas.width/mpl.ratio\n",
" var dataURL = this.canvas.toDataURL();\n",
" this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
"}\n",
"\n",
"mpl.figure.prototype.updated_canvas_event = function() {\n",
" // Tell IPython that the notebook contents must change.\n",
" IPython.notebook.set_dirty(true);\n",
" this.send_message(\"ack\", {});\n",
" var fig = this;\n",
" // Wait a second, then push the new image to the DOM so\n",
" // that it is saved nicely (might be nice to debounce this).\n",
" setTimeout(function () { fig.push_to_output() }, 1000);\n",
"}\n",
"\n",
"mpl.figure.prototype._init_toolbar = function() {\n",
" var fig = this;\n",
"\n",
" var nav_element = $('<div/>');\n",
" nav_element.attr('style', 'width: 100%');\n",
" this.root.append(nav_element);\n",
"\n",
" // Define a callback function for later on.\n",
" function toolbar_event(event) {\n",
" return fig.toolbar_button_onclick(event['data']);\n",
" }\n",
" function toolbar_mouse_event(event) {\n",
" return fig.toolbar_button_onmouseover(event['data']);\n",
" }\n",
"\n",
" for(var toolbar_ind in mpl.toolbar_items){\n",
" var name = mpl.toolbar_items[toolbar_ind][0];\n",
" var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
" var image = mpl.toolbar_items[toolbar_ind][2];\n",
" var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
"\n",
" if (!name) { continue; };\n",
"\n",
" var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
" button.click(method_name, toolbar_event);\n",
" button.mouseover(tooltip, toolbar_mouse_event);\n",
" nav_element.append(button);\n",
" }\n",
"\n",
" // Add the status bar.\n",
" var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
" nav_element.append(status_bar);\n",
" this.message = status_bar[0];\n",
"\n",
" // Add the close button to the window.\n",
" var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
" var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
" button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
" button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
" buttongrp.append(button);\n",
" var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
" titlebar.prepend(buttongrp);\n",
"}\n",
"\n",
"mpl.figure.prototype._root_extra_style = function(el){\n",
" var fig = this\n",
" el.on(\"remove\", function(){\n",
"\tfig.close_ws(fig, {});\n",
" });\n",
"}\n",
"\n",
"mpl.figure.prototype._canvas_extra_style = function(el){\n",
" // this is important to make the div 'focusable\n",
" el.attr('tabindex', 0)\n",
" // reach out to IPython and tell the keyboard manager to turn it's self\n",
" // off when our div gets focus\n",
"\n",
" // location in version 3\n",
" if (IPython.notebook.keyboard_manager) {\n",
" IPython.notebook.keyboard_manager.register_events(el);\n",
" }\n",
" else {\n",
" // location in version 2\n",
" IPython.keyboard_manager.register_events(el);\n",
" }\n",
"\n",
"}\n",
"\n",
"mpl.figure.prototype._key_event_extra = function(event, name) {\n",
" var manager = IPython.notebook.keyboard_manager;\n",
" if (!manager)\n",
" manager = IPython.keyboard_manager;\n",
"\n",
" // Check for shift+enter\n",
" if (event.shiftKey && event.which == 13) {\n",
" this.canvas_div.blur();\n",
" event.shiftKey = false;\n",
" // Send a \"J\" for go to next cell\n",
" event.which = 74;\n",
" event.keyCode = 74;\n",
" manager.command_mode();\n",
" manager.handle_keydown(event);\n",
" }\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_save = function(fig, msg) {\n",
" fig.ondownload(fig, null);\n",
"}\n",
"\n",
"\n",
"mpl.find_output_cell = function(html_output) {\n",
" // Return the cell and output element which can be found *uniquely* in the notebook.\n",
" // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
" // IPython event is triggered only after the cells have been serialised, which for\n",
" // our purposes (turning an active figure into a static one), is too late.\n",
" var cells = IPython.notebook.get_cells();\n",
" var ncells = cells.length;\n",
" for (var i=0; i<ncells; i++) {\n",
" var cell = cells[i];\n",
" if (cell.cell_type === 'code'){\n",
" for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
" var data = cell.output_area.outputs[j];\n",
" if (data.data) {\n",
" // IPython >= 3 moved mimebundle to data attribute of output\n",
" data = data.data;\n",
" }\n",
" if (data['text/html'] == html_output) {\n",
" return [cell, data, j];\n",
" }\n",
" }\n",
" }\n",
" }\n",
"}\n",
"\n",
"// Register the function which deals with the matplotlib target/channel.\n",
"// The kernel may be null if the page has been refreshed.\n",
"if (IPython.notebook.kernel != null) {\n",
" IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
"}\n"
],
"text/plain": [
"<IPython.core.display.Javascript object>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"text/html": [
"<img src=\"\" width=\"800\">"
],
"text/plain": [
"<IPython.core.display.HTML object>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"application/vnd.jupyter.widget-view+json": {
"model_id": "d481ea4c927043fda3365e37acd19bb3",
"version_major": 2,
"version_minor": 0
},
"text/plain": [
"interactive(children=(FloatSlider(value=1.8, description='log10(z_loop_spread/step)', layout=Layout(height='80…"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"fig, ax =prepare_canvas(REFSC_30m)\n",
"\n",
"def get_simple_bb_scaling(\n",
" z_loop_width_step_log10_ratio,\n",
" ang_rw_step,\n",
" ang_drift_step,\n",
" min_log10_s=MIN_LOG10_S, \n",
" max_log10_s=MAX_LOG10_S,\n",
" in_loop_slope=IN_LOOP_SLOPE):\n",
" \n",
" s = 10**np.linspace(MIN_LOG10_S,MAX_LOG10_S,1000)\n",
"\n",
" in_loop_scaling = s**(in_loop_slope)\n",
"\n",
" between_loop_scaling_z = (\n",
" st.norm.pdf(s, \n",
" loc=0, \n",
" scale=np.sqrt(2)*(10**z_loop_width_step_log10_ratio))\n",
" )\n",
"\n",
" between_loop_scaling_ang = np.vstack(\n",
" st.norm.pdf(x , loc=ang_drift_step*s, scale=ang_rw_step*np.sqrt(s))\n",
" for x in 2*np.pi*np.arange(-100,100+0.1)\n",
" ).sum(axis=0)\n",
"\n",
" between_loop_scaling = between_loop_scaling_ang * between_loop_scaling_z\n",
" \n",
" in_loop_scaling /= in_loop_scaling[np.argmin(np.abs(np.log10(s/GLUE_AT)))]\n",
" between_loop_scaling /= between_loop_scaling[np.argmin(np.abs(np.log10(s/GLUE_AT)))]\n",
"\n",
" cp = np.exp(-s) * in_loop_scaling + (1-np.exp(-s)) * between_loop_scaling\n",
"\n",
" return s, cp\n",
"\n",
"def plot_interactive():\n",
" \n",
" def update_scalings(z_loop_width_step_log10_ratio,\n",
" ang_rw_step,\n",
" ang_drift_step):\n",
" \n",
" ang_rw_step = 2 * np.pi * (10**ang_rw_step)\n",
" ang_drift_step = 2 * np.pi * (10**ang_drift_step)\n",
" s,cp = get_simple_bb_scaling(\n",
" z_loop_width_step_log10_ratio,\n",
" ang_rw_step,\n",
" ang_drift_step,\n",
" )\n",
" ax[0].lines[0].set_data(np.log10(s), np.log10(cp))\n",
"\n",
" ax[1].lines[0].set_data(\n",
" (np.log10(s)[1:] + np.log10(s)[:-1])/2,\n",
" np.diff(np.log10(cp)) / np.diff(np.log10(s))\n",
" )\n",
" \n",
" \n",
" widget_z_loop_width_step_log10_ratio = widgets.FloatSlider(\n",
" description='log10(z_loop_spread/step)',\n",
" layout=widgets.Layout(width='75%', height='80px'),\n",
" value=1.8,\n",
" min=-4, \n",
" max=4)\n",
" widget_ang_rw_step = widgets.FloatSlider(\n",
" description='log10 (ang_rw_step / 2 Pi)',\n",
" layout=widgets.Layout(width='75%', height='80px'),\n",
" value=-1.4,\n",
" min=-4, \n",
" max=0)\n",
" widget_ang_drift_step = widgets.FloatSlider(\n",
" description='log10 (ang_drift_step / 2 Pi)',\n",
" layout=widgets.Layout(width='75%', height='80px'),\n",
" value=-2.0,\n",
" min=-4, \n",
" max=0)\n",
"\n",
" interact(\n",
" update_scalings, \n",
" z_loop_width_step_log10_ratio=widget_z_loop_width_step_log10_ratio,\n",
" ang_rw_step=widget_ang_rw_step,\n",
" ang_drift_step=widget_ang_drift_step)\n",
" \n",
"\n",
"plot_interactive()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# Bottle brush with OU angular loop orientation (approximate)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"A bottlebrush with angular correlations of loops.\n",
"- Below the loop size the scaling is calculated as s^-3/2.\n",
"- Above the loop size, contact probability is the probability for two particles to have the same z-component and same angle.\n",
" - The probability of an overlap in z is calculated as in (1).\n",
" - The angular orientations of loops perform a contrained random walk with a drift (trending Ornstein Uhlenbeck process). The probability of an overlap == the return probability.\n",
" - The 2nd slider sets log10 standard deviation of angular spread for loops emanating from the same anchor / $2\\pi$.\n",
" - The 3nd slider sets log10 characteristic length scale of angular loop correlations (in number of loops)\n",
" - The 4th slider sets $log10 (angular\\_drift\\_per\\_loop\\_in\\_radians / 2 \\pi ) $. The inverse of this number is the period of the spiral in loops.\n",
"\n",
"\n",
"References:\n",
"- trending Ornstein-Uhlenbeck (http://web.mit.edu/wangj/www/pap/LoWang95.pdf, page 35)"
]
},
{
"cell_type": "code",
"execution_count": 13,
"metadata": {
"ExecuteTime": {
"end_time": "2020-06-22T20:22:48.710558Z",
"start_time": "2020-06-22T20:22:48.535586Z"
}
},
"outputs": [
{
"data": {
"application/javascript": [
"/* Put everything inside the global mpl namespace */\n",
"window.mpl = {};\n",
"\n",
"\n",
"mpl.get_websocket_type = function() {\n",
" if (typeof(WebSocket) !== 'undefined') {\n",
" return WebSocket;\n",
" } else if (typeof(MozWebSocket) !== 'undefined') {\n",
" return MozWebSocket;\n",
" } else {\n",
" alert('Your browser does not have WebSocket support. ' +\n",
" 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
" 'Firefox 4 and 5 are also supported but you ' +\n",
" 'have to enable WebSockets in about:config.');\n",
" };\n",
"}\n",
"\n",
"mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
" this.id = figure_id;\n",
"\n",
" this.ws = websocket;\n",
"\n",
" this.supports_binary = (this.ws.binaryType != undefined);\n",
"\n",
" if (!this.supports_binary) {\n",
" var warnings = document.getElementById(\"mpl-warnings\");\n",
" if (warnings) {\n",
" warnings.style.display = 'block';\n",
" warnings.textContent = (\n",
" \"This browser does not support binary websocket messages. \" +\n",
" \"Performance may be slow.\");\n",
" }\n",
" }\n",
"\n",
" this.imageObj = new Image();\n",
"\n",
" this.context = undefined;\n",
" this.message = undefined;\n",
" this.canvas = undefined;\n",
" this.rubberband_canvas = undefined;\n",
" this.rubberband_context = undefined;\n",
" this.format_dropdown = undefined;\n",
"\n",
" this.image_mode = 'full';\n",
"\n",
" this.root = $('<div/>');\n",
" this._root_extra_style(this.root)\n",
" this.root.attr('style', 'display: inline-block');\n",
"\n",
" $(parent_element).append(this.root);\n",
"\n",
" this._init_header(this);\n",
" this._init_canvas(this);\n",
" this._init_toolbar(this);\n",
"\n",
" var fig = this;\n",
"\n",
" this.waiting = false;\n",
"\n",
" this.ws.onopen = function () {\n",
" fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
" fig.send_message(\"send_image_mode\", {});\n",
" if (mpl.ratio != 1) {\n",
" fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
" }\n",
" fig.send_message(\"refresh\", {});\n",
" }\n",
"\n",
" this.imageObj.onload = function() {\n",
" if (fig.image_mode == 'full') {\n",
" // Full images could contain transparency (where diff images\n",
" // almost always do), so we need to clear the canvas so that\n",
" // there is no ghosting.\n",
" fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
" }\n",
" fig.context.drawImage(fig.imageObj, 0, 0);\n",
" };\n",
"\n",
" this.imageObj.onunload = function() {\n",
" fig.ws.close();\n",
" }\n",
"\n",
" this.ws.onmessage = this._make_on_message_function(this);\n",
"\n",
" this.ondownload = ondownload;\n",
"}\n",
"\n",
"mpl.figure.prototype._init_header = function() {\n",
" var titlebar = $(\n",
" '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
" 'ui-helper-clearfix\"/>');\n",
" var titletext = $(\n",
" '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
" 'text-align: center; padding: 3px;\"/>');\n",
" titlebar.append(titletext)\n",
" this.root.append(titlebar);\n",
" this.header = titletext[0];\n",
"}\n",
"\n",
"\n",
"\n",
"mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
"\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
"\n",
"}\n",
"\n",
"mpl.figure.prototype._init_canvas = function() {\n",
" var fig = this;\n",
"\n",
" var canvas_div = $('<div/>');\n",
"\n",
" canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
"\n",
" function canvas_keyboard_event(event) {\n",
" return fig.key_event(event, event['data']);\n",
" }\n",
"\n",
" canvas_div.keydown('key_press', canvas_keyboard_event);\n",
" canvas_div.keyup('key_release', canvas_keyboard_event);\n",
" this.canvas_div = canvas_div\n",
" this._canvas_extra_style(canvas_div)\n",
" this.root.append(canvas_div);\n",
"\n",
" var canvas = $('<canvas/>');\n",
" canvas.addClass('mpl-canvas');\n",
" canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
"\n",
" this.canvas = canvas[0];\n",
" this.context = canvas[0].getContext(\"2d\");\n",
"\n",
" var backingStore = this.context.backingStorePixelRatio ||\n",
"\tthis.context.webkitBackingStorePixelRatio ||\n",
"\tthis.context.mozBackingStorePixelRatio ||\n",
"\tthis.context.msBackingStorePixelRatio ||\n",
"\tthis.context.oBackingStorePixelRatio ||\n",
"\tthis.context.backingStorePixelRatio || 1;\n",
"\n",
" mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
"\n",
" var rubberband = $('<canvas/>');\n",
" rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
"\n",
" var pass_mouse_events = true;\n",
"\n",
" canvas_div.resizable({\n",
" start: function(event, ui) {\n",
" pass_mouse_events = false;\n",
" },\n",
" resize: function(event, ui) {\n",
" fig.request_resize(ui.size.width, ui.size.height);\n",
" },\n",
" stop: function(event, ui) {\n",
" pass_mouse_events = true;\n",
" fig.request_resize(ui.size.width, ui.size.height);\n",
" },\n",
" });\n",
"\n",
" function mouse_event_fn(event) {\n",
" if (pass_mouse_events)\n",
" return fig.mouse_event(event, event['data']);\n",
" }\n",
"\n",
" rubberband.mousedown('button_press', mouse_event_fn);\n",
" rubberband.mouseup('button_release', mouse_event_fn);\n",
" // Throttle sequential mouse events to 1 every 20ms.\n",
" rubberband.mousemove('motion_notify', mouse_event_fn);\n",
"\n",
" rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
" rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
"\n",
" canvas_div.on(\"wheel\", function (event) {\n",
" event = event.originalEvent;\n",
" event['data'] = 'scroll'\n",
" if (event.deltaY < 0) {\n",
" event.step = 1;\n",
" } else {\n",
" event.step = -1;\n",
" }\n",
" mouse_event_fn(event);\n",
" });\n",
"\n",
" canvas_div.append(canvas);\n",
" canvas_div.append(rubberband);\n",
"\n",
" this.rubberband = rubberband;\n",
" this.rubberband_canvas = rubberband[0];\n",
" this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
" this.rubberband_context.strokeStyle = \"#000000\";\n",
"\n",
" this._resize_canvas = function(width, height) {\n",
" // Keep the size of the canvas, canvas container, and rubber band\n",
" // canvas in synch.\n",
" canvas_div.css('width', width)\n",
" canvas_div.css('height', height)\n",
"\n",
" canvas.attr('width', width * mpl.ratio);\n",
" canvas.attr('height', height * mpl.ratio);\n",
" canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
"\n",
" rubberband.attr('width', width);\n",
" rubberband.attr('height', height);\n",
" }\n",
"\n",
" // Set the figure to an initial 600x600px, this will subsequently be updated\n",
" // upon first draw.\n",
" this._resize_canvas(600, 600);\n",
"\n",
" // Disable right mouse context menu.\n",
" $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
" return false;\n",
" });\n",
"\n",
" function set_focus () {\n",
" canvas.focus();\n",
" canvas_div.focus();\n",
" }\n",
"\n",
" window.setTimeout(set_focus, 100);\n",
"}\n",
"\n",
"mpl.figure.prototype._init_toolbar = function() {\n",
" var fig = this;\n",
"\n",
" var nav_element = $('<div/>');\n",
" nav_element.attr('style', 'width: 100%');\n",
" this.root.append(nav_element);\n",
"\n",
" // Define a callback function for later on.\n",
" function toolbar_event(event) {\n",
" return fig.toolbar_button_onclick(event['data']);\n",
" }\n",
" function toolbar_mouse_event(event) {\n",
" return fig.toolbar_button_onmouseover(event['data']);\n",
" }\n",
"\n",
" for(var toolbar_ind in mpl.toolbar_items) {\n",
" var name = mpl.toolbar_items[toolbar_ind][0];\n",
" var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
" var image = mpl.toolbar_items[toolbar_ind][2];\n",
" var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
"\n",
" if (!name) {\n",
" // put a spacer in here.\n",
" continue;\n",
" }\n",
" var button = $('<button/>');\n",
" button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
" 'ui-button-icon-only');\n",
" button.attr('role', 'button');\n",
" button.attr('aria-disabled', 'false');\n",
" button.click(method_name, toolbar_event);\n",
" button.mouseover(tooltip, toolbar_mouse_event);\n",
"\n",
" var icon_img = $('<span/>');\n",
" icon_img.addClass('ui-button-icon-primary ui-icon');\n",
" icon_img.addClass(image);\n",
" icon_img.addClass('ui-corner-all');\n",
"\n",
" var tooltip_span = $('<span/>');\n",
" tooltip_span.addClass('ui-button-text');\n",
" tooltip_span.html(tooltip);\n",
"\n",
" button.append(icon_img);\n",
" button.append(tooltip_span);\n",
"\n",
" nav_element.append(button);\n",
" }\n",
"\n",
" var fmt_picker_span = $('<span/>');\n",
"\n",
" var fmt_picker = $('<select/>');\n",
" fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
" fmt_picker_span.append(fmt_picker);\n",
" nav_element.append(fmt_picker_span);\n",
" this.format_dropdown = fmt_picker[0];\n",
"\n",
" for (var ind in mpl.extensions) {\n",
" var fmt = mpl.extensions[ind];\n",
" var option = $(\n",
" '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
" fmt_picker.append(option);\n",
" }\n",
"\n",
" // Add hover states to the ui-buttons\n",
" $( \".ui-button\" ).hover(\n",
" function() { $(this).addClass(\"ui-state-hover\");},\n",
" function() { $(this).removeClass(\"ui-state-hover\");}\n",
" );\n",
"\n",
" var status_bar = $('<span class=\"mpl-message\"/>');\n",
" nav_element.append(status_bar);\n",
" this.message = status_bar[0];\n",
"}\n",
"\n",
"mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
" // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
" // which will in turn request a refresh of the image.\n",
" this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
"}\n",
"\n",
"mpl.figure.prototype.send_message = function(type, properties) {\n",
" properties['type'] = type;\n",
" properties['figure_id'] = this.id;\n",
" this.ws.send(JSON.stringify(properties));\n",
"}\n",
"\n",
"mpl.figure.prototype.send_draw_message = function() {\n",
" if (!this.waiting) {\n",
" this.waiting = true;\n",
" this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
" }\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype.handle_save = function(fig, msg) {\n",
" var format_dropdown = fig.format_dropdown;\n",
" var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
" fig.ondownload(fig, format);\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
" var size = msg['size'];\n",
" if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
" fig._resize_canvas(size[0], size[1]);\n",
" fig.send_message(\"refresh\", {});\n",
" };\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
" var x0 = msg['x0'] / mpl.ratio;\n",
" var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
" var x1 = msg['x1'] / mpl.ratio;\n",
" var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
" x0 = Math.floor(x0) + 0.5;\n",
" y0 = Math.floor(y0) + 0.5;\n",
" x1 = Math.floor(x1) + 0.5;\n",
" y1 = Math.floor(y1) + 0.5;\n",
" var min_x = Math.min(x0, x1);\n",
" var min_y = Math.min(y0, y1);\n",
" var width = Math.abs(x1 - x0);\n",
" var height = Math.abs(y1 - y0);\n",
"\n",
" fig.rubberband_context.clearRect(\n",
" 0, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\n",
"\n",
" fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
" // Updates the figure title.\n",
" fig.header.textContent = msg['label'];\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
" var cursor = msg['cursor'];\n",
" switch(cursor)\n",
" {\n",
" case 0:\n",
" cursor = 'pointer';\n",
" break;\n",
" case 1:\n",
" cursor = 'default';\n",
" break;\n",
" case 2:\n",
" cursor = 'crosshair';\n",
" break;\n",
" case 3:\n",
" cursor = 'move';\n",
" break;\n",
" }\n",
" fig.rubberband_canvas.style.cursor = cursor;\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_message = function(fig, msg) {\n",
" fig.message.textContent = msg['message'];\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
" // Request the server to send over a new figure.\n",
" fig.send_draw_message();\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
" fig.image_mode = msg['mode'];\n",
"}\n",
"\n",
"mpl.figure.prototype.updated_canvas_event = function() {\n",
" // Called whenever the canvas gets updated.\n",
" this.send_message(\"ack\", {});\n",
"}\n",
"\n",
"// A function to construct a web socket function for onmessage handling.\n",
"// Called in the figure constructor.\n",
"mpl.figure.prototype._make_on_message_function = function(fig) {\n",
" return function socket_on_message(evt) {\n",
" if (evt.data instanceof Blob) {\n",
" /* FIXME: We get \"Resource interpreted as Image but\n",
" * transferred with MIME type text/plain:\" errors on\n",
" * Chrome. But how to set the MIME type? It doesn't seem\n",
" * to be part of the websocket stream */\n",
" evt.data.type = \"image/png\";\n",
"\n",
" /* Free the memory for the previous frames */\n",
" if (fig.imageObj.src) {\n",
" (window.URL || window.webkitURL).revokeObjectURL(\n",
" fig.imageObj.src);\n",
" }\n",
"\n",
" fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
" evt.data);\n",
" fig.updated_canvas_event();\n",
" fig.waiting = false;\n",
" return;\n",
" }\n",
" else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
" fig.imageObj.src = evt.data;\n",
" fig.updated_canvas_event();\n",
" fig.waiting = false;\n",
" return;\n",
" }\n",
"\n",
" var msg = JSON.parse(evt.data);\n",
" var msg_type = msg['type'];\n",
"\n",
" // Call the \"handle_{type}\" callback, which takes\n",
" // the figure and JSON message as its only arguments.\n",
" try {\n",
" var callback = fig[\"handle_\" + msg_type];\n",
" } catch (e) {\n",
" console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
" return;\n",
" }\n",
"\n",
" if (callback) {\n",
" try {\n",
" // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
" callback(fig, msg);\n",
" } catch (e) {\n",
" console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
" }\n",
" }\n",
" };\n",
"}\n",
"\n",
"// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
"mpl.findpos = function(e) {\n",
" //this section is from http://www.quirksmode.org/js/events_properties.html\n",
" var targ;\n",
" if (!e)\n",
" e = window.event;\n",
" if (e.target)\n",
" targ = e.target;\n",
" else if (e.srcElement)\n",
" targ = e.srcElement;\n",
" if (targ.nodeType == 3) // defeat Safari bug\n",
" targ = targ.parentNode;\n",
"\n",
" // jQuery normalizes the pageX and pageY\n",
" // pageX,Y are the mouse positions relative to the document\n",
" // offset() returns the position of the element relative to the document\n",
" var x = e.pageX - $(targ).offset().left;\n",
" var y = e.pageY - $(targ).offset().top;\n",
"\n",
" return {\"x\": x, \"y\": y};\n",
"};\n",
"\n",
"/*\n",
" * return a copy of an object with only non-object keys\n",
" * we need this to avoid circular references\n",
" * http://stackoverflow.com/a/24161582/3208463\n",
" */\n",
"function simpleKeys (original) {\n",
" return Object.keys(original).reduce(function (obj, key) {\n",
" if (typeof original[key] !== 'object')\n",
" obj[key] = original[key]\n",
" return obj;\n",
" }, {});\n",
"}\n",
"\n",
"mpl.figure.prototype.mouse_event = function(event, name) {\n",
" var canvas_pos = mpl.findpos(event)\n",
"\n",
" if (name === 'button_press')\n",
" {\n",
" this.canvas.focus();\n",
" this.canvas_div.focus();\n",
" }\n",
"\n",
" var x = canvas_pos.x * mpl.ratio;\n",
" var y = canvas_pos.y * mpl.ratio;\n",
"\n",
" this.send_message(name, {x: x, y: y, button: event.button,\n",
" step: event.step,\n",
" guiEvent: simpleKeys(event)});\n",
"\n",
" /* This prevents the web browser from automatically changing to\n",
" * the text insertion cursor when the button is pressed. We want\n",
" * to control all of the cursor setting manually through the\n",
" * 'cursor' event from matplotlib */\n",
" event.preventDefault();\n",
" return false;\n",
"}\n",
"\n",
"mpl.figure.prototype._key_event_extra = function(event, name) {\n",
" // Handle any extra behaviour associated with a key event\n",
"}\n",
"\n",
"mpl.figure.prototype.key_event = function(event, name) {\n",
"\n",
" // Prevent repeat events\n",
" if (name == 'key_press')\n",
" {\n",
" if (event.which === this._key)\n",
" return;\n",
" else\n",
" this._key = event.which;\n",
" }\n",
" if (name == 'key_release')\n",
" this._key = null;\n",
"\n",
" var value = '';\n",
" if (event.ctrlKey && event.which != 17)\n",
" value += \"ctrl+\";\n",
" if (event.altKey && event.which != 18)\n",
" value += \"alt+\";\n",
" if (event.shiftKey && event.which != 16)\n",
" value += \"shift+\";\n",
"\n",
" value += 'k';\n",
" value += event.which.toString();\n",
"\n",
" this._key_event_extra(event, name);\n",
"\n",
" this.send_message(name, {key: value,\n",
" guiEvent: simpleKeys(event)});\n",
" return false;\n",
"}\n",
"\n",
"mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
" if (name == 'download') {\n",
" this.handle_save(this, null);\n",
" } else {\n",
" this.send_message(\"toolbar_button\", {name: name});\n",
" }\n",
"};\n",
"\n",
"mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
" this.message.textContent = tooltip;\n",
"};\n",
"mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
"\n",
"mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
"\n",
"mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
" // Create a \"websocket\"-like object which calls the given IPython comm\n",
" // object with the appropriate methods. Currently this is a non binary\n",
" // socket, so there is still some room for performance tuning.\n",
" var ws = {};\n",
"\n",
" ws.close = function() {\n",
" comm.close()\n",
" };\n",
" ws.send = function(m) {\n",
" //console.log('sending', m);\n",
" comm.send(m);\n",
" };\n",
" // Register the callback with on_msg.\n",
" comm.on_msg(function(msg) {\n",
" //console.log('receiving', msg['content']['data'], msg);\n",
" // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
" ws.onmessage(msg['content']['data'])\n",
" });\n",
" return ws;\n",
"}\n",
"\n",
"mpl.mpl_figure_comm = function(comm, msg) {\n",
" // This is the function which gets called when the mpl process\n",
" // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
"\n",
" var id = msg.content.data.id;\n",
" // Get hold of the div created by the display call when the Comm\n",
" // socket was opened in Python.\n",
" var element = $(\"#\" + id);\n",
" var ws_proxy = comm_websocket_adapter(comm)\n",
"\n",
" function ondownload(figure, format) {\n",
" window.open(figure.imageObj.src);\n",
" }\n",
"\n",
" var fig = new mpl.figure(id, ws_proxy,\n",
" ondownload,\n",
" element.get(0));\n",
"\n",
" // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
" // web socket which is closed, not our websocket->open comm proxy.\n",
" ws_proxy.onopen();\n",
"\n",
" fig.parent_element = element.get(0);\n",
" fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
" if (!fig.cell_info) {\n",
" console.error(\"Failed to find cell for figure\", id, fig);\n",
" return;\n",
" }\n",
"\n",
" var output_index = fig.cell_info[2]\n",
" var cell = fig.cell_info[0];\n",
"\n",
"};\n",
"\n",
"mpl.figure.prototype.handle_close = function(fig, msg) {\n",
" var width = fig.canvas.width/mpl.ratio\n",
" fig.root.unbind('remove')\n",
"\n",
" // Update the output cell to use the data from the current canvas.\n",
" fig.push_to_output();\n",
" var dataURL = fig.canvas.toDataURL();\n",
" // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
" // the notebook keyboard shortcuts fail.\n",
" IPython.keyboard_manager.enable()\n",
" $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
" fig.close_ws(fig, msg);\n",
"}\n",
"\n",
"mpl.figure.prototype.close_ws = function(fig, msg){\n",
" fig.send_message('closing', msg);\n",
" // fig.ws.close()\n",
"}\n",
"\n",
"mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
" // Turn the data on the canvas into data in the output cell.\n",
" var width = this.canvas.width/mpl.ratio\n",
" var dataURL = this.canvas.toDataURL();\n",
" this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
"}\n",
"\n",
"mpl.figure.prototype.updated_canvas_event = function() {\n",
" // Tell IPython that the notebook contents must change.\n",
" IPython.notebook.set_dirty(true);\n",
" this.send_message(\"ack\", {});\n",
" var fig = this;\n",
" // Wait a second, then push the new image to the DOM so\n",
" // that it is saved nicely (might be nice to debounce this).\n",
" setTimeout(function () { fig.push_to_output() }, 1000);\n",
"}\n",
"\n",
"mpl.figure.prototype._init_toolbar = function() {\n",
" var fig = this;\n",
"\n",
" var nav_element = $('<div/>');\n",
" nav_element.attr('style', 'width: 100%');\n",
" this.root.append(nav_element);\n",
"\n",
" // Define a callback function for later on.\n",
" function toolbar_event(event) {\n",
" return fig.toolbar_button_onclick(event['data']);\n",
" }\n",
" function toolbar_mouse_event(event) {\n",
" return fig.toolbar_button_onmouseover(event['data']);\n",
" }\n",
"\n",
" for(var toolbar_ind in mpl.toolbar_items){\n",
" var name = mpl.toolbar_items[toolbar_ind][0];\n",
" var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
" var image = mpl.toolbar_items[toolbar_ind][2];\n",
" var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
"\n",
" if (!name) { continue; };\n",
"\n",
" var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
" button.click(method_name, toolbar_event);\n",
" button.mouseover(tooltip, toolbar_mouse_event);\n",
" nav_element.append(button);\n",
" }\n",
"\n",
" // Add the status bar.\n",
" var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
" nav_element.append(status_bar);\n",
" this.message = status_bar[0];\n",
"\n",
" // Add the close button to the window.\n",
" var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
" var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
" button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
" button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
" buttongrp.append(button);\n",
" var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
" titlebar.prepend(buttongrp);\n",
"}\n",
"\n",
"mpl.figure.prototype._root_extra_style = function(el){\n",
" var fig = this\n",
" el.on(\"remove\", function(){\n",
"\tfig.close_ws(fig, {});\n",
" });\n",
"}\n",
"\n",
"mpl.figure.prototype._canvas_extra_style = function(el){\n",
" // this is important to make the div 'focusable\n",
" el.attr('tabindex', 0)\n",
" // reach out to IPython and tell the keyboard manager to turn it's self\n",
" // off when our div gets focus\n",
"\n",
" // location in version 3\n",
" if (IPython.notebook.keyboard_manager) {\n",
" IPython.notebook.keyboard_manager.register_events(el);\n",
" }\n",
" else {\n",
" // location in version 2\n",
" IPython.keyboard_manager.register_events(el);\n",
" }\n",
"\n",
"}\n",
"\n",
"mpl.figure.prototype._key_event_extra = function(event, name) {\n",
" var manager = IPython.notebook.keyboard_manager;\n",
" if (!manager)\n",
" manager = IPython.keyboard_manager;\n",
"\n",
" // Check for shift+enter\n",
" if (event.shiftKey && event.which == 13) {\n",
" this.canvas_div.blur();\n",
" event.shiftKey = false;\n",
" // Send a \"J\" for go to next cell\n",
" event.which = 74;\n",
" event.keyCode = 74;\n",
" manager.command_mode();\n",
" manager.handle_keydown(event);\n",
" }\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_save = function(fig, msg) {\n",
" fig.ondownload(fig, null);\n",
"}\n",
"\n",
"\n",
"mpl.find_output_cell = function(html_output) {\n",
" // Return the cell and output element which can be found *uniquely* in the notebook.\n",
" // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
" // IPython event is triggered only after the cells have been serialised, which for\n",
" // our purposes (turning an active figure into a static one), is too late.\n",
" var cells = IPython.notebook.get_cells();\n",
" var ncells = cells.length;\n",
" for (var i=0; i<ncells; i++) {\n",
" var cell = cells[i];\n",
" if (cell.cell_type === 'code'){\n",
" for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
" var data = cell.output_area.outputs[j];\n",
" if (data.data) {\n",
" // IPython >= 3 moved mimebundle to data attribute of output\n",
" data = data.data;\n",
" }\n",
" if (data['text/html'] == html_output) {\n",
" return [cell, data, j];\n",
" }\n",
" }\n",
" }\n",
" }\n",
"}\n",
"\n",
"// Register the function which deals with the matplotlib target/channel.\n",
"// The kernel may be null if the page has been refreshed.\n",
"if (IPython.notebook.kernel != null) {\n",
" IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
"}\n"
],
"text/plain": [
"<IPython.core.display.Javascript object>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"text/html": [
"<img src=\"\" width=\"800\">"
],
"text/plain": [
"<IPython.core.display.HTML object>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"application/vnd.jupyter.widget-view+json": {
"model_id": "97760157676e4c4a8328de8df6e690aa",
"version_major": 2,
"version_minor": 0
},
"text/plain": [
"interactive(children=(FloatSlider(value=1.75, description='log10(z_loop_spread/step)', layout=Layout(height='8…"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"fig, ax =prepare_canvas(REFSC_60m, 80000)\n",
"#fig, ax =prepare_canvas(REFSC_30m, 80000)\n",
"\n",
"def get_simple_bb_scaling(\n",
" z_loop_width_step_log10_ratio,\n",
" ang_rw_step,\n",
" ang_loop_spread,\n",
" ang_drift_step,\n",
" ang_rw_return_scale,\n",
" min_log10_s=MIN_LOG10_S, \n",
" max_log10_s=MAX_LOG10_S):\n",
" \n",
" s = 10**np.linspace(MIN_LOG10_S,MAX_LOG10_S,1000)\n",
"\n",
" in_loop_scaling = s**(-3/2)\n",
"\n",
" between_loop_scaling_z = (\n",
" st.norm.pdf(s, loc=0, scale=np.sqrt(2)*(10**z_loop_width_step_log10_ratio)) )\n",
" between_loop_scaling_z /= between_loop_scaling_z[np.argmin(np.abs(np.log10(s/GLUE_AT)))]\n",
" \n",
" between_loop_scaling_ang = np.vstack(\n",
" st.norm.pdf(x , \n",
" loc=ang_drift_step*s, \n",
" scale=np.sqrt(2*ang_loop_spread**2\n",
" +\n",
" (ang_rw_step**2)*(1-np.exp(-s/ang_rw_return_scale)) * ang_rw_return_scale )\n",
" )\n",
" for x in 2*np.pi*np.arange(-100,100+0.1)\n",
" ).sum(axis=0)\n",
" \n",
" between_loop_scaling = between_loop_scaling_ang * between_loop_scaling_z\n",
" \n",
" in_loop_scaling /= in_loop_scaling[np.argmin(np.abs(np.log10(s/GLUE_AT)))]\n",
" between_loop_scaling /= between_loop_scaling[np.argmin(np.abs(np.log10(s/GLUE_AT)))]\n",
"\n",
" cp = np.exp(-s) * in_loop_scaling + (1-np.exp(-s)) * between_loop_scaling\n",
"\n",
" return s, cp\n",
"\n",
"def plot_interactive():\n",
" \n",
" def update_scalings(z_loop_width_step_log10_ratio,ang_rw_stat_std,ang_rw_return_scale,ang_loop_spread,ang_drift_step):\n",
" ang_rw_stat_std = 2 * np.pi * (10**ang_rw_stat_std)\n",
" ang_rw_return_scale = 10 ** (ang_rw_return_scale)\n",
" ang_loop_spread = 2 * np.pi * (10**ang_loop_spread)\n",
" ang_drift_step = 2 * np.pi * (10**ang_drift_step)\n",
" ang_rw_step = ang_rw_stat_std * np.sqrt(ang_rw_return_scale)\n",
" s,cp = get_simple_bb_scaling(\n",
" z_loop_width_step_log10_ratio,\n",
" ang_rw_step,\n",
" ang_loop_spread,\n",
" ang_drift_step,\n",
" ang_rw_return_scale\n",
" )\n",
"\n",
" ax[0].lines[0].set_data(np.log10(s), np.log10(cp))\n",
"\n",
" ax[1].lines[0].set_data(\n",
" (np.log10(s)[1:] + np.log10(s)[:-1])/2,\n",
" np.diff(np.log10(cp)) / np.diff(np.log10(s))\n",
" )\n",
" \n",
" \n",
" widget_z_loop_width_step_log10_ratio = widgets.FloatSlider(\n",
" description='log10(z_loop_spread/step)',\n",
" layout=widgets.Layout(width='75%', height='80px'),\n",
" #value=1.65, #WT-30m\n",
" value=1.75, #WT-60m\n",
" #value=1.57, #CAPH1-R2-30m 200kb\n",
" #value=1.30, #CAPH1-R2-30m 400kb\n",
" min=-4, \n",
" step=0.025,\n",
" max=4)\n",
" widget_ang_rw_stat_std = widgets.FloatSlider(\n",
" description='log10 (ang_rw_stat_std / 2 Pi)',\n",
" layout=widgets.Layout(width='75%', height='80px'),\n",
" #value=-1.7, #WT-30m,\n",
" value=-1.65, #WT-60m\n",
" #value=-1.45, #CAPH2-30m\n",
" #value=-1.4, #CAPH2-R2-30m 400kb\n",
" min=-2, \n",
" step=0.025,\n",
"\n",
" max=0)\n",
" widget_ang_loop_spread = widgets.FloatSlider(\n",
" description='log10 (ang_loop_spread / 2 Pi)',\n",
" layout=widgets.Layout(width='50%', height='80px'),\n",
" #value=-1.4, #WT-30m\n",
" value=-1.675, #WT-60m\n",
" #value=-1.1, #CAPH1-R2-30m 200kb\n",
" #value=-0.9, #CAPH1-R2-30m 400kb\n",
" min=-4, \n",
" max=0)\n",
" widget_ang_rw_return_scale = widgets.FloatSlider(\n",
" description='log10 (ang_rw_return_scale)',\n",
" layout=widgets.Layout(width='75%', height='80px'),\n",
" #value=1.15, #WT-30m\n",
" value=1.05, #WT-60m\n",
" #value=1.00, #CAPH1-R2-30m 200kb\n",
" #value=0.95, #CAPH1-R2-30m 400kb\n",
" \n",
"\n",
" step=0.025,\n",
" \n",
" min=0, \n",
" max=4)\n",
" widget_ang_drift_step = widgets.FloatSlider(\n",
" description='log10 (ang_drift_step / 2 Pi)',\n",
" layout=widgets.Layout(width='75%', height='80px'),\n",
" step=0.025,\n",
" \n",
" #value=-1.975, #WT-30m\n",
" value=-2.15, #WT-60m\n",
" #value=-1.7, #CAPH1-R2-30m 200kb\n",
" #value=-1.425, #CAPH1-R2-30m 400kb\n",
" min=-4, \n",
" max=0)\n",
"\n",
" interact(\n",
" update_scalings, \n",
" z_loop_width_step_log10_ratio=widget_z_loop_width_step_log10_ratio,\n",
" ang_rw_stat_std=widget_ang_rw_stat_std,\n",
" ang_loop_spread=widget_ang_loop_spread,\n",
" ang_rw_return_scale=widget_ang_rw_return_scale,\n",
" ang_drift_step=widget_ang_drift_step)\n",
"\n",
" ax[0].set_ylim(-2,1)\n",
" ax[0].set_xlim(-1,3)\n",
" #plt.savefig(f'{FIG_FOLDER}/coarse_grained_RW_scaling_WT-30m-80kb.svg')\n",
" #plt.savefig(f'{FIG_FOLDER}/coarse_grained_RW_scaling_WT-60m-80kb.svg')\n",
" #plt.savefig(f'{FIG_FOLDER}/coarse_grained_RW_scaling_CAPH1-R2-30m-200kb.svg')\n",
"\n",
" \n",
"\n",
"plot_interactive()\n",
"\n"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# Experimental"
]
},
{
"cell_type": "code",
"execution_count": 46,
"metadata": {
"ExecuteTime": {
"end_time": "2017-07-04T03:35:38.072280Z",
"start_time": "2017-07-04T03:35:38.029228Z"
},
"collapsed": true
},
"outputs": [],
"source": [
"%matplotlib notebook"
]
},
{
"cell_type": "code",
"execution_count": 32,
"metadata": {
"ExecuteTime": {
"end_time": "2017-07-04T03:55:46.332312Z",
"start_time": "2017-07-04T03:55:46.291926Z"
},
"collapsed": true
},
"outputs": [],
"source": [
"def simulate_trending_ou(\n",
" N, ang_rw_stat_std,ang_rw_return_scale,ang_loop_spread,ang_drift_step):\n",
" \n",
" ang_rw_stat_std = 2 * np.pi * (10**ang_rw_stat_std)\n",
" ang_rw_return_scale = 10 ** (ang_rw_return_scale)\n",
" ang_loop_spread = 2 * np.pi * (10**ang_loop_spread)\n",
" ang_drift_step = 2 * np.pi * (10**ang_drift_step)\n",
" ang_rw_step = ang_rw_stat_std * np.sqrt(ang_rw_return_scale)\n",
" \n",
" angles = [0]\n",
" for i in range(1,N):\n",
" new_ang = angles[i-1] + ang_drift_step - (angles[i-1] - ang_drift_step * i) / ang_rw_return_scale + np.random.normal(scale=ang_rw_step)\n",
" angles.append(new_ang)\n",
" \n",
" return angles\n",
" \n",
" \n"
]
},
{
"cell_type": "code",
"execution_count": 34,
"metadata": {
"ExecuteTime": {
"end_time": "2017-07-04T03:56:06.866708Z",
"start_time": "2017-07-04T03:56:06.830419Z"
}
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"0.0771791515585\n"
]
}
],
"source": [
"ang_rw_stat_std = -1.675\n",
"ang_rw_return_scale = 1.125\n",
"ang_loop_spread = -1.3\n",
"ang_drift_step = -1.975\n",
"\n",
"# ang_rw_stat_std = -1.75\n",
"# ang_rw_return_scale = 1.38\n",
"# ang_loop_spread = -0.7\n",
"# ang_drift_step = -1.77\n",
"\n",
"ang_rw_stat_std = 2 * np.pi * (10**ang_rw_stat_std)\n",
"ang_rw_return_scale = 10 ** (ang_rw_return_scale)\n",
"ang_loop_spread = 2 * np.pi * (10**ang_loop_spread)\n",
"ang_drift_step = 2 * np.pi * (10**ang_drift_step)\n",
"\n",
"ang_rw_step = ang_rw_stat_std * np.sqrt(ang_rw_return_scale)\n",
"print(ang_rw_step / 2 / np.pi)"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": true
},
"outputs": [],
"source": [
"\n",
"ang_rw_stat_std = 2 * np.pi * (10**ang_rw_stat_std)\n",
"ang_rw_return_scale = 10 ** (ang_rw_return_scale)\n",
"ang_loop_spread = 2 * np.pi * (10**ang_loop_spread)\n",
"ang_drift_step = 2 * np.pi * (10**ang_drift_step)\n",
"\n",
"ang_rw_step = ang_rw_stat_std * np.sqrt(ang_rw_return_scale)\n",
"print(ang_rw_step / 2 / np.pi)"
]
},
{
"cell_type": "code",
"execution_count": 33,
"metadata": {
"ExecuteTime": {
"end_time": "2017-07-04T03:55:48.356214Z",
"start_time": "2017-07-04T03:55:48.062921Z"
}
},
"outputs": [
{
"data": {
"text/plain": [
"<matplotlib.text.Text at 0x7fe8a5c51a90>"
]
},
"execution_count": 33,
"metadata": {},
"output_type": "execute_result"
},
{
"data": {
"image/svg+xml": [
"<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?>\n",
"<!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\"\n",
" \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\">\n",
"<!-- Created with matplotlib (http://matplotlib.org/) -->\n",
"<svg height=\"161pt\" version=\"1.1\" viewBox=\"0 0 228 161\" width=\"228pt\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\n",
" <defs>\n",
" <style type=\"text/css\">\n",
"*{stroke-linecap:butt;stroke-linejoin:round;}\n",
" </style>\n",
" </defs>\n",
" <g id=\"figure_1\">\n",
" <g id=\"patch_1\">\n",
" <path d=\"M 0 161.186703 \n",
"L 228.344064 161.186703 \n",
"L 228.344064 0 \n",
"L 0 0 \n",
"z\n",
"\" style=\"fill:none;\"/>\n",
" </g>\n",
" <g id=\"axes_1\">\n",
" <g id=\"patch_2\">\n",
" <path d=\"M 49.744594 115.92 \n",
"L 217.144594 115.92 \n",
"L 217.144594 7.2 \n",
"L 49.744594 7.2 \n",
"z\n",
"\" style=\"fill:#ffffff;\"/>\n",
" </g>\n",
" <g id=\"matplotlib.axis_1\">\n",
" <g id=\"xtick_1\">\n",
" <g id=\"line2d_1\"/>\n",
" <g id=\"text_1\">\n",
" <!-- 0 -->\n",
" <defs>\n",
" <path d=\"M 4.15625 35.296875 \n",
"Q 4.15625 48 6.765625 55.734375 \n",
"Q 9.375 63.484375 14.515625 67.671875 \n",
"Q 19.671875 71.875 27.484375 71.875 \n",
"Q 33.25 71.875 37.59375 69.546875 \n",
"Q 41.9375 67.234375 44.765625 62.859375 \n",
"Q 47.609375 58.5 49.21875 52.21875 \n",
"Q 50.828125 45.953125 50.828125 35.296875 \n",
"Q 50.828125 22.703125 48.234375 14.96875 \n",
"Q 45.65625 7.234375 40.5 3 \n",
"Q 35.359375 -1.21875 27.484375 -1.21875 \n",
"Q 17.140625 -1.21875 11.234375 6.203125 \n",
"Q 4.15625 15.140625 4.15625 35.296875 \n",
"M 13.1875 35.296875 \n",
"Q 13.1875 17.671875 17.3125 11.828125 \n",
"Q 21.4375 6 27.484375 6 \n",
"Q 33.546875 6 37.671875 11.859375 \n",
"Q 41.796875 17.71875 41.796875 35.296875 \n",
"Q 41.796875 52.984375 37.671875 58.78125 \n",
"Q 33.546875 64.59375 27.390625 64.59375 \n",
"Q 21.34375 64.59375 17.71875 59.46875 \n",
"Q 13.1875 52.9375 13.1875 35.296875 \n",
"\" id=\"ArialMT-30\"/>\n",
" </defs>\n",
" <g style=\"fill:#262626;\" transform=\"translate(53.739075 134.325156)scale(0.13 -0.13)\">\n",
" <use xlink:href=\"#ArialMT-30\"/>\n",
" </g>\n",
" </g>\n",
" </g>\n",
" <g id=\"xtick_2\">\n",
" <g id=\"line2d_2\"/>\n",
" <g id=\"text_2\">\n",
" <!-- 100 -->\n",
" <defs>\n",
" <path d=\"M 37.25 0 \n",
"L 28.46875 0 \n",
"L 28.46875 56 \n",
"Q 25.296875 52.984375 20.140625 49.953125 \n",
"Q 14.984375 46.921875 10.890625 45.40625 \n",
"L 10.890625 53.90625 \n",
"Q 18.265625 57.375 23.78125 62.296875 \n",
"Q 29.296875 67.234375 31.59375 71.875 \n",
"L 37.25 71.875 \n",
"z\n",
"\" id=\"ArialMT-31\"/>\n",
" </defs>\n",
" <g style=\"fill:#262626;\" transform=\"translate(122.983132 134.325156)scale(0.13 -0.13)\">\n",
" <use xlink:href=\"#ArialMT-31\"/>\n",
" <use x=\"55.615234\" xlink:href=\"#ArialMT-30\"/>\n",
" <use x=\"111.230469\" xlink:href=\"#ArialMT-30\"/>\n",
" </g>\n",
" </g>\n",
" </g>\n",
" <g id=\"xtick_3\">\n",
" <g id=\"line2d_3\"/>\n",
" <g id=\"text_3\">\n",
" <!-- 200 -->\n",
" <defs>\n",
" <path d=\"M 50.34375 8.453125 \n",
"L 50.34375 0 \n",
"L 3.03125 0 \n",
"Q 2.9375 3.171875 4.046875 6.109375 \n",
"Q 5.859375 10.9375 9.828125 15.625 \n",
"Q 13.8125 20.3125 21.34375 26.46875 \n",
"Q 33.015625 36.03125 37.109375 41.625 \n",
"Q 41.21875 47.21875 41.21875 52.203125 \n",
"Q 41.21875 57.421875 37.46875 61 \n",
"Q 33.734375 64.59375 27.734375 64.59375 \n",
"Q 21.390625 64.59375 17.578125 60.78125 \n",
"Q 13.765625 56.984375 13.71875 50.25 \n",
"L 4.6875 51.171875 \n",
"Q 5.609375 61.28125 11.65625 66.578125 \n",
"Q 17.71875 71.875 27.9375 71.875 \n",
"Q 38.234375 71.875 44.234375 66.15625 \n",
"Q 50.25 60.453125 50.25 52 \n",
"Q 50.25 47.703125 48.484375 43.546875 \n",
"Q 46.734375 39.40625 42.65625 34.8125 \n",
"Q 38.578125 30.21875 29.109375 22.21875 \n",
"Q 21.1875 15.578125 18.9375 13.203125 \n",
"Q 16.703125 10.84375 15.234375 8.453125 \n",
"z\n",
"\" id=\"ArialMT-32\"/>\n",
" </defs>\n",
" <g style=\"fill:#262626;\" transform=\"translate(199.456407 134.325156)scale(0.13 -0.13)\">\n",
" <use xlink:href=\"#ArialMT-32\"/>\n",
" <use x=\"55.615234\" xlink:href=\"#ArialMT-30\"/>\n",
" <use x=\"111.230469\" xlink:href=\"#ArialMT-30\"/>\n",
" </g>\n",
" </g>\n",
" </g>\n",
" <g id=\"text_4\">\n",
" <!-- loop index -->\n",
" <defs>\n",
" <path d=\"M 6.390625 0 \n",
"L 6.390625 71.578125 \n",
"L 15.1875 71.578125 \n",
"L 15.1875 0 \n",
"z\n",
"\" id=\"ArialMT-6c\"/>\n",
" <path d=\"M 3.328125 25.921875 \n",
"Q 3.328125 40.328125 11.328125 47.265625 \n",
"Q 18.015625 53.03125 27.640625 53.03125 \n",
"Q 38.328125 53.03125 45.109375 46.015625 \n",
"Q 51.90625 39.015625 51.90625 26.65625 \n",
"Q 51.90625 16.65625 48.90625 10.90625 \n",
"Q 45.90625 5.171875 40.15625 2 \n",
"Q 34.421875 -1.171875 27.640625 -1.171875 \n",
"Q 16.75 -1.171875 10.03125 5.8125 \n",
"Q 3.328125 12.796875 3.328125 25.921875 \n",
"M 12.359375 25.921875 \n",
"Q 12.359375 15.96875 16.703125 11.015625 \n",
"Q 21.046875 6.0625 27.640625 6.0625 \n",
"Q 34.1875 6.0625 38.53125 11.03125 \n",
"Q 42.875 16.015625 42.875 26.21875 \n",
"Q 42.875 35.84375 38.5 40.796875 \n",
"Q 34.125 45.75 27.640625 45.75 \n",
"Q 21.046875 45.75 16.703125 40.8125 \n",
"Q 12.359375 35.890625 12.359375 25.921875 \n",
"\" id=\"ArialMT-6f\"/>\n",
" <path d=\"M 6.59375 -19.875 \n",
"L 6.59375 51.859375 \n",
"L 14.59375 51.859375 \n",
"L 14.59375 45.125 \n",
"Q 17.4375 49.078125 21 51.046875 \n",
"Q 24.5625 53.03125 29.640625 53.03125 \n",
"Q 36.28125 53.03125 41.359375 49.609375 \n",
"Q 46.4375 46.1875 49.015625 39.953125 \n",
"Q 51.609375 33.734375 51.609375 26.3125 \n",
"Q 51.609375 18.359375 48.75 11.984375 \n",
"Q 45.90625 5.609375 40.453125 2.21875 \n",
"Q 35.015625 -1.171875 29 -1.171875 \n",
"Q 24.609375 -1.171875 21.109375 0.6875 \n",
"Q 17.625 2.546875 15.375 5.375 \n",
"L 15.375 -19.875 \n",
"z\n",
"M 14.546875 25.640625 \n",
"Q 14.546875 15.625 18.59375 10.84375 \n",
"Q 22.65625 6.0625 28.421875 6.0625 \n",
"Q 34.28125 6.0625 38.453125 11.015625 \n",
"Q 42.625 15.96875 42.625 26.375 \n",
"Q 42.625 36.28125 38.546875 41.203125 \n",
"Q 34.46875 46.140625 28.8125 46.140625 \n",
"Q 23.1875 46.140625 18.859375 40.890625 \n",
"Q 14.546875 35.640625 14.546875 25.640625 \n",
"\" id=\"ArialMT-70\"/>\n",
" <path id=\"ArialMT-20\"/>\n",
" <path d=\"M 6.640625 61.46875 \n",
"L 6.640625 71.578125 \n",
"L 15.4375 71.578125 \n",
"L 15.4375 61.46875 \n",
"z\n",
"M 6.640625 0 \n",
"L 6.640625 51.859375 \n",
"L 15.4375 51.859375 \n",
"L 15.4375 0 \n",
"z\n",
"\" id=\"ArialMT-69\"/>\n",
" <path d=\"M 6.59375 0 \n",
"L 6.59375 51.859375 \n",
"L 14.5 51.859375 \n",
"L 14.5 44.484375 \n",
"Q 20.21875 53.03125 31 53.03125 \n",
"Q 35.6875 53.03125 39.625 51.34375 \n",
"Q 43.5625 49.65625 45.515625 46.921875 \n",
"Q 47.46875 44.1875 48.25 40.4375 \n",
"Q 48.734375 37.984375 48.734375 31.890625 \n",
"L 48.734375 0 \n",
"L 39.9375 0 \n",
"L 39.9375 31.546875 \n",
"Q 39.9375 36.921875 38.90625 39.578125 \n",
"Q 37.890625 42.234375 35.28125 43.8125 \n",
"Q 32.671875 45.40625 29.15625 45.40625 \n",
"Q 23.53125 45.40625 19.453125 41.84375 \n",
"Q 15.375 38.28125 15.375 28.328125 \n",
"L 15.375 0 \n",
"z\n",
"\" id=\"ArialMT-6e\"/>\n",
" <path d=\"M 40.234375 0 \n",
"L 40.234375 6.546875 \n",
"Q 35.296875 -1.171875 25.734375 -1.171875 \n",
"Q 19.53125 -1.171875 14.328125 2.25 \n",
"Q 9.125 5.671875 6.265625 11.796875 \n",
"Q 3.421875 17.921875 3.421875 25.875 \n",
"Q 3.421875 33.640625 6 39.96875 \n",
"Q 8.59375 46.296875 13.765625 49.65625 \n",
"Q 18.953125 53.03125 25.34375 53.03125 \n",
"Q 30.03125 53.03125 33.6875 51.046875 \n",
"Q 37.359375 49.078125 39.65625 45.90625 \n",
"L 39.65625 71.578125 \n",
"L 48.390625 71.578125 \n",
"L 48.390625 0 \n",
"z\n",
"M 12.453125 25.875 \n",
"Q 12.453125 15.921875 16.640625 10.984375 \n",
"Q 20.84375 6.0625 26.5625 6.0625 \n",
"Q 32.328125 6.0625 36.34375 10.765625 \n",
"Q 40.375 15.484375 40.375 25.140625 \n",
"Q 40.375 35.796875 36.265625 40.765625 \n",
"Q 32.171875 45.75 26.171875 45.75 \n",
"Q 20.3125 45.75 16.375 40.96875 \n",
"Q 12.453125 36.1875 12.453125 25.875 \n",
"\" id=\"ArialMT-64\"/>\n",
" <path d=\"M 42.09375 16.703125 \n",
"L 51.171875 15.578125 \n",
"Q 49.03125 7.625 43.21875 3.21875 \n",
"Q 37.40625 -1.171875 28.375 -1.171875 \n",
"Q 17 -1.171875 10.328125 5.828125 \n",
"Q 3.65625 12.84375 3.65625 25.484375 \n",
"Q 3.65625 38.578125 10.390625 45.796875 \n",
"Q 17.140625 53.03125 27.875 53.03125 \n",
"Q 38.28125 53.03125 44.875 45.953125 \n",
"Q 51.46875 38.875 51.46875 26.03125 \n",
"Q 51.46875 25.25 51.421875 23.6875 \n",
"L 12.75 23.6875 \n",
"Q 13.234375 15.140625 17.578125 10.59375 \n",
"Q 21.921875 6.0625 28.421875 6.0625 \n",
"Q 33.25 6.0625 36.671875 8.59375 \n",
"Q 40.09375 11.140625 42.09375 16.703125 \n",
"M 13.234375 30.90625 \n",
"L 42.1875 30.90625 \n",
"Q 41.609375 37.453125 38.875 40.71875 \n",
"Q 34.671875 45.796875 27.984375 45.796875 \n",
"Q 21.921875 45.796875 17.796875 41.75 \n",
"Q 13.671875 37.703125 13.234375 30.90625 \n",
"\" id=\"ArialMT-65\"/>\n",
" <path d=\"M 0.734375 0 \n",
"L 19.671875 26.953125 \n",
"L 2.15625 51.859375 \n",
"L 13.140625 51.859375 \n",
"L 21.09375 39.703125 \n",
"Q 23.34375 36.234375 24.703125 33.890625 \n",
"Q 26.859375 37.109375 28.65625 39.59375 \n",
"L 37.40625 51.859375 \n",
"L 47.90625 51.859375 \n",
"L 29.984375 27.4375 \n",
"L 49.265625 0 \n",
"L 38.484375 0 \n",
"L 27.828125 16.109375 \n",
"L 25 20.453125 \n",
"L 11.375 0 \n",
"z\n",
"\" id=\"ArialMT-78\"/>\n",
" </defs>\n",
" <g style=\"fill:#262626;\" transform=\"translate(100.849531 151.144578)scale(0.143 -0.143)\">\n",
" <use xlink:href=\"#ArialMT-6c\"/>\n",
" <use x=\"22.216797\" xlink:href=\"#ArialMT-6f\"/>\n",
" <use x=\"77.832031\" xlink:href=\"#ArialMT-6f\"/>\n",
" <use x=\"133.447266\" xlink:href=\"#ArialMT-70\"/>\n",
" <use x=\"189.0625\" xlink:href=\"#ArialMT-20\"/>\n",
" <use x=\"216.845703\" xlink:href=\"#ArialMT-69\"/>\n",
" <use x=\"239.0625\" xlink:href=\"#ArialMT-6e\"/>\n",
" <use x=\"294.677734\" xlink:href=\"#ArialMT-64\"/>\n",
" <use x=\"350.292969\" xlink:href=\"#ArialMT-65\"/>\n",
" <use x=\"405.908203\" xlink:href=\"#ArialMT-78\"/>\n",
" </g>\n",
" </g>\n",
" </g>\n",
" <g id=\"matplotlib.axis_2\">\n",
" <g id=\"ytick_1\">\n",
" <g id=\"line2d_4\"/>\n",
" <g id=\"text_5\">\n",
" <!-- 0 -->\n",
" <g style=\"fill:#262626;\" transform=\"translate(33.415375 113.68953)scale(0.13 -0.13)\">\n",
" <use xlink:href=\"#ArialMT-30\"/>\n",
" </g>\n",
" </g>\n",
" </g>\n",
" <g id=\"ytick_2\">\n",
" <g id=\"line2d_5\"/>\n",
" <g id=\"text_6\">\n",
" <!-- 2π -->\n",
" <defs>\n",
" <path d=\"M 24.65625 44.734375 \n",
"L 24.65625 0 \n",
"L 15.875 0 \n",
"L 15.875 44.734375 \n",
"L 2.203125 44.734375 \n",
"L 2.203125 51.859375 \n",
"L 66.84375 51.859375 \n",
"L 66.84375 44.734375 \n",
"L 55.03125 44.734375 \n",
"L 55.03125 0 \n",
"L 46.234375 0 \n",
"L 46.234375 44.734375 \n",
"z\n",
"\" id=\"ArialMT-3c0\"/>\n",
" </defs>\n",
" <g style=\"fill:#262626;\" transform=\"translate(24.445375 68.360818)scale(0.13 -0.13)\">\n",
" <use xlink:href=\"#ArialMT-32\"/>\n",
" <use x=\"55.615234\" xlink:href=\"#ArialMT-3c0\"/>\n",
" </g>\n",
" </g>\n",
" </g>\n",
" <g id=\"ytick_3\">\n",
" <g id=\"line2d_6\"/>\n",
" <g id=\"text_7\">\n",
" <!-- 4π -->\n",
" <defs>\n",
" <path d=\"M 32.328125 0 \n",
"L 32.328125 17.140625 \n",
"L 1.265625 17.140625 \n",
"L 1.265625 25.203125 \n",
"L 33.9375 71.578125 \n",
"L 41.109375 71.578125 \n",
"L 41.109375 25.203125 \n",
"L 50.78125 25.203125 \n",
"L 50.78125 17.140625 \n",
"L 41.109375 17.140625 \n",
"L 41.109375 0 \n",
"z\n",
"M 32.328125 25.203125 \n",
"L 32.328125 57.46875 \n",
"L 9.90625 25.203125 \n",
"z\n",
"\" id=\"ArialMT-34\"/>\n",
" </defs>\n",
" <g style=\"fill:#262626;\" transform=\"translate(24.445375 23.032107)scale(0.13 -0.13)\">\n",
" <use xlink:href=\"#ArialMT-34\"/>\n",
" <use x=\"55.615234\" xlink:href=\"#ArialMT-3c0\"/>\n",
" </g>\n",
" </g>\n",
" </g>\n",
" <g id=\"text_8\">\n",
" <!-- loop angle α -->\n",
" <defs>\n",
" <path d=\"M 40.4375 6.390625 \n",
"Q 35.546875 2.25 31.03125 0.53125 \n",
"Q 26.515625 -1.171875 21.34375 -1.171875 \n",
"Q 12.796875 -1.171875 8.203125 3 \n",
"Q 3.609375 7.171875 3.609375 13.671875 \n",
"Q 3.609375 17.484375 5.34375 20.625 \n",
"Q 7.078125 23.78125 9.890625 25.6875 \n",
"Q 12.703125 27.59375 16.21875 28.5625 \n",
"Q 18.796875 29.25 24.03125 29.890625 \n",
"Q 34.671875 31.15625 39.703125 32.90625 \n",
"Q 39.75 34.71875 39.75 35.203125 \n",
"Q 39.75 40.578125 37.25 42.78125 \n",
"Q 33.890625 45.75 27.25 45.75 \n",
"Q 21.046875 45.75 18.09375 43.578125 \n",
"Q 15.140625 41.40625 13.71875 35.890625 \n",
"L 5.125 37.0625 \n",
"Q 6.296875 42.578125 8.984375 45.96875 \n",
"Q 11.671875 49.359375 16.75 51.1875 \n",
"Q 21.828125 53.03125 28.515625 53.03125 \n",
"Q 35.15625 53.03125 39.296875 51.46875 \n",
"Q 43.453125 49.90625 45.40625 47.53125 \n",
"Q 47.359375 45.171875 48.140625 41.546875 \n",
"Q 48.578125 39.3125 48.578125 33.453125 \n",
"L 48.578125 21.734375 \n",
"Q 48.578125 9.46875 49.140625 6.21875 \n",
"Q 49.703125 2.984375 51.375 0 \n",
"L 42.1875 0 \n",
"Q 40.828125 2.734375 40.4375 6.390625 \n",
"M 39.703125 26.03125 \n",
"Q 34.90625 24.078125 25.34375 22.703125 \n",
"Q 19.921875 21.921875 17.671875 20.9375 \n",
"Q 15.4375 19.96875 14.203125 18.09375 \n",
"Q 12.984375 16.21875 12.984375 13.921875 \n",
"Q 12.984375 10.40625 15.640625 8.0625 \n",
"Q 18.3125 5.71875 23.4375 5.71875 \n",
"Q 28.515625 5.71875 32.46875 7.9375 \n",
"Q 36.421875 10.15625 38.28125 14.015625 \n",
"Q 39.703125 17 39.703125 22.796875 \n",
"z\n",
"\" id=\"ArialMT-61\"/>\n",
" <path d=\"M 4.984375 -4.296875 \n",
"L 13.53125 -5.5625 \n",
"Q 14.0625 -9.515625 16.5 -11.328125 \n",
"Q 19.78125 -13.765625 25.4375 -13.765625 \n",
"Q 31.546875 -13.765625 34.859375 -11.328125 \n",
"Q 38.1875 -8.890625 39.359375 -4.5 \n",
"Q 40.046875 -1.8125 39.984375 6.78125 \n",
"Q 34.234375 0 25.640625 0 \n",
"Q 14.9375 0 9.078125 7.71875 \n",
"Q 3.21875 15.4375 3.21875 26.21875 \n",
"Q 3.21875 33.640625 5.90625 39.90625 \n",
"Q 8.59375 46.1875 13.6875 49.609375 \n",
"Q 18.796875 53.03125 25.6875 53.03125 \n",
"Q 34.859375 53.03125 40.828125 45.609375 \n",
"L 40.828125 51.859375 \n",
"L 48.921875 51.859375 \n",
"L 48.921875 7.03125 \n",
"Q 48.921875 -5.078125 46.453125 -10.125 \n",
"Q 44 -15.1875 38.640625 -18.109375 \n",
"Q 33.296875 -21.046875 25.484375 -21.046875 \n",
"Q 16.21875 -21.046875 10.5 -16.875 \n",
"Q 4.78125 -12.703125 4.984375 -4.296875 \n",
"M 12.25 26.859375 \n",
"Q 12.25 16.65625 16.296875 11.96875 \n",
"Q 20.359375 7.28125 26.46875 7.28125 \n",
"Q 32.515625 7.28125 36.609375 11.9375 \n",
"Q 40.71875 16.609375 40.71875 26.5625 \n",
"Q 40.71875 36.078125 36.5 40.90625 \n",
"Q 32.28125 45.75 26.3125 45.75 \n",
"Q 20.453125 45.75 16.34375 40.984375 \n",
"Q 12.25 36.234375 12.25 26.859375 \n",
"\" id=\"ArialMT-67\"/>\n",
" <path d=\"M 45.0625 51.859375 \n",
"L 54.046875 51.859375 \n",
"Q 50.640625 41.109375 47.75 25.921875 \n",
"Q 51.171875 7.078125 54.046875 0 \n",
"L 45.3125 0 \n",
"Q 43.21875 4.890625 42.140625 9.46875 \n",
"Q 38.09375 -1.171875 25.203125 -1.171875 \n",
"Q 15.4375 -1.171875 9.46875 6.15625 \n",
"Q 3.515625 13.484375 3.515625 26.03125 \n",
"Q 3.515625 38.921875 9.5 45.96875 \n",
"Q 15.484375 53.03125 25.34375 53.03125 \n",
"Q 31.453125 53.03125 35.296875 50.5625 \n",
"Q 39.15625 48.09375 42.484375 43.0625 \n",
"Q 42.828125 44.78125 45.0625 51.859375 \n",
"M 26.8125 45.75 \n",
"Q 20.515625 45.75 16.84375 40.671875 \n",
"Q 13.1875 35.59375 13.1875 26.03125 \n",
"Q 13.1875 16.703125 16.65625 11.375 \n",
"Q 20.125 6.0625 26.3125 6.0625 \n",
"Q 32.375 6.0625 36.421875 11.296875 \n",
"Q 40.484375 16.546875 40.484375 26.421875 \n",
"Q 40.484375 35.984375 36.6875 40.859375 \n",
"Q 32.90625 45.75 26.8125 45.75 \n",
"\" id=\"ArialMT-3b1\"/>\n",
" </defs>\n",
" <g style=\"fill:#262626;\" transform=\"translate(17.435672 100.676086)rotate(-90)scale(0.143 -0.143)\">\n",
" <use xlink:href=\"#ArialMT-6c\"/>\n",
" <use x=\"22.216797\" xlink:href=\"#ArialMT-6f\"/>\n",
" <use x=\"77.832031\" xlink:href=\"#ArialMT-6f\"/>\n",
" <use x=\"133.447266\" xlink:href=\"#ArialMT-70\"/>\n",
" <use x=\"189.0625\" xlink:href=\"#ArialMT-20\"/>\n",
" <use x=\"216.845703\" xlink:href=\"#ArialMT-61\"/>\n",
" <use x=\"272.460938\" xlink:href=\"#ArialMT-6e\"/>\n",
" <use x=\"328.076172\" xlink:href=\"#ArialMT-67\"/>\n",
" <use x=\"383.691406\" xlink:href=\"#ArialMT-6c\"/>\n",
" <use x=\"405.908203\" xlink:href=\"#ArialMT-65\"/>\n",
" <use x=\"461.523438\" xlink:href=\"#ArialMT-20\"/>\n",
" <use x=\"489.306641\" xlink:href=\"#ArialMT-3b1\"/>\n",
" </g>\n",
" </g>\n",
" </g>\n",
" <g id=\"line2d_7\">\n",
" <path clip-path=\"url(#p6978e90c3e)\" d=\"M 57.353685 109.036951 \n",
"L 58.118417 109.595382 \n",
"L 58.88315 110.978182 \n",
"L 59.647883 104.664237 \n",
"L 60.412616 108.626055 \n",
"L 61.177348 106.950822 \n",
"L 61.942081 102.434763 \n",
"L 62.706814 103.092817 \n",
"L 63.471547 102.884566 \n",
"L 64.236279 105.239211 \n",
"L 65.001012 108.57143 \n",
"L 65.765745 106.36523 \n",
"L 66.530478 105.287623 \n",
"L 67.29521 100.725379 \n",
"L 68.059943 92.634149 \n",
"L 68.824676 90.215834 \n",
"L 69.589409 85.025518 \n",
"L 70.354141 86.969703 \n",
"L 71.118874 84.552349 \n",
"L 71.883607 86.398754 \n",
"L 72.64834 89.301067 \n",
"L 73.413073 83.952956 \n",
"L 74.177805 86.732338 \n",
"L 74.942538 79.751213 \n",
"L 76.472004 84.884498 \n",
"L 77.236736 91.852531 \n",
"L 78.001469 92.927705 \n",
"L 78.766202 89.584892 \n",
"L 79.530935 88.08312 \n",
"L 80.295667 90.170187 \n",
"L 81.0604 91.717308 \n",
"L 81.825133 97.498279 \n",
"L 82.589866 97.111263 \n",
"L 83.354598 99.905391 \n",
"L 84.119331 98.868383 \n",
"L 84.884064 93.995798 \n",
"L 85.648797 94.274132 \n",
"L 86.413529 96.758744 \n",
"L 87.178262 94.724895 \n",
"L 87.942995 97.193739 \n",
"L 89.47246 90.706776 \n",
"L 91.766659 98.160923 \n",
"L 92.531391 90.714113 \n",
"L 93.296124 99.099067 \n",
"L 94.82559 91.292715 \n",
"L 95.590322 94.508107 \n",
"L 96.355055 95.661585 \n",
"L 97.119788 90.669334 \n",
"L 97.884521 93.610827 \n",
"L 98.649253 91.91794 \n",
"L 99.413986 88.837404 \n",
"L 100.943452 90.976446 \n",
"L 101.708184 95.33084 \n",
"L 102.472917 90.316482 \n",
"L 103.23765 87.017546 \n",
"L 104.002383 89.814838 \n",
"L 106.296581 77.201776 \n",
"L 107.061314 76.586464 \n",
"L 107.826046 75.284033 \n",
"L 109.355512 79.51474 \n",
"L 110.120245 76.650831 \n",
"L 111.64971 78.521891 \n",
"L 112.414443 78.978897 \n",
"L 113.179176 76.257191 \n",
"L 113.943909 72.184495 \n",
"L 115.473374 58.963378 \n",
"L 116.238107 68.92088 \n",
"L 117.00284 66.749344 \n",
"L 117.767572 70.534186 \n",
"L 118.532305 67.078608 \n",
"L 119.297038 67.903087 \n",
"L 120.061771 64.673871 \n",
"L 120.826503 63.836258 \n",
"L 121.591236 59.985319 \n",
"L 122.355969 61.73857 \n",
"L 123.120702 64.064397 \n",
"L 123.885434 62.202097 \n",
"L 125.4149 64.030554 \n",
"L 126.179633 66.038023 \n",
"L 126.944365 67.482371 \n",
"L 127.709098 70.363335 \n",
"L 128.473831 66.162805 \n",
"L 129.238564 66.9374 \n",
"L 130.003296 69.679882 \n",
"L 130.768029 70.437345 \n",
"L 131.532762 68.17751 \n",
"L 132.297495 72.453073 \n",
"L 133.062227 62.286767 \n",
"L 133.82696 59.41786 \n",
"L 134.591693 64.383369 \n",
"L 135.356426 62.950666 \n",
"L 136.121158 58.03437 \n",
"L 136.885891 57.454985 \n",
"L 137.650624 58.151595 \n",
"L 138.415357 57.277852 \n",
"L 139.180089 53.897307 \n",
"L 139.944822 54.988963 \n",
"L 140.709555 49.642401 \n",
"L 141.474288 48.796287 \n",
"L 142.23902 48.515984 \n",
"L 143.003753 54.789221 \n",
"L 143.768486 49.930813 \n",
"L 144.533219 47.806731 \n",
"L 145.297951 43.635293 \n",
"L 146.062684 48.677266 \n",
"L 146.827417 52.260039 \n",
"L 147.59215 48.299491 \n",
"L 148.356882 50.417733 \n",
"L 149.121615 58.138474 \n",
"L 149.886348 49.406911 \n",
"L 150.651081 46.408918 \n",
"L 152.180546 51.894762 \n",
"L 152.945279 51.509752 \n",
"L 153.710012 49.628749 \n",
"L 154.474745 53.926211 \n",
"L 155.239477 50.674404 \n",
"L 156.00421 51.559413 \n",
"L 156.768943 46.944557 \n",
"L 157.533676 46.664284 \n",
"L 158.298408 47.631009 \n",
"L 159.063141 45.930186 \n",
"L 159.827874 46.674656 \n",
"L 160.592607 40.011723 \n",
"L 161.357339 45.055829 \n",
"L 162.122072 46.253634 \n",
"L 162.886805 42.110495 \n",
"L 163.651538 42.76614 \n",
"L 164.41627 40.486426 \n",
"L 165.181003 41.665215 \n",
"L 165.945736 34.708153 \n",
"L 166.710469 35.231382 \n",
"L 167.475201 39.234364 \n",
"L 168.239934 42.275276 \n",
"L 169.004667 39.421584 \n",
"L 169.7694 38.930009 \n",
"L 170.534132 35.849662 \n",
"L 171.298865 33.729071 \n",
"L 172.063598 34.138015 \n",
"L 172.828331 34.755351 \n",
"L 173.593063 23.632558 \n",
"L 174.357796 19.677578 \n",
"L 175.122529 16.867458 \n",
"L 175.887262 24.264627 \n",
"L 176.651994 23.296634 \n",
"L 178.18146 25.462351 \n",
"L 178.946193 27.534079 \n",
"L 179.710925 30.017849 \n",
"L 180.475658 35.3343 \n",
"L 181.240391 34.304086 \n",
"L 182.005124 31.07489 \n",
"L 182.769856 32.780892 \n",
"L 183.534589 31.397979 \n",
"L 184.299322 31.534864 \n",
"L 185.064055 25.919438 \n",
"L 185.828787 29.288987 \n",
"L 186.59352 26.251375 \n",
"L 187.358253 27.159908 \n",
"L 188.887718 23.591698 \n",
"L 189.652451 26.633561 \n",
"L 190.417184 27.821946 \n",
"L 191.181917 21.566671 \n",
"L 191.946649 18.534913 \n",
"L 192.711382 21.620602 \n",
"L 193.476115 22.951989 \n",
"L 194.240848 16.392393 \n",
"L 195.005581 16.139719 \n",
"L 195.770313 14.197077 \n",
"L 196.535046 12.721272 \n",
"L 197.299779 15.534597 \n",
"L 198.064512 19.171687 \n",
"L 198.829244 17.441026 \n",
"L 199.593977 16.812061 \n",
"L 200.35871 18.041315 \n",
"L 201.123443 17.31444 \n",
"L 201.888175 20.304353 \n",
"L 202.652908 24.790503 \n",
"L 203.417641 26.714528 \n",
"L 204.182374 23.15589 \n",
"L 204.947106 16.978918 \n",
"L 205.711839 19.307985 \n",
"L 206.476572 12.141818 \n",
"L 207.241305 19.343387 \n",
"L 208.006037 14.317321 \n",
"L 208.77077 13.905846 \n",
"L 209.535503 13.354585 \n",
"L 209.535503 13.354585 \n",
"\" style=\"fill:none;stroke:#4c72b0;stroke-linecap:round;stroke-width:2.275;\"/>\n",
" </g>\n",
" <g id=\"patch_3\">\n",
" <path d=\"M 49.744594 115.92 \n",
"L 49.744594 7.2 \n",
"\" style=\"fill:none;stroke:#262626;stroke-linecap:square;stroke-linejoin:miter;stroke-width:1.25;\"/>\n",
" </g>\n",
" <g id=\"patch_4\">\n",
" <path d=\"M 217.144594 115.92 \n",
"L 217.144594 7.2 \n",
"\" style=\"fill:none;stroke:#262626;stroke-linecap:square;stroke-linejoin:miter;stroke-width:1.25;\"/>\n",
" </g>\n",
" <g id=\"patch_5\">\n",
" <path d=\"M 49.744594 115.92 \n",
"L 217.144594 115.92 \n",
"\" style=\"fill:none;stroke:#262626;stroke-linecap:square;stroke-linejoin:miter;stroke-width:1.25;\"/>\n",
" </g>\n",
" <g id=\"patch_6\">\n",
" <path d=\"M 49.744594 7.2 \n",
"L 217.144594 7.2 \n",
"\" style=\"fill:none;stroke:#262626;stroke-linecap:square;stroke-linejoin:miter;stroke-width:1.25;\"/>\n",
" </g>\n",
" </g>\n",
" </g>\n",
" <defs>\n",
" <clipPath id=\"p6978e90c3e\">\n",
" <rect height=\"108.72\" width=\"167.4\" x=\"49.744594\" y=\"7.2\"/>\n",
" </clipPath>\n",
" </defs>\n",
"</svg>\n"
],
"text/plain": [
"<matplotlib.figure.Figure at 0x7fe8a5828080>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"%matplotlib inline\n",
"plt.figure(figsize=(3,2))\n",
"angles = np.array(simulate_trending_ou(\n",
" N=200, \n",
" ang_rw_stat_std=-1.675,\n",
" ang_rw_return_scale=1.125,\n",
" ang_loop_spread=-1.3,\n",
" ang_drift_step=-1.975,\n",
" ))\n",
"plt.plot(\n",
" angles\n",
")\n",
"plt.yticks(np.arange(0,3)*2*np.pi, [('{}π'.format(i) if i>0 else '0') for i in 2*np.arange(0,4) ] )\n",
"plt.ylabel('loop angle α')\n",
"plt.xlabel('loop index')\n",
"\n",
" \n",
"#plt.savefig(f'{FIG_FOLDER}/coarse_grained_OURW_example_loop_angles.pdf',\n",
"# bbox_inches='tight')"
]
},
{
"cell_type": "code",
"execution_count": 61,
"metadata": {
"ExecuteTime": {
"end_time": "2017-06-21T17:00:14.037764Z",
"start_time": "2017-06-21T17:00:13.808296Z"
}
},
"outputs": [
{
"data": {
"image/png": "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\n",
"text/plain": [
"<matplotlib.figure.Figure at 0x7f341f2874e0>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"%matplotlib inline\n",
"rw_step = 0.1*np.pi\n",
"plt.figure(figsize=(3,2))\n",
"angles = np.pi+ np.cumsum(np.random.normal(scale=rw_step,size=200))\n",
"plt.plot(\n",
" angles\n",
")\n",
"plt.yticks(np.arange(0,3)*2*np.pi, [('{}π'.format(i) if i>0 else '0') for i in 2*np.arange(0,4) ] )\n",
"plt.ylabel('loop angle α')\n",
"plt.xlabel('loop index')\n",
"plt.ylim(0,2*np.pi)\n",
"\n",
" \n",
"#plt.savefig(f'{FIG_FOLDER}/coarse_grained_RW_example_loop_angles.pdf',\n",
"# bbox_inches='tight')"
]
},
{
"cell_type": "code",
"execution_count": 66,
"metadata": {
"ExecuteTime": {
"end_time": "2017-06-21T17:00:41.732765Z",
"start_time": "2017-06-21T17:00:41.501757Z"
}
},
"outputs": [
{
"data": {
"image/png": "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\nLmg5ctQB/wd2DZkkjKwPQQAAAABJRU5ErkJggg==\n",
"text/plain": [
"<matplotlib.figure.Figure at 0x7f341f396b70>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"%matplotlib inline\n",
"plt.figure(figsize=(3,2))\n",
"angles = np.array(np.random.random(200)*2*np.pi)\n",
"plt.plot(\n",
" angles\n",
")\n",
"plt.yticks(np.arange(0,2)*2*np.pi, [('{}π'.format(i) if i>0 else '0') for i in 2*np.arange(0,4) ] )\n",
"plt.ylabel('loop angle α')\n",
"plt.xlabel('loop index')\n",
"plt.ylim(0,2*np.pi)\n",
"\n",
" \n",
"#plt.savefig(f'{FIG_FOLDER}/coarse_grained_random_example_loop_angles.pdf',\n",
"# bbox_inches='tight')"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": true
},
"outputs": [],
"source": [
"%matplotlib inline\n",
"plt.figure(figsize=(4,2))\n",
"angles = np.array(simulate_trending_ou(200,-1.675, 1.125, -1.3, -1.975))\n",
"full_circle_points = np.r_[0, 1+np.where(angles[1:] // (2 * np.pi) != angles[:-1] // (2 * np.pi))[0], len(angles)]\n",
"for i,j in zip(full_circle_points[:-1], full_circle_points[1:]):\n",
" plt.plot(\n",
" np.arange(i,j), \n",
" np.mod(angles[i:j], 2*np.pi)\n",
" )\n",
"plt.yticks(np.arange(0,3)*2*np.pi, [('{}π'.format(i) if i>0 else '0') for i in 2*np.arange(0,4) ] )\n",
"plt.ylabel('loop angle α')\n",
"plt.ylim(0,2*np.pi)\n",
"plt.show()"
]
},
{
"cell_type": "code",
"execution_count": 68,
"metadata": {
"ExecuteTime": {
"end_time": "2017-06-16T21:31:34.585522Z",
"start_time": "2017-06-16T21:31:34.579515Z"
}
},
"outputs": [
{
"data": {
"text/plain": [
"array([51])"
]
},
"execution_count": 68,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"np.arange(i,j)"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {
"collapsed": true
},
"outputs": [],
"source": []
},
{
"cell_type": "code",
"execution_count": 65,
"metadata": {
"ExecuteTime": {
"end_time": "2017-06-16T21:30:48.391981Z",
"start_time": "2017-06-16T21:30:48.385697Z"
}
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"[ 4 7 13 17 30 52 53 55 56 62 64 66 67 69 70 72 80 82\n",
" 91 102 104 117 118 119 120 135 136 138 146 148 150 157 165 171 182 193\n",
" 195 196]\n"
]
}
],
"source": [
"print(full_circle_points)"
]
},
{
"cell_type": "code",
"execution_count": 403,
"metadata": {
"ExecuteTime": {
"end_time": "2017-05-26T17:59:47.925480",
"start_time": "2017-05-26T17:59:47.909067"
},
"collapsed": true
},
"outputs": [],
"source": [
"# MIN_LOG10_S = -1\n",
"# MAX_LOG10_S = 4\n",
"\n",
"# Z_LOOP_WIDTH = 50\n",
"# Z_LOOP_STEP = 1\n",
"# PERIOD_LOOPS = 100\n",
"\n",
"# ANG_RW_STAT_STD = 2 * np.pi / 3\n",
"# ANG_RW_RETURN_COEFF = 1.0/30\n",
"\n",
"# ANG_DRIFT_STEP = 2 * np.pi / PERIOD_LOOPS\n",
"# ANG_RW_STEP = ANG_RW_STAT_STD * np.sqrt(ANG_RW_RETURN_COEFF)"
]
}
],
"metadata": {
"kernelspec": {
"display_name": "Python 3",
"language": "python",
"name": "python3"
},
"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.7.4"
},
"nav_menu": {},
"toc": {
"navigate_menu": true,
"number_sections": true,
"sideBar": false,
"threshold": 6,
"toc_cell": true,
"toc_section_display": "block",
"toc_window_display": false
},
"widgets": {
"application/vnd.jupyter.widget-state+json": {
"state": {
"0028938bf9274630b2be4f96f6d7a179": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_0b8e28c4b838482eba03b1a36bafcccf",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.8
}
},
"0141106ca4f04064b31214a63ff7c731": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"035df7dee11d44239650c2334a91f266": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"04858ed933814f72b32a60f85ffa33e2": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"068603b731574d9b8a8106c52e6ed69b": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"06c24fbc989d42c196a83bb16dcda0fb": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_6020a1fbafe241c2a545c81111ab9433",
"msg_throttle": 1
}
},
"06f22cb3d88744c68d04d823bb7e76c6": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"0861a7b05dd0432487206c9d369552b9": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"094bfea00c15424eb84b2ac664a2b9ac": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_775e92a257214727ae771a419a51ce20",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.8
}
},
"099cd8b10d634c37b702f96017163856": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"099e107e563c405086480ed77d9cc470": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_23c791c73f5a4f5ab461db671d5c3a99",
"msg_throttle": 1
}
},
"0af2e49a660347d2a6a39939ea33502c": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"0b8e28c4b838482eba03b1a36bafcccf": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"0caf747a1be24887900da5f240d51c63": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"0cc9f0c7a45a46f390b15f21de07719e": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"0cdbc7bb1b074462af0f9bf6b2b0be4a": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"0d0ce29ea138427abfadb0145dfa4dde": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_step / 2 Pi)",
"layout": "IPY_MODEL_67b2b7b99f594aa886e8bc49bd5dbd0b",
"max": 0,
"min": -4,
"step": 0.1,
"value": -2.4
}
},
"0d2e4f89430a4c43950a39cddf40310f": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_stat_std / 2 Pi)",
"layout": "IPY_MODEL_21514e5dd5e543fb8ffdefb4186492cc",
"max": 0,
"min": -2,
"step": 0.1,
"value": -0.2
}
},
"0d38e29d261447409013f8feca841b7e": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "frequency",
"layout": "IPY_MODEL_2aa690a3d47543afaca8845f40fc8030",
"min": 1,
"step": 0.1,
"value": 32.6
}
},
"0d4785cad089443f99a06973f46ae5f1": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"0dd5e60627c2438ba207c05e2cef4cad": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "frequency",
"layout": "IPY_MODEL_1e4b258ee6b7415ba4adb99e92da2e1b",
"min": 1,
"step": 0.1,
"value": 1
}
},
"0e3036fb1c47488f9c09f5a3d727b083": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_bc21378ef6344b0ab4d2cca323cb7845",
"IPY_MODEL_805a95817c1d4d7998e4f3a6924b8bd9",
"IPY_MODEL_4e7ab413653d497ead18fd1fa6ed863a",
"IPY_MODEL_60e5bfb8fa994a82bc28f015989dbe8b"
],
"layout": "IPY_MODEL_a2f5f020b37749398732dfd88162a963"
}
},
"0eca72edf5144ae194b3a332df8153d4": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"100de71247a84a5c81d87e14d4b1451c": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"12071858820846b8ac928c6a69fd039b": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "step",
"layout": "IPY_MODEL_914e18e2cd8345afa8c5a8c1b876b745",
"min": 1,
"step": 0.1,
"value": 1
}
},
"125a96ea39b048908210afdd050219e8": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_ad615203d361469391c55802ec23c04a",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.1
}
},
"12a0daf40a35416f878eeac418c580e1": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_04858ed933814f72b32a60f85ffa33e2",
"msg_throttle": 1
}
},
"12abc4804b4449b99444d1ca5f0407bf": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_drift_step / 2 Pi)",
"layout": "IPY_MODEL_3c8f977577ca47e39c91a2a98582d8e1",
"max": 0,
"min": -4,
"step": 0.1,
"value": -2.7
}
},
"135c95a45d104a59be769842b4e552b3": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"1364fc3ed238470f92a073154a5ac407": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "frequency",
"layout": "IPY_MODEL_e8d7a469ac1c45379dbf4d4889e8b7d1",
"min": 1,
"step": 0.1,
"value": 27.3
}
},
"141066412fa84d54a1f1d176903c8993": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_drift_step / 2 Pi)",
"layout": "IPY_MODEL_c9a07cc4933549eda9be2d22183f643f",
"max": 0,
"min": -4,
"step": 0.1,
"value": -1.9
}
},
"141cc43a369448c7a473e5888c105781": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_drift_step / 2 Pi)",
"layout": "IPY_MODEL_2499afc725b1499782b73b88ea3a4429",
"max": 0,
"min": -4,
"step": 0.1,
"value": -1.9
}
},
"145ea83356504485ba372a6ee6163041": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_drift_step / 2 Pi)",
"layout": "IPY_MODEL_1dc3e8bcfc31485daac2e89b1ac48270",
"max": 0,
"min": -4,
"step": 0.1,
"value": -1.9
}
},
"15288b1209f94538864d2cdc360d6f4e": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"15dcd8d6a72e4280812645441c12b7ff": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_889d7bcb450344d69a22a7626faea3f7",
"IPY_MODEL_ac54fb63beaa48b99d936ea7707c574f",
"IPY_MODEL_d1e03fba61ba4396a3b511d5b6f3d4b9",
"IPY_MODEL_6ce75422be0b44a58c8909cca8c63408",
"IPY_MODEL_2638cb4a3fc942a185609c26e21d8109"
],
"layout": "IPY_MODEL_682fd0d07e4847958ab8abf70675a77d"
}
},
"164e0e6a62bb44c9b036745e383c0ab6": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_a7a7ba5d6fe7458baf31f0ef3b6ff0fc",
"msg_throttle": 1
}
},
"16756cbfb45f4ac98126ecca03c986cb": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"169c29e4a6ad440f9c0db050068ee162": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_cc1b3be91a8745698faad6323efaa88a",
"msg_throttle": 1
}
},
"16f63a3c902a4e01a457f3565b9f5722": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_e5b153ede0854e859d658519fe6587bb",
"max": 4,
"min": -4,
"step": 0.1,
"value": 3.2
}
},
"1714671da00a4aa49be854fd66569e74": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"1759230fce0b4c1eb76c4826cade5c96": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_5b9c34dc70e94e8d9b081f8809c6aebe",
"max": 4,
"min": -4,
"step": 0.1,
"value": 0.9
}
},
"1794d119c7c74dc4850d5949103508ae": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_c134611300144961a6c8a0ad2974700f",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.9
}
},
"17eec1d904574af8854ec4db08098b56": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"190053f49f964483b0076bab95a9cf9b": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_da32a472292a4c55b7073dc3ce0cdaf7",
"IPY_MODEL_532dd0f152fb4931a91bd4d8abe991fa"
],
"layout": "IPY_MODEL_e4a682743b2b4d639efdc20dc5dd2f72"
}
},
"1953753e0cda4911af9e3ebb235cb2c5": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_1759230fce0b4c1eb76c4826cade5c96",
"IPY_MODEL_29a0f129515145358bfddfb3d26881a6"
],
"layout": "IPY_MODEL_38eea3699f764ee3ab1018c1b82393c0"
}
},
"195beb5ac3e9475a94918277941a9eb9": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"1971fbd9b20b4c328c6cf63fcaf6f9ef": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "step",
"layout": "IPY_MODEL_e909d8b60de2454eac5bbc14507f463f",
"min": 1,
"step": 0.1,
"value": 1
}
},
"19d4978945fd4b3ba880a4dcaea262b9": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_56c3ec700edc4a0e934137ca688692b5",
"msg_throttle": 1
}
},
"1a13a51dcce343f181beb95630d2b11d": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_1714671da00a4aa49be854fd66569e74",
"msg_throttle": 1
}
},
"1af8cfaf92e349b6b3664933c3f31fcb": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_25f0d73319454e42bc26079412c403c3",
"msg_throttle": 1
}
},
"1b44c33957274611999eb368fd061e33": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"1b5e853b972b4ec59d8229cdd53ae000": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"1d21883f4a694a5d8cb39b1fd5cb7aa1": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_afdfda0ccb0d4aad8f3f508feba9dd46",
"msg_throttle": 1
}
},
"1d6da6ad46fd4d029e04612511aeb58f": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"1dc3e8bcfc31485daac2e89b1ac48270": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"1e4b258ee6b7415ba4adb99e92da2e1b": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"1e637ca8098d4f05a131d30830f4bc82": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"1e71182ff4554ca6a6af38b625185251": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"1ed8d813d46d48778ea8157b8beea818": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"1ef640b29e3541b19540a2b49507a91f": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"1f327e2205e34b66bbaf88698f80cbc4": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"1f987affbd7a49be9b929dbcff087d42": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_7ff310f6054e445ea6d2c57048cc2210",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.7
}
},
"1fcea8e6d31a4ce18b291cbc85601e72": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_drift_step / 2 Pi)",
"layout": "IPY_MODEL_78daf3b2616046c9b1d014725b25a9b2",
"max": 0,
"min": -4,
"step": 0.1,
"value": -1.9
}
},
"20197775b6484781bd48f5e844dfee34": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"21514e5dd5e543fb8ffdefb4186492cc": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"21e12812b4124176ad76114324a60cc2": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"237c075ba3e6424f85139789f4bbc755": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_a683a2a6b6c749ae8fc8d6f8ca0415db",
"max": 4,
"min": -4,
"step": 0.1,
"value": -0.1
}
},
"23c791c73f5a4f5ab461db671d5c3a99": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"23da4f02dde241e488056010f33d7bdd": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_099cd8b10d634c37b702f96017163856",
"msg_throttle": 1
}
},
"23ee64584a3345b9aa6fa50e8c9c438d": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"240a3df57f4e40da92bfb30eb4862652": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_7a36cf973199455d8ff0569ae7ea2d7c",
"msg_throttle": 1
}
},
"243ba72e14c04c049f23e91ae2f36df5": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"2499afc725b1499782b73b88ea3a4429": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"258720b2eec34245bb145cb3c88cad0a": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"25f0d73319454e42bc26079412c403c3": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"2638cb4a3fc942a185609c26e21d8109": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_0cc9f0c7a45a46f390b15f21de07719e",
"msg_throttle": 1
}
},
"26df2d166fa54400af01574728033670": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"26f4976a63824b4395a3a7ac4ec27fc3": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_81f1d27061194bbfafabbb760775d70b",
"msg_throttle": 1
}
},
"27df4103a9e747edaf06b89dc4031396": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"27f5f9f8d1bf44f6a57ec1bbf4b1e738": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_drift_step / 2 Pi)",
"layout": "IPY_MODEL_627b33bc22344dc0b4b1498203a8fc8e",
"max": 0,
"min": -4,
"step": 0.1,
"value": -1.5
}
},
"28faf62d57a94626868424e572c992e5": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_0dd5e60627c2438ba207c05e2cef4cad",
"IPY_MODEL_12071858820846b8ac928c6a69fd039b",
"IPY_MODEL_e614cd2f612d4461980ba57ee4b18341"
],
"layout": "IPY_MODEL_c2371eca38304f1e9ea2a41831e67c00"
}
},
"29571c2b401248779c99079647d25312": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"29a0f129515145358bfddfb3d26881a6": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_f652c029548a4da78ad261b5b92607fe",
"msg_throttle": 1
}
},
"2a020714d3654d308de4a7b5a605030a": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_663e6bcabd084e29b7dfd5f551059c9a",
"IPY_MODEL_fced36bf9d74432dbd46013cee811cdc"
],
"layout": "IPY_MODEL_4c8ef909863742d987a49ab2e958334f"
}
},
"2a743e08097f40c8a5ff610966f3f060": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_0028938bf9274630b2be4f96f6d7a179",
"IPY_MODEL_5f63a0eca48b4eaa8a2861adf65da417",
"IPY_MODEL_ad4f70d9557e467b8428730d4756d5a6",
"IPY_MODEL_12abc4804b4449b99444d1ca5f0407bf",
"IPY_MODEL_2d691177fb18471088e59f17ec84c665"
],
"layout": "IPY_MODEL_c52b5841517b45668b0e76ad3c5fb3e8"
}
},
"2a78d8dd9a6145428586366b89b98d06": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_da5a239751a44c288f0f6c179f02b404",
"msg_throttle": 1
}
},
"2aa178d90dd64e1f8891ed8e3e0f7afe": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"2aa690a3d47543afaca8845f40fc8030": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"2c6d3b76ec1f4ece87df89886ae72e1a": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_step / 2 Pi)",
"layout": "IPY_MODEL_c6e0fa72c05241ba989c3b53e089f338",
"max": 0,
"min": -4,
"step": 0.1
}
},
"2d2b66211dd347f0b11afcbe548a196f": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"2d60c9fd4f45466db5d626c52d5379cc": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"2d691177fb18471088e59f17ec84c665": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_1b44c33957274611999eb368fd061e33",
"msg_throttle": 1
}
},
"2e9a279ff95e4029a7902915d9bdd346": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"3013d5f09d6e43838230f32dca57061b": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"3066e711f65d4cae943ab79a02c886c5": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_1e637ca8098d4f05a131d30830f4bc82",
"max": 4,
"min": -4,
"step": 0.1,
"value": 4
}
},
"3078cf58558a42baa5ae4dc594cc93dd": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_a0a761e923174aedaf8da0705d6e10ce",
"IPY_MODEL_c351a91e4f2a4f188b316f4b45790046",
"IPY_MODEL_fdcc4d82e04249d5a614c5a7f5ac462c"
],
"layout": "IPY_MODEL_1ef640b29e3541b19540a2b49507a91f"
}
},
"30f827f63b7d4eb8b0fcb6e72345f83f": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_fe43299750b5402781703e74ec892c4e",
"msg_throttle": 1
}
},
"33841350cd744e3f894cd07860ed3f6a": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_7cb1ef8324b742a8bb3a0ffec23f8b97",
"IPY_MODEL_e5110c2697b74c1fbb25bba8df0742a6",
"IPY_MODEL_63f60f7398d84c8caf7100ba46fc1250",
"IPY_MODEL_a513edd59e064c33b9f796ba9b84bd1b"
],
"layout": "IPY_MODEL_da85ba1f93b14e6bb22c3a738e19c8a8"
}
},
"3593212756894874a32a1fd256147227": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"35f76f6803d948fc89579cc0de35cbe7": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"35f7ab6fd9e8407aa09e26d8c22f0565": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"36163bfa4e9e40d08a9b9145ebfe7d47": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_stat_std / 2 Pi)",
"layout": "IPY_MODEL_8b1de3ef6cd24e6bab1bf650d677d573",
"max": 0,
"min": -2,
"step": 0.1,
"value": -0.5
}
},
"36272349c40c460ca9ddb3c094ceffe8": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"38eea3699f764ee3ab1018c1b82393c0": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"3a0d8327c8d84c72b72af4f78a84dc8d": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_ed6c998110414866b1c7edb424141c4e",
"IPY_MODEL_6b5858687da84e44b78ebfac90cb79c0",
"IPY_MODEL_8ed777e160894b4db63fbfa0c0a13f68",
"IPY_MODEL_1fcea8e6d31a4ce18b291cbc85601e72",
"IPY_MODEL_4ebf8201520346b5a1c252879c72f233"
],
"layout": "IPY_MODEL_eb900005d71449a2a33a39aadb212a41"
}
},
"3a594ef5414642248636e2db76a9b412": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"3aa4b718a31048758ca32a9b25e4ae62": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_7cdcdec35281486e872872c5d2954f65",
"msg_throttle": 1
}
},
"3b4c9fed85f94a2b923c53f6798f0d5f": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"3bf1f8e85146422b9caa9a59d7dcc47c": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_step / 2 Pi)",
"layout": "IPY_MODEL_3e577cd536194d389dc937550546201a",
"max": 0,
"min": -4,
"step": 0.1,
"value": -1.5
}
},
"3c8f977577ca47e39c91a2a98582d8e1": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"3ca4a05f623641f39f9ea39e7a17f883": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_99cf9b9f7fb9456d8dcae7cbd1cb6446",
"IPY_MODEL_3d0af48f45f4419bbcc2048330851e60"
],
"layout": "IPY_MODEL_d620d6008ac54564b73f2225a6b29799"
}
},
"3caa7c2bab1e4254af104fb8a9312bc4": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"3d0af48f45f4419bbcc2048330851e60": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_ca4b3d82c92a494b8abf827921580984",
"msg_throttle": 1
}
},
"3d92781653e64376bdfdf85749b2a327": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"3dc98d5c21fb41c4a0d2cc6ef77adf4d": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"3ddb5a57e74c4e8e95071ba03fca83e8": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"3e577cd536194d389dc937550546201a": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"3edecb9b6ed5443f8be6a90d5fa67218": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_ec2f7056af7d429c80192ba5028791cc",
"IPY_MODEL_a4b2b304577d47658dd52838be6dbd43",
"IPY_MODEL_141066412fa84d54a1f1d176903c8993",
"IPY_MODEL_e4b7cdb1bcb849fba77764f74f77c668"
],
"layout": "IPY_MODEL_7bddcdf64fef45edae488ad98ee6f475"
}
},
"3f94f2338ece47c8909a7e65b02d4e1c": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"417e2d316d1b4b5c9abc56add023af18": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"41dcd656e76e4e64987d3e08b79cfeb1": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"429a5061cb09442aa837a3415a10ee0d": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_stat_std / 2 Pi)",
"layout": "IPY_MODEL_46c902aee0b447caa818344c10288b5d",
"max": 0,
"min": -2,
"step": 0.1,
"value": -1.5
}
},
"43096724d6b04ca9a2ed1e7f2264d5f7": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"4478aacd241a45938f2d58d75f660f6e": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_16756cbfb45f4ac98126ecca03c986cb",
"msg_throttle": 1
}
},
"45a1209608bc4be095d3064f7a1ea33b": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"46a7a9357eea44e78422157789e75509": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"46c902aee0b447caa818344c10288b5d": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"471df48cae8f4359a2d29366cc870e98": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_aad1a5e56fbe4c958e9708b929c544bd",
"max": 4,
"min": -4,
"step": 0.1,
"value": 3.2
}
},
"48fb19b222644b7898e4204aafd07cb7": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"49532f7bf88d4bff94ddf28255ed4946": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"4aeef968a3144205b5bc522868ab828e": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_drift_step / 2 Pi)",
"layout": "IPY_MODEL_5415aa38185348ea8f373f01a145f24a",
"max": 0,
"min": -4,
"step": 0.1,
"value": -1.9
}
},
"4c456aa03ee4406081db172b5d0e6710": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_f6b4dcaa19304e468b06f05a0517d706",
"msg_throttle": 1
}
},
"4c7e30af7aa1410091f4eea85d975e85": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"4c87938fed584cb594ea154b139d8fc9": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_c8d71353a67241ba8f3e409bb21e4e8f",
"msg_throttle": 1
}
},
"4c8ef909863742d987a49ab2e958334f": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"4d767addc3824d2ebfe8ac5f2ae0b047": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_471df48cae8f4359a2d29366cc870e98",
"IPY_MODEL_ffc4826a5cf64704ae9b5a6b3a0d1bbe",
"IPY_MODEL_1af8cfaf92e349b6b3664933c3f31fcb"
],
"layout": "IPY_MODEL_7169433033f34fe8beccab451dff97b7"
}
},
"4db9a4e26a854455bf7ea96c0132fb5f": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_drift_step / 2 Pi)",
"layout": "IPY_MODEL_eb1fee51f35b4573a3b9b8b2e4c85b2f",
"max": 0,
"min": -4,
"step": 0.1,
"value": -2
}
},
"4dcec28e1a42403c9822955a9013fdb1": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_237c075ba3e6424f85139789f4bbc755",
"IPY_MODEL_240a3df57f4e40da92bfb30eb4862652"
],
"layout": "IPY_MODEL_87e82345819f478191107a3304c9effd"
}
},
"4dda754a283143a5904d193a9185ed47": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_d43e9f78b2314c54875af7d519674be3",
"IPY_MODEL_cbd2c81addc849a2819c1fd97500ae6d",
"IPY_MODEL_8cdc4ced8af54298bae43625f1922279",
"IPY_MODEL_b48e4271dae243368e9c3fff02c523cb",
"IPY_MODEL_12a0daf40a35416f878eeac418c580e1"
],
"layout": "IPY_MODEL_7322a695315c46ab803f454274282ddd"
}
},
"4e7ab413653d497ead18fd1fa6ed863a": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_drift_step / 2 Pi)",
"layout": "IPY_MODEL_f58f4ce57d2040faafdbbdd6d01d5dc0",
"max": 0,
"min": -4,
"step": 0.1,
"value": -2.1
}
},
"4ebf8201520346b5a1c252879c72f233": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_e3c0b344a2c24beeb16169d5d5235d22",
"msg_throttle": 1
}
},
"4eee134724c440828e60ac8f01de6b67": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"500722cb9fef49918c3b16cc57e7d57d": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"5243cb6138844ba69db2d4be8a632e25": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_drift_step / 2 Pi)",
"layout": "IPY_MODEL_3f94f2338ece47c8909a7e65b02d4e1c",
"max": 0,
"min": -4,
"step": 0.1,
"value": -3.4
}
},
"5280217cf2fc465faf42d110db694cb8": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_f867f105641c41678d190b8cc07e4e95",
"max": 4,
"min": -4,
"step": 0.1,
"value": 2.5
}
},
"532dd0f152fb4931a91bd4d8abe991fa": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_d9d0a2383eda492caf87379afcfd8db7",
"msg_throttle": 1
}
},
"535b861226034fca936574b769fb8813": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_035df7dee11d44239650c2334a91f266",
"msg_throttle": 1
}
},
"53cdd0e9e29940e9870f8634246244c2": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"5415aa38185348ea8f373f01a145f24a": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"552a5b8718fc440087d730e9e7c095bb": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_return_scale)",
"layout": "IPY_MODEL_bfe275880ee54f6cbae505abdf2130b6",
"max": 4,
"step": 0.1,
"value": 0.9
}
},
"55da5477db2e4d22b6f6c146f2de4420": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"56c3ec700edc4a0e934137ca688692b5": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"57008f6555fb47fab4ae032c62a6bfcb": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_2d60c9fd4f45466db5d626c52d5379cc",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.9
}
},
"57446b27d4d94e93968b93cbe4e51d4a": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_53cdd0e9e29940e9870f8634246244c2",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.1
}
},
"57aa41f399274aa4926cb866a16dcf01": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"57f40409b91c4d6599216b55aa84bdfe": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"58b99b201e9740df9dfca4bf61e15d91": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_57f40409b91c4d6599216b55aa84bdfe",
"msg_throttle": 1
}
},
"5a0d310d6b0c43ef955903cd68aa748b": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"5a38e11b723f4525b1c275774cc020cf": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"5b6dd8d8edf645c28d912e92f0231f25": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_aafe5f60975741299d0e078a98b1e446",
"msg_throttle": 1
}
},
"5b9c34dc70e94e8d9b081f8809c6aebe": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"5eeab87f628d4d358a3da6bc96f8e685": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"5f4d7a568a2341219268046e48cd92a3": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"5f63a0eca48b4eaa8a2861adf65da417": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_stat_std / 2 Pi)",
"layout": "IPY_MODEL_feccdea0d4594e12a989d0b3792f067d",
"max": 0,
"min": -2,
"step": 0.1,
"value": -0.5
}
},
"6020a1fbafe241c2a545c81111ab9433": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"605de0f34fc9445588ab4e5886d9c32d": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"60e5bfb8fa994a82bc28f015989dbe8b": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_d414545cfceb432c9cfeee4e66f8c7f0",
"msg_throttle": 1
}
},
"6135ac7411a448fb83a7abcd856b7cac": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_f53f9926e5c54de99b383f0c55e60d33",
"IPY_MODEL_7fd859e7e018416080dfccc7abca8b41"
],
"layout": "IPY_MODEL_b612d5fee76c4dae828dfd65db068ba0"
}
},
"61505e5a079f413480398331412bac7a": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"627b33bc22344dc0b4b1498203a8fc8e": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"62e5c53c04b34d0984ecc4137163accf": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"62f11f9e872f4320ab0e92b995a1fd0b": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_2e9a279ff95e4029a7902915d9bdd346",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1
}
},
"638cad5283fa4cffb79cd6bffd27d1a8": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"63f60f7398d84c8caf7100ba46fc1250": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_drift_step / 2 Pi)",
"layout": "IPY_MODEL_35f7ab6fd9e8407aa09e26d8c22f0565",
"max": 0,
"min": -4,
"step": 0.1,
"value": -1.9
}
},
"6623ac05acc3422fa7538c8953a0b81e": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"663e6bcabd084e29b7dfd5f551059c9a": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_ab70f2e88ae448c9a0b171cace681d59",
"max": 4,
"min": -4,
"step": 0.1,
"value": 3
}
},
"6680f533eb844045910c8ff3741506d6": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_d93154383cca47eaa7f2f6b4c38c8524",
"IPY_MODEL_535b861226034fca936574b769fb8813"
],
"layout": "IPY_MODEL_cec320a0e5ea4c0e9024f5a2c1e7e628"
}
},
"67b2b7b99f594aa886e8bc49bd5dbd0b": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"67c98a9cd8af4d91b0b5846b0acd03c0": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_7f276efa8ff643faa217ce11b6ac981b",
"msg_throttle": 1
}
},
"67e2b95e564b43d080063b678bb52edd": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_fbe4cd3a1e35497abc6fb0bb8664e8c4",
"IPY_MODEL_baa22b69499e4a12bff7beda8394e371",
"IPY_MODEL_883daccb188a4782b0d88c36f181e691",
"IPY_MODEL_70c3a8a27bac4c8eb515d07da6f4656e",
"IPY_MODEL_e3dba6425f294aa589703f5cf0e0ba4c"
],
"layout": "IPY_MODEL_6c446762813c4e729f7a210917744d92"
}
},
"67f0474e16514a6196427f49396aecf2": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"67ff500e4e4b413cae77d7af8f5d984a": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_b0ece426ba2142a990033a8a826e57af"
}
},
"682fd0d07e4847958ab8abf70675a77d": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"685a665ef2c547828fa54768686b0240": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"69727d00f39240bab2041656671a8173": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_d470e117295a4cbeaa99fba888246259",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.8
}
},
"69affcbe0dc748b6999b611d39c61e45": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread\n/step)",
"layout": "IPY_MODEL_1ed8d813d46d48778ea8157b8beea818",
"max": 4,
"min": -4,
"step": 0.1
}
},
"6a486afafa8c47aead0d65330fd57266": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_2d2b66211dd347f0b11afcbe548a196f",
"msg_throttle": 1
}
},
"6ac8a9175f4d41caac03a22762027d40": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_1364fc3ed238470f92a073154a5ac407",
"IPY_MODEL_d3611be47b764301871ef4bdba48e0b9",
"IPY_MODEL_4c456aa03ee4406081db172b5d0e6710"
],
"layout": "IPY_MODEL_135c95a45d104a59be769842b4e552b3"
}
},
"6ae09faddcdc47ce816d646394d8f1fd": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"6b5858687da84e44b78ebfac90cb79c0": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_stat_std / 2 Pi)",
"layout": "IPY_MODEL_8a9e0b4ac51640e3bd3d7f275df1000f",
"max": 0,
"min": -2,
"step": 0.1,
"value": -0.5
}
},
"6c446762813c4e729f7a210917744d92": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"6ccc042823254d778e295c3ad568b2be": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_ae8fb34b96304f91b4088db804aaa45c",
"IPY_MODEL_67c98a9cd8af4d91b0b5846b0acd03c0"
],
"layout": "IPY_MODEL_fa80d89cedb240d88ec31a87c94af163"
}
},
"6ce75422be0b44a58c8909cca8c63408": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_drift_step / 2 Pi)",
"layout": "IPY_MODEL_b42658e3c87843e1872d1522cf797d7a",
"max": 0,
"min": -4,
"step": 0.1,
"value": -1.9
}
},
"6cf712c642f247d6ad25a5b7688bab01": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"6df34ab3bacc45c5a12ac54a3812cc1f": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_return_scale)",
"layout": "IPY_MODEL_7bf2450640d345fc93db2dcca51423e2",
"max": 4,
"step": 0.1,
"value": 1
}
},
"6f88e206509445a3821e3c508a2280c9": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_step / 2 Pi)",
"layout": "IPY_MODEL_85600c7956aa40a288b4156393035792",
"max": 0,
"min": -4,
"step": 0.1
}
},
"6ff8f3ecefdf4745b6d8833e605a75ab": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_7647cdb244a1453096d8e233c99acda6",
"IPY_MODEL_da66f81b858548cd9b629907367ea7da",
"IPY_MODEL_9fc611262e284274a479e14f5385160b",
"IPY_MODEL_1a13a51dcce343f181beb95630d2b11d"
],
"layout": "IPY_MODEL_d36abaa47bab477d89ec77d68a0986de"
}
},
"7094c0a07e4a4d4c9a3ba705f12ef120": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"70c3a8a27bac4c8eb515d07da6f4656e": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_drift_step / 2 Pi)",
"layout": "IPY_MODEL_880ce7298250454c9c34748acc025368",
"max": 0,
"min": -4,
"step": 0.1,
"value": -1.9
}
},
"710081acc19346059e209ef38a640420": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_69affcbe0dc748b6999b611d39c61e45",
"IPY_MODEL_bb78e530839f4414b83f575ad5f0ccfe"
],
"layout": "IPY_MODEL_27df4103a9e747edaf06b89dc4031396"
}
},
"7169433033f34fe8beccab451dff97b7": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"7192ee33b45640c1a27ffa566a7b4091": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_stat_std / 2 Pi)",
"layout": "IPY_MODEL_ed12bfa4a78845aaafcb58206da55326",
"max": 0,
"min": -2,
"step": 0.1,
"value": -1.3
}
},
"72982849a33443508b64aa8cbe4830eb": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_3066e711f65d4cae943ab79a02c886c5",
"IPY_MODEL_a77c3e0276974a9bb0ea86c7a04bd1d9"
],
"layout": "IPY_MODEL_46a7a9357eea44e78422157789e75509"
}
},
"72b0ff42077a482d91e9cb772289b4a8": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"7322a695315c46ab803f454274282ddd": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"739831bbb2d046ceadf87db14c062e01": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"74d48294b8474de7aef663869f480dff": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_drift_step / 2 Pi)",
"layout": "IPY_MODEL_d8b4ee66c3d24a8ab7016368064872a8",
"max": 0,
"min": -4,
"step": 0.1,
"value": -0.9
}
},
"7647cdb244a1453096d8e233c99acda6": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_a44eb0658f8c4760b28b0de27667610d",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.7
}
},
"76b8cbce5f9042ec9bff4c8619156ba0": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_e55b5e08cfba404aa6220b6ec44ddf6d",
"IPY_MODEL_7192ee33b45640c1a27ffa566a7b4091",
"IPY_MODEL_fe816e011086412688332d262d86cc96",
"IPY_MODEL_a097aac9024847c99e0f581c9a0a61e9",
"IPY_MODEL_c4fda87be44043d393ccdc30e02a8d33"
],
"layout": "IPY_MODEL_17eec1d904574af8854ec4db08098b56"
}
},
"775e92a257214727ae771a419a51ce20": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"77669491858d4c4f9d0af27ff7264d62": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"78c70b25a8c241fc8fde11221b84d036": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"78daf3b2616046c9b1d014725b25a9b2": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"79a607e639f54833b096f33b13b533d7": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_e67f4e5e2ebc4e26ad0509cc1cbd61b6",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1
}
},
"7a258d54babc459b94eb15c0064fad41": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_67f0474e16514a6196427f49396aecf2",
"max": 4,
"min": -4,
"step": 0.1,
"value": 2
}
},
"7a36cf973199455d8ff0569ae7ea2d7c": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"7adfe2becd034bc5864490779cb20860": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_a555964f6d1445faaaba406e38585730",
"IPY_MODEL_3bf1f8e85146422b9caa9a59d7dcc47c",
"IPY_MODEL_ba47c2d6c12a420fb15efb3f5d62ab1a"
],
"layout": "IPY_MODEL_100de71247a84a5c81d87e14d4b1451c"
}
},
"7bdb9a5c54834b588f8694f936c900ec": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_62e5c53c04b34d0984ecc4137163accf",
"msg_throttle": 1
}
},
"7bddcdf64fef45edae488ad98ee6f475": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"7bf2450640d345fc93db2dcca51423e2": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"7c5d36a7a3f046298c39dc2286f62a49": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_125a96ea39b048908210afdd050219e8",
"IPY_MODEL_ebcbd38fb49643de9c3f42abd04cd7f0",
"IPY_MODEL_27f5f9f8d1bf44f6a57ec1bbf4b1e738",
"IPY_MODEL_26f4976a63824b4395a3a7ac4ec27fc3"
],
"layout": "IPY_MODEL_06f22cb3d88744c68d04d823bb7e76c6"
}
},
"7cb1ef8324b742a8bb3a0ffec23f8b97": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_21e12812b4124176ad76114324a60cc2",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.8
}
},
"7cdcdec35281486e872872c5d2954f65": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"7d23415cacd8401c9b205394b621829f": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_79a607e639f54833b096f33b13b533d7",
"IPY_MODEL_c3a472d6e4054987af9429fae433f540",
"IPY_MODEL_169c29e4a6ad440f9c0db050068ee162"
],
"layout": "IPY_MODEL_3a594ef5414642248636e2db76a9b412"
}
},
"7dbf9b6ad3064bf9bc283224c3cc6dc1": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_0d38e29d261447409013f8feca841b7e",
"IPY_MODEL_db9a198f59ba41dd9c9ddbbab984099d"
],
"layout": "IPY_MODEL_955a1b84df6a4d99b3e7635645ed9f5e"
}
},
"7dfa52a3c60544c891e24a76c295db89": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "step",
"layout": "IPY_MODEL_cdf38f67be754cd589637a570814040b",
"min": 1,
"step": 0.1,
"value": 1
}
},
"7f276efa8ff643faa217ce11b6ac981b": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"7fd859e7e018416080dfccc7abca8b41": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_d914beb4a1f84fcd9654c7d6de23f409",
"msg_throttle": 1
}
},
"7ff310f6054e445ea6d2c57048cc2210": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"805a95817c1d4d7998e4f3a6924b8bd9": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_step / 2 Pi)",
"layout": "IPY_MODEL_c5dd765a33a14ce385f91be4b1d7f29c",
"max": 0,
"min": -4,
"step": 0.1,
"value": -1.5
}
},
"80d49a9649204081a87f70ee80df93f0": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"80d4bfe07ed0446d98db9af175e43c7e": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"819726b4c088451b95809b2145d60cd1": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_69727d00f39240bab2041656671a8173",
"IPY_MODEL_cffb1ba9342748fba793262d9d81fe6e",
"IPY_MODEL_6df34ab3bacc45c5a12ac54a3812cc1f",
"IPY_MODEL_145ea83356504485ba372a6ee6163041",
"IPY_MODEL_bd68253fb4974206bf04254faa0930b9"
],
"layout": "IPY_MODEL_258720b2eec34245bb145cb3c88cad0a"
}
},
"81f1d27061194bbfafabbb760775d70b": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"82e70459e4544a7c99e634539a23c11a": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_stat_std / 2 Pi)",
"layout": "IPY_MODEL_57aa41f399274aa4926cb866a16dcf01",
"max": 0,
"min": -2,
"step": 0.1,
"value": -0.5
}
},
"833115d8f5e749dca8355162527484fd": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"8353d929fa0b49209c8399a17e7a76f3": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"83a353406ea141f484263926e91793b5": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_f773971ad74b472ba86f822369e601b1",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.9
}
},
"841be6fe0bf14903a3986d587c17b365": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"853e42789eee4126b06102c8e3554e50": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_62f11f9e872f4320ab0e92b995a1fd0b",
"IPY_MODEL_2c6d3b76ec1f4ece87df89886ae72e1a",
"IPY_MODEL_fea34ba5e2fe4bb8baac94220eb39426",
"IPY_MODEL_c75016bcd5b74a09a89179438e548d31"
],
"layout": "IPY_MODEL_ac6dae805f7d434a96f7e2f299bb6841"
}
},
"85600c7956aa40a288b4156393035792": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"875228e82b67497eb56b1e2216f2c693": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "frequency",
"layout": "IPY_MODEL_2aa178d90dd64e1f8891ed8e3e0f7afe",
"min": 1,
"step": 0.1,
"value": 1
}
},
"87e82345819f478191107a3304c9effd": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"880ce7298250454c9c34748acc025368": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"88383e4aed5a4150854a3af83f85d3d4": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"883daccb188a4782b0d88c36f181e691": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (return_scale)",
"layout": "IPY_MODEL_e5edc69d286c4d36bed5a107814f08ae",
"max": 4,
"step": 0.1,
"value": 1
}
},
"889d7bcb450344d69a22a7626faea3f7": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_48fb19b222644b7898e4204aafd07cb7",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.8
}
},
"8a9e0b4ac51640e3bd3d7f275df1000f": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"8ae46c0141f2408ba0e3af3f2376b73d": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"8b1de3ef6cd24e6bab1bf650d677d573": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"8cdc4ced8af54298bae43625f1922279": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (return_scale)",
"layout": "IPY_MODEL_195beb5ac3e9475a94918277941a9eb9",
"max": 4,
"step": 0.1,
"value": 2.8
}
},
"8d2836f0db3141e8921909d397f3bd25": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"8ed777e160894b4db63fbfa0c0a13f68": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (return_scale)",
"layout": "IPY_MODEL_43096724d6b04ca9a2ed1e7f2264d5f7",
"max": 4,
"step": 0.1,
"value": 1
}
},
"8f41726ccdcb4bc38422a2fda15024fb": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"914e18e2cd8345afa8c5a8c1b876b745": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"935727ac397e41358ab99598f74e585d": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"955a1b84df6a4d99b3e7635645ed9f5e": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"95f12fbcf8254386960ed4f87097e83d": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"95fcb4a911524daa91d1cf96457fe817": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_57008f6555fb47fab4ae032c62a6bfcb",
"IPY_MODEL_0d0ce29ea138427abfadb0145dfa4dde",
"IPY_MODEL_19d4978945fd4b3ba880a4dcaea262b9"
],
"layout": "IPY_MODEL_5a0d310d6b0c43ef955903cd68aa748b"
}
},
"96bfea52b8db46738f43006c470b7506": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"971831706209493bba35e6e1e16a3574": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_step / 2 Pi)",
"layout": "IPY_MODEL_a0bd6e95703542519d5b6861c95d6db4",
"max": 0,
"min": -4,
"step": 0.1,
"value": -2.4
}
},
"97abfc0ba9c14053a6c513ae983cf600": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_97bd49ae1d6c43bebcadd73480122de7",
"IPY_MODEL_4478aacd241a45938f2d58d75f660f6e"
],
"layout": "IPY_MODEL_6623ac05acc3422fa7538c8953a0b81e"
}
},
"97bd49ae1d6c43bebcadd73480122de7": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_36272349c40c460ca9ddb3c094ceffe8",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1
}
},
"9882a6bf22b24ea18206e9c71fc03bb0": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_drift_step / 2 Pi)",
"layout": "IPY_MODEL_29571c2b401248779c99079647d25312",
"max": 0,
"min": -4,
"step": 0.1
}
},
"99cf9b9f7fb9456d8dcae7cbd1cb6446": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_0cdbc7bb1b074462af0f9bf6b2b0be4a",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.6
}
},
"9c661199a1394d02a43a7e91b61ae2d4": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"9dc71ad0aa7c4105b984b5bcaa2769f6": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "step",
"layout": "IPY_MODEL_41dcd656e76e4e64987d3e08b79cfeb1",
"min": 1,
"step": 0.1,
"value": 1
}
},
"9f13f09f160442be889085a71b424793": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"9fc611262e284274a479e14f5385160b": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_drift_step / 2 Pi)",
"layout": "IPY_MODEL_95f12fbcf8254386960ed4f87097e83d",
"max": 0,
"min": -4,
"step": 0.1
}
},
"a097aac9024847c99e0f581c9a0a61e9": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_drift_step / 2 Pi)",
"layout": "IPY_MODEL_eda1345a561545d39197977555edeabb",
"max": 0,
"min": -4,
"step": 0.1,
"value": -1.2
}
},
"a0a761e923174aedaf8da0705d6e10ce": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_d8e1d036192f4affb6c950d978ad7216",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1
}
},
"a0bd6e95703542519d5b6861c95d6db4": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"a10c1caa2d22428e948d29359a399d4b": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_d10dd332687b45618423fa553377b8ca",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.8
}
},
"a2f5f020b37749398732dfd88162a963": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"a44eb0658f8c4760b28b0de27667610d": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"a47802fd5bb447aaabeca3c14177c245": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_417e2d316d1b4b5c9abc56add023af18",
"max": 4,
"min": -4,
"step": 0.1,
"value": 3.3
}
},
"a4b2b304577d47658dd52838be6dbd43": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_step / 2 Pi)",
"layout": "IPY_MODEL_638cad5283fa4cffb79cd6bffd27d1a8",
"max": 0,
"min": -4,
"step": 0.1,
"value": -1.4
}
},
"a4ce375251ed49828d1d57bcbfab9724": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_d930f195ceb94914bd1f953261c80406",
"IPY_MODEL_7dfa52a3c60544c891e24a76c295db89",
"IPY_MODEL_099e107e563c405086480ed77d9cc470"
],
"layout": "IPY_MODEL_88383e4aed5a4150854a3af83f85d3d4"
}
},
"a513edd59e064c33b9f796ba9b84bd1b": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_6cf712c642f247d6ad25a5b7688bab01",
"msg_throttle": 1
}
},
"a555964f6d1445faaaba406e38585730": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_add495a584d847e58d8b974827a9609e",
"max": 4,
"min": -4,
"step": 0.1,
"value": 2.2
}
},
"a683a2a6b6c749ae8fc8d6f8ca0415db": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"a77c3211092c4430b1ac9342fe78e133": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_1794d119c7c74dc4850d5949103508ae",
"IPY_MODEL_971831706209493bba35e6e1e16a3574",
"IPY_MODEL_b20733e957b54da19daa824de75cbdd4"
],
"layout": "IPY_MODEL_f672129eeca84f4d9b5f51a96b275281"
}
},
"a77c3e0276974a9bb0ea86c7a04bd1d9": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_841be6fe0bf14903a3986d587c17b365",
"msg_throttle": 1
}
},
"a7a405c8c5724510888ff62f71a533ce": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_094bfea00c15424eb84b2ac664a2b9ac",
"IPY_MODEL_36163bfa4e9e40d08a9b9145ebfe7d47",
"IPY_MODEL_cbd8bae7b42541a6bce867858ff74e98",
"IPY_MODEL_4aeef968a3144205b5bc522868ab828e",
"IPY_MODEL_06c24fbc989d42c196a83bb16dcda0fb"
],
"layout": "IPY_MODEL_ee78ef721bce43ee9fff3aaac1c44fa5"
}
},
"a7a7ba5d6fe7458baf31f0ef3b6ff0fc": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"a87cf9425b164b6399a2d3b2f8f4a461": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_500722cb9fef49918c3b16cc57e7d57d",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.2
}
},
"a945bcd7a7414fe1b582a16404170580": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"aabc62751a9d41ab8103534c8b1f0fc2": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "frequency",
"layout": "IPY_MODEL_a945bcd7a7414fe1b582a16404170580",
"min": 1,
"step": 0.1,
"value": 10.7
}
},
"aad1a5e56fbe4c958e9708b929c544bd": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"aad4b35a2528446495a645ebe643d28c": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"aafe5f60975741299d0e078a98b1e446": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"ab3321a4fe3d4b2da664b0be19a13156": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_e7cbbb24deb042dab4453e262fec2d89",
"IPY_MODEL_fe28b2adce3a435f97f521e0120f3943"
],
"layout": "IPY_MODEL_ca704407fa6d49a7a5f64b719940bfd7"
}
},
"ab70f2e88ae448c9a0b171cace681d59": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"ac54fb63beaa48b99d936ea7707c574f": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_stat_std / 2 Pi)",
"layout": "IPY_MODEL_cedad762dd0a401b9b6a315f2b068fd2",
"max": 0,
"min": -2,
"step": 0.1,
"value": -0.5
}
},
"ac6dae805f7d434a96f7e2f299bb6841": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"ac8d1f78072046e4a0691b92bcdb527f": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"acdf2891fe3e4121937e0cc11110cb7c": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_a47802fd5bb447aaabeca3c14177c245",
"IPY_MODEL_0d2e4f89430a4c43950a39cddf40310f",
"IPY_MODEL_bd2e404b2f7f4581a9530562cd7137a6",
"IPY_MODEL_74d48294b8474de7aef663869f480dff",
"IPY_MODEL_7bdb9a5c54834b588f8694f936c900ec"
],
"layout": "IPY_MODEL_3caa7c2bab1e4254af104fb8a9312bc4"
}
},
"ad3a3ca61bcb44a192155b88c8c8bd55": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "step",
"layout": "IPY_MODEL_935727ac397e41358ab99598f74e585d",
"min": 1,
"step": 0.1,
"value": 25
}
},
"ad4f70d9557e467b8428730d4756d5a6": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_return_scale)",
"layout": "IPY_MODEL_aad4b35a2528446495a645ebe643d28c",
"max": 4,
"step": 0.1,
"value": 2.8
}
},
"ad615203d361469391c55802ec23c04a": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"add495a584d847e58d8b974827a9609e": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"ae8fb34b96304f91b4088db804aaa45c": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_0af2e49a660347d2a6a39939ea33502c",
"max": 4,
"min": -4,
"step": 0.1,
"value": -0.9
}
},
"afdfda0ccb0d4aad8f3f508feba9dd46": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"b0ece426ba2142a990033a8a826e57af": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"b20733e957b54da19daa824de75cbdd4": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_5eeab87f628d4d358a3da6bc96f8e685",
"msg_throttle": 1
}
},
"b42658e3c87843e1872d1522cf797d7a": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"b48e4271dae243368e9c3fff02c523cb": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_drift_step / 2 Pi)",
"layout": "IPY_MODEL_243ba72e14c04c049f23e91ae2f36df5",
"max": 0,
"min": -4,
"step": 0.1,
"value": -0.3
}
},
"b5effa7c44dc431382f5cf430bb4a63e": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"b612d5fee76c4dae828dfd65db068ba0": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"b857064d95e0471e840cb74bef353fb0": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"ba47c2d6c12a420fb15efb3f5d62ab1a": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_8ae46c0141f2408ba0e3af3f2376b73d",
"msg_throttle": 1
}
},
"baa22b69499e4a12bff7beda8394e371": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_stat_std / 2 Pi)",
"layout": "IPY_MODEL_3dc98d5c21fb41c4a0d2cc6ef77adf4d",
"max": 0,
"min": -2,
"step": 0.1,
"value": -0.5
}
},
"bad5e9586a2344d58aa25f5229a4787e": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_aabc62751a9d41ab8103534c8b1f0fc2",
"IPY_MODEL_ad3a3ca61bcb44a192155b88c8c8bd55",
"IPY_MODEL_23da4f02dde241e488056010f33d7bdd"
],
"layout": "IPY_MODEL_3b4c9fed85f94a2b923c53f6798f0d5f"
}
},
"baeceb0ce56747fb9947ab00a94b01ee": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_83a353406ea141f484263926e91793b5",
"IPY_MODEL_3aa4b718a31048758ca32a9b25e4ae62"
],
"layout": "IPY_MODEL_9f13f09f160442be889085a71b424793"
}
},
"bb78e530839f4414b83f575ad5f0ccfe": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_61505e5a079f413480398331412bac7a",
"msg_throttle": 1
}
},
"bba57d83f23148ec9d8520a2fc4d8135": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_1f987affbd7a49be9b929dbcff087d42",
"IPY_MODEL_429a5061cb09442aa837a3415a10ee0d",
"IPY_MODEL_552a5b8718fc440087d730e9e7c095bb",
"IPY_MODEL_4db9a4e26a854455bf7ea96c0132fb5f",
"IPY_MODEL_e8d5d75269d742848f2a51b2dd1a279c"
],
"layout": "IPY_MODEL_5f4d7a568a2341219268046e48cd92a3"
}
},
"bc21378ef6344b0ab4d2cca323cb7845": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_d02690c3ae2d478a805ab2aadf918931",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.6
}
},
"bd2e404b2f7f4581a9530562cd7137a6": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (return_scale)",
"layout": "IPY_MODEL_77669491858d4c4f9d0af27ff7264d62",
"max": 4,
"step": 0.1,
"value": 3.6
}
},
"bd68253fb4974206bf04254faa0930b9": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_605de0f34fc9445588ab4e5886d9c32d",
"msg_throttle": 1
}
},
"bd6f80e764d845b39c568a9d6c678915": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_return_scale)",
"layout": "IPY_MODEL_0861a7b05dd0432487206c9d369552b9",
"max": 4,
"step": 0.1,
"value": 1
}
},
"be15a7436d3141ca9800d9056004036f": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"be972764ca1546ea9a7120c719c92651": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_7a258d54babc459b94eb15c0064fad41",
"IPY_MODEL_d4c76328b47f414b9c680a541436ab98",
"IPY_MODEL_bf1e255c0c8d4bf7a64eca6cc37c4ac3",
"IPY_MODEL_eac900b086e648bfb6326f2ef64bf826"
],
"layout": "IPY_MODEL_fa7470d741d54548a670375e61bb9ccd"
}
},
"bf1e255c0c8d4bf7a64eca6cc37c4ac3": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_drift_step / 2 Pi)",
"layout": "IPY_MODEL_d8f2965f88f344138c281debadb03dae",
"max": 0,
"min": -4,
"step": 0.1,
"value": -0.5
}
},
"bfe275880ee54f6cbae505abdf2130b6": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"c134611300144961a6c8a0ad2974700f": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"c21a5d6539744f42a4d3cff15123e1b2": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"c2371eca38304f1e9ea2a41831e67c00": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"c2b4fadc63454c5c9f04cb64a26134a4": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_stat_std / 2 Pi)",
"layout": "IPY_MODEL_35f76f6803d948fc89579cc0de35cbe7",
"max": 0,
"min": -2,
"step": 0.1,
"value": -0.5
}
},
"c351a91e4f2a4f188b316f4b45790046": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_step / 2 Pi)",
"layout": "IPY_MODEL_0141106ca4f04064b31214a63ff7c731",
"max": 0,
"min": -4,
"step": 0.1,
"value": -1.3
}
},
"c3a472d6e4054987af9429fae433f540": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "ang_rw_step",
"layout": "IPY_MODEL_80d4bfe07ed0446d98db9af175e43c7e",
"max": 4,
"min": -4,
"step": 0.1,
"value": 0.1
}
},
"c4fda87be44043d393ccdc30e02a8d33": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_c942d360d8db44459f4462063105e1c1",
"msg_throttle": 1
}
},
"c50c25d385ba48b1a397f11ce75533c9": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"c52b5841517b45668b0e76ad3c5fb3e8": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"c5dd765a33a14ce385f91be4b1d7f29c": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"c6e0fa72c05241ba989c3b53e089f338": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"c75016bcd5b74a09a89179438e548d31": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_0eca72edf5144ae194b3a332df8153d4",
"msg_throttle": 1
}
},
"c7c78ccfe1704f1cb57f7e2a1c313fed": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_eafa3c07d43442d1b314d51b486480d3",
"IPY_MODEL_82e70459e4544a7c99e634539a23c11a",
"IPY_MODEL_ccd52a22e6a6480f95ed904f3401fe0a",
"IPY_MODEL_5243cb6138844ba69db2d4be8a632e25",
"IPY_MODEL_4c87938fed584cb594ea154b139d8fc9"
],
"layout": "IPY_MODEL_1f327e2205e34b66bbaf88698f80cbc4"
}
},
"c7f1a0314acd48198cc7c4f0cfe29ff0": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"c8d71353a67241ba8f3e409bb21e4e8f": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"c942d360d8db44459f4462063105e1c1": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"c9a07cc4933549eda9be2d22183f643f": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"c9e86ffd96db453a9e588b369e89cde0": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_57446b27d4d94e93968b93cbe4e51d4a",
"IPY_MODEL_5b6dd8d8edf645c28d912e92f0231f25"
],
"layout": "IPY_MODEL_55da5477db2e4d22b6f6c146f2de4420"
}
},
"ca4b3d82c92a494b8abf827921580984": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"ca704407fa6d49a7a5f64b719940bfd7": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"cb6b54a5470d4fbe99743cc4389c8104": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"cbd2c81addc849a2819c1fd97500ae6d": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_stat_std / 2 Pi)",
"layout": "IPY_MODEL_3ddb5a57e74c4e8e95071ba03fca83e8",
"max": 0,
"min": -2,
"step": 0.1,
"value": -0.5
}
},
"cbd8bae7b42541a6bce867858ff74e98": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (return_scale)",
"layout": "IPY_MODEL_45a1209608bc4be095d3064f7a1ea33b",
"max": 4,
"step": 0.1,
"value": 1
}
},
"cc1b3be91a8745698faad6323efaa88a": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"ccd52a22e6a6480f95ed904f3401fe0a": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_return_scale)",
"layout": "IPY_MODEL_8d2836f0db3141e8921909d397f3bd25",
"max": 4,
"step": 0.1,
"value": 2.9
}
},
"cd7ef07e29794c8c8274d40a401cf19e": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_fab31e31a74c462790e2de77002a6584",
"IPY_MODEL_6f88e206509445a3821e3c508a2280c9",
"IPY_MODEL_1d21883f4a694a5d8cb39b1fd5cb7aa1"
],
"layout": "IPY_MODEL_8353d929fa0b49209c8399a17e7a76f3"
}
},
"cdf38f67be754cd589637a570814040b": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"cec320a0e5ea4c0e9024f5a2c1e7e628": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"cedad762dd0a401b9b6a315f2b068fd2": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"cf2c6da272f14b5c834a25074fd88f5d": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_step / 2 Pi)",
"layout": "IPY_MODEL_c50c25d385ba48b1a397f11ce75533c9",
"max": 0,
"min": -4,
"step": 0.1
}
},
"cffb1ba9342748fba793262d9d81fe6e": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_stat_std / 2 Pi)",
"layout": "IPY_MODEL_f2a44b31bad24be09eb0034b8154949c",
"max": 0,
"min": -2,
"step": 0.1,
"value": -0.5
}
},
"d02690c3ae2d478a805ab2aadf918931": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"d10dd332687b45618423fa553377b8ca": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"d1bdf1584e704aa9bef18971d3603402": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_b5effa7c44dc431382f5cf430bb4a63e",
"msg_throttle": 1
}
},
"d1e03fba61ba4396a3b511d5b6f3d4b9": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_return_scale)",
"layout": "IPY_MODEL_96bfea52b8db46738f43006c470b7506",
"max": 4,
"step": 0.1,
"value": 1
}
},
"d3611be47b764301871ef4bdba48e0b9": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "step",
"layout": "IPY_MODEL_20197775b6484781bd48f5e844dfee34",
"min": 1,
"step": 0.1,
"value": 1
}
},
"d36abaa47bab477d89ec77d68a0986de": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"d414545cfceb432c9cfeee4e66f8c7f0": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"d43e9f78b2314c54875af7d519674be3": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_26df2d166fa54400af01574728033670",
"max": 4,
"min": -4,
"step": 0.1,
"value": -3
}
},
"d4576f4d9e334d91b487695a68861dd7": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"d470e117295a4cbeaa99fba888246259": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"d4c76328b47f414b9c680a541436ab98": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_step / 2 Pi)",
"layout": "IPY_MODEL_1b5e853b972b4ec59d8229cdd53ae000",
"max": 0,
"min": -4,
"step": 0.1,
"value": -1.3
}
},
"d4f7553ca7044d5a8e24b2b5511a58d5": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_e01bd2c976ce43529d95ec117d0200d2",
"IPY_MODEL_58b99b201e9740df9dfca4bf61e15d91"
],
"layout": "IPY_MODEL_3d92781653e64376bdfdf85749b2a327"
}
},
"d620d6008ac54564b73f2225a6b29799": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"d8b4ee66c3d24a8ab7016368064872a8": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"d8e1d036192f4affb6c950d978ad7216": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"d8f2965f88f344138c281debadb03dae": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"d914beb4a1f84fcd9654c7d6de23f409": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"d930f195ceb94914bd1f953261c80406": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "frequency",
"layout": "IPY_MODEL_d4576f4d9e334d91b487695a68861dd7",
"min": 1,
"step": 0.1,
"value": 1
}
},
"d93154383cca47eaa7f2f6b4c38c8524": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_685a665ef2c547828fa54768686b0240",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1
}
},
"d9d0a2383eda492caf87379afcfd8db7": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"da32a472292a4c55b7073dc3ce0cdaf7": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_0caf747a1be24887900da5f240d51c63",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1
}
},
"da5a239751a44c288f0f6c179f02b404": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"da66f81b858548cd9b629907367ea7da": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_step / 2 Pi)",
"layout": "IPY_MODEL_5a38e11b723f4525b1c275774cc020cf",
"max": 0,
"min": -4,
"step": 0.1,
"value": -2.2
}
},
"da85ba1f93b14e6bb22c3a738e19c8a8": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"db9a198f59ba41dd9c9ddbbab984099d": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_b857064d95e0471e840cb74bef353fb0",
"msg_throttle": 1
}
},
"ddaf3cdcf4924e9fbca9faf22a80d2ee": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"de16c303e48449389af07dca15590c7c": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_a10c1caa2d22428e948d29359a399d4b",
"IPY_MODEL_c2b4fadc63454c5c9f04cb64a26134a4",
"IPY_MODEL_bd6f80e764d845b39c568a9d6c678915",
"IPY_MODEL_141cc43a369448c7a473e5888c105781",
"IPY_MODEL_d1bdf1584e704aa9bef18971d3603402"
],
"layout": "IPY_MODEL_833115d8f5e749dca8355162527484fd"
}
},
"e01bd2c976ce43529d95ec117d0200d2": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_8f41726ccdcb4bc38422a2fda15024fb",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.6
}
},
"e3c0b344a2c24beeb16169d5d5235d22": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"e3dba6425f294aa589703f5cf0e0ba4c": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_72b0ff42077a482d91e9cb772289b4a8",
"msg_throttle": 1
}
},
"e4a682743b2b4d639efdc20dc5dd2f72": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"e4b7cdb1bcb849fba77764f74f77c668": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_c7f1a0314acd48198cc7c4f0cfe29ff0",
"msg_throttle": 1
}
},
"e5110c2697b74c1fbb25bba8df0742a6": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_step / 2 Pi)",
"layout": "IPY_MODEL_ddaf3cdcf4924e9fbca9faf22a80d2ee",
"max": 0,
"min": -4,
"step": 0.1,
"value": -1.4
}
},
"e55b5e08cfba404aa6220b6ec44ddf6d": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_4eee134724c440828e60ac8f01de6b67",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.8
}
},
"e5b153ede0854e859d658519fe6587bb": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"e5edc69d286c4d36bed5a107814f08ae": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"e614cd2f612d4461980ba57ee4b18341": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_c21a5d6539744f42a4d3cff15123e1b2",
"msg_throttle": 1
}
},
"e67f4e5e2ebc4e26ad0509cc1cbd61b6": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"e7cbbb24deb042dab4453e262fec2d89": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_78c70b25a8c241fc8fde11221b84d036",
"max": 4,
"min": -4,
"step": 0.1,
"value": 0.3
}
},
"e8489ceb90494eb7a905f8c940d63292": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"e87204958f82437dbcb286c57d98e605": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_5280217cf2fc465faf42d110db694cb8",
"IPY_MODEL_cf2c6da272f14b5c834a25074fd88f5d",
"IPY_MODEL_9882a6bf22b24ea18206e9c71fc03bb0",
"IPY_MODEL_164e0e6a62bb44c9b036745e383c0ab6"
],
"layout": "IPY_MODEL_0d4785cad089443f99a06973f46ae5f1"
}
},
"e8d5d75269d742848f2a51b2dd1a279c": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_23ee64584a3345b9aa6fa50e8c9c438d",
"msg_throttle": 1
}
},
"e8d7a469ac1c45379dbf4d4889e8b7d1": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"e909d8b60de2454eac5bbc14507f463f": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"eac784dc3e95458e8b70fd79de30b216": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "frequency",
"layout": "IPY_MODEL_cb6b54a5470d4fbe99743cc4389c8104",
"min": 1,
"step": 0.1,
"value": 1
}
},
"eac900b086e648bfb6326f2ef64bf826": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_7094c0a07e4a4d4c9a3ba705f12ef120",
"msg_throttle": 1
}
},
"eafa3c07d43442d1b314d51b486480d3": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_9c661199a1394d02a43a7e91b61ae2d4",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.8
}
},
"eb1fee51f35b4573a3b9b8b2e4c85b2f": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"eb900005d71449a2a33a39aadb212a41": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"ebcbd38fb49643de9c3f42abd04cd7f0": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_step / 2 Pi)",
"layout": "IPY_MODEL_ac8d1f78072046e4a0691b92bcdb527f",
"max": 0,
"min": -4,
"step": 0.1,
"value": -1.2
}
},
"ec2f7056af7d429c80192ba5028791cc": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_739831bbb2d046ceadf87db14c062e01",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.8
}
},
"ed12bfa4a78845aaafcb58206da55326": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"ed6c998110414866b1c7edb424141c4e": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_e8489ceb90494eb7a905f8c940d63292",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.8
}
},
"eda1345a561545d39197977555edeabb": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"ee78ef721bce43ee9fff3aaac1c44fa5": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"f2a44b31bad24be09eb0034b8154949c": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"f2eac213441e462290d86602ea9bc465": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_a87cf9425b164b6399a2d3b2f8f4a461",
"IPY_MODEL_2a78d8dd9a6145428586366b89b98d06"
],
"layout": "IPY_MODEL_fbfdf6a6375748c1ba9f4989f7fcfb4b"
}
},
"f53f9926e5c54de99b383f0c55e60d33": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_1d6da6ad46fd4d029e04612511aeb58f",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.3
}
},
"f58f4ce57d2040faafdbbdd6d01d5dc0": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"f652c029548a4da78ad261b5b92607fe": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"f672129eeca84f4d9b5f51a96b275281": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"f6b4dcaa19304e468b06f05a0517d706": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"f773971ad74b472ba86f822369e601b1": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"f867f105641c41678d190b8cc07e4e95": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "50%"
}
},
"f957d2cd3a9546ba83debfb8044f3965": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_875228e82b67497eb56b1e2216f2c693",
"IPY_MODEL_9dc71ad0aa7c4105b984b5bcaa2769f6",
"IPY_MODEL_6a486afafa8c47aead0d65330fd57266"
],
"layout": "IPY_MODEL_068603b731574d9b8a8106c52e6ed69b"
}
},
"fa7470d741d54548a670375e61bb9ccd": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"fa80d89cedb240d88ec31a87c94af163": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"fab31e31a74c462790e2de77002a6584": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_80d49a9649204081a87f70ee80df93f0",
"max": 4,
"min": -4,
"step": 0.1,
"value": 0.8
}
},
"faf2f67cef4f4277acdccfc136f2e1ba": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "VBoxModel",
"state": {
"_dom_classes": [
"widget-interact"
],
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"children": [
"IPY_MODEL_16f63a3c902a4e01a457f3565b9f5722",
"IPY_MODEL_30f827f63b7d4eb8b0fcb6e72345f83f"
],
"layout": "IPY_MODEL_49532f7bf88d4bff94ddf28255ed4946"
}
},
"fbe4cd3a1e35497abc6fb0bb8664e8c4": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10(z_loop_spread/step)",
"layout": "IPY_MODEL_4c7e30af7aa1410091f4eea85d975e85",
"max": 4,
"min": -4,
"step": 0.1,
"value": 1.8
}
},
"fbfdf6a6375748c1ba9f4989f7fcfb4b": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"fced36bf9d74432dbd46013cee811cdc": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_1e71182ff4554ca6a6af38b625185251",
"msg_throttle": 1
}
},
"fdcc4d82e04249d5a614c5a7f5ac462c": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_6ae09faddcdc47ce816d646394d8f1fd",
"msg_throttle": 1
}
},
"fe28b2adce3a435f97f521e0120f3943": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "OutputModel",
"state": {
"_dom_classes": [],
"_model_module": "jupyter-js-widgets",
"_model_module_version": "~2.1.4",
"_view_module": "jupyter-js-widgets",
"_view_module_version": "~2.1.4",
"layout": "IPY_MODEL_3013d5f09d6e43838230f32dca57061b",
"msg_throttle": 1
}
},
"fe43299750b5402781703e74ec892c4e": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4"
}
},
"fe816e011086412688332d262d86cc96": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_return_scale)",
"layout": "IPY_MODEL_be15a7436d3141ca9800d9056004036f",
"max": 4,
"step": 0.1,
"value": 2.8
}
},
"fea34ba5e2fe4bb8baac94220eb39426": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_drift_step / 2 Pi)",
"layout": "IPY_MODEL_15288b1209f94538864d2cdc360d6f4e",
"max": 0,
"min": -4,
"step": 0.1
}
},
"feccdea0d4594e12a989d0b3792f067d": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "LayoutModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"height": "80px",
"width": "75%"
}
},
"ffc4826a5cf64704ae9b5a6b3a0d1bbe": {
"model_module": "jupyter-js-widgets",
"model_module_version": "~2.1.4",
"model_name": "FloatSliderModel",
"state": {
"_model_module_version": "~2.1.4",
"_view_module_version": "~2.1.4",
"description": "log10 (ang_rw_step / 2 Pi)",
"layout": "IPY_MODEL_3593212756894874a32a1fd256147227",
"max": 0,
"min": -4,
"step": 0.1,
"value": -1.2
}
}
},
"version_major": 1,
"version_minor": 0
}
}
},
"nbformat": 4,
"nbformat_minor": 2
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment