``````

In [10]:

import pandas as pd
import numpy as np
import matplotlib.pyplot as plt, mpld3
import ThermoPyle as TP
import CoolProp.CoolProp as CP
from cytoolz import get
import itertools as it
%matplotlib notebook
mpld3.enable_notebook()
#print(plt.style.available)
plt.style.use(["seaborn-talk","seaborn-notebook","seaborn-paper"])

``````
``````

In [9]:

%run ../scripts/der_CSV_gen.py

``````
``````

Iteration 0
Generating Initial Fluid Object.
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 11.194 seconds
Time Elapsed: 0 hours, 0 minutes, 11.194 seconds

Iteration 1 of 124:
Calculating Column d(P)/d(S)|U
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 11.184 seconds
Time Elapsed: 0 hours, 0 minutes, 22.378 seconds

Iteration 2 of 124:
Calculating Column d(G)/d(D)|T
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 10.643 seconds
Time Elapsed: 0 hours, 0 minutes, 33.024 seconds

Iteration 3 of 124:
Calculating Column d(S)/d(D)|P
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 10.733 seconds
Time Elapsed: 0 hours, 0 minutes, 43.758 seconds

Iteration 4 of 124:
Calculating Column d(T)/d(G)|D
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 10.638 seconds
Time Elapsed: 0 hours, 0 minutes, 54.397 seconds

Iteration 5 of 124:
Calculating Column d(T)/d(D)|G
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 11.417 seconds
Time Elapsed: 0 hours, 1 minutes, 5.814 seconds

Iteration 6 of 124:
Calculating Column d(S)/d(P)|D
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 10.369 seconds
Time Elapsed: 0 hours, 1 minutes, 16.183 seconds

Iteration 7 of 124:
Calculating Column d(S)/d(G)|D
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 10.603 seconds
Time Elapsed: 0 hours, 1 minutes, 26.787 seconds

Iteration 8 of 124:
Calculating Column d(U)/d(G)|D
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 11.198 seconds
Time Elapsed: 0 hours, 1 minutes, 37.985 seconds

Iteration 9 of 124:
Calculating Column d(P)/d(T)|S
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 10.949 seconds
Time Elapsed: 0 hours, 1 minutes, 48.934 seconds

Iteration 10 of 124:
Calculating Column d(S)/d(P)|U
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.952 seconds
Time Elapsed: 0 hours, 1 minutes, 58.887 seconds

Iteration 11 of 124:
Calculating Column d(G)/d(T)|P
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 11.421 seconds
Time Elapsed: 0 hours, 2 minutes, 10.307 seconds

Iteration 12 of 124:
Calculating Column d(D)/d(U)|T
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 11.041 seconds
Time Elapsed: 0 hours, 2 minutes, 21.348 seconds

Iteration 13 of 124:
Calculating Column d(P)/d(T)|U
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 11.416 seconds
Time Elapsed: 0 hours, 2 minutes, 32.764 seconds

Iteration 14 of 124:
Calculating Column d(T)/d(P)|G
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.415 seconds
Time Elapsed: 0 hours, 2 minutes, 42.179 seconds

Iteration 15 of 124:
Calculating Column d(S)/d(U)|D
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.361 seconds
Time Elapsed: 0 hours, 2 minutes, 51.54 seconds

Iteration 16 of 124:
Calculating Column d(P)/d(T)|D
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 10.797 seconds
Time Elapsed: 0 hours, 3 minutes, 2.337 seconds

Iteration 17 of 124:
Calculating Column d(P)/d(U)|T
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.895 seconds
Time Elapsed: 0 hours, 3 minutes, 12.232 seconds

Iteration 18 of 124:
Calculating Column d(S)/d(U)|P
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.702 seconds
Time Elapsed: 0 hours, 3 minutes, 21.934 seconds

Iteration 19 of 124:
Calculating Column d(D)/d(S)|P
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.947 seconds
Time Elapsed: 0 hours, 3 minutes, 31.881 seconds

Iteration 20 of 124:
Calculating Column d(S)/d(P)|T
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.72 seconds
Time Elapsed: 0 hours, 3 minutes, 41.601 seconds

Iteration 21 of 124:
Calculating Column d(T)/d(P)|D
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.769 seconds
Time Elapsed: 0 hours, 3 minutes, 51.37 seconds

Iteration 22 of 124:
Calculating Column d(T)/d(S)|G
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.745 seconds
Time Elapsed: 0 hours, 4 minutes, 1.115 seconds

Iteration 23 of 124:
Calculating Column d(D)/d(T)|S
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.753 seconds
Time Elapsed: 0 hours, 4 minutes, 10.868 seconds

Iteration 24 of 124:
Calculating Column d(U)/d(S)|G
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.897 seconds
Time Elapsed: 0 hours, 4 minutes, 20.765 seconds

Iteration 25 of 124:
Calculating Column d(T)/d(U)|S
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 10.12 seconds
Time Elapsed: 0 hours, 4 minutes, 30.885 seconds

Iteration 26 of 124:
Calculating Column d(P)/d(D)|S
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 10.711 seconds
Time Elapsed: 0 hours, 4 minutes, 41.596 seconds

Iteration 27 of 124:
Calculating Column d(D)/d(G)|P
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 13.808 seconds
Time Elapsed: 0 hours, 4 minutes, 55.404 seconds

Iteration 28 of 124:
Calculating Column d(T)/d(D)|U
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 13.979 seconds
Time Elapsed: 0 hours, 5 minutes, 9.383 seconds

Iteration 29 of 124:
Calculating Column d(P)/d(U)|S
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.901 seconds
Time Elapsed: 0 hours, 5 minutes, 19.284 seconds

Iteration 30 of 124:
Calculating Column d(U)/d(T)|D
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 10.014 seconds
Time Elapsed: 0 hours, 5 minutes, 29.297 seconds

Iteration 31 of 124:
Calculating Column d(P)/d(S)|T
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 12.244 seconds
Time Elapsed: 0 hours, 5 minutes, 41.541 seconds

Iteration 32 of 124:
Calculating Column d(D)/d(S)|G
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 12.406 seconds
Time Elapsed: 0 hours, 5 minutes, 53.948 seconds

Iteration 33 of 124:
Calculating Column d(S)/d(U)|G
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 12.027 seconds
Time Elapsed: 0 hours, 6 minutes, 5.975 seconds

Iteration 34 of 124:
Calculating Column d(G)/d(T)|U
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 12.804 seconds
Time Elapsed: 0 hours, 6 minutes, 18.78 seconds

Iteration 35 of 124:
Calculating Column d(G)/d(P)|D
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.615 seconds
Time Elapsed: 0 hours, 6 minutes, 28.395 seconds

Iteration 36 of 124:
Calculating Column d(S)/d(U)|T
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 10.652 seconds
Time Elapsed: 0 hours, 6 minutes, 39.047 seconds

Iteration 37 of 124:
Calculating Column d(G)/d(D)|S
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 12.476 seconds
Time Elapsed: 0 hours, 6 minutes, 51.528 seconds

Iteration 38 of 124:
Calculating Column d(U)/d(T)|G
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 12.636 seconds
Time Elapsed: 0 hours, 7 minutes, 4.164 seconds

Iteration 39 of 124:
Calculating Column d(P)/d(S)|G
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.979 seconds
Time Elapsed: 0 hours, 7 minutes, 14.143 seconds

Iteration 40 of 124:
Calculating Column d(T)/d(S)|U
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 11.951 seconds
Time Elapsed: 0 hours, 7 minutes, 26.094 seconds

Iteration 41 of 124:
Calculating Column d(D)/d(T)|G
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 11.975 seconds
Time Elapsed: 0 hours, 7 minutes, 38.069 seconds

Iteration 42 of 124:
Calculating Column d(S)/d(G)|U
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 11.603 seconds
Time Elapsed: 0 hours, 7 minutes, 49.672 seconds

Iteration 43 of 124:
Calculating Column d(P)/d(G)|U
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 12.305 seconds
Time Elapsed: 0 hours, 8 minutes, 1.976 seconds

Iteration 44 of 124:
Calculating Column d(G)/d(U)|P
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.884 seconds
Time Elapsed: 0 hours, 8 minutes, 11.86 seconds

Iteration 45 of 124:
Calculating Column d(S)/d(D)|T
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 10.839 seconds
Time Elapsed: 0 hours, 8 minutes, 22.7 seconds

