Skip to content

Instantly share code, notes, and snippets.

@Leo-Yan
Created September 27, 2021 02:29
Show Gist options
  • Save Leo-Yan/c1e33b0c399762dcbbe943fc632fbad5 to your computer and use it in GitHub Desktop.
Save Leo-Yan/c1e33b0c399762dcbbe943fc632fbad5 to your computer and use it in GitHub Desktop.
Display the source blob
Display the rendered blob
Raw
{
"cells": [
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Typical LISA experiment"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"This notebook shows a typical LISA-use case:\n",
"\n",
"* Connecting to a target\n",
"* Configuring an rt-app workload\n",
"* Collecting a trace while executing a workload\n",
"* Displaying the trace\n",
"* Analysing the trace\n",
"\n",
"It can serve as a template for different kind of experiments, - you could only change the workload to execute & the trace events to collect"
]
},
{
"cell_type": "code",
"execution_count": 5,
"metadata": {},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"2021-09-25 22:00:18,077 INFO : root : Using LISA logging configuration: /home/leoy/Work2/Develop/tools/lisa/logging.conf\n"
]
}
],
"source": [
"import logging\n",
"from lisa.utils import setup_logging\n",
"setup_logging(filepath='logging.conf')"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Target configuration"
]
},
{
"cell_type": "code",
"execution_count": 6,
"metadata": {},
"outputs": [],
"source": [
"from lisa.target import Target, TargetConf"
]
},
{
"cell_type": "code",
"execution_count": 7,
"metadata": {},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"2021-09-25 22:00:25,081 INFO : lisa.energy_model.EnergyModel.from_target : Attempting to load EM using LinuxEnergyModel\n",
"2021-09-25 22:00:28,131 INFO : sched : Scheduler sched_domain procfs entries found\n",
"2021-09-25 22:00:28,134 INFO : sched : Detected kernel compiled with SCHED_DEBUG=y\n",
"2021-09-25 22:00:28,136 INFO : sched : CPU capacity sysfs entries found\n"
]
}
],
"source": [
"target = Target.from_default_conf()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Setting up an rt-app workload"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"rt-app is very convenient for scheduler experiments, and the majority of the tests within LISA rely on it. Here we're going to create a somewhat useless workload just to show off the API.\n",
"\n",
"Relevant documentation:\n",
"\n",
"* **rt-app**: https://github.com/scheduler-tools/rt-app\n",
"* **rt-app LISA class**: https://lisa-linux-integrated-system-analysis.readthedocs.io/en/master/workloads.html#lisa.wlgen.rta.RTA\n",
"* **RTAPhase class**: https://lisa-linux-integrated-system-analysis.readthedocs.io/en/master/workloads.html#lisa.wlgen.rta.RTAPhase\n",
"* **PeriodicWload class**: https://lisa-linux-integrated-system-analysis.readthedocs.io/en/master/workloads.html#lisa.wlgen.rta.PeriodicWload"
]
},
{
"cell_type": "code",
"execution_count": 8,
"metadata": {},
"outputs": [],
"source": [
"from lisa.wlgen.rta import RTA, RTAPhase, PeriodicWload, DutyCycleSweepPhase"
]
},
{
"cell_type": "code",
"execution_count": 9,
"metadata": {},
"outputs": [],
"source": [
"rtapp_profile = {\n",
" **{\n",
" f'tsk{cpu}_{i}': RTAPhase(\n",
" prop_wload=PeriodicWload(\n",
" duty_cycle_pct=20,\n",
" period=16e-3,\n",
" duration=1,\n",
" )\n",
" )\n",
" for cpu in range(target.number_of_cpus)\n",
" for i in range(3)\n",
" },\n",
" **{\n",
" f'tsk_ru': DutyCycleSweepPhase(\n",
" start=5,\n",
" stop=20,\n",
" step=5,\n",
" duration=1,\n",
" duration_of='step',\n",
" period=16e-3,\n",
" )\n",
" }\n",
"}"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"rt-app needs some calibration information (20% duty cycle isn't the same amount of work on all platforms!). It can be manually specified like so:"
]
},
{
"cell_type": "code",
"execution_count": 10,
"metadata": {},
"outputs": [],
"source": [
"def provide_calibration(calibration):\n",
" target.plat_info[\"rtapp\"].add_src(\"user\", {\"calib\" : calibration})"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"However, it is automatically collected when first creating an rt-app workload if it is not specified, so you can forego the above step and let the calibration happen on-demand:"
]
},
{
"cell_type": "code",
"execution_count": 11,
"metadata": {},
"outputs": [],
"source": [
"wload = RTA.from_profile(target, rtapp_profile, name='experiment_workload')"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Prepare the energy meter"
]
},
{
"cell_type": "code",
"execution_count": 12,
"metadata": {},
"outputs": [],
"source": [
"import devlib\n",
"from devlib.instrument.arm_energy_probe import ArmEnergyProbeInstrument\n",
"from devlib import DerivedEnergyMeasurements"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"The Arm energy probe config file for Hikey960:\n",
"\n",
"```\n",
"# arm-probe configuration file\n",
"#\n",
"# setup name\n",
"Hikey960\n",
"\n",
"# <device path>\n",
"/dev/serial/by-id/usb-NXP_SEMICOND_ARM_Energy_Probe_S_NO00000000-if00\n",
" DCIN\t0.082000\t1\t-0.015796\t0.129143\t-0.001024\t0.000970\t0\tMain\tVBAT\t#ff0000\tSoC\n",
" VDD\t0.033000\t2\t-0.114682\t0.049773\t-0.000439\t0.001129\t0\tVDD_4V2\tDCIN\t#ff0000\tSoC\n",
" SYS\t0.100000\t3\t-0.155547\t0.177045\t-0.000242\t0.000600\t0\tSYS_5V\tDCIN\t#ff0000\tSoC\n",
" ```"
]
},
{
"cell_type": "code",
"execution_count": 13,
"metadata": {},
"outputs": [],
"source": [
"aep = ArmEnergyProbeInstrument(target, '/tmp/config-aep-hikey960')"
]
},
{
"cell_type": "code",
"execution_count": 14,
"metadata": {},
"outputs": [],
"source": [
"aep.reset()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Prepare Ftrace tracepoints"
]
},
{
"cell_type": "code",
"execution_count": 15,
"metadata": {},
"outputs": [],
"source": [
"import os\n",
"from lisa.trace import FtraceCollector"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"We need to specify the trace events we want to record. We could list what's available like so:"
]
},
{
"cell_type": "code",
"execution_count": 16,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"['task:task_newtask', 'task:task_rename', 'sched:sched_kthread_stop', 'sched:sched_kthread_stop_ret', 'sched:sched_waking', 'sched:sched_wakeup', 'sched:sched_wakeup_new', 'sched:sched_switch', 'sched:sched_migrate_task', 'sched:sched_process_free', 'sched:sched_process_exit', 'sched:sched_wait_task', 'sched:sched_process_wait', 'sched:sched_process_fork', 'sched:sched_process_exec', 'sched:sched_stat_wait', 'sched:sched_stat_sleep', 'sched:sched_stat_iowait', 'sched:sched_stat_blocked', 'sched:sched_blocked_reason', 'sched:sched_stat_runtime', 'sched:sched_pi_setprio', 'sched:sched_move_numa', 'sched:sched_stick_numa', 'sched:sched_swap_numa', 'sched:sched_wake_idle_without_ipi', 'sched:sched_pelt_cfs', 'sched:sched_pelt_rt', 'sched:sched_pelt_dl', 'sched:sched_pelt_irq', 'sched:sched_pelt_se', 'sched:sched_overutilized', 'sched:sched_update_nr_running', 'sched:sched_util_est_se', 'sched:sched_util_est_cfs', 'sched:uclamp_util_se', 'sched:uclamp_util_cfs', 'sched:sched_cpu_capacity']\n"
]
}
],
"source": [
"available_events = target.execute(\"cat /sys/kernel/debug/tracing/available_events\").splitlines()\n",
"\n",
"# That's gonna be a pretty big list, let's focus on the scheduler events\n",
"sched_events = [\n",
" event\n",
" for event in available_events\n",
" if (\n",
" event.startswith(\"sched:\") or\n",
" event.startswith(\"task:\")\n",
" )\n",
"]\n",
"print(sched_events)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Let's just collect the base events required to plot task scheduling:"
]
},
{
"cell_type": "code",
"execution_count": 17,
"metadata": {},
"outputs": [],
"source": [
"events = [\n",
" 'sched_switch',\n",
" 'sched_wakeup',\n",
" 'sched_wakeup_new',\n",
" 'task_rename',\n",
" 'sched_update_nr_running',\n",
" 'sched_pelt_cfs',\n",
" 'sched_pelt_se',\n",
" 'cpu_frequency',\n",
" 'sched_overutilized',\n",
" 'sched_migrate_task'\n",
"]"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"And now we can actually record traces while running our workload:"
]
},
{
"cell_type": "code",
"execution_count": 18,
"metadata": {},
"outputs": [],
"source": [
"trace_path = os.path.join(wload.res_dir, \"trace.dat\")\n",
"ftrace_coll = FtraceCollector(target, events=events, buffer_size=10240, output_path=trace_path)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Running the workload"
]
},
{
"cell_type": "code",
"execution_count": 19,
"metadata": {},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"2021-09-25 22:00:48,258 INFO : lisa.wlgen.rta.RTA : Created workload's run target directory: /data/local/tmp/devlib-target/lisa/wlgen/20210925_220029_ffba09a0937d4242ad125c48a08f416a\n",
"2021-09-25 22:00:48,634 WARNING : lisa.wlgen.rta.RTA : CPU capacities will not be updated on this platform\n",
"2021-09-25 22:00:48,715 INFO : lisa.wlgen.rta.RTA : CPU capacities according to rt-app workload: {0: 462, 1: 462, 2: 462, 3: 462, 4: 1024, 5: 1024, 6: 1024, 7: 1024}\n",
"2021-09-25 22:00:57,761 INFO : lisa.wlgen.rta.RTA : Execution start: rt-app /data/local/tmp/devlib-target/lisa/wlgen/20210925_220029_ffba09a0937d4242ad125c48a08f416a/experiment_workload.json 2>&1\n",
"2021-09-25 22:01:06,617 INFO : lisa.wlgen.rta.RTA : Wiping target run directory: /data/local/tmp/devlib-target/lisa/wlgen/20210925_220029_ffba09a0937d4242ad125c48a08f416a\n"
]
}
],
"source": [
"# Start energy measurement\n",
"aep.start()\n",
"\n",
"with wload, ftrace_coll:\n",
" wload.run()\n",
" \n",
"# Stop energy measurement\n",
"aep.stop()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Output the energy result"
]
},
{
"cell_type": "code",
"execution_count": 20,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"DCIN_total_energy\n",
"426.33916062012116\n",
"SYS_total_energy\n",
"0.03313607321000001\n",
"VDD_total_energy\n",
"26.671370196030512\n",
"DCIN_average_power\n",
"22.9342851870115\n",
"SYS_average_power\n",
"0.0017826054051437107\n",
"VDD_average_power\n",
"1.4347503275953284\n"
]
}
],
"source": [
"measurement = aep.get_data('/tmp/energy_raw.txt')\n",
"derived_measurements = DerivedEnergyMeasurements.process(measurement)\n",
"for meas in derived_measurements:\n",
" print(meas.name)\n",
" print(meas.value)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Loading up the trace"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"We have a Trace class that lets us easily access trace events. It can also do some post-processing to provide different kinds of analysis."
]
},
{
"cell_type": "code",
"execution_count": 21,
"metadata": {},
"outputs": [],
"source": [
"from lisa.trace import Trace"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"You can pass the platform info directly from the **Target**:"
]
},
{
"cell_type": "code",
"execution_count": 22,
"metadata": {},
"outputs": [],
"source": [
"trace = Trace(trace_path, target.plat_info, events=events)"
]
},
{
"cell_type": "code",
"execution_count": 24,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"'/home/leoy/Work2/Develop/tools/lisa/results/Target-hikey960-20210925_220020.359338/RTA-experiment_workload-20210925_220029.823086/trace.dat'"
]
},
"execution_count": 24,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"trace_path"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Looking at the trace"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Kernelshark can be opened from the notebook:"
]
},
{
"cell_type": "code",
"execution_count": 23,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"<os._wrap_close at 0x7f6aa97358e0>"
]
},
"execution_count": 23,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"trace.show()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Analysing the trace"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Relevant documentation: https://lisa-linux-integrated-system-analysis.readthedocs.io/en/master/trace_analysis.html"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Reading trace events"
]
},
{
"cell_type": "code",
"execution_count": 79,
"metadata": {},
"outputs": [],
"source": [
"df = trace.df_event(\"sched_overutilized\")"
]
},
{
"cell_type": "code",
"execution_count": 80,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>__comm</th>\n",
" <th>__pid</th>\n",
" <th>__cpu</th>\n",
" <th>span</th>\n",
" <th>overutilized</th>\n",
" </tr>\n",
" <tr>\n",
" <th>Time</th>\n",
" <th></th>\n",
" <th></th>\n",
" <th></th>\n",
" <th></th>\n",
" <th></th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>9893.916168</th>\n",
" <td>trace-cmd</td>\n",
" <td>4948</td>\n",
" <td>1</td>\n",
" <td>255</td>\n",
" <td>False</td>\n",
" </tr>\n",
" <tr>\n",
" <th>9893.919544</th>\n",
" <td>rcu_preempt</td>\n",
" <td>11</td>\n",
" <td>1</td>\n",
" <td>255</td>\n",
" <td>False</td>\n",
" </tr>\n",
" <tr>\n",
" <th>9893.921548</th>\n",
" <td>sh</td>\n",
" <td>4946</td>\n",
" <td>7</td>\n",
" <td>255</td>\n",
" <td>True</td>\n",
" </tr>\n",
" <tr>\n",
" <th>9893.923157</th>\n",
" <td>kworker/7:1</td>\n",
" <td>52</td>\n",
" <td>7</td>\n",
" <td>255</td>\n",
" <td>False</td>\n",
" </tr>\n",
" <tr>\n",
" <th>9893.925815</th>\n",
" <td>adbd</td>\n",
" <td>1904</td>\n",
" <td>3</td>\n",
" <td>255</td>\n",
" <td>False</td>\n",
" </tr>\n",
" <tr>\n",
" <th>...</th>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" </tr>\n",
" <tr>\n",
" <th>9898.661268</th>\n",
" <td>sh</td>\n",
" <td>5026</td>\n",
" <td>7</td>\n",
" <td>255</td>\n",
" <td>False</td>\n",
" </tr>\n",
" <tr>\n",
" <th>9898.663760</th>\n",
" <td>rcu_preempt</td>\n",
" <td>11</td>\n",
" <td>2</td>\n",
" <td>255</td>\n",
" <td>False</td>\n",
" </tr>\n",
" <tr>\n",
" <th>9898.675339</th>\n",
" <td>rcu_preempt</td>\n",
" <td>11</td>\n",
" <td>2</td>\n",
" <td>255</td>\n",
" <td>False</td>\n",
" </tr>\n",
" <tr>\n",
" <th>9898.678074</th>\n",
" <td>sugov:4</td>\n",
" <td>200</td>\n",
" <td>4</td>\n",
" <td>255</td>\n",
" <td>False</td>\n",
" </tr>\n",
" <tr>\n",
" <th>9898.679020</th>\n",
" <td>sh</td>\n",
" <td>5028</td>\n",
" <td>7</td>\n",
" <td>255</td>\n",
" <td>False</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"<p>1574 rows × 5 columns</p>\n",
"</div>"
],
"text/plain": [
" __comm __pid __cpu span overutilized\n",
"Time \n",
"9893.916168 trace-cmd 4948 1 255 False\n",
"9893.919544 rcu_preempt 11 1 255 False\n",
"9893.921548 sh 4946 7 255 True\n",
"9893.923157 kworker/7:1 52 7 255 False\n",
"9893.925815 adbd 1904 3 255 False\n",
"... ... ... ... ... ...\n",
"9898.661268 sh 5026 7 255 False\n",
"9898.663760 rcu_preempt 11 2 255 False\n",
"9898.675339 rcu_preempt 11 2 255 False\n",
"9898.678074 sugov:4 200 4 255 False\n",
"9898.679020 sh 5028 7 255 False\n",
"\n",
"[1574 rows x 5 columns]"
]
},
"execution_count": 80,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"The standard DataFrame operations are available, so you can filter/slice it however you wish:"
]
},
{
"cell_type": "code",
"execution_count": 55,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>__comm</th>\n",
" <th>__pid</th>\n",
" <th>__cpu</th>\n",
" <th>path</th>\n",
" <th>rbl_load</th>\n",
" <th>util</th>\n",
" <th>update_time</th>\n",
" <th>load</th>\n",
" <th>cpu</th>\n",
" </tr>\n",
" <tr>\n",
" <th>Time</th>\n",
" <th></th>\n",
" <th></th>\n",
" <th></th>\n",
" <th></th>\n",
" <th></th>\n",
" <th></th>\n",
" <th></th>\n",
" <th></th>\n",
" <th></th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>5462.577371</th>\n",
" <td>tsk1_2-5</td>\n",
" <td>4742</td>\n",
" <td>1</td>\n",
" <td>/</td>\n",
" <td>25</td>\n",
" <td>347</td>\n",
" <td>5455396322304</td>\n",
" <td>68</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>5462.590715</th>\n",
" <td>tsk1_2-5</td>\n",
" <td>4742</td>\n",
" <td>1</td>\n",
" <td>/system</td>\n",
" <td>914</td>\n",
" <td>70</td>\n",
" <td>5455405534208</td>\n",
" <td>913</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>5462.602942</th>\n",
" <td>tsk1_2-5</td>\n",
" <td>4742</td>\n",
" <td>1</td>\n",
" <td>/system</td>\n",
" <td>1713</td>\n",
" <td>242</td>\n",
" <td>5455416195072</td>\n",
" <td>1713</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>5462.602945</th>\n",
" <td>tsk1_2-5</td>\n",
" <td>4742</td>\n",
" <td>1</td>\n",
" <td>/</td>\n",
" <td>85</td>\n",
" <td>357</td>\n",
" <td>5455416195072</td>\n",
" <td>98</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>5462.602946</th>\n",
" <td>tsk1_2-5</td>\n",
" <td>4742</td>\n",
" <td>1</td>\n",
" <td>/</td>\n",
" <td>70</td>\n",
" <td>247</td>\n",
" <td>5455416195072</td>\n",
" <td>81</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>...</th>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" </tr>\n",
" <tr>\n",
" <th>5463.496767</th>\n",
" <td>tsk1_2-5</td>\n",
" <td>4742</td>\n",
" <td>6</td>\n",
" <td>/</td>\n",
" <td>260</td>\n",
" <td>609</td>\n",
" <td>5462075510784</td>\n",
" <td>260</td>\n",
" <td>4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>5463.496768</th>\n",
" <td>tsk1_2-5</td>\n",
" <td>4742</td>\n",
" <td>6</td>\n",
" <td>/system</td>\n",
" <td>231</td>\n",
" <td>554</td>\n",
" <td>5462075510784</td>\n",
" <td>938</td>\n",
" <td>4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>5463.496769</th>\n",
" <td>tsk1_2-5</td>\n",
" <td>4742</td>\n",
" <td>6</td>\n",
" <td>/</td>\n",
" <td>152</td>\n",
" <td>554</td>\n",
" <td>5462075510784</td>\n",
" <td>165</td>\n",
" <td>4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>5463.496771</th>\n",
" <td>tsk1_2-5</td>\n",
" <td>4742</td>\n",
" <td>6</td>\n",
" <td>/system</td>\n",
" <td>0</td>\n",
" <td>663</td>\n",
" <td>5461410040832</td>\n",
" <td>995</td>\n",
" <td>6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>5463.496771</th>\n",
" <td>tsk1_2-5</td>\n",
" <td>4742</td>\n",
" <td>6</td>\n",
" <td>/</td>\n",
" <td>0</td>\n",
" <td>663</td>\n",
" <td>5461410040832</td>\n",
" <td>96</td>\n",
" <td>6</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"<p>263 rows × 9 columns</p>\n",
"</div>"
],
"text/plain": [
" __comm __pid __cpu path rbl_load util update_time \\\n",
"Time \n",
"5462.577371 tsk1_2-5 4742 1 / 25 347 5455396322304 \n",
"5462.590715 tsk1_2-5 4742 1 /system 914 70 5455405534208 \n",
"5462.602942 tsk1_2-5 4742 1 /system 1713 242 5455416195072 \n",
"5462.602945 tsk1_2-5 4742 1 / 85 357 5455416195072 \n",
"5462.602946 tsk1_2-5 4742 1 / 70 247 5455416195072 \n",
"... ... ... ... ... ... ... ... \n",
"5463.496767 tsk1_2-5 4742 6 / 260 609 5462075510784 \n",
"5463.496768 tsk1_2-5 4742 6 /system 231 554 5462075510784 \n",
"5463.496769 tsk1_2-5 4742 6 / 152 554 5462075510784 \n",
"5463.496771 tsk1_2-5 4742 6 /system 0 663 5461410040832 \n",
"5463.496771 tsk1_2-5 4742 6 / 0 663 5461410040832 \n",
"\n",
" load cpu \n",
"Time \n",
"5462.577371 68 1 \n",
"5462.590715 913 1 \n",
"5462.602942 1713 1 \n",
"5462.602945 98 1 \n",
"5462.602946 81 1 \n",
"... ... ... \n",
"5463.496767 260 4 \n",
"5463.496768 938 4 \n",
"5463.496769 165 4 \n",
"5463.496771 995 6 \n",
"5463.496771 96 6 \n",
"\n",
"[263 rows x 9 columns]"
]
},
"execution_count": 55,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df[df.__comm == \"tsk1_2-5\"][5462.5:5463.5]"
]
},
{
"cell_type": "code",
"execution_count": 56,
"metadata": {},
"outputs": [],
"source": [
"from lisa._doc.helpers import get_analysis_list"
]
},
{
"cell_type": "code",
"execution_count": 57,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"\n",
"* :class:`cpus<lisa.analysis.cpus.CpusAnalysis>`::meth:`~lisa.analysis.cpus.CpusAnalysis.plot_context_switches`\n",
"* :class:`cpus<lisa.analysis.cpus.CpusAnalysis>`::meth:`~lisa.analysis.cpus.CpusAnalysis.plot_orig_capacity`\n",
"* :class:`frequency<lisa.analysis.frequency.FrequencyAnalysis>`::meth:`~lisa.analysis.frequency.FrequencyAnalysis.plot_cpu_frequencies`\n",
"* :class:`frequency<lisa.analysis.frequency.FrequencyAnalysis>`::meth:`~lisa.analysis.frequency.FrequencyAnalysis.plot_cpu_frequency_residency`\n",
"* :class:`frequency<lisa.analysis.frequency.FrequencyAnalysis>`::meth:`~lisa.analysis.frequency.FrequencyAnalysis.plot_cpu_frequency_transitions`\n",
"* :class:`frequency<lisa.analysis.frequency.FrequencyAnalysis>`::meth:`~lisa.analysis.frequency.FrequencyAnalysis.plot_domain_frequencies`\n",
"* :class:`frequency<lisa.analysis.frequency.FrequencyAnalysis>`::meth:`~lisa.analysis.frequency.FrequencyAnalysis.plot_domain_frequency_residency`\n",
"* :class:`frequency<lisa.analysis.frequency.FrequencyAnalysis>`::meth:`~lisa.analysis.frequency.FrequencyAnalysis.plot_domain_frequency_transitions`\n",
"* :class:`functions_json<lisa.analysis.functions.JSONStatsFunctionsAnalysis>`::meth:`~lisa.analysis.functions.JSONStatsFunctionsAnalysis.plot_profiling_stats`\n",
"* :class:`idle<lisa.analysis.idle.IdleAnalysis>`::meth:`~lisa.analysis.idle.IdleAnalysis.plot_cluster_idle_state_residency`\n",
"* :class:`idle<lisa.analysis.idle.IdleAnalysis>`::meth:`~lisa.analysis.idle.IdleAnalysis.plot_clusters_idle_state_residency`\n",
"* :class:`idle<lisa.analysis.idle.IdleAnalysis>`::meth:`~lisa.analysis.idle.IdleAnalysis.plot_cpu_idle_state_residency`\n",
"* :class:`latency<lisa.analysis.latency.LatencyAnalysis>`::meth:`~lisa.analysis.latency.LatencyAnalysis.plot_activations`\n",
"* :class:`latency<lisa.analysis.latency.LatencyAnalysis>`::meth:`~lisa.analysis.latency.LatencyAnalysis.plot_latencies_cdf`\n",
"* :class:`latency<lisa.analysis.latency.LatencyAnalysis>`::meth:`~lisa.analysis.latency.LatencyAnalysis.plot_latencies_histogram`\n",
"* :class:`latency<lisa.analysis.latency.LatencyAnalysis>`::meth:`~lisa.analysis.latency.LatencyAnalysis.plot_latencies`\n",
"* :class:`latency<lisa.analysis.latency.LatencyAnalysis>`::meth:`~lisa.analysis.latency.LatencyAnalysis.plot_latency_bands`\n",
"* :class:`latency<lisa.analysis.latency.LatencyAnalysis>`::meth:`~lisa.analysis.latency.LatencyAnalysis.plot_runtimes`\n",
"* :class:`load_tracking<lisa.analysis.load_tracking.LoadTrackingAnalysis>`::meth:`~lisa.analysis.load_tracking.LoadTrackingAnalysis.plot_cpus_signals`\n",
"* :class:`load_tracking<lisa.analysis.load_tracking.LoadTrackingAnalysis>`::meth:`~lisa.analysis.load_tracking.LoadTrackingAnalysis.plot_task_placement`\n",
"* :class:`load_tracking<lisa.analysis.load_tracking.LoadTrackingAnalysis>`::meth:`~lisa.analysis.load_tracking.LoadTrackingAnalysis.plot_task_required_capacity`\n",
"* :class:`load_tracking<lisa.analysis.load_tracking.LoadTrackingAnalysis>`::meth:`~lisa.analysis.load_tracking.LoadTrackingAnalysis.plot_task_signals`\n",
"* :class:`notebook<lisa.analysis.notebook.NotebookAnalysis>`::meth:`~lisa.analysis.notebook.NotebookAnalysis.plot_event_field`\n",
"* :class:`rta<lisa.analysis.rta.RTAEventsAnalysis>`::meth:`~lisa.analysis.rta.RTAEventsAnalysis.plot_latency`\n",
"* :class:`rta<lisa.analysis.rta.RTAEventsAnalysis>`::meth:`~lisa.analysis.rta.RTAEventsAnalysis.plot_perf_index_histogram`\n",
"* :class:`rta<lisa.analysis.rta.RTAEventsAnalysis>`::meth:`~lisa.analysis.rta.RTAEventsAnalysis.plot_perf`\n",
"* :class:`rta<lisa.analysis.rta.RTAEventsAnalysis>`::meth:`~lisa.analysis.rta.RTAEventsAnalysis.plot_phases`\n",
"* :class:`rta<lisa.analysis.rta.RTAEventsAnalysis>`::meth:`~lisa.analysis.rta.RTAEventsAnalysis.plot_slack_histogram`\n",
"* :class:`status<lisa.analysis.status.StatusAnalysis>`::meth:`~lisa.analysis.status.StatusAnalysis.plot_overutilized`\n",
"* :class:`tasks<lisa.analysis.tasks.TasksAnalysis>`::meth:`~lisa.analysis.tasks.TasksAnalysis.plot_task_activation`\n",
"* :class:`tasks<lisa.analysis.tasks.TasksAnalysis>`::meth:`~lisa.analysis.tasks.TasksAnalysis.plot_task_residency`\n",
"* :class:`tasks<lisa.analysis.tasks.TasksAnalysis>`::meth:`~lisa.analysis.tasks.TasksAnalysis.plot_task_total_residency`\n",
"* :class:`tasks<lisa.analysis.tasks.TasksAnalysis>`::meth:`~lisa.analysis.tasks.TasksAnalysis.plot_tasks_activation`\n",
"* :class:`tasks<lisa.analysis.tasks.TasksAnalysis>`::meth:`~lisa.analysis.tasks.TasksAnalysis.plot_tasks_forks_heatmap`\n",
"* :class:`tasks<lisa.analysis.tasks.TasksAnalysis>`::meth:`~lisa.analysis.tasks.TasksAnalysis.plot_tasks_forks`\n",
"* :class:`tasks<lisa.analysis.tasks.TasksAnalysis>`::meth:`~lisa.analysis.tasks.TasksAnalysis.plot_tasks_total_residency`\n",
"* :class:`tasks<lisa.analysis.tasks.TasksAnalysis>`::meth:`~lisa.analysis.tasks.TasksAnalysis.plot_tasks_wakeups_heatmap`\n",
"* :class:`tasks<lisa.analysis.tasks.TasksAnalysis>`::meth:`~lisa.analysis.tasks.TasksAnalysis.plot_tasks_wakeups`\n",
"* :class:`thermal<lisa.analysis.thermal.ThermalAnalysis>`::meth:`~lisa.analysis.thermal.ThermalAnalysis.plot_cpu_cooling_states`\n",
"* :class:`thermal<lisa.analysis.thermal.ThermalAnalysis>`::meth:`~lisa.analysis.thermal.ThermalAnalysis.plot_dev_freq_cooling_states`\n",
"* :class:`thermal<lisa.analysis.thermal.ThermalAnalysis>`::meth:`~lisa.analysis.thermal.ThermalAnalysis.plot_thermal_zone_temperature`\n"
]
}
],
"source": [
"print(get_analysis_list(\"plot\"))"
]
},
{
"cell_type": "code",
"execution_count": 58,
"metadata": {},
"outputs": [],
"source": [
"from lisa.notebook import plot_signal, _hv_neutral"
]
},
{
"cell_type": "code",
"execution_count": 63,
"metadata": {},
"outputs": [],
"source": [
"fig = plot_signal(df[df.__comm == \"tsk1_2-5\"][5462.5:5463.5]['util'], name=f'Task util')\n"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"import holoviews as hv"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"fig *= plot_signal(df[df.__comm == \"tsk1_3-6\"][5462.5:5463.5]['util'], name=f'Task util')"
]
},
{
"cell_type": "code",
"execution_count": 64,
"metadata": {},
"outputs": [
{
"ename": "ValueError",
"evalue": "negative dimensions are not allowed",
"output_type": "error",
"traceback": [
"\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
"\u001b[0;31mValueError\u001b[0m Traceback (most recent call last)",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/IPython/core/formatters.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, obj, include, exclude)\u001b[0m\n\u001b[1;32m 968\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 969\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0mmethod\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 970\u001b[0;31m \u001b[0;32mreturn\u001b[0m \u001b[0mmethod\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0minclude\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0minclude\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mexclude\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mexclude\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 971\u001b[0m \u001b[0;32mreturn\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 972\u001b[0m \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/core/dimension.py\u001b[0m in \u001b[0;36m_repr_mimebundle_\u001b[0;34m(self, include, exclude)\u001b[0m\n\u001b[1;32m 1315\u001b[0m \u001b[0mcombined\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0mreturned\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 1316\u001b[0m \"\"\"\n\u001b[0;32m-> 1317\u001b[0;31m \u001b[0;32mreturn\u001b[0m \u001b[0mStore\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrender\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 1318\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 1319\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/core/options.py\u001b[0m in \u001b[0;36mrender\u001b[0;34m(cls, obj)\u001b[0m\n\u001b[1;32m 1403\u001b[0m \u001b[0mdata\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmetadata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m{\u001b[0m\u001b[0;34m}\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m{\u001b[0m\u001b[0;34m}\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 1404\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mhook\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mhooks\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1405\u001b[0;31m \u001b[0mret\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mhook\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mobj\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 1406\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0mret\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 1407\u001b[0m \u001b[0;32mcontinue\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/ipython/display_hooks.py\u001b[0m in \u001b[0;36mpprint_display\u001b[0;34m(obj)\u001b[0m\n\u001b[1;32m 280\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0mip\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdisplay_formatter\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mformatters\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m'text/plain'\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpprint\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 281\u001b[0m \u001b[0;32mreturn\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 282\u001b[0;31m \u001b[0;32mreturn\u001b[0m \u001b[0mdisplay\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mobj\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mraw_output\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mTrue\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 283\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 284\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/ipython/display_hooks.py\u001b[0m in \u001b[0;36mdisplay\u001b[0;34m(obj, raw_output, **kwargs)\u001b[0m\n\u001b[1;32m 250\u001b[0m \u001b[0;32melif\u001b[0m \u001b[0misinstance\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mobj\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mCompositeOverlay\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mViewableElement\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 251\u001b[0m \u001b[0;32mwith\u001b[0m \u001b[0moption_state\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mobj\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 252\u001b[0;31m \u001b[0moutput\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0melement_display\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mobj\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 253\u001b[0m \u001b[0;32melif\u001b[0m \u001b[0misinstance\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mobj\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mLayout\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mNdLayout\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mAdjointLayout\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 254\u001b[0m \u001b[0;32mwith\u001b[0m \u001b[0moption_state\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mobj\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/ipython/display_hooks.py\u001b[0m in \u001b[0;36mwrapped\u001b[0;34m(element)\u001b[0m\n\u001b[1;32m 144\u001b[0m \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 145\u001b[0m \u001b[0mmax_frames\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mOutputSettings\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0moptions\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m'max_frames'\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 146\u001b[0;31m \u001b[0mmimebundle\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mfn\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0melement\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmax_frames\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mmax_frames\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 147\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0mmimebundle\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 148\u001b[0m \u001b[0;32mreturn\u001b[0m \u001b[0;34m{\u001b[0m\u001b[0;34m}\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m{\u001b[0m\u001b[0;34m}\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/ipython/display_hooks.py\u001b[0m in \u001b[0;36melement_display\u001b[0;34m(element, max_frames)\u001b[0m\n\u001b[1;32m 190\u001b[0m \u001b[0;32mreturn\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 191\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 192\u001b[0;31m \u001b[0;32mreturn\u001b[0m \u001b[0mrender\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0melement\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 193\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 194\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/ipython/display_hooks.py\u001b[0m in \u001b[0;36mrender\u001b[0;34m(obj, **kwargs)\u001b[0m\n\u001b[1;32m 66\u001b[0m \u001b[0mrenderer\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mrenderer\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0minstance\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfig\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m'png'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 67\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 68\u001b[0;31m \u001b[0;32mreturn\u001b[0m \u001b[0mrenderer\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcomponents\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mobj\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 69\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 70\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/renderer.py\u001b[0m in \u001b[0;36mcomponents\u001b[0;34m(self, obj, fmt, comm, **kwargs)\u001b[0m\n\u001b[1;32m 386\u001b[0m \u001b[0mplot\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mobj\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 387\u001b[0m \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 388\u001b[0;31m \u001b[0mplot\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfmt\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_validate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mobj\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfmt\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 389\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 390\u001b[0m \u001b[0mdata\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmetadata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m{\u001b[0m\u001b[0;34m}\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m{\u001b[0m\u001b[0;34m}\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/renderer.py\u001b[0m in \u001b[0;36m_validate\u001b[0;34m(self, obj, fmt, **kwargs)\u001b[0m\n\u001b[1;32m 312\u001b[0m renderer=self)\n\u001b[1;32m 313\u001b[0m \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 314\u001b[0;31m \u001b[0mplot\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget_plot\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mobj\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mrenderer\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 315\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 316\u001b[0m \u001b[0mall_formats\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mset\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfig_formats\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0mholomap_formats\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/renderer.py\u001b[0m in \u001b[0;36mget_plot\u001b[0;34m(self_or_cls, obj, doc, renderer, comm, **kwargs)\u001b[0m\n\u001b[1;32m 241\u001b[0m init_key = tuple(v if d is None else d for v, d in\n\u001b[1;32m 242\u001b[0m zip(plot.keys[0], defaults))\n\u001b[0;32m--> 243\u001b[0;31m \u001b[0mplot\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mupdate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0minit_key\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 244\u001b[0m \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 245\u001b[0m \u001b[0mplot\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mobj\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/plot.py\u001b[0m in \u001b[0;36mupdate\u001b[0;34m(self, key)\u001b[0m\n\u001b[1;32m 249\u001b[0m \u001b[0;32mdef\u001b[0m \u001b[0mupdate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkey\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 250\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m1\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mkey\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mor\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mkey\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mkeys\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdrawn\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 251\u001b[0;31m \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0minitialize_plot\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 252\u001b[0m \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__getitem__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mkey\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 253\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/plot.py\u001b[0m in \u001b[0;36mwrapper\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m 45\u001b[0m \u001b[0;32mdef\u001b[0m \u001b[0mwrapper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 46\u001b[0m \u001b[0;32mwith\u001b[0m \u001b[0m_rc_context\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfig_rcparams\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 47\u001b[0;31m \u001b[0;32mreturn\u001b[0m \u001b[0mf\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 48\u001b[0m \u001b[0;32mreturn\u001b[0m \u001b[0mwrapper\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 49\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/element.py\u001b[0m in \u001b[0;36minitialize_plot\u001b[0;34m(self, ranges)\u001b[0m\n\u001b[1;32m 1121\u001b[0m \u001b[0mranges\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcompute_ranges\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mhmap\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkey\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mranges\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 1122\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mk\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0msubplot\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msubplots\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mitems\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1123\u001b[0;31m \u001b[0msubplot\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0minitialize_plot\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mranges\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mranges\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 1124\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0misinstance\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0melement\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mCompositeOverlay\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 1125\u001b[0m \u001b[0mframe\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0melement\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/plot.py\u001b[0m in \u001b[0;36mwrapper\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m 45\u001b[0m \u001b[0;32mdef\u001b[0m \u001b[0mwrapper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 46\u001b[0m \u001b[0;32mwith\u001b[0m \u001b[0m_rc_context\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfig_rcparams\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 47\u001b[0;31m \u001b[0;32mreturn\u001b[0m \u001b[0mf\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 48\u001b[0m \u001b[0;32mreturn\u001b[0m \u001b[0mwrapper\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 49\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/element.py\u001b[0m in \u001b[0;36minitialize_plot\u001b[0;34m(self, ranges)\u001b[0m\n\u001b[1;32m 512\u001b[0m \u001b[0mstyle\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m'label'\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0melement\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlabel\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 513\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 514\u001b[0;31m \u001b[0mplot_data\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mplot_kwargs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0maxis_kwargs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mget_data\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0melement\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mranges\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mstyle\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 515\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 516\u001b[0m \u001b[0;32mwith\u001b[0m \u001b[0mabbreviated_exception\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/chart.py\u001b[0m in \u001b[0;36mget_data\u001b[0;34m(self, element, ranges, style)\u001b[0m\n\u001b[1;32m 79\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 80\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0;34m'steps'\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0minterpolation\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 81\u001b[0;31m \u001b[0melement\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0minterpolate_curve\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0melement\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0minterpolation\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0minterpolation\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 82\u001b[0m \u001b[0mxs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0melement\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdimension_values\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 83\u001b[0m \u001b[0mys\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0melement\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdimension_values\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/param/parameterized.py\u001b[0m in \u001b[0;36m__new__\u001b[0;34m(class_, *args, **params)\u001b[0m\n\u001b[1;32m 3098\u001b[0m \u001b[0minst\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mclass_\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0minstance\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 3099\u001b[0m \u001b[0minst\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mparam\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_set_name\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mclass_\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__name__\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 3100\u001b[0;31m \u001b[0;32mreturn\u001b[0m \u001b[0minst\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__call__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m**\u001b[0m\u001b[0mparams\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 3101\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 3102\u001b[0m \u001b[0;32mdef\u001b[0m \u001b[0m__call__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m**\u001b[0m\u001b[0mkw\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/core/operation.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, element, **kwargs)\u001b[0m\n\u001b[1;32m 218\u001b[0m \u001b[0mkwargs\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m'link_dataset'\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_propagate_dataset\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 219\u001b[0m \u001b[0mkwargs\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m'link_inputs'\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlink_inputs\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 220\u001b[0;31m \u001b[0;32mreturn\u001b[0m \u001b[0melement\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mapply\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 221\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 222\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/core/accessors.py\u001b[0m in \u001b[0;36mpipelined_call\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m 43\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 44\u001b[0m \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 45\u001b[0;31m \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0m__call__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 46\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 47\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0min_method\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/core/accessors.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, apply_function, streams, link_inputs, link_dataset, dynamic, per_element, **kwargs)\u001b[0m\n\u001b[1;32m 202\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0mhasattr\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mapply_function\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'dynamic'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 203\u001b[0m \u001b[0minner_kwargs\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m'dynamic'\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mFalse\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 204\u001b[0;31m \u001b[0mnew_obj\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mapply_function\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_obj\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0minner_kwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 205\u001b[0m if (link_dataset and isinstance(self._obj, Dataset) and\n\u001b[1;32m 206\u001b[0m isinstance(new_obj, Dataset) and new_obj._dataset is None):\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/core/operation.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, element, **kwargs)\u001b[0m\n\u001b[1;32m 212\u001b[0m elif ((self._per_element and isinstance(element, Element)) or\n\u001b[1;32m 213\u001b[0m (not self._per_element and isinstance(element, ViewableElement))):\n\u001b[0;32m--> 214\u001b[0;31m \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_apply\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0melement\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 215\u001b[0m \u001b[0;32melif\u001b[0m \u001b[0;34m'streams'\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mkwargs\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 216\u001b[0m \u001b[0mkwargs\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m'streams'\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstreams\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/core/operation.py\u001b[0m in \u001b[0;36m_apply\u001b[0;34m(self, element, key)\u001b[0m\n\u001b[1;32m 139\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0min_method\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 140\u001b[0m \u001b[0melement\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_in_method\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mTrue\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 141\u001b[0;31m \u001b[0mret\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_process\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0melement\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkey\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 142\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0mhasattr\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0melement\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'_in_method'\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0min_method\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 143\u001b[0m \u001b[0melement\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_in_method\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0min_method\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/operation/element.py\u001b[0m in \u001b[0;36m_process\u001b[0;34m(self, element, key)\u001b[0m\n\u001b[1;32m 975\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 976\u001b[0m \u001b[0;32mdef\u001b[0m \u001b[0m_process\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0melement\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mkey\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;32mNone\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 977\u001b[0;31m \u001b[0;32mreturn\u001b[0m \u001b[0melement\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmap\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_process_layer\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mElement\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 978\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 979\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/core/data/__init__.py\u001b[0m in \u001b[0;36mpipelined_fn\u001b[0;34m(*args, **kwargs)\u001b[0m\n\u001b[1;32m 203\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 204\u001b[0m \u001b[0;32mtry\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 205\u001b[0;31m \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mmethod_fn\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 206\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0mPipelineMeta\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdisable\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 207\u001b[0m \u001b[0;32mreturn\u001b[0m \u001b[0mresult\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/core/data/__init__.py\u001b[0m in \u001b[0;36mmap\u001b[0;34m(self, *args, **kwargs)\u001b[0m\n\u001b[1;32m 1220\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 1221\u001b[0m \u001b[0;32mdef\u001b[0m \u001b[0mmap\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 1222\u001b[0;31m \u001b[0;32mreturn\u001b[0m \u001b[0msuper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mDataset\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmap\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 1223\u001b[0m \u001b[0mmap\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__doc__\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mLabelledData\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmap\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__doc__\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 1224\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/core/dimension.py\u001b[0m in \u001b[0;36mmap\u001b[0;34m(self, map_fn, specs, clone)\u001b[0m\n\u001b[1;32m 708\u001b[0m \u001b[0;32mreturn\u001b[0m \u001b[0mdeep_mapped\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 709\u001b[0m \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 710\u001b[0;31m \u001b[0;32mreturn\u001b[0m \u001b[0mmap_fn\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0mapplies\u001b[0m \u001b[0;32melse\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 711\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 712\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/operation/element.py\u001b[0m in \u001b[0;36m_process_layer\u001b[0;34m(self, element, key)\u001b[0m\n\u001b[1;32m 969\u001b[0m \u001b[0mx\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mx\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mastype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdt_type\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 970\u001b[0m \u001b[0mdvals\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtuple\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0melement\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdimension_values\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0md\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0md\u001b[0m \u001b[0;32min\u001b[0m \u001b[0melement\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdimensions\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 971\u001b[0;31m \u001b[0mxs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdvals\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mINTERPOLATE_FUNCS\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0minterpolation\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdvals\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 972\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0mis_datetime\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 973\u001b[0m \u001b[0mxs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mxs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mastype\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdt_type\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;32m~/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/operation/element.py\u001b[0m in \u001b[0;36mpts_to_poststep\u001b[0;34m(cls, x, values)\u001b[0m\n\u001b[1;32m 943\u001b[0m \u001b[0;34m@\u001b[0m\u001b[0mclassmethod\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 944\u001b[0m \u001b[0;32mdef\u001b[0m \u001b[0mpts_to_poststep\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mcls\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mx\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mvalues\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 945\u001b[0;31m \u001b[0msteps\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mzeros\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m2\u001b[0m \u001b[0;34m*\u001b[0m \u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m-\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 946\u001b[0m \u001b[0mvalue_steps\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtuple\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mempty\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m2\u001b[0m \u001b[0;34m*\u001b[0m \u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m-\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdtype\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mv\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdtype\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mv\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mvalues\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 947\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;31mValueError\u001b[0m: negative dimensions are not allowed"
]
},
{
"data": {
"text/plain": [
":Overlay\n",
" .Curve.Task_util :Curve [Time] (util)\n",
" .Marker.Task_util :Scatter [Time] (util)\n",
" .Curve.I :Curve [Time] (util)\n",
" .Marker.I :Scatter [Time] (util)"
]
},
"execution_count": 64,
"metadata": {},
"output_type": "execute_result"
},
{
"data": {
"image/png": "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\n",
"text/plain": [
"<Figure size 288x288 with 1 Axes>"
]
},
"metadata": {},
"output_type": "display_data"
}
],
"source": [
"fig"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Using the trace analysis"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"#### Example dataframes\n",
"\n",
"LISA ships a number of namespaced trace analysis methods. They can all be called on a trace with `trace.ana.<analysis name>.<method name>()`.\n",
"They fall mostly into two categories:\n",
" * Method starting with `df_`: returns a pandas DataFrame\n",
" * Method starting with `plot_`: returns a holoviews element ready to be displayed"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"The `trace.ana` object can be used to set default values to analysis methods. Simply calling it with keyword arguments will set default values, which can later be overridden when the method is called if necessary. \n",
"\n",
"This avoids repetition of fixed parameters such as `ŧask`, `tasks`, `cpu` etc. Just be careful as some methods might take more parameters than you expect: some task-related methods also accept a `cpu` parameter to restrict to a given CPU, so it might be a good idea to have a proxy object for all CPU-related calls and another one for task-related calls."
]
},
{
"cell_type": "code",
"execution_count": 39,
"metadata": {},
"outputs": [],
"source": [
"ana = trace.ana(task='tsk4_1-13')\n",
"\n",
"df = ana.tasks.df_task_states(stringify=True)\n",
"\n",
"# Default values can be overridden by calling it again\n",
"ana2 = ana(task='trace-cmd')\n",
"# And overridden again when calling the method\n",
"df = ana2.tasks.df_task_states(task='tsk4_1-13', stringify=True)"
]
},
{
"cell_type": "code",
"execution_count": 40,
"metadata": {},
"outputs": [],
"source": [
"from lisa.analysis.tasks import TaskState"
]
},
{
"cell_type": "code",
"execution_count": 41,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>target_cpu</th>\n",
" <th>cpu</th>\n",
" <th>curr_state</th>\n",
" <th>next_state</th>\n",
" <th>delta</th>\n",
" <th>curr_state_str</th>\n",
" <th>next_state_str</th>\n",
" </tr>\n",
" <tr>\n",
" <th>Time</th>\n",
" <th></th>\n",
" <th></th>\n",
" <th></th>\n",
" <th></th>\n",
" <th></th>\n",
" <th></th>\n",
" <th></th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
"Empty DataFrame\n",
"Columns: [target_cpu, cpu, curr_state, next_state, delta, curr_state_str, next_state_str]\n",
"Index: []"
]
},
"execution_count": 41,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df[df.curr_state == TaskState.TASK_ACTIVE][5462.3:5462.4]"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"#### Example plots"
]
},
{
"cell_type": "code",
"execution_count": 88,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<img src='' style='max-width:100%; margin: auto; display: block; '/>"
],
"text/plain": [
":Bars [cpu] (runtime)"
]
},
"execution_count": 88,
"metadata": {
"application/vnd.holoviews_exec.v0+json": {}
},
"output_type": "execute_result"
}
],
"source": [
"trace.ana.tasks.plot_task_total_residency(\"tsk_ru-24\")"
]
},
{
"cell_type": "code",
"execution_count": 90,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<img src='' style='max-width:100%; margin: auto; display: block; '/>"
],
"text/plain": [
":Overlay\n",
" .Scatter.Wakeup :Scatter [Time] (wakeup_latency)\n",
" .Scatter.Preemption :Scatter [Time] (preempt_latency)\n",
" .Threshold.A_1ms_threshold :HLine [x,y]"
]
},
"execution_count": 90,
"metadata": {
"application/vnd.holoviews_exec.v0+json": {}
},
"output_type": "execute_result"
}
],
"source": [
"trace.ana.latency.plot_latencies(\"tsk_ru-24\")"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"import holoviews as hv\n",
"# Before rendering any plot, a plotting backend for holoviews has to be chosen.\n",
"# Bokeh provides much better interactive (and HTML) plots than matplotlib\n",
"hv.extension('bokeh')"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"trace.ana.latency.plot_latencies(\"tsk4_1-13\")"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"trace.ana.latency.plot_latencies_cdf(\"tsk4_1-13\")"
]
},
{
"cell_type": "code",
"execution_count": 87,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<img src='' style='max-width:100%; margin: auto; display: block; '/>"
],
"text/plain": [
":Bars [cpu] (runtime)"
]
},
"execution_count": 87,
"metadata": {
"application/vnd.holoviews_exec.v0+json": {}
},
"output_type": "execute_result"
}
],
"source": [
"trace.ana.tasks.plot_task_total_residency(\"tsk_ru-24\")"
]
},
{
"cell_type": "code",
"execution_count": 84,
"metadata": {},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"2021-09-24 12:23:22,061 WARNING : py.warnings : /home/leoy/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/annotation.py:119: UserWarning: Setting the 'color' property will override the edgecolor or facecolor properties.\n",
" return [axis.axvspan(*positions, **opts)]\n",
"\n",
"2021-09-24 12:23:22,072 WARNING : py.warnings : /home/leoy/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/annotation.py:119: UserWarning: Setting the 'color' property will override the edgecolor or facecolor properties.\n",
" return [axis.axvspan(*positions, **opts)]\n",
"\n",
"2021-09-24 12:23:22,084 WARNING : py.warnings : /home/leoy/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/annotation.py:119: UserWarning: Setting the 'color' property will override the edgecolor or facecolor properties.\n",
" return [axis.axvspan(*positions, **opts)]\n",
"\n",
"2021-09-24 12:23:22,095 WARNING : py.warnings : /home/leoy/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/annotation.py:119: UserWarning: Setting the 'color' property will override the edgecolor or facecolor properties.\n",
" return [axis.axvspan(*positions, **opts)]\n",
"\n",
"2021-09-24 12:23:22,106 WARNING : py.warnings : /home/leoy/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/annotation.py:119: UserWarning: Setting the 'color' property will override the edgecolor or facecolor properties.\n",
" return [axis.axvspan(*positions, **opts)]\n",
"\n",
"2021-09-24 12:23:22,117 WARNING : py.warnings : /home/leoy/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/annotation.py:119: UserWarning: Setting the 'color' property will override the edgecolor or facecolor properties.\n",
" return [axis.axvspan(*positions, **opts)]\n",
"\n",
"2021-09-24 12:23:22,130 WARNING : py.warnings : /home/leoy/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/annotation.py:119: UserWarning: Setting the 'color' property will override the edgecolor or facecolor properties.\n",
" return [axis.axvspan(*positions, **opts)]\n",
"\n",
"2021-09-24 12:23:22,142 WARNING : py.warnings : /home/leoy/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/annotation.py:119: UserWarning: Setting the 'color' property will override the edgecolor or facecolor properties.\n",
" return [axis.axvspan(*positions, **opts)]\n",
"\n",
"2021-09-24 12:23:22,154 WARNING : py.warnings : /home/leoy/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/annotation.py:119: UserWarning: Setting the 'color' property will override the edgecolor or facecolor properties.\n",
" return [axis.axvspan(*positions, **opts)]\n",
"\n",
"2021-09-24 12:23:22,165 WARNING : py.warnings : /home/leoy/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/annotation.py:119: UserWarning: Setting the 'color' property will override the edgecolor or facecolor properties.\n",
" return [axis.axvspan(*positions, **opts)]\n",
"\n"
]
},
{
"data": {
"text/html": [
"<img src='' style='max-width:100%; margin: auto; display: block; '/>"
],
"text/plain": [
":Overlay\n",
" .Scatter.Task_running_in_domain_left_square_bracket_0_comma_1_comma_2_comma_3_right_square_bracket :Scatter [Time] (__cpu)\n",
" .VSpan.Overutilized.I :VSpan [x,y]\n",
" .VSpan.Overutilized.II :VSpan [x,y]\n",
" .VSpan.Overutilized.III :VSpan [x,y]\n",
" .VSpan.Overutilized.IV :VSpan [x,y]\n",
" .VSpan.Overutilized.V :VSpan [x,y]\n",
" .VSpan.Overutilized.VI :VSpan [x,y]\n",
" .VSpan.Overutilized.VII :VSpan [x,y]\n",
" .VSpan.Overutilized.VIII :VSpan [x,y]\n",
" .VSpan.Overutilized.IX :VSpan [x,y]\n",
" .VSpan.Overutilized.X :VSpan [x,y]"
]
},
"execution_count": 84,
"metadata": {
"application/vnd.holoviews_exec.v0+json": {}
},
"output_type": "execute_result"
}
],
"source": [
"trace.ana.tasks.plot_task_residency(\"tsk4_1-13\")"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"trace.ana.tasks.plot_tasks_wakeups_heatmap(bins=200)"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"trace.ana.tasks.plot_tasks_forks_heatmap(bins=200)"
]
},
{
"cell_type": "code",
"execution_count": 82,
"metadata": {},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"2021-09-24 12:20:11,335 WARNING : py.warnings : /home/leoy/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/annotation.py:119: UserWarning: Setting the 'color' property will override the edgecolor or facecolor properties.\n",
" return [axis.axvspan(*positions, **opts)]\n",
"\n",
"2021-09-24 12:20:11,392 WARNING : py.warnings : /home/leoy/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/annotation.py:119: UserWarning: Setting the 'color' property will override the edgecolor or facecolor properties.\n",
" return [axis.axvspan(*positions, **opts)]\n",
"\n",
"2021-09-24 12:20:11,411 WARNING : py.warnings : /home/leoy/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/annotation.py:119: UserWarning: Setting the 'color' property will override the edgecolor or facecolor properties.\n",
" return [axis.axvspan(*positions, **opts)]\n",
"\n",
"2021-09-24 12:20:11,431 WARNING : py.warnings : /home/leoy/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/annotation.py:119: UserWarning: Setting the 'color' property will override the edgecolor or facecolor properties.\n",
" return [axis.axvspan(*positions, **opts)]\n",
"\n",
"2021-09-24 12:20:11,447 WARNING : py.warnings : /home/leoy/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/annotation.py:119: UserWarning: Setting the 'color' property will override the edgecolor or facecolor properties.\n",
" return [axis.axvspan(*positions, **opts)]\n",
"\n",
"2021-09-24 12:20:11,461 WARNING : py.warnings : /home/leoy/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/annotation.py:119: UserWarning: Setting the 'color' property will override the edgecolor or facecolor properties.\n",
" return [axis.axvspan(*positions, **opts)]\n",
"\n",
"2021-09-24 12:20:11,477 WARNING : py.warnings : /home/leoy/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/annotation.py:119: UserWarning: Setting the 'color' property will override the edgecolor or facecolor properties.\n",
" return [axis.axvspan(*positions, **opts)]\n",
"\n",
"2021-09-24 12:20:11,499 WARNING : py.warnings : /home/leoy/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/annotation.py:119: UserWarning: Setting the 'color' property will override the edgecolor or facecolor properties.\n",
" return [axis.axvspan(*positions, **opts)]\n",
"\n",
"2021-09-24 12:20:11,507 WARNING : py.warnings : /home/leoy/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/annotation.py:119: UserWarning: Setting the 'color' property will override the edgecolor or facecolor properties.\n",
" return [axis.axvspan(*positions, **opts)]\n",
"\n",
"2021-09-24 12:20:11,513 WARNING : py.warnings : /home/leoy/Work2/Develop/tools/lisa/.lisa-venv-3.8/lib/python3.8/site-packages/holoviews/plotting/mpl/annotation.py:119: UserWarning: Setting the 'color' property will override the edgecolor or facecolor properties.\n",
" return [axis.axvspan(*positions, **opts)]\n",
"\n"
]
},
{
"data": {
"text/html": [
"<img src='' style='max-width:100%; margin: auto; display: block; '/>"
],
"text/plain": [
":Overlay\n",
" .VSpan.Overutilized.I :VSpan [x,y]\n",
" .VSpan.Overutilized.II :VSpan [x,y]\n",
" .VSpan.Overutilized.III :VSpan [x,y]\n",
" .VSpan.Overutilized.IV :VSpan [x,y]\n",
" .VSpan.Overutilized.V :VSpan [x,y]\n",
" .VSpan.Overutilized.VI :VSpan [x,y]\n",
" .VSpan.Overutilized.VII :VSpan [x,y]\n",
" .VSpan.Overutilized.VIII :VSpan [x,y]\n",
" .VSpan.Overutilized.IX :VSpan [x,y]\n",
" .VSpan.Overutilized.X :VSpan [x,y]"
]
},
"execution_count": 82,
"metadata": {
"application/vnd.holoviews_exec.v0+json": {}
},
"output_type": "execute_result"
}
],
"source": [
"trace.ana.status.plot_overutilized()"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": []
}
],
"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.8.10"
}
},
"nbformat": 4,
"nbformat_minor": 4
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment