Skip to content

Instantly share code, notes, and snippets.

@Leo-Yan
Created September 26, 2021 14:09
Show Gist options
  • Save Leo-Yan/d2fdd0f77b6ee973cd6d649bb1e39e56 to your computer and use it in GitHub Desktop.
Save Leo-Yan/d2fdd0f77b6ee973cd6d649bb1e39e56 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": 48,
"metadata": {},
"outputs": [],
"source": [
"import logging\n",
"from lisa.utils import setup_logging\n",
"setup_logging(filepath='logging.conf', level=logging.DEBUG)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Target configuration"
]
},
{
"cell_type": "code",
"execution_count": 49,
"metadata": {},
"outputs": [],
"source": [
"from lisa.target import Target, TargetConf"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"Create a target config file target_config.yml:\n",
"\n",
"```\n",
"# LISA Target configuration required by devlib to connect to a target.\n",
"#\n",
"# See the doc for available keys:\n",
"# https://lisa-linux-integrated-system-analysis.readthedocs.io/en/master/target.html#lisa.target.TargetConf\n",
"#\n",
"\n",
"target-conf:\n",
" kind : linux\n",
"\n",
" # Board\n",
" # Optional board name used for better prettier logs\n",
" name: qemu\n",
"\n",
" # Target IP or domain name\n",
" host: 192.168.3.103\n",
" port: 2222\n",
"\n",
" # Login username (has to be sudo enabled)\n",
" username: root\n",
" password: \"root\"\n",
"\n",
"platform-info:\n",
" conf:\n",
" rtapp:\n",
" # Calibration mapping of CPU numbers to calibration value for rtapp\n",
" calib: {0: 152, 1: 61}\n",
"\n",
"```"
]
},
{
"cell_type": "code",
"execution_count": 113,
"metadata": {},
"outputs": [],
"source": [
"#target = Target(\n",
"# kind='linux',\n",
"# name='qemu',\n",
"# host='192.168.3.103',\n",
"# port='2222',\n",
"# username='root',\n",
"# password='root',\n",
"#)\n",
"\n",
"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": 114,
"metadata": {},
"outputs": [],
"source": [
"from lisa.wlgen.rta import RTA, RTAPhase, PeriodicWload, DutyCycleSweepPhase"
]
},
{
"cell_type": "code",
"execution_count": 115,
"metadata": {},
"outputs": [],
"source": [
"rtapp_profile = {\n",
" **{\n",
" f'task1': RTAPhase(\n",
" prop_wload=PeriodicWload(\n",
" duty_cycle_pct=5,\n",
" period=16e-3,\n",
" duration=1,\n",
" )\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": 116,
"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": 117,
"metadata": {},
"outputs": [],
"source": [
"wload = RTA.from_profile(target, rtapp_profile, name='experiment_workload')"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Prepare Ftrace tracepoints"
]
},
{
"cell_type": "code",
"execution_count": 118,
"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": 119,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"['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:sched_cpu_capacity', 'task:task_rename', 'task:task_newtask', 'sched:sched_wake_idle_without_ipi', 'sched:sched_swap_numa', 'sched:sched_stick_numa', 'sched:sched_move_numa', 'sched:sched_pi_setprio', 'sched:sched_stat_runtime', 'sched:sched_stat_blocked', 'sched:sched_stat_iowait', 'sched:sched_stat_sleep', 'sched:sched_stat_wait', 'sched:sched_process_exec', 'sched:sched_process_fork', 'sched:sched_process_wait', 'sched:sched_wait_task', 'sched:sched_process_exit', 'sched:sched_process_free', 'sched:sched_migrate_task', 'sched:sched_switch', 'sched:sched_wakeup_new', 'sched:sched_wakeup', 'sched:sched_waking', 'sched:sched_kthread_work_execute_end', 'sched:sched_kthread_work_execute_start', 'sched:sched_kthread_work_queue_work', 'sched:sched_kthread_stop_ret', 'sched:sched_kthread_stop']\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": 120,
"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",
" 'sched_pelt_cfs',\n",
" 'sched_pelt_se',\n",
"]"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"And now we can actually record traces while running our workload:"
]
},
{
"cell_type": "code",
"execution_count": 121,
"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": 122,
"metadata": {},
"outputs": [],
"source": [
"with wload, ftrace_coll:\n",
" wload.run()"
]
},
{
"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": 123,
"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": 124,
"metadata": {},
"outputs": [],
"source": [
"trace = Trace(trace_path, target.plat_info, events=events)"
]
},
{
"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": 125,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"<os._wrap_close at 0x7fb3f8ca0e20>"
]
},
"execution_count": 125,
"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": [
"### 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": 128,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<img src='' style='max-width:100%; margin: auto; display: block; '/>"
],
"text/plain": [
":Bars [cpu] (runtime)"
]
},
"execution_count": 128,
"metadata": {
"application/vnd.holoviews_exec.v0+json": {}
},
"output_type": "execute_result"
}
],
"source": [
"trace.ana.tasks.plot_task_total_residency(\"task1-0\")"
]
},
{
"cell_type": "code",
"execution_count": 129,
"metadata": {},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"[2021-09-26 21:17:34,871][py.warnings] WARNING /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-26 21:17:34,945][py.warnings] WARNING /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-26 21:17:34,957][py.warnings] WARNING /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-26 21:17:35,001][py.warnings] WARNING /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-26 21:17:35,022][py.warnings] WARNING /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-26 21:17:35,035][py.warnings] WARNING /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-26 21:17:35,044][py.warnings] WARNING /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-26 21:17:35,065][py.warnings] WARNING /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-26 21:17:35,076][py.warnings] WARNING /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-26 21:17:35,092][py.warnings] WARNING /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-26 21:17:35,102][py.warnings] WARNING /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-26 21:17:35,113][py.warnings] WARNING /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-26 21:17:35,127][py.warnings] WARNING /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-26 21:17:35,138][py.warnings] WARNING /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-26 21:17:35,149][py.warnings] WARNING /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-26 21:17:35,162][py.warnings] WARNING /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-26 21:17:35,175][py.warnings] WARNING /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-26 21:17:35,186][py.warnings] WARNING /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-26 21:17:35,203][py.warnings] WARNING /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-26 21:17:35,213][py.warnings] WARNING /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-26 21:17:35,229][py.warnings] WARNING /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-26 21:17:35,238][py.warnings] WARNING /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",
" .Curve.Util :Curve [Time] (util)\n",
" .Marker.Util :Scatter [Time] (util)\n",
" .Curve.Load :Curve [Time] (load)\n",
" .Marker.Load :Scatter [Time] (load)\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]\n",
" .VSpan.Overutilized.XI :VSpan [x,y]\n",
" .VSpan.Overutilized.XII :VSpan [x,y]\n",
" .VSpan.Overutilized.XIII :VSpan [x,y]\n",
" .VSpan.Overutilized.XIV :VSpan [x,y]\n",
" .VSpan.Overutilized.XV :VSpan [x,y]\n",
" .VSpan.Overutilized.XVI :VSpan [x,y]\n",
" .VSpan.Overutilized.XVII :VSpan [x,y]\n",
" .VSpan.Overutilized.XVIII :VSpan [x,y]\n",
" .VSpan.Overutilized.XIX :VSpan [x,y]\n",
" .VSpan.Overutilized.XX :VSpan [x,y]\n",
" .VSpan.Overutilized.XXI :VSpan [x,y]\n",
" .VSpan.Overutilized.XXII :VSpan [x,y]"
]
},
"execution_count": 129,
"metadata": {
"application/vnd.holoviews_exec.v0+json": {}
},
"output_type": "execute_result"
}
],
"source": [
"trace.ana.load_tracking.plot_task_signals(\"task1-0\")"
]
},
{
"cell_type": "code",
"execution_count": 130,
"metadata": {},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
"[2021-09-26 21:18:21,894][py.warnings] WARNING /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-26 21:18:21,903][py.warnings] WARNING /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-26 21:18:21,912][py.warnings] WARNING /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-26 21:18:21,923][py.warnings] WARNING /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-26 21:18:21,937][py.warnings] WARNING /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-26 21:18:21,951][py.warnings] WARNING /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-26 21:18:21,965][py.warnings] WARNING /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-26 21:18:21,984][py.warnings] WARNING /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-26 21:18:21,996][py.warnings] WARNING /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-26 21:18:22,007][py.warnings] WARNING /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-26 21:18:22,019][py.warnings] WARNING /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-26 21:18:22,036][py.warnings] WARNING /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-26 21:18:22,046][py.warnings] WARNING /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-26 21:18:22,069][py.warnings] WARNING /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-26 21:18:22,084][py.warnings] WARNING /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-26 21:18:22,091][py.warnings] WARNING /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-26 21:18:22,101][py.warnings] WARNING /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-26 21:18:22,120][py.warnings] WARNING /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-26 21:18:22,132][py.warnings] WARNING /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-26 21:18:22,146][py.warnings] WARNING /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-26 21:18:22,152][py.warnings] WARNING /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-26 21:18:22,162][py.warnings] WARNING /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_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]\n",
" .VSpan.Overutilized.XI :VSpan [x,y]\n",
" .VSpan.Overutilized.XII :VSpan [x,y]\n",
" .VSpan.Overutilized.XIII :VSpan [x,y]\n",
" .VSpan.Overutilized.XIV :VSpan [x,y]\n",
" .VSpan.Overutilized.XV :VSpan [x,y]\n",
" .VSpan.Overutilized.XVI :VSpan [x,y]\n",
" .VSpan.Overutilized.XVII :VSpan [x,y]\n",
" .VSpan.Overutilized.XVIII :VSpan [x,y]\n",
" .VSpan.Overutilized.XIX :VSpan [x,y]\n",
" .VSpan.Overutilized.XX :VSpan [x,y]\n",
" .VSpan.Overutilized.XXI :VSpan [x,y]\n",
" .VSpan.Overutilized.XXII :VSpan [x,y]"
]
},
"execution_count": 130,
"metadata": {
"application/vnd.holoviews_exec.v0+json": {}
},
"output_type": "execute_result"
}
],
"source": [
"trace.ana.tasks.plot_task_residency(\"task1-0\")"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Analyze the overulized signal "
]
},
{
"cell_type": "code",
"execution_count": 131,
"metadata": {},
"outputs": [],
"source": [
"df_overutilized = trace.df_event(\"sched_overutilized\")\n",
"df_overutilized[\"overutilized\"] = df_overutilized[\"overutilized\"].astype(int)"
]
},
{
"cell_type": "code",
"execution_count": 132,
"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>prio</th>\n",
" <th>comm</th>\n",
" <th>orig_cpu</th>\n",
" <th>pid</th>\n",
" <th>dest_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",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>2815.985447</th>\n",
" <td>&lt;...&gt;</td>\n",
" <td>1647</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>sh</td>\n",
" <td>0</td>\n",
" <td>1646</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.073521</th>\n",
" <td>sh</td>\n",
" <td>1649</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>tcf-agent</td>\n",
" <td>0</td>\n",
" <td>298</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.088744</th>\n",
" <td>sh</td>\n",
" <td>1649</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>rcu_preempt</td>\n",
" <td>0</td>\n",
" <td>12</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.193702</th>\n",
" <td>migration/0</td>\n",
" <td>13</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>shutils</td>\n",
" <td>0</td>\n",
" <td>1651</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.200682</th>\n",
" <td>shutils</td>\n",
" <td>1651</td>\n",
" <td>1</td>\n",
" <td>120</td>\n",
" <td>rcu_preempt</td>\n",
" <td>1</td>\n",
" <td>12</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.226236</th>\n",
" <td>shutils</td>\n",
" <td>1651</td>\n",
" <td>1</td>\n",
" <td>120</td>\n",
" <td>tcf-agent</td>\n",
" <td>1</td>\n",
" <td>298</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.276827</th>\n",
" <td>busybox</td>\n",
" <td>1652</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>rcu_preempt</td>\n",
" <td>0</td>\n",
" <td>12</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.292783</th>\n",
" <td>shutils</td>\n",
" <td>1651</td>\n",
" <td>1</td>\n",
" <td>120</td>\n",
" <td>rcu_preempt</td>\n",
" <td>1</td>\n",
" <td>12</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.392885</th>\n",
" <td>shutils</td>\n",
" <td>1654</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>rcu_preempt</td>\n",
" <td>0</td>\n",
" <td>12</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.409002</th>\n",
" <td>migration/0</td>\n",
" <td>13</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>shutils</td>\n",
" <td>0</td>\n",
" <td>1654</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.412868</th>\n",
" <td>shutils</td>\n",
" <td>1654</td>\n",
" <td>1</td>\n",
" <td>120</td>\n",
" <td>rcu_preempt</td>\n",
" <td>1</td>\n",
" <td>12</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.488477</th>\n",
" <td>shutils</td>\n",
" <td>1654</td>\n",
" <td>1</td>\n",
" <td>120</td>\n",
" <td>shutils</td>\n",
" <td>0</td>\n",
" <td>1656</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.529613</th>\n",
" <td>migration/0</td>\n",
" <td>13</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>shutils</td>\n",
" <td>0</td>\n",
" <td>1658</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.535032</th>\n",
" <td>true</td>\n",
" <td>1655</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>shutils</td>\n",
" <td>1</td>\n",
" <td>1654</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.549223</th>\n",
" <td>migration/0</td>\n",
" <td>13</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>shutils</td>\n",
" <td>0</td>\n",
" <td>1654</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.559439</th>\n",
" <td>shutils</td>\n",
" <td>1654</td>\n",
" <td>1</td>\n",
" <td>120</td>\n",
" <td>sh</td>\n",
" <td>1</td>\n",
" <td>1653</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.560245</th>\n",
" <td>kworker/1:2</td>\n",
" <td>60</td>\n",
" <td>1</td>\n",
" <td>120</td>\n",
" <td>sh</td>\n",
" <td>0</td>\n",
" <td>1653</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.780786</th>\n",
" <td>rt-app</td>\n",
" <td>1660</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>rcu_preempt</td>\n",
" <td>0</td>\n",
" <td>12</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.783112</th>\n",
" <td>rt-app</td>\n",
" <td>1660</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>tcf-agent</td>\n",
" <td>0</td>\n",
" <td>298</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.801315</th>\n",
" <td>migration/0</td>\n",
" <td>13</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>rt-app</td>\n",
" <td>0</td>\n",
" <td>1660</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.812723</th>\n",
" <td>&lt;idle&gt;</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>rcu_preempt</td>\n",
" <td>1</td>\n",
" <td>12</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.822108</th>\n",
" <td>task1-0</td>\n",
" <td>1661</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>sshd</td>\n",
" <td>0</td>\n",
" <td>1431</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.828642</th>\n",
" <td>task1-0</td>\n",
" <td>1661</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>rcu_preempt</td>\n",
" <td>0</td>\n",
" <td>12</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.849032</th>\n",
" <td>migration/0</td>\n",
" <td>13</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>task1-0</td>\n",
" <td>0</td>\n",
" <td>1661</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2816.884239</th>\n",
" <td>task1-0</td>\n",
" <td>1661</td>\n",
" <td>1</td>\n",
" <td>120</td>\n",
" <td>tcf-agent</td>\n",
" <td>1</td>\n",
" <td>298</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2817.817659</th>\n",
" <td>task1-0</td>\n",
" <td>1661</td>\n",
" <td>1</td>\n",
" <td>120</td>\n",
" <td>sshd</td>\n",
" <td>1</td>\n",
" <td>1431</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2817.820753</th>\n",
" <td>task1-0</td>\n",
" <td>1661</td>\n",
" <td>1</td>\n",
" <td>120</td>\n",
" <td>rt-app</td>\n",
" <td>1</td>\n",
" <td>1660</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2817.821785</th>\n",
" <td>migration/0</td>\n",
" <td>13</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>rt-app</td>\n",
" <td>0</td>\n",
" <td>1660</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2817.824791</th>\n",
" <td>sh</td>\n",
" <td>1659</td>\n",
" <td>1</td>\n",
" <td>120</td>\n",
" <td>rcu_preempt</td>\n",
" <td>1</td>\n",
" <td>12</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2817.929133</th>\n",
" <td>shutils</td>\n",
" <td>1663</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>rcu_preempt</td>\n",
" <td>0</td>\n",
" <td>12</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2817.945138</th>\n",
" <td>migration/0</td>\n",
" <td>13</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>shutils</td>\n",
" <td>0</td>\n",
" <td>1663</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2817.952723</th>\n",
" <td>shutils</td>\n",
" <td>1663</td>\n",
" <td>1</td>\n",
" <td>120</td>\n",
" <td>rcu_preempt</td>\n",
" <td>1</td>\n",
" <td>12</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2818.036874</th>\n",
" <td>busybox</td>\n",
" <td>1664</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>rcu_preempt</td>\n",
" <td>0</td>\n",
" <td>12</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2818.052812</th>\n",
" <td>&lt;idle&gt;</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>rcu_preempt</td>\n",
" <td>1</td>\n",
" <td>12</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2818.065440</th>\n",
" <td>shutils</td>\n",
" <td>1663</td>\n",
" <td>1</td>\n",
" <td>120</td>\n",
" <td>sh</td>\n",
" <td>1</td>\n",
" <td>1662</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2818.069277</th>\n",
" <td>migration/0</td>\n",
" <td>13</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>sh</td>\n",
" <td>0</td>\n",
" <td>1662</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2818.157453</th>\n",
" <td>sh</td>\n",
" <td>1665</td>\n",
" <td>1</td>\n",
" <td>120</td>\n",
" <td>kcompactd0</td>\n",
" <td>0</td>\n",
" <td>28</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2818.172685</th>\n",
" <td>sh</td>\n",
" <td>1666</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>rcu_preempt</td>\n",
" <td>0</td>\n",
" <td>12</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2818.184789</th>\n",
" <td>sshd</td>\n",
" <td>1431</td>\n",
" <td>0</td>\n",
" <td>120</td>\n",
" <td>rcu_preempt</td>\n",
" <td>1</td>\n",
" <td>12</td>\n",
" <td>0</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" __comm __pid __cpu prio comm orig_cpu pid \\\n",
"Time \n",
"2815.985447 <...> 1647 0 120 sh 0 1646 \n",
"2816.073521 sh 1649 0 120 tcf-agent 0 298 \n",
"2816.088744 sh 1649 0 120 rcu_preempt 0 12 \n",
"2816.193702 migration/0 13 0 120 shutils 0 1651 \n",
"2816.200682 shutils 1651 1 120 rcu_preempt 1 12 \n",
"2816.226236 shutils 1651 1 120 tcf-agent 1 298 \n",
"2816.276827 busybox 1652 0 120 rcu_preempt 0 12 \n",
"2816.292783 shutils 1651 1 120 rcu_preempt 1 12 \n",
"2816.392885 shutils 1654 0 120 rcu_preempt 0 12 \n",
"2816.409002 migration/0 13 0 120 shutils 0 1654 \n",
"2816.412868 shutils 1654 1 120 rcu_preempt 1 12 \n",
"2816.488477 shutils 1654 1 120 shutils 0 1656 \n",
"2816.529613 migration/0 13 0 120 shutils 0 1658 \n",
"2816.535032 true 1655 0 120 shutils 1 1654 \n",
"2816.549223 migration/0 13 0 120 shutils 0 1654 \n",
"2816.559439 shutils 1654 1 120 sh 1 1653 \n",
"2816.560245 kworker/1:2 60 1 120 sh 0 1653 \n",
"2816.780786 rt-app 1660 0 120 rcu_preempt 0 12 \n",
"2816.783112 rt-app 1660 0 120 tcf-agent 0 298 \n",
"2816.801315 migration/0 13 0 120 rt-app 0 1660 \n",
"2816.812723 <idle> 0 0 120 rcu_preempt 1 12 \n",
"2816.822108 task1-0 1661 0 120 sshd 0 1431 \n",
"2816.828642 task1-0 1661 0 120 rcu_preempt 0 12 \n",
"2816.849032 migration/0 13 0 120 task1-0 0 1661 \n",
"2816.884239 task1-0 1661 1 120 tcf-agent 1 298 \n",
"2817.817659 task1-0 1661 1 120 sshd 1 1431 \n",
"2817.820753 task1-0 1661 1 120 rt-app 1 1660 \n",
"2817.821785 migration/0 13 0 120 rt-app 0 1660 \n",
"2817.824791 sh 1659 1 120 rcu_preempt 1 12 \n",
"2817.929133 shutils 1663 0 120 rcu_preempt 0 12 \n",
"2817.945138 migration/0 13 0 120 shutils 0 1663 \n",
"2817.952723 shutils 1663 1 120 rcu_preempt 1 12 \n",
"2818.036874 busybox 1664 0 120 rcu_preempt 0 12 \n",
"2818.052812 <idle> 0 0 120 rcu_preempt 1 12 \n",
"2818.065440 shutils 1663 1 120 sh 1 1662 \n",
"2818.069277 migration/0 13 0 120 sh 0 1662 \n",
"2818.157453 sh 1665 1 120 kcompactd0 0 28 \n",
"2818.172685 sh 1666 0 120 rcu_preempt 0 12 \n",
"2818.184789 sshd 1431 0 120 rcu_preempt 1 12 \n",
"\n",
" dest_cpu \n",
"Time \n",
"2815.985447 1 \n",
"2816.073521 1 \n",
"2816.088744 1 \n",
"2816.193702 1 \n",
"2816.200682 0 \n",
"2816.226236 0 \n",
"2816.276827 1 \n",
"2816.292783 0 \n",
"2816.392885 1 \n",
"2816.409002 1 \n",
"2816.412868 0 \n",
"2816.488477 1 \n",
"2816.529613 1 \n",
"2816.535032 0 \n",
"2816.549223 1 \n",
"2816.559439 0 \n",
"2816.560245 1 \n",
"2816.780786 1 \n",
"2816.783112 1 \n",
"2816.801315 1 \n",
"2816.812723 0 \n",
"2816.822108 1 \n",
"2816.828642 1 \n",
"2816.849032 1 \n",
"2816.884239 0 \n",
"2817.817659 0 \n",
"2817.820753 0 \n",
"2817.821785 1 \n",
"2817.824791 0 \n",
"2817.929133 1 \n",
"2817.945138 1 \n",
"2817.952723 0 \n",
"2818.036874 1 \n",
"2818.052812 0 \n",
"2818.065440 0 \n",
"2818.069277 1 \n",
"2818.157453 1 \n",
"2818.172685 1 \n",
"2818.184789 0 "
]
},
"execution_count": 132,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df_migrate_task = trace.df_event(\"sched_migrate_task\")\n",
"df_migrate_task"
]
},
{
"cell_type": "code",
"execution_count": 133,
"metadata": {},
"outputs": [],
"source": [
"import matplotlib.pyplot as plt\n",
"import matplotlib.gridspec as gridspec\n",
"\n",
"def analysis_tipping_point(pid):\n",
" colors=['c', 'b', 'r']\n",
" \n",
" gs = gridspec.GridSpec(1,1)\n",
" fig = plt.figure(figsize=(16,5))\n",
" fig.subplots_adjust(top=0.92)\n",
" plt.suptitle(\"Tipping point analysis\", fontsize=14, fontweight='bold')\n",
" \n",
" axes = plt.subplot(gs[0,0])\n",
" \n",
" df = df_migrate_task[df_migrate_task.pid == pid][['dest_cpu']]\n",
" axes.scatter(df.index, df['dest_cpu'], color=colors[1])\n",
" \n",
" tipping_point = df_overutilized[['overutilized']]\n",
" tipping_point.plot(ax=axes, drawstyle='steps-post', color=colors[2], linewidth=3, ylim=(0,8))\n",
" \n",
" axes.grid(True)"
]
},
{
"cell_type": "code",
"execution_count": 134,
"metadata": {},
"outputs": [
{
"data": {
"image/png": "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HjL3Pr+LL744Z5xxRo455pgkyWtf+9o5x1166aVjq3FP2IMJAAAwgje84Q059thjc+yxx+Yv/uIv8qpXvSpvectbdjz/mte8Juedd16S5PWvf32e+tSn5slPfnJe/erBNz5ef/31Ofroo/OiF70oxx57bG688casXr16x+svvPDCnHvuufnc5z6XD33oQ3nlK1+Z4447Ltddd13OPffcXHjhhT9W01FHHZXbb789b33rW3PcccfluOOOy9q1a7Nu3bokyWWXXZaTTjopxx9/fM4888xs27YtSfLRj340T3jCE3L88cfngx/8YLdtJGACAACTpWp80y5s2rQp73znO3PFFVfk8ssvz9ve9racddZZef/7379jzPvf//6cddZZueyyy3LNNdfkC1/4QjZv3pxNmzblU5/6VJLkmmuuyUtf+tJcddVVOfLII+dc1tOf/vQ897nPzetf//ps3rw5j33sY+fdJL/1W7+VzZs354tf/GIOP/zw/N7v/V5uv/32vO51r8snPvGJXHnllZmamsob3vCG3HfffXnJS16SD3/4w9m0aVNuueWWBf4Cds0hsgAAAPP4zGc+k+c973k5+OCDkyS/+qu/mk9/+tO59dZbc/PNN+e2227LIx7xiBxxxBF54xvfmMsuuyxPecpTkiTbtm3LNddck5/6qZ/KkUcemRNPPHFsdb7sZS/LKaeckl/+5V/OJZdckquvvjrPeMYzkiTf//73c9JJJ+VrX/ta1q5dm8c97nFJknPOOSfnn39+l+ULmAAAAHvozDPPzIUXXphbbrklZ511VpLB+ZV/+Id/mN/8zd/8kbHXX3/9joC63ewrtS70K0F29q53vSs33HBD3vzmN++o45nPfGbe+973/si4zZs379VydschsgAAwGRpbXzTLpx88sm5+OKLc++99+aee+7JRRddlJNPPjlnnXVWNmzYkAsvvDBnnnlmkuSXfumX8o53vGPH+Y433XRTbr311jnnu2bNmmzZsiUPPPBALrrooh2PH3LIIbn77rtH3iSbNm3KeeedlwsuuGDHhYNOPPHEfPazn821116bJLnnnnvyjW98I094whNy/fXX57rrrkuSHwuge8MeTAAAgHkcf/zxOffcc/O0pz0tSfLiF794xyGwd999dw477LA8+tGPTpI861nPypYtW3LSSSclSVavXp0LLrgg++2334/N98/+7M9yxhln5JGPfGSmpqZ2hNKzzz47L3nJS/KmN71pzov77OzNb35zvvOd7+y4uM/U1FTe/va3513velde8IIX5P7770+SvO51r8vjH//4nH/++Tn99NNz0EEH5eSTT15QmN2dartJ6Xtqamqqbf9elkkxMzOT6enppS4DFkzvMqn0LpNI3zKpVkLvbtmyJU984hOXuox9zlzbvao2tdam5hrvEFkAAAC6EDABAADoQsAEAACgCwETAACYCOO4fgy7tifbW8AEAACWvQMOOCB33HGHkLlIWmu54447csABByzodb6mBAAAWPYOP/zwbN26NbfddttSl7LPOOCAA3L44Ycv6DUCJgAAsOztv//+Wbt27VKXwTwcIgsAAEAXAiYAAABdCJgAAAB0IWACAADQhYAJAABAFwImAAAAXQiYAAAAdDFvwKyqo6tq86zprqp6+SLUBgAAwARZNd+A1trXkxyXJFW1X5Kbklw03rIAAACYNAs9RPbUJNe11m4YRzEAAABMrmqtjT646h1JrmytvXmO59YnWZ8ka9asOWHDhg3dilwM27Zty+rVq5e6DFgwvcuk0rtMIn3LpNK79LRu3bpNrbWpuZ4bOWBW1UOT3JzkSa21f9zd2KmpqbZx48YFF7qUZmZmMj09vdRlwILpXSaV3mUS6Vsmld6lp6raZcBcyCGyz8lg7+VuwyUAAAD7poUEzBckee+4CgEAAGCyjRQwq+rgJM9M8sHxlgMAAMCkmvdrSpKktXZPkkPHXAsAAAATbKFfUwIAAABzEjABAADoQsAEAACgCwETAACALgRMAAAAuhAwAQAA6ELABAAAoAsBEwAAgC4ETAAAALoQMAEAAOhCwAQAAKALARMAAIAuBEwAAAC6EDABAADoQsAEAACgCwETAACALgRMAAAAuhAwAQAA6ELABAAAoAsBEwAAgC4ETAAAALoQMAEAAOhCwAQAAKALARMAAIAuBEwAAAC6EDABAADoYqSAWVUPr6oLq+prVbWlqk4ad2EAAABMllUjjntjko+21p5fVQ9NctAYawIAAGACzRswq+phSf5VknOTpLX2/STfH29ZAAAATJpRDpFdm+S2JO+sqi9V1dur6uAx1wUAAMCEqdba7gdUTSW5PMkzWmtXVNUbk9zVWvujncatT7I+SdasWXPChg0bxlTyeGzbti2rV69e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\n",
"text/plain": [
"<Figure size 1152x360 with 1 Axes>"
]
},
"metadata": {
"needs_background": "light"
},
"output_type": "display_data"
}
],
"source": [
"analysis_tipping_point(1661)"
]
},
{
"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