Iteration 46 of 124:
Calculating Column d(D)/d(P)|S
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 11.649 seconds
Time Elapsed: 0 hours, 8 minutes, 34.349 seconds

Iteration 47 of 124:
Calculating Column d(G)/d(S)|P
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 16.546 seconds
Time Elapsed: 0 hours, 8 minutes, 50.895 seconds

Iteration 48 of 124:
Calculating Column d(D)/d(P)|U
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 13.253 seconds
Time Elapsed: 0 hours, 9 minutes, 4.148 seconds

Iteration 49 of 124:
Calculating Column d(G)/d(S)|D
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 13.55 seconds
Time Elapsed: 0 hours, 9 minutes, 17.698 seconds

Iteration 50 of 124:
Calculating Column d(U)/d(D)|T
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 15.743 seconds
Time Elapsed: 0 hours, 9 minutes, 33.442 seconds

Iteration 51 of 124:
Calculating Column d(S)/d(T)|P
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 12.692 seconds
Time Elapsed: 0 hours, 9 minutes, 46.134 seconds

Iteration 52 of 124:
Calculating Column d(U)/d(P)|S
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 14.055 seconds
Time Elapsed: 0 hours, 10 minutes, 0.189 seconds

Iteration 53 of 124:
Calculating Column d(G)/d(T)|S
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 10.735 seconds
Time Elapsed: 0 hours, 10 minutes, 10.924 seconds

Iteration 54 of 124:
Calculating Column PHASE
================================================
Success!
This Iteration: 0 hours, 0 minutes, 8.87 seconds
Time Elapsed: 0 hours, 10 minutes, 19.794 seconds

Iteration 55 of 124:
Calculating Column d(D)/d(U)|P
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 10.0 seconds
Time Elapsed: 0 hours, 10 minutes, 29.794 seconds

Iteration 56 of 124:
Calculating Column d(T)/d(U)|G
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.074 seconds
Time Elapsed: 0 hours, 10 minutes, 38.869 seconds

Iteration 57 of 124:
Calculating Column d(U)/d(G)|P
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.328 seconds
Time Elapsed: 0 hours, 10 minutes, 48.197 seconds

Iteration 58 of 124:
Calculating Column d(U)/d(T)|P
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 10.748 seconds
Time Elapsed: 0 hours, 10 minutes, 58.946 seconds

Iteration 59 of 124:
Calculating Column d(U)/d(P)|D
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.947 seconds
Time Elapsed: 0 hours, 11 minutes, 8.893 seconds

Iteration 60 of 124:
Calculating Column d(U)/d(S)|D
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.222 seconds
Time Elapsed: 0 hours, 11 minutes, 18.116 seconds

Iteration 61 of 124:
Calculating Column d(U)/d(D)|S
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 10.429 seconds
Time Elapsed: 0 hours, 11 minutes, 28.544 seconds

Iteration 62 of 124:
Calculating Column G
============================================
Success!
This Iteration: 0 hours, 0 minutes, 11.214 seconds
Time Elapsed: 0 hours, 11 minutes, 39.758 seconds

Iteration 63 of 124:
Calculating Column d(U)/d(G)|S
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 10.418 seconds
Time Elapsed: 0 hours, 11 minutes, 50.176 seconds

Iteration 64 of 124:
Calculating Column d(U)/d(D)|G
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.931 seconds
Time Elapsed: 0 hours, 12 minutes, 0.106 seconds

Iteration 65 of 124:
Calculating Column d(S)/d(P)|G
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.409 seconds
Time Elapsed: 0 hours, 12 minutes, 9.515 seconds

Iteration 66 of 124:
Calculating Column d(T)/d(G)|U
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 17.732 seconds
Time Elapsed: 0 hours, 12 minutes, 27.248 seconds

Iteration 67 of 124:
Calculating Column d(P)/d(U)|G
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 15.979 seconds
Time Elapsed: 0 hours, 12 minutes, 43.227 seconds

Iteration 68 of 124:
Calculating Column d(U)/d(P)|G
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 11.993 seconds
Time Elapsed: 0 hours, 12 minutes, 55.219 seconds

Iteration 69 of 124:
Calculating Column d(S)/d(D)|U
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 13.799 seconds
Time Elapsed: 0 hours, 13 minutes, 9.018 seconds

Iteration 70 of 124:
Calculating Column d(U)/d(P)|T
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 10.66 seconds
Time Elapsed: 0 hours, 13 minutes, 19.679 seconds

Iteration 71 of 124:
Calculating Column d(U)/d(S)|P
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 11.627 seconds
Time Elapsed: 0 hours, 13 minutes, 31.306 seconds

Iteration 72 of 124:
Calculating Column d(P)/d(D)|U
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 11.018 seconds
Time Elapsed: 0 hours, 13 minutes, 42.324 seconds

Iteration 73 of 124:
Calculating Column d(T)/d(S)|D
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.799 seconds
Time Elapsed: 0 hours, 13 minutes, 52.124 seconds

Iteration 74 of 124:
Calculating Column S
============================================
Success!
This Iteration: 0 hours, 0 minutes, 9.356 seconds
Time Elapsed: 0 hours, 14 minutes, 1.479 seconds

Iteration 75 of 124:
Calculating Column d(S)/d(D)|G
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.467 seconds
Time Elapsed: 0 hours, 14 minutes, 10.946 seconds

Iteration 76 of 124:
Calculating Column d(U)/d(T)|S
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.52 seconds
Time Elapsed: 0 hours, 14 minutes, 20.467 seconds

Iteration 77 of 124:
Calculating Column d(P)/d(D)|G
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.628 seconds
Time Elapsed: 0 hours, 14 minutes, 30.094 seconds

Iteration 78 of 124:
Calculating Column d(D)/d(G)|U
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.41 seconds
Time Elapsed: 0 hours, 14 minutes, 39.505 seconds

Iteration 79 of 124:
Calculating Column d(T)/d(D)|P
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.235 seconds
Time Elapsed: 0 hours, 14 minutes, 48.74 seconds

Iteration 80 of 124:
Calculating Column d(S)/d(G)|P
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.321 seconds
Time Elapsed: 0 hours, 14 minutes, 58.061 seconds

Iteration 81 of 124:
Calculating Column d(T)/d(G)|S
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.128 seconds
Time Elapsed: 0 hours, 15 minutes, 7.189 seconds

Iteration 82 of 124:
Calculating Column d(D)/d(T)|P
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 8.974 seconds
Time Elapsed: 0 hours, 15 minutes, 16.162 seconds

Iteration 83 of 124:
Calculating Column d(U)/d(S)|T
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.693 seconds
Time Elapsed: 0 hours, 15 minutes, 25.855 seconds

Iteration 84 of 124:
Calculating Column d(T)/d(P)|U
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.222 seconds
Time Elapsed: 0 hours, 15 minutes, 35.078 seconds

Iteration 85 of 124:
Calculating Column d(S)/d(T)|U
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.14 seconds
Time Elapsed: 0 hours, 15 minutes, 44.218 seconds

Iteration 86 of 124:
Calculating Column d(G)/d(U)|S
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.179 seconds
Time Elapsed: 0 hours, 15 minutes, 53.397 seconds

Iteration 87 of 124:
Calculating Column d(P)/d(G)|T
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.108 seconds
Time Elapsed: 0 hours, 16 minutes, 2.505 seconds

Iteration 88 of 124:
Calculating Column d(T)/d(P)|S
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.22 seconds
Time Elapsed: 0 hours, 16 minutes, 11.725 seconds

Iteration 89 of 124:
Calculating Column d(S)/d(G)|T
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.25 seconds
Time Elapsed: 0 hours, 16 minutes, 20.975 seconds

Iteration 90 of 124:
Calculating Column d(T)/d(G)|P
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.253 seconds
Time Elapsed: 0 hours, 16 minutes, 30.228 seconds

Iteration 91 of 124:
Calculating Column d(P)/d(U)|D
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.06 seconds
Time Elapsed: 0 hours, 16 minutes, 39.289 seconds

Iteration 92 of 124:
Calculating Column d(G)/d(P)|S
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.799 seconds
Time Elapsed: 0 hours, 16 minutes, 49.088 seconds

Iteration 93 of 124:
Calculating Column d(G)/d(P)|T
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 11.251 seconds
Time Elapsed: 0 hours, 17 minutes, 0.339 seconds

Iteration 94 of 124:
Calculating Column d(G)/d(S)|U
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.924 seconds
Time Elapsed: 0 hours, 17 minutes, 10.263 seconds

Iteration 95 of 124:
Calculating Column d(G)/d(U)|T
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.271 seconds
Time Elapsed: 0 hours, 17 minutes, 19.534 seconds

Iteration 96 of 124:
Calculating Column d(T)/d(D)|S
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.586 seconds
Time Elapsed: 0 hours, 17 minutes, 29.12 seconds

Iteration 97 of 124:
Calculating Column d(D)/d(U)|G
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.472 seconds
Time Elapsed: 0 hours, 17 minutes, 38.592 seconds

Iteration 98 of 124:
Calculating Column d(D)/d(G)|S
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.238 seconds
Time Elapsed: 0 hours, 17 minutes, 47.83 seconds

Iteration 99 of 124:
Calculating Column d(S)/d(T)|G
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.157 seconds
Time Elapsed: 0 hours, 17 minutes, 56.988 seconds

Iteration 100 of 124:
Calculating Column d(D)/d(S)|T
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.006 seconds
Time Elapsed: 0 hours, 18 minutes, 5.994 seconds

Iteration 101 of 124:
Calculating Column d(D)/d(T)|U
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.153 seconds
Time Elapsed: 0 hours, 18 minutes, 15.147 seconds

Iteration 102 of 124:
Calculating Column d(P)/d(S)|D
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.314 seconds
Time Elapsed: 0 hours, 18 minutes, 24.46 seconds

Iteration 103 of 124:
Calculating Column d(T)/d(U)|P
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.168 seconds
Time Elapsed: 0 hours, 18 minutes, 33.628 seconds

Iteration 104 of 124:
Calculating Column d(D)/d(U)|S
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.306 seconds
Time Elapsed: 0 hours, 18 minutes, 42.935 seconds

Iteration 105 of 124:
Calculating Column d(G)/d(U)|D
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.365 seconds
Time Elapsed: 0 hours, 18 minutes, 52.3 seconds

Iteration 106 of 124:
Calculating Column d(P)/d(D)|T
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.258 seconds
Time Elapsed: 0 hours, 19 minutes, 1.558 seconds

Iteration 107 of 124:
Calculating Column d(P)/d(G)|D
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.222 seconds
Time Elapsed: 0 hours, 19 minutes, 10.78 seconds

Iteration 108 of 124:
Calculating Column d(T)/d(S)|P
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.082 seconds
Time Elapsed: 0 hours, 19 minutes, 19.862 seconds

Iteration 109 of 124:
Calculating Column d(T)/d(U)|D
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.378 seconds
Time Elapsed: 0 hours, 19 minutes, 29.24 seconds

Iteration 110 of 124:
Calculating Column d(G)/d(S)|T
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.223 seconds
Time Elapsed: 0 hours, 19 minutes, 38.463 seconds

Iteration 111 of 124:
Calculating Column d(D)/d(P)|T
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 8.993 seconds
Time Elapsed: 0 hours, 19 minutes, 47.456 seconds

Iteration 112 of 124:
Calculating Column d(P)/d(T)|G
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.289 seconds
Time Elapsed: 0 hours, 19 minutes, 56.745 seconds

Iteration 113 of 124:
Calculating Column d(D)/d(P)|G
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.279 seconds
Time Elapsed: 0 hours, 20 minutes, 6.024 seconds

Iteration 114 of 124:
Calculating Column d(G)/d(D)|U
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.199 seconds
Time Elapsed: 0 hours, 20 minutes, 15.223 seconds

Iteration 115 of 124:
Calculating Column d(D)/d(S)|U
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.121 seconds
Time Elapsed: 0 hours, 20 minutes, 24.344 seconds

Iteration 116 of 124:
Calculating Column d(G)/d(T)|D
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.237 seconds
Time Elapsed: 0 hours, 20 minutes, 33.581 seconds

Iteration 117 of 124:
Calculating Column d(G)/d(D)|P
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.118 seconds
Time Elapsed: 0 hours, 20 minutes, 42.699 seconds

Iteration 118 of 124:
Calculating Column d(G)/d(P)|U
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.171 seconds
Time Elapsed: 0 hours, 20 minutes, 51.871 seconds

Iteration 119 of 124:
Calculating Column d(D)/d(G)|T
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.133 seconds
Time Elapsed: 0 hours, 21 minutes, 1.003 seconds

Iteration 120 of 124:
Calculating Column D
============================================
Success!
This Iteration: 0 hours, 0 minutes, 8.948 seconds
Time Elapsed: 0 hours, 21 minutes, 9.951 seconds

Iteration 121 of 124:
Calculating Column d(U)/d(D)|P
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.154 seconds
Time Elapsed: 0 hours, 21 minutes, 19.105 seconds

Iteration 122 of 124:
Calculating Column d(U)/d(G)|T
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.3 seconds
Time Elapsed: 0 hours, 21 minutes, 28.405 seconds

Iteration 123 of 124:
Calculating Column d(S)/d(T)|D
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.169 seconds
Time Elapsed: 0 hours, 21 minutes, 37.574 seconds

Iteration 124 of 124:
Calculating Column d(P)/d(G)|S
======================================================
Success!
This Iteration: 0 hours, 0 minutes, 9.175 seconds
Time Elapsed: 0 hours, 21 minutes, 46.75 seconds

---------------------------------------------------------------------------
NameError                                 Traceback (most recent call last)
C:\Users\at8183jk\Desktop\Drive\Dropsync\School\Winona\ResearchProject\code\scripts\der_CSV_gen.py in <module>()
67
68
---> 69 myfluid.data["V"] = pd.Series(myfluid.M / myfluid.data["D"], index=myfluid.data.index)
70 myfluid.refresh()
71 myfluid.clean()

NameError: name 'pd' is not defined

``````
``````

In [17]:

myfluid.data["V"] = pd.Series(myfluid.M / myfluid.data["D"], index=myfluid.data.index)
myfluid.refresh()
myfluid.clean()

``````
``````

In [19]:

myfluid.write_data("../finalData/", mode="dual", filename="with_derivatives_and_volume")

``````
``````

In [26]:

rescaled = myfluid.copy()

``````
``````

In [23]:

varrange = {col:[min(rescaled.data[col]),max(rescaled.data[col])] for col in rescaled.vars}

invars = ["T", "P", "S", "D", "V"]

for var in invars:
rescaled.data[var] = rescaled.data[var].apply(TP.rescale(get(var, varrange), [0,216]))

rescaled.data["U"] = rescaled.data["U"].apply(TP.rescale(urange, [15, 152]))

``````
``````

In [27]:

rescaled.write_data("../finalData/", mode="dual", filename="with_derivatives_and_volume_SCALED")

``````
``````

In [40]:

for i in range(10):
dU = 0.1*i + 0.1
uSel = 10 + 10*i
rescaled.data.ix[np.abs(rescaled.data["U"] - uSel) <= 1, "U"] = rescaled.data.ix[np.abs(rescaled.data["U"] - uSel) <= 1 , "U"] + dU

rescaled.data.ix[np.abs(rescaled.data["d(U)/d(S)|P"] - 400) <= 50, 'U'] = rescaled.data.ix[np.abs(rescaled.data["d(U)/d(S)|P"] - 400) <= 50, 'U'] + 5

``````
``````

In [41]:

TP.fluid_plot(rescaled)

``````
``````

var element = \$('#96498a5c-610e-4bbd-aa3e-8b8662872b1e');
/* Put everything inside the global mpl namespace */
window.mpl = {};

mpl.get_websocket_type = function() {
if (typeof(WebSocket) !== 'undefined') {
return WebSocket;
} else if (typeof(MozWebSocket) !== 'undefined') {
return MozWebSocket;
} else {
alert('Your browser does not have WebSocket support.' +
'Please try Chrome, Safari or Firefox ≥ 6. ' +
'Firefox 4 and 5 are also supported but you ' +
'have to enable WebSockets in about:config.');
};
}

mpl.figure = function(figure_id, websocket, ondownload, parent_element) {
this.id = figure_id;

this.ws = websocket;

this.supports_binary = (this.ws.binaryType != undefined);

if (!this.supports_binary) {
var warnings = document.getElementById("mpl-warnings");
if (warnings) {
warnings.style.display = 'block';
warnings.textContent = (
"This browser does not support binary websocket messages. " +
"Performance may be slow.");
}
}

this.imageObj = new Image();

this.context = undefined;
this.message = undefined;
this.canvas = undefined;
this.rubberband_canvas = undefined;
this.rubberband_context = undefined;
this.format_dropdown = undefined;

this.image_mode = 'full';

this.root = \$('<div/>');
this._root_extra_style(this.root)
this.root.attr('style', 'display: inline-block');

\$(parent_element).append(this.root);

this._init_canvas(this);
this._init_toolbar(this);

var fig = this;

this.waiting = false;

this.ws.onopen =  function () {
fig.send_message("supports_binary", {value: fig.supports_binary});
fig.send_message("send_image_mode", {});
if (mpl.ratio != 1) {
fig.send_message("set_dpi_ratio", {'dpi_ratio': mpl.ratio});
}
fig.send_message("refresh", {});
}

this.imageObj.onload = function() {
if (fig.image_mode == 'full') {
// Full images could contain transparency (where diff images
// almost always do), so we need to clear the canvas so that
// there is no ghosting.
fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);
}
fig.context.drawImage(fig.imageObj, 0, 0);
};

this.imageObj.onunload = function() {
this.ws.close();
}

this.ws.onmessage = this._make_on_message_function(this);

}

mpl.figure.prototype._init_header = function() {
var titlebar = \$(
'<div class="ui-dialog-titlebar ui-widget-header ui-corner-all ' +
'ui-helper-clearfix"/>');
var titletext = \$(
'<div class="ui-dialog-title" style="width: 100%; ' +
'text-align: center; padding: 3px;"/>');
titlebar.append(titletext)
this.root.append(titlebar);
}

mpl.figure.prototype._canvas_extra_style = function(canvas_div) {

}

mpl.figure.prototype._root_extra_style = function(canvas_div) {

}

mpl.figure.prototype._init_canvas = function() {
var fig = this;

var canvas_div = \$('<div/>');

canvas_div.attr('style', 'position: relative; clear: both; outline: 0');

function canvas_keyboard_event(event) {
return fig.key_event(event, event['data']);
}

canvas_div.keydown('key_press', canvas_keyboard_event);
canvas_div.keyup('key_release', canvas_keyboard_event);
this.canvas_div = canvas_div
this._canvas_extra_style(canvas_div)
this.root.append(canvas_div);

var canvas = \$('<canvas/>');
canvas.attr('style', "left: 0; top: 0; z-index: 0; outline: 0")

this.canvas = canvas[0];
this.context = canvas[0].getContext("2d");

var backingStore = this.context.backingStorePixelRatio ||
this.context.webkitBackingStorePixelRatio ||
this.context.mozBackingStorePixelRatio ||
this.context.msBackingStorePixelRatio ||
this.context.oBackingStorePixelRatio ||
this.context.backingStorePixelRatio || 1;

mpl.ratio = (window.devicePixelRatio || 1) / backingStore;

var rubberband = \$('<canvas/>');
rubberband.attr('style', "position: absolute; left: 0; top: 0; z-index: 1;")

var pass_mouse_events = true;

canvas_div.resizable({
start: function(event, ui) {
pass_mouse_events = false;
},
resize: function(event, ui) {
fig.request_resize(ui.size.width, ui.size.height);
},
stop: function(event, ui) {
pass_mouse_events = true;
fig.request_resize(ui.size.width, ui.size.height);
},
});

function mouse_event_fn(event) {
if (pass_mouse_events)
return fig.mouse_event(event, event['data']);
}

rubberband.mousedown('button_press', mouse_event_fn);
rubberband.mouseup('button_release', mouse_event_fn);
// Throttle sequential mouse events to 1 every 20ms.
rubberband.mousemove('motion_notify', mouse_event_fn);

rubberband.mouseenter('figure_enter', mouse_event_fn);
rubberband.mouseleave('figure_leave', mouse_event_fn);

canvas_div.on("wheel", function (event) {
event = event.originalEvent;
event['data'] = 'scroll'
if (event.deltaY < 0) {
event.step = 1;
} else {
event.step = -1;
}
mouse_event_fn(event);
});

canvas_div.append(canvas);
canvas_div.append(rubberband);

this.rubberband = rubberband;
this.rubberband_canvas = rubberband[0];
this.rubberband_context = rubberband[0].getContext("2d");
this.rubberband_context.strokeStyle = "#000000";

this._resize_canvas = function(width, height) {
// Keep the size of the canvas, canvas container, and rubber band
// canvas in synch.
canvas_div.css('width', width)
canvas_div.css('height', height)

canvas.attr('width', width * mpl.ratio);
canvas.attr('height', height * mpl.ratio);
canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');

rubberband.attr('width', width);
rubberband.attr('height', height);
}

// Set the figure to an initial 600x600px, this will subsequently be updated
// upon first draw.
this._resize_canvas(600, 600);

// Disable right mouse context menu.
return false;
});

function set_focus () {
canvas.focus();
canvas_div.focus();
}

window.setTimeout(set_focus, 100);
}

mpl.figure.prototype._init_toolbar = function() {
var fig = this;

var nav_element = \$('<div/>')
nav_element.attr('style', 'width: 100%');
this.root.append(nav_element);

// Define a callback function for later on.
function toolbar_event(event) {
return fig.toolbar_button_onclick(event['data']);
}
function toolbar_mouse_event(event) {
return fig.toolbar_button_onmouseover(event['data']);
}

for(var toolbar_ind in mpl.toolbar_items) {
var name = mpl.toolbar_items[toolbar_ind][0];
var tooltip = mpl.toolbar_items[toolbar_ind][1];
var image = mpl.toolbar_items[toolbar_ind][2];
var method_name = mpl.toolbar_items[toolbar_ind][3];

if (!name) {
// put a spacer in here.
continue;
}
var button = \$('<button/>');
button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +
'ui-button-icon-only');
button.attr('role', 'button');
button.attr('aria-disabled', 'false');
button.click(method_name, toolbar_event);
button.mouseover(tooltip, toolbar_mouse_event);

var icon_img = \$('<span/>');

var tooltip_span = \$('<span/>');
tooltip_span.html(tooltip);

button.append(icon_img);
button.append(tooltip_span);

nav_element.append(button);
}

var fmt_picker_span = \$('<span/>');

var fmt_picker = \$('<select/>');
fmt_picker_span.append(fmt_picker);
nav_element.append(fmt_picker_span);
this.format_dropdown = fmt_picker[0];

for (var ind in mpl.extensions) {
var fmt = mpl.extensions[ind];
var option = \$(
'<option/>', {selected: fmt === mpl.default_extension}).html(fmt);
fmt_picker.append(option)
}

// Add hover states to the ui-buttons
\$( ".ui-button" ).hover(
function() { \$(this).removeClass("ui-state-hover");}
);

var status_bar = \$('<span class="mpl-message"/>');
nav_element.append(status_bar);
this.message = status_bar[0];
}

mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {
// Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,
// which will in turn request a refresh of the image.
this.send_message('resize', {'width': x_pixels, 'height': y_pixels});
}

mpl.figure.prototype.send_message = function(type, properties) {
properties['type'] = type;
properties['figure_id'] = this.id;
this.ws.send(JSON.stringify(properties));
}

mpl.figure.prototype.send_draw_message = function() {
if (!this.waiting) {
this.waiting = true;
this.ws.send(JSON.stringify({type: "draw", figure_id: this.id}));
}
}

mpl.figure.prototype.handle_save = function(fig, msg) {
var format_dropdown = fig.format_dropdown;
var format = format_dropdown.options[format_dropdown.selectedIndex].value;
}

mpl.figure.prototype.handle_resize = function(fig, msg) {
var size = msg['size'];
if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {
fig._resize_canvas(size[0], size[1]);
fig.send_message("refresh", {});
};
}

mpl.figure.prototype.handle_rubberband = function(fig, msg) {
var x0 = msg['x0'] / mpl.ratio;
var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;
var x1 = msg['x1'] / mpl.ratio;
var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;
x0 = Math.floor(x0) + 0.5;
y0 = Math.floor(y0) + 0.5;
x1 = Math.floor(x1) + 0.5;
y1 = Math.floor(y1) + 0.5;
var min_x = Math.min(x0, x1);
var min_y = Math.min(y0, y1);
var width = Math.abs(x1 - x0);
var height = Math.abs(y1 - y0);

fig.rubberband_context.clearRect(
0, 0, fig.canvas.width, fig.canvas.height);

fig.rubberband_context.strokeRect(min_x, min_y, width, height);
}

mpl.figure.prototype.handle_figure_label = function(fig, msg) {
// Updates the figure title.
}

mpl.figure.prototype.handle_cursor = function(fig, msg) {
var cursor = msg['cursor'];
switch(cursor)
{
case 0:
cursor = 'pointer';
break;
case 1:
cursor = 'default';
break;
case 2:
cursor = 'crosshair';
break;
case 3:
cursor = 'move';
break;
}
fig.rubberband_canvas.style.cursor = cursor;
}

mpl.figure.prototype.handle_message = function(fig, msg) {
fig.message.textContent = msg['message'];
}

mpl.figure.prototype.handle_draw = function(fig, msg) {
// Request the server to send over a new figure.
fig.send_draw_message();
}

mpl.figure.prototype.handle_image_mode = function(fig, msg) {
fig.image_mode = msg['mode'];
}

mpl.figure.prototype.updated_canvas_event = function() {
// Called whenever the canvas gets updated.
this.send_message("ack", {});
}

// A function to construct a web socket function for onmessage handling.
// Called in the figure constructor.
mpl.figure.prototype._make_on_message_function = function(fig) {
return function socket_on_message(evt) {
if (evt.data instanceof Blob) {
/* FIXME: We get "Resource interpreted as Image but
* transferred with MIME type text/plain:" errors on
* Chrome.  But how to set the MIME type?  It doesn't seem
* to be part of the websocket stream */
evt.data.type = "image/png";

/* Free the memory for the previous frames */
if (fig.imageObj.src) {
(window.URL || window.webkitURL).revokeObjectURL(
fig.imageObj.src);
}

fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(
evt.data);
fig.updated_canvas_event();
fig.waiting = false;
return;
}
else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == "data:image/png;base64") {
fig.imageObj.src = evt.data;
fig.updated_canvas_event();
fig.waiting = false;
return;
}

var msg = JSON.parse(evt.data);
var msg_type = msg['type'];

// Call the  "handle_{type}" callback, which takes
// the figure and JSON message as its only arguments.
try {
var callback = fig["handle_" + msg_type];
} catch (e) {
console.log("No handler for the '" + msg_type + "' message type: ", msg);
return;
}

if (callback) {
try {
// console.log("Handling '" + msg_type + "' message: ", msg);
callback(fig, msg);
} catch (e) {
console.log("Exception inside the 'handler_" + msg_type + "' callback:", e, e.stack, msg);
}
}
};
}

// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas
mpl.findpos = function(e) {
//this section is from http://www.quirksmode.org/js/events_properties.html
var targ;
if (!e)
e = window.event;
if (e.target)
targ = e.target;
else if (e.srcElement)
targ = e.srcElement;
if (targ.nodeType == 3) // defeat Safari bug
targ = targ.parentNode;

// jQuery normalizes the pageX and pageY
// pageX,Y are the mouse positions relative to the document
// offset() returns the position of the element relative to the document
var x = e.pageX - \$(targ).offset().left;
var y = e.pageY - \$(targ).offset().top;

return {"x": x, "y": y};
};

/*
* return a copy of an object with only non-object keys
* we need this to avoid circular references
* http://stackoverflow.com/a/24161582/3208463
*/
function simpleKeys (original) {
return Object.keys(original).reduce(function (obj, key) {
if (typeof original[key] !== 'object')
obj[key] = original[key]
return obj;
}, {});
}

mpl.figure.prototype.mouse_event = function(event, name) {
var canvas_pos = mpl.findpos(event)

if (name === 'button_press')
{
this.canvas.focus();
this.canvas_div.focus();
}

var x = canvas_pos.x * mpl.ratio;
var y = canvas_pos.y * mpl.ratio;

this.send_message(name, {x: x, y: y, button: event.button,
step: event.step,
guiEvent: simpleKeys(event)});

/* This prevents the web browser from automatically changing to
* the text insertion cursor when the button is pressed.  We want
* to control all of the cursor setting manually through the
* 'cursor' event from matplotlib */
event.preventDefault();
return false;
}

mpl.figure.prototype._key_event_extra = function(event, name) {
// Handle any extra behaviour associated with a key event
}

mpl.figure.prototype.key_event = function(event, name) {

// Prevent repeat events
if (name == 'key_press')
{
if (event.which === this._key)
return;
else
this._key = event.which;
}
if (name == 'key_release')
this._key = null;

var value = '';
if (event.ctrlKey && event.which != 17)
value += "ctrl+";
if (event.altKey && event.which != 18)
value += "alt+";
if (event.shiftKey && event.which != 16)
value += "shift+";

value += 'k';
value += event.which.toString();

this._key_event_extra(event, name);

this.send_message(name, {key: value,
guiEvent: simpleKeys(event)});
return false;
}

mpl.figure.prototype.toolbar_button_onclick = function(name) {
this.handle_save(this, null);
} else {
this.send_message("toolbar_button", {name: name});
}
};

mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {
this.message.textContent = tooltip;
};
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"]];

mpl.extensions = ["eps", "jpeg", "pdf", "png", "ps", "raw", "svg", "tif"];

mpl.default_extension = "png";var comm_websocket_adapter = function(comm) {
// Create a "websocket"-like object which calls the given IPython comm
// object with the appropriate methods. Currently this is a non binary
// socket, so there is still some room for performance tuning.
var ws = {};

ws.close = function() {
comm.close()
};
ws.send = function(m) {
//console.log('sending', m);
comm.send(m);
};
// Register the callback with on_msg.
comm.on_msg(function(msg) {
//console.log('receiving', msg['content']['data'], msg);
// Pass the mpl event to the overriden (by mpl) onmessage function.
ws.onmessage(msg['content']['data'])
});
return ws;
}

mpl.mpl_figure_comm = function(comm, msg) {
// This is the function which gets called when the mpl process
// starts-up an IPython Comm through the "matplotlib" channel.

var id = msg.content.data.id;
// Get hold of the div created by the display call when the Comm
// socket was opened in Python.
var element = \$("#" + id);
var ws_proxy = comm_websocket_adapter(comm)

window.open(figure.imageObj.src);
}

var fig = new mpl.figure(id, ws_proxy,
element.get(0));

// Call onopen now - mpl needs it, as it is assuming we've passed it a real
// web socket which is closed, not our websocket->open comm proxy.
ws_proxy.onopen();

fig.parent_element = element.get(0);
fig.cell_info = mpl.find_output_cell("<div id='" + id + "'></div>");
if (!fig.cell_info) {
console.error("Failed to find cell for figure", id, fig);
return;
}

var output_index = fig.cell_info[2]
var cell = fig.cell_info[0];

};

mpl.figure.prototype.handle_close = function(fig, msg) {
var width = fig.canvas.width/mpl.ratio
fig.root.unbind('remove')

// Update the output cell to use the data from the current canvas.
fig.push_to_output();
var dataURL = fig.canvas.toDataURL();
// Re-enable the keyboard manager in IPython - without this line, in FF,
// the notebook keyboard shortcuts fail.
IPython.keyboard_manager.enable()
\$(fig.parent_element).html('<amp-img layout="responsive" width="500" height="300" src="' + dataURL + '" width="' + width + '">');
fig.close_ws(fig, msg);
}

mpl.figure.prototype.close_ws = function(fig, msg){
fig.send_message('closing', msg);
// fig.ws.close()
}

mpl.figure.prototype.push_to_output = function(remove_interactive) {
// Turn the data on the canvas into data in the output cell.
var width = this.canvas.width/mpl.ratio
var dataURL = this.canvas.toDataURL();
this.cell_info[1]['text/html'] = '<amp-img layout="responsive" width="500" height="300" src="' + dataURL + '" width="' + width + '">';
}

mpl.figure.prototype.updated_canvas_event = function() {
// Tell IPython that the notebook contents must change.
IPython.notebook.set_dirty(true);
this.send_message("ack", {});
var fig = this;
// Wait a second, then push the new image to the DOM so
// that it is saved nicely (might be nice to debounce this).
setTimeout(function () { fig.push_to_output() }, 1000);
}

mpl.figure.prototype._init_toolbar = function() {
var fig = this;

var nav_element = \$('<div/>')
nav_element.attr('style', 'width: 100%');
this.root.append(nav_element);

// Define a callback function for later on.
function toolbar_event(event) {
return fig.toolbar_button_onclick(event['data']);
}
function toolbar_mouse_event(event) {
return fig.toolbar_button_onmouseover(event['data']);
}

for(var toolbar_ind in mpl.toolbar_items){
var name = mpl.toolbar_items[toolbar_ind][0];
var tooltip = mpl.toolbar_items[toolbar_ind][1];
var image = mpl.toolbar_items[toolbar_ind][2];
var method_name = mpl.toolbar_items[toolbar_ind][3];

if (!name) { continue; };

var button = \$('<button class="btn btn-default" href="#" title="' + name + '"><i class="fa ' + image + ' fa-lg"></i></button>');
button.click(method_name, toolbar_event);
button.mouseover(tooltip, toolbar_mouse_event);
nav_element.append(button);
}

// Add the status bar.
var status_bar = \$('<span class="mpl-message" style="text-align:right; float: right;"/>');
nav_element.append(status_bar);
this.message = status_bar[0];

// Add the close button to the window.
var buttongrp = \$('<div class="btn-group inline pull-right"></div>');
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>');
button.click(function (evt) { fig.handle_close(fig, {}); } );
button.mouseover('Stop Interaction', toolbar_mouse_event);
buttongrp.append(button);
var titlebar = this.root.find(\$('.ui-dialog-titlebar'));
titlebar.prepend(buttongrp);
}

mpl.figure.prototype._root_extra_style = function(el){
var fig = this
el.on("remove", function(){
fig.close_ws(fig, {});
});
}

mpl.figure.prototype._canvas_extra_style = function(el){
// this is important to make the div 'focusable
el.attr('tabindex', 0)
// reach out to IPython and tell the keyboard manager to turn it's self
// off when our div gets focus

// location in version 3
if (IPython.notebook.keyboard_manager) {
IPython.notebook.keyboard_manager.register_events(el);
}
else {
// location in version 2
IPython.keyboard_manager.register_events(el);
}

}

mpl.figure.prototype._key_event_extra = function(event, name) {
var manager = IPython.notebook.keyboard_manager;
if (!manager)
manager = IPython.keyboard_manager;

// Check for shift+enter
if (event.shiftKey && event.which == 13) {
this.canvas_div.blur();
// select the cell after this one
var index = IPython.notebook.find_cell_index(this.cell_info[0]);
IPython.notebook.select(index + 1);
}
}

mpl.figure.prototype.handle_save = function(fig, msg) {
}

mpl.find_output_cell = function(html_output) {
// Return the cell and output element which can be found *uniquely* in the notebook.
// Note - this is a bit hacky, but it is done because the "notebook_saving.Notebook"
// IPython event is triggered only after the cells have been serialised, which for
// our purposes (turning an active figure into a static one), is too late.
var cells = IPython.notebook.get_cells();
var ncells = cells.length;
for (var i=0; i<ncells; i++) {
var cell = cells[i];
if (cell.cell_type === 'code'){
for (var j=0; j<cell.output_area.outputs.length; j++) {
var data = cell.output_area.outputs[j];
if (data.data) {
// IPython >= 3 moved mimebundle to data attribute of output
data = data.data;
}
if (data['text/html'] == html_output) {
return [cell, data, j];
}
}
}
}
}

// Register the function which deals with the matplotlib target/channel.
// The kernel may be null if the page has been refreshed.
if (IPython.notebook.kernel != null) {
IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);
}

``````
``````

In [25]:

myfluid2 = rescaled.copy()
print(myfluid2.vars)
myfluid2.yvar = "S"
myfluid2.vars[1] = "S"
myfluid2.units[1] = "J/kg*K"
#myfluid2.clean()
myfluid2.make_meta()
print(myfluid2.meta)
TP.fluid_plot(myfluid2)

``````
``````

['T', 'P', 'U', 'S', 'd(U)/d(S)|P', 'd(U)/d(P)|T', 'd(U)/d(T)|P']
pmap({'fluid': 'Water', 'numPoints': [216, 216], 'date': '2017-03-01 @ 10:28:53', 'units': ['K', 'J/kg/K', 'J/kg', 'J/kg/K', 'UnknownVar', 'UnknownVar', 'UnknownVar'], 'yvar': 'S', 'colorMap': 'viridis', 'xvar': 'T', 'vars': ['T', 'S', 'U', 'S', 'd(U)/d(S)|P', 'd(U)/d(P)|T', 'd(U)/d(T)|P'], 'zvar': 'U'})

var element = \$('#5c251435-598b-4611-ae75-d6a7a1e4e63f');
/* Put everything inside the global mpl namespace */
window.mpl = {};

mpl.get_websocket_type = function() {
if (typeof(WebSocket) !== 'undefined') {
return WebSocket;
} else if (typeof(MozWebSocket) !== 'undefined') {
return MozWebSocket;
} else {
alert('Your browser does not have WebSocket support.' +
'Please try Chrome, Safari or Firefox ≥ 6. ' +
'Firefox 4 and 5 are also supported but you ' +
'have to enable WebSockets in about:config.');
};
}

mpl.figure = function(figure_id, websocket, ondownload, parent_element) {
this.id = figure_id;

this.ws = websocket;

this.supports_binary = (this.ws.binaryType != undefined);

if (!this.supports_binary) {
var warnings = document.getElementById("mpl-warnings");
if (warnings) {
warnings.style.display = 'block';
warnings.textContent = (
"This browser does not support binary websocket messages. " +
"Performance may be slow.");
}
}

this.imageObj = new Image();

this.context = undefined;
this.message = undefined;
this.canvas = undefined;
this.rubberband_canvas = undefined;
this.rubberband_context = undefined;
this.format_dropdown = undefined;

this.image_mode = 'full';

this.root = \$('<div/>');
this._root_extra_style(this.root)
this.root.attr('style', 'display: inline-block');

\$(parent_element).append(this.root);

this._init_canvas(this);
this._init_toolbar(this);

var fig = this;

this.waiting = false;

this.ws.onopen =  function () {
fig.send_message("supports_binary", {value: fig.supports_binary});
fig.send_message("send_image_mode", {});
if (mpl.ratio != 1) {
fig.send_message("set_dpi_ratio", {'dpi_ratio': mpl.ratio});
}
fig.send_message("refresh", {});
}

this.imageObj.onload = function() {
if (fig.image_mode == 'full') {
// Full images could contain transparency (where diff images
// almost always do), so we need to clear the canvas so that
// there is no ghosting.
fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);
}
fig.context.drawImage(fig.imageObj, 0, 0);
};

this.imageObj.onunload = function() {
this.ws.close();
}

this.ws.onmessage = this._make_on_message_function(this);

}

mpl.figure.prototype._init_header = function() {
var titlebar = \$(
'<div class="ui-dialog-titlebar ui-widget-header ui-corner-all ' +
'ui-helper-clearfix"/>');
var titletext = \$(
'<div class="ui-dialog-title" style="width: 100%; ' +
'text-align: center; padding: 3px;"/>');
titlebar.append(titletext)
this.root.append(titlebar);
}

mpl.figure.prototype._canvas_extra_style = function(canvas_div) {

}

mpl.figure.prototype._root_extra_style = function(canvas_div) {

}

mpl.figure.prototype._init_canvas = function() {
var fig = this;

var canvas_div = \$('<div/>');

canvas_div.attr('style', 'position: relative; clear: both; outline: 0');

function canvas_keyboard_event(event) {
return fig.key_event(event, event['data']);
}

canvas_div.keydown('key_press', canvas_keyboard_event);
canvas_div.keyup('key_release', canvas_keyboard_event);
this.canvas_div = canvas_div
this._canvas_extra_style(canvas_div)
this.root.append(canvas_div);

var canvas = \$('<canvas/>');
canvas.attr('style', "left: 0; top: 0; z-index: 0; outline: 0")

this.canvas = canvas[0];
this.context = canvas[0].getContext("2d");

var backingStore = this.context.backingStorePixelRatio ||
this.context.webkitBackingStorePixelRatio ||
this.context.mozBackingStorePixelRatio ||
this.context.msBackingStorePixelRatio ||
this.context.oBackingStorePixelRatio ||
this.context.backingStorePixelRatio || 1;

mpl.ratio = (window.devicePixelRatio || 1) / backingStore;

var rubberband = \$('<canvas/>');
rubberband.attr('style', "position: absolute; left: 0; top: 0; z-index: 1;")

var pass_mouse_events = true;

canvas_div.resizable({
start: function(event, ui) {
pass_mouse_events = false;
},
resize: function(event, ui) {
fig.request_resize(ui.size.width, ui.size.height);
},
stop: function(event, ui) {
pass_mouse_events = true;
fig.request_resize(ui.size.width, ui.size.height);
},
});

function mouse_event_fn(event) {
if (pass_mouse_events)
return fig.mouse_event(event, event['data']);
}

rubberband.mousedown('button_press', mouse_event_fn);
rubberband.mouseup('button_release', mouse_event_fn);
// Throttle sequential mouse events to 1 every 20ms.
rubberband.mousemove('motion_notify', mouse_event_fn);

rubberband.mouseenter('figure_enter', mouse_event_fn);
rubberband.mouseleave('figure_leave', mouse_event_fn);

canvas_div.on("wheel", function (event) {
event = event.originalEvent;
event['data'] = 'scroll'
if (event.deltaY < 0) {
event.step = 1;
} else {
event.step = -1;
}
mouse_event_fn(event);
});

canvas_div.append(canvas);
canvas_div.append(rubberband);

this.rubberband = rubberband;
this.rubberband_canvas = rubberband[0];
this.rubberband_context = rubberband[0].getContext("2d");
this.rubberband_context.strokeStyle = "#000000";

this._resize_canvas = function(width, height) {
// Keep the size of the canvas, canvas container, and rubber band
// canvas in synch.
canvas_div.css('width', width)
canvas_div.css('height', height)

canvas.attr('width', width * mpl.ratio);
canvas.attr('height', height * mpl.ratio);
canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');

rubberband.attr('width', width);
rubberband.attr('height', height);
}

// Set the figure to an initial 600x600px, this will subsequently be updated
// upon first draw.
this._resize_canvas(600, 600);

// Disable right mouse context menu.
return false;
});

function set_focus () {
canvas.focus();
canvas_div.focus();
}

window.setTimeout(set_focus, 100);
}

mpl.figure.prototype._init_toolbar = function() {
var fig = this;

var nav_element = \$('<div/>')
nav_element.attr('style', 'width: 100%');
this.root.append(nav_element);

// Define a callback function for later on.
function toolbar_event(event) {
return fig.toolbar_button_onclick(event['data']);
}
function toolbar_mouse_event(event) {
return fig.toolbar_button_onmouseover(event['data']);
}

for(var toolbar_ind in mpl.toolbar_items) {
var name = mpl.toolbar_items[toolbar_ind][0];
var tooltip = mpl.toolbar_items[toolbar_ind][1];
var image = mpl.toolbar_items[toolbar_ind][2];
var method_name = mpl.toolbar_items[toolbar_ind][3];

if (!name) {
// put a spacer in here.
continue;
}
var button = \$('<button/>');
button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +
'ui-button-icon-only');
button.attr('role', 'button');
button.attr('aria-disabled', 'false');
button.click(method_name, toolbar_event);
button.mouseover(tooltip, toolbar_mouse_event);

var icon_img = \$('<span/>');

var tooltip_span = \$('<span/>');
tooltip_span.html(tooltip);

button.append(icon_img);
button.append(tooltip_span);

nav_element.append(button);
}

var fmt_picker_span = \$('<span/>');

var fmt_picker = \$('<select/>');
fmt_picker_span.append(fmt_picker);
nav_element.append(fmt_picker_span);
this.format_dropdown = fmt_picker[0];

for (var ind in mpl.extensions) {
var fmt = mpl.extensions[ind];
var option = \$(
'<option/>', {selected: fmt === mpl.default_extension}).html(fmt);
fmt_picker.append(option)
}

// Add hover states to the ui-buttons
\$( ".ui-button" ).hover(
function() { \$(this).removeClass("ui-state-hover");}
);

var status_bar = \$('<span class="mpl-message"/>');
nav_element.append(status_bar);
this.message = status_bar[0];
}

mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {
// Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,
// which will in turn request a refresh of the image.
this.send_message('resize', {'width': x_pixels, 'height': y_pixels});
}

mpl.figure.prototype.send_message = function(type, properties) {
properties['type'] = type;
properties['figure_id'] = this.id;
this.ws.send(JSON.stringify(properties));
}

mpl.figure.prototype.send_draw_message = function() {
if (!this.waiting) {
this.waiting = true;
this.ws.send(JSON.stringify({type: "draw", figure_id: this.id}));
}
}

mpl.figure.prototype.handle_save = function(fig, msg) {
var format_dropdown = fig.format_dropdown;
var format = format_dropdown.options[format_dropdown.selectedIndex].value;
}

mpl.figure.prototype.handle_resize = function(fig, msg) {
var size = msg['size'];
if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {
fig._resize_canvas(size[0], size[1]);
fig.send_message("refresh", {});
};
}

mpl.figure.prototype.handle_rubberband = function(fig, msg) {
var x0 = msg['x0'] / mpl.ratio;
var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;
var x1 = msg['x1'] / mpl.ratio;
var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;
x0 = Math.floor(x0) + 0.5;
y0 = Math.floor(y0) + 0.5;
x1 = Math.floor(x1) + 0.5;
y1 = Math.floor(y1) + 0.5;
var min_x = Math.min(x0, x1);
var min_y = Math.min(y0, y1);
var width = Math.abs(x1 - x0);
var height = Math.abs(y1 - y0);

fig.rubberband_context.clearRect(
0, 0, fig.canvas.width, fig.canvas.height);

fig.rubberband_context.strokeRect(min_x, min_y, width, height);
}

mpl.figure.prototype.handle_figure_label = function(fig, msg) {
// Updates the figure title.
}

mpl.figure.prototype.handle_cursor = function(fig, msg) {
var cursor = msg['cursor'];
switch(cursor)
{
case 0:
cursor = 'pointer';
break;
case 1:
cursor = 'default';
break;
case 2:
cursor = 'crosshair';
break;
case 3:
cursor = 'move';
break;
}
fig.rubberband_canvas.style.cursor = cursor;
}

mpl.figure.prototype.handle_message = function(fig, msg) {
fig.message.textContent = msg['message'];
}

mpl.figure.prototype.handle_draw = function(fig, msg) {
// Request the server to send over a new figure.
fig.send_draw_message();
}

mpl.figure.prototype.handle_image_mode = function(fig, msg) {
fig.image_mode = msg['mode'];
}

mpl.figure.prototype.updated_canvas_event = function() {
// Called whenever the canvas gets updated.
this.send_message("ack", {});
}

// A function to construct a web socket function for onmessage handling.
// Called in the figure constructor.
mpl.figure.prototype._make_on_message_function = function(fig) {
return function socket_on_message(evt) {
if (evt.data instanceof Blob) {
/* FIXME: We get "Resource interpreted as Image but
* transferred with MIME type text/plain:" errors on
* Chrome.  But how to set the MIME type?  It doesn't seem
* to be part of the websocket stream */
evt.data.type = "image/png";

/* Free the memory for the previous frames */
if (fig.imageObj.src) {
(window.URL || window.webkitURL).revokeObjectURL(
fig.imageObj.src);
}

fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(
evt.data);
fig.updated_canvas_event();
fig.waiting = false;
return;
}
else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == "data:image/png;base64") {
fig.imageObj.src = evt.data;
fig.updated_canvas_event();
fig.waiting = false;
return;
}

var msg = JSON.parse(evt.data);
var msg_type = msg['type'];

// Call the  "handle_{type}" callback, which takes
// the figure and JSON message as its only arguments.
try {
var callback = fig["handle_" + msg_type];
} catch (e) {
console.log("No handler for the '" + msg_type + "' message type: ", msg);
return;
}

if (callback) {
try {
// console.log("Handling '" + msg_type + "' message: ", msg);
callback(fig, msg);
} catch (e) {
console.log("Exception inside the 'handler_" + msg_type + "' callback:", e, e.stack, msg);
}
}
};
}

// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas
mpl.findpos = function(e) {
//this section is from http://www.quirksmode.org/js/events_properties.html
var targ;
if (!e)
e = window.event;
if (e.target)
targ = e.target;
else if (e.srcElement)
targ = e.srcElement;
if (targ.nodeType == 3) // defeat Safari bug
targ = targ.parentNode;

// jQuery normalizes the pageX and pageY
// pageX,Y are the mouse positions relative to the document
// offset() returns the position of the element relative to the document
var x = e.pageX - \$(targ).offset().left;
var y = e.pageY - \$(targ).offset().top;

return {"x": x, "y": y};
};

/*
* return a copy of an object with only non-object keys
* we need this to avoid circular references
* http://stackoverflow.com/a/24161582/3208463
*/
function simpleKeys (original) {
return Object.keys(original).reduce(function (obj, key) {
if (typeof original[key] !== 'object')
obj[key] = original[key]
return obj;
}, {});
}

mpl.figure.prototype.mouse_event = function(event, name) {
var canvas_pos = mpl.findpos(event)

if (name === 'button_press')
{
this.canvas.focus();
this.canvas_div.focus();
}

var x = canvas_pos.x * mpl.ratio;
var y = canvas_pos.y * mpl.ratio;

this.send_message(name, {x: x, y: y, button: event.button,
step: event.step,
guiEvent: simpleKeys(event)});

/* This prevents the web browser from automatically changing to
* the text insertion cursor when the button is pressed.  We want
* to control all of the cursor setting manually through the
* 'cursor' event from matplotlib */
event.preventDefault();
return false;
}

mpl.figure.prototype._key_event_extra = function(event, name) {
// Handle any extra behaviour associated with a key event
}

mpl.figure.prototype.key_event = function(event, name) {

// Prevent repeat events
if (name == 'key_press')
{
if (event.which === this._key)
return;
else
this._key = event.which;
}
if (name == 'key_release')
this._key = null;

var value = '';
if (event.ctrlKey && event.which != 17)
value += "ctrl+";
if (event.altKey && event.which != 18)
value += "alt+";
if (event.shiftKey && event.which != 16)
value += "shift+";

value += 'k';
value += event.which.toString();

this._key_event_extra(event, name);

this.send_message(name, {key: value,
guiEvent: simpleKeys(event)});
return false;
}

mpl.figure.prototype.toolbar_button_onclick = function(name) {
this.handle_save(this, null);
} else {
this.send_message("toolbar_button", {name: name});
}
};

mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {
this.message.textContent = tooltip;
};
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"]];

mpl.extensions = ["eps", "jpeg", "pdf", "png", "ps", "raw", "svg", "tif"];

mpl.default_extension = "png";var comm_websocket_adapter = function(comm) {
// Create a "websocket"-like object which calls the given IPython comm
// object with the appropriate methods. Currently this is a non binary
// socket, so there is still some room for performance tuning.
var ws = {};

ws.close = function() {
comm.close()
};
ws.send = function(m) {
//console.log('sending', m);
comm.send(m);
};
// Register the callback with on_msg.
comm.on_msg(function(msg) {
//console.log('receiving', msg['content']['data'], msg);
// Pass the mpl event to the overriden (by mpl) onmessage function.
ws.onmessage(msg['content']['data'])
});
return ws;
}

mpl.mpl_figure_comm = function(comm, msg) {
// This is the function which gets called when the mpl process
// starts-up an IPython Comm through the "matplotlib" channel.

var id = msg.content.data.id;
// Get hold of the div created by the display call when the Comm
// socket was opened in Python.
var element = \$("#" + id);
var ws_proxy = comm_websocket_adapter(comm)

window.open(figure.imageObj.src);
}

var fig = new mpl.figure(id, ws_proxy,
element.get(0));

// Call onopen now - mpl needs it, as it is assuming we've passed it a real
// web socket which is closed, not our websocket->open comm proxy.
ws_proxy.onopen();

fig.parent_element = element.get(0);
fig.cell_info = mpl.find_output_cell("<div id='" + id + "'></div>");
if (!fig.cell_info) {
console.error("Failed to find cell for figure", id, fig);
return;
}

var output_index = fig.cell_info[2]
var cell = fig.cell_info[0];

};

mpl.figure.prototype.handle_close = function(fig, msg) {
var width = fig.canvas.width/mpl.ratio
fig.root.unbind('remove')

// Update the output cell to use the data from the current canvas.
fig.push_to_output();
var dataURL = fig.canvas.toDataURL();
// Re-enable the keyboard manager in IPython - without this line, in FF,
// the notebook keyboard shortcuts fail.
IPython.keyboard_manager.enable()
\$(fig.parent_element).html('<amp-img layout="responsive" width="500" height="300" src="' + dataURL + '" width="' + width + '">');
fig.close_ws(fig, msg);
}

mpl.figure.prototype.close_ws = function(fig, msg){
fig.send_message('closing', msg);
// fig.ws.close()
}

mpl.figure.prototype.push_to_output = function(remove_interactive) {
// Turn the data on the canvas into data in the output cell.
var width = this.canvas.width/mpl.ratio
var dataURL = this.canvas.toDataURL();
this.cell_info[1]['text/html'] = '<amp-img layout="responsive" width="500" height="300" src="' + dataURL + '" width="' + width + '">';
}

mpl.figure.prototype.updated_canvas_event = function() {
// Tell IPython that the notebook contents must change.
IPython.notebook.set_dirty(true);
this.send_message("ack", {});
var fig = this;
// Wait a second, then push the new image to the DOM so
// that it is saved nicely (might be nice to debounce this).
setTimeout(function () { fig.push_to_output() }, 1000);
}

mpl.figure.prototype._init_toolbar = function() {
var fig = this;

var nav_element = \$('<div/>')
nav_element.attr('style', 'width: 100%');
this.root.append(nav_element);

// Define a callback function for later on.
function toolbar_event(event) {
return fig.toolbar_button_onclick(event['data']);
}
function toolbar_mouse_event(event) {
return fig.toolbar_button_onmouseover(event['data']);
}

for(var toolbar_ind in mpl.toolbar_items){
var name = mpl.toolbar_items[toolbar_ind][0];
var tooltip = mpl.toolbar_items[toolbar_ind][1];
var image = mpl.toolbar_items[toolbar_ind][2];
var method_name = mpl.toolbar_items[toolbar_ind][3];

if (!name) { continue; };

var button = \$('<button class="btn btn-default" href="#" title="' + name + '"><i class="fa ' + image + ' fa-lg"></i></button>');
button.click(method_name, toolbar_event);
button.mouseover(tooltip, toolbar_mouse_event);
nav_element.append(button);
}

// Add the status bar.
var status_bar = \$('<span class="mpl-message" style="text-align:right; float: right;"/>');
nav_element.append(status_bar);
this.message = status_bar[0];

// Add the close button to the window.
var buttongrp = \$('<div class="btn-group inline pull-right"></div>');
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>');
button.click(function (evt) { fig.handle_close(fig, {}); } );
button.mouseover('Stop Interaction', toolbar_mouse_event);
buttongrp.append(button);
var titlebar = this.root.find(\$('.ui-dialog-titlebar'));
titlebar.prepend(buttongrp);
}

mpl.figure.prototype._root_extra_style = function(el){
var fig = this
el.on("remove", function(){
fig.close_ws(fig, {});
});
}

mpl.figure.prototype._canvas_extra_style = function(el){
// this is important to make the div 'focusable
el.attr('tabindex', 0)
// reach out to IPython and tell the keyboard manager to turn it's self
// off when our div gets focus

// location in version 3
if (IPython.notebook.keyboard_manager) {
IPython.notebook.keyboard_manager.register_events(el);
}
else {
// location in version 2
IPython.keyboard_manager.register_events(el);
}

}

mpl.figure.prototype._key_event_extra = function(event, name) {
var manager = IPython.notebook.keyboard_manager;
if (!manager)
manager = IPython.keyboard_manager;

// Check for shift+enter
if (event.shiftKey && event.which == 13) {
this.canvas_div.blur();
// select the cell after this one
var index = IPython.notebook.find_cell_index(this.cell_info[0]);
IPython.notebook.select(index + 1);
}
}

mpl.figure.prototype.handle_save = function(fig, msg) {
}

mpl.find_output_cell = function(html_output) {
// Return the cell and output element which can be found *uniquely* in the notebook.
// Note - this is a bit hacky, but it is done because the "notebook_saving.Notebook"
// IPython event is triggered only after the cells have been serialised, which for
// our purposes (turning an active figure into a static one), is too late.
var cells = IPython.notebook.get_cells();
var ncells = cells.length;
for (var i=0; i<ncells; i++) {
var cell = cells[i];
if (cell.cell_type === 'code'){
for (var j=0; j<cell.output_area.outputs.length; j++) {
var data = cell.output_area.outputs[j];
if (data.data) {
// IPython >= 3 moved mimebundle to data attribute of output
data = data.data;
}
if (data['text/html'] == html_output) {
return [cell, data, j];
}
}
}
}
}

// Register the function which deals with the matplotlib target/channel.
// The kernel may be null if the page has been refreshed.
if (IPython.notebook.kernel != null) {
IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);
}

``````
``````

In [42]:

rescaled.write_data("../finalData/")

``````
``````

In [ ]:

``````