Skip to content

Instantly share code, notes, and snippets.

@pushpendre
Created July 4, 2021 19:49
Show Gist options
  • Star 21 You must be signed in to star a gist
  • Fork 1 You must be signed in to fork a gist
  • Save pushpendre/359706010c20bc1d18123510749f5da5 to your computer and use it in GitHub Desktop.
Save pushpendre/359706010c20bc1d18123510749f5da5 to your computer and use it in GitHub Desktop.
PID Controller for controlling the number of servers in a data-center. This notebook accompanies the video https://youtu.be/pKuVUmpYkLk
Display the source blob
Display the rendered blob
Raw
{
"cells": [
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### PID Controller for controlling the num of servers in a data-center\n",
"\n",
"* This notebook accompanies the video https://youtu.be/pKuVUmpYkLk"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"%matplotlib notebook\n",
"import numpy as np\n",
"from bisect import bisect_left, bisect_right\n",
"from pdb import set_trace as st\n",
"from dataclasses import dataclass\n",
"from typing import Optional, List\n",
"from collections import defaultdict, deque\n",
"from itertools import islice\n",
"SPD = 24 * 3600 # Seconds per day\n",
"\n",
"class Env:\n",
" def __init__(self):\n",
" self.resolution = 1\n",
" self.current_time = 0\n",
" \n",
" def time(self):\n",
" self.current_time += 1\n",
" return self.current_time - 1\n",
" \n",
" def time_series(self):\n",
" while True:\n",
" yield self.time()\n",
" \n",
" def reset(self):\n",
" self.current_time = 0 \n",
"\n",
"@dataclass\n",
"class Task:\n",
" creation_time: float\n",
" end_time: Optional[float]\n",
" proc_time_needed: float\n",
" proc_time_remaining: float\n",
" server: Optional[int] = None\n",
" thread: Optional[int] = None\n",
"\n",
"def mean_load(t):\n",
" return int(550 - 450 * np.cos((t % SPD)/SPD * 2 * np.pi))"
]
},
{
"cell_type": "code",
"execution_count": 30,
"metadata": {},
"outputs": [
{
"data": {
"application/javascript": [
"/* Put everything inside the global mpl namespace */\n",
"window.mpl = {};\n",
"\n",
"\n",
"mpl.get_websocket_type = function() {\n",
" if (typeof(WebSocket) !== 'undefined') {\n",
" return WebSocket;\n",
" } else if (typeof(MozWebSocket) !== 'undefined') {\n",
" return MozWebSocket;\n",
" } else {\n",
" alert('Your browser does not have WebSocket support.' +\n",
" 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
" 'Firefox 4 and 5 are also supported but you ' +\n",
" 'have to enable WebSockets in about:config.');\n",
" };\n",
"}\n",
"\n",
"mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
" this.id = figure_id;\n",
"\n",
" this.ws = websocket;\n",
"\n",
" this.supports_binary = (this.ws.binaryType != undefined);\n",
"\n",
" if (!this.supports_binary) {\n",
" var warnings = document.getElementById(\"mpl-warnings\");\n",
" if (warnings) {\n",
" warnings.style.display = 'block';\n",
" warnings.textContent = (\n",
" \"This browser does not support binary websocket messages. \" +\n",
" \"Performance may be slow.\");\n",
" }\n",
" }\n",
"\n",
" this.imageObj = new Image();\n",
"\n",
" this.context = undefined;\n",
" this.message = undefined;\n",
" this.canvas = undefined;\n",
" this.rubberband_canvas = undefined;\n",
" this.rubberband_context = undefined;\n",
" this.format_dropdown = undefined;\n",
"\n",
" this.image_mode = 'full';\n",
"\n",
" this.root = $('<div/>');\n",
" this._root_extra_style(this.root)\n",
" this.root.attr('style', 'display: inline-block');\n",
"\n",
" $(parent_element).append(this.root);\n",
"\n",
" this._init_header(this);\n",
" this._init_canvas(this);\n",
" this._init_toolbar(this);\n",
"\n",
" var fig = this;\n",
"\n",
" this.waiting = false;\n",
"\n",
" this.ws.onopen = function () {\n",
" fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
" fig.send_message(\"send_image_mode\", {});\n",
" if (mpl.ratio != 1) {\n",
" fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
" }\n",
" fig.send_message(\"refresh\", {});\n",
" }\n",
"\n",
" this.imageObj.onload = function() {\n",
" if (fig.image_mode == 'full') {\n",
" // Full images could contain transparency (where diff images\n",
" // almost always do), so we need to clear the canvas so that\n",
" // there is no ghosting.\n",
" fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
" }\n",
" fig.context.drawImage(fig.imageObj, 0, 0);\n",
" };\n",
"\n",
" this.imageObj.onunload = function() {\n",
" fig.ws.close();\n",
" }\n",
"\n",
" this.ws.onmessage = this._make_on_message_function(this);\n",
"\n",
" this.ondownload = ondownload;\n",
"}\n",
"\n",
"mpl.figure.prototype._init_header = function() {\n",
" var titlebar = $(\n",
" '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
" 'ui-helper-clearfix\"/>');\n",
" var titletext = $(\n",
" '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
" 'text-align: center; padding: 3px;\"/>');\n",
" titlebar.append(titletext)\n",
" this.root.append(titlebar);\n",
" this.header = titletext[0];\n",
"}\n",
"\n",
"\n",
"\n",
"mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
"\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
"\n",
"}\n",
"\n",
"mpl.figure.prototype._init_canvas = function() {\n",
" var fig = this;\n",
"\n",
" var canvas_div = $('<div/>');\n",
"\n",
" canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
"\n",
" function canvas_keyboard_event(event) {\n",
" return fig.key_event(event, event['data']);\n",
" }\n",
"\n",
" canvas_div.keydown('key_press', canvas_keyboard_event);\n",
" canvas_div.keyup('key_release', canvas_keyboard_event);\n",
" this.canvas_div = canvas_div\n",
" this._canvas_extra_style(canvas_div)\n",
" this.root.append(canvas_div);\n",
"\n",
" var canvas = $('<canvas/>');\n",
" canvas.addClass('mpl-canvas');\n",
" canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
"\n",
" this.canvas = canvas[0];\n",
" this.context = canvas[0].getContext(\"2d\");\n",
"\n",
" var backingStore = this.context.backingStorePixelRatio ||\n",
"\tthis.context.webkitBackingStorePixelRatio ||\n",
"\tthis.context.mozBackingStorePixelRatio ||\n",
"\tthis.context.msBackingStorePixelRatio ||\n",
"\tthis.context.oBackingStorePixelRatio ||\n",
"\tthis.context.backingStorePixelRatio || 1;\n",
"\n",
" mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
"\n",
" var rubberband = $('<canvas/>');\n",
" rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
"\n",
" var pass_mouse_events = true;\n",
"\n",
" canvas_div.resizable({\n",
" start: function(event, ui) {\n",
" pass_mouse_events = false;\n",
" },\n",
" resize: function(event, ui) {\n",
" fig.request_resize(ui.size.width, ui.size.height);\n",
" },\n",
" stop: function(event, ui) {\n",
" pass_mouse_events = true;\n",
" fig.request_resize(ui.size.width, ui.size.height);\n",
" },\n",
" });\n",
"\n",
" function mouse_event_fn(event) {\n",
" if (pass_mouse_events)\n",
" return fig.mouse_event(event, event['data']);\n",
" }\n",
"\n",
" rubberband.mousedown('button_press', mouse_event_fn);\n",
" rubberband.mouseup('button_release', mouse_event_fn);\n",
" // Throttle sequential mouse events to 1 every 20ms.\n",
" rubberband.mousemove('motion_notify', mouse_event_fn);\n",
"\n",
" rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
" rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
"\n",
" canvas_div.on(\"wheel\", function (event) {\n",
" event = event.originalEvent;\n",
" event['data'] = 'scroll'\n",
" if (event.deltaY < 0) {\n",
" event.step = 1;\n",
" } else {\n",
" event.step = -1;\n",
" }\n",
" mouse_event_fn(event);\n",
" });\n",
"\n",
" canvas_div.append(canvas);\n",
" canvas_div.append(rubberband);\n",
"\n",
" this.rubberband = rubberband;\n",
" this.rubberband_canvas = rubberband[0];\n",
" this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
" this.rubberband_context.strokeStyle = \"#000000\";\n",
"\n",
" this._resize_canvas = function(width, height) {\n",
" // Keep the size of the canvas, canvas container, and rubber band\n",
" // canvas in synch.\n",
" canvas_div.css('width', width)\n",
" canvas_div.css('height', height)\n",
"\n",
" canvas.attr('width', width * mpl.ratio);\n",
" canvas.attr('height', height * mpl.ratio);\n",
" canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
"\n",
" rubberband.attr('width', width);\n",
" rubberband.attr('height', height);\n",
" }\n",
"\n",
" // Set the figure to an initial 600x600px, this will subsequently be updated\n",
" // upon first draw.\n",
" this._resize_canvas(600, 600);\n",
"\n",
" // Disable right mouse context menu.\n",
" $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
" return false;\n",
" });\n",
"\n",
" function set_focus () {\n",
" canvas.focus();\n",
" canvas_div.focus();\n",
" }\n",
"\n",
" window.setTimeout(set_focus, 100);\n",
"}\n",
"\n",
"mpl.figure.prototype._init_toolbar = function() {\n",
" var fig = this;\n",
"\n",
" var nav_element = $('<div/>')\n",
" nav_element.attr('style', 'width: 100%');\n",
" this.root.append(nav_element);\n",
"\n",
" // Define a callback function for later on.\n",
" function toolbar_event(event) {\n",
" return fig.toolbar_button_onclick(event['data']);\n",
" }\n",
" function toolbar_mouse_event(event) {\n",
" return fig.toolbar_button_onmouseover(event['data']);\n",
" }\n",
"\n",
" for(var toolbar_ind in mpl.toolbar_items) {\n",
" var name = mpl.toolbar_items[toolbar_ind][0];\n",
" var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
" var image = mpl.toolbar_items[toolbar_ind][2];\n",
" var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
"\n",
" if (!name) {\n",
" // put a spacer in here.\n",
" continue;\n",
" }\n",
" var button = $('<button/>');\n",
" button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
" 'ui-button-icon-only');\n",
" button.attr('role', 'button');\n",
" button.attr('aria-disabled', 'false');\n",
" button.click(method_name, toolbar_event);\n",
" button.mouseover(tooltip, toolbar_mouse_event);\n",
"\n",
" var icon_img = $('<span/>');\n",
" icon_img.addClass('ui-button-icon-primary ui-icon');\n",
" icon_img.addClass(image);\n",
" icon_img.addClass('ui-corner-all');\n",
"\n",
" var tooltip_span = $('<span/>');\n",
" tooltip_span.addClass('ui-button-text');\n",
" tooltip_span.html(tooltip);\n",
"\n",
" button.append(icon_img);\n",
" button.append(tooltip_span);\n",
"\n",
" nav_element.append(button);\n",
" }\n",
"\n",
" var fmt_picker_span = $('<span/>');\n",
"\n",
" var fmt_picker = $('<select/>');\n",
" fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
" fmt_picker_span.append(fmt_picker);\n",
" nav_element.append(fmt_picker_span);\n",
" this.format_dropdown = fmt_picker[0];\n",
"\n",
" for (var ind in mpl.extensions) {\n",
" var fmt = mpl.extensions[ind];\n",
" var option = $(\n",
" '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
" fmt_picker.append(option)\n",
" }\n",
"\n",
" // Add hover states to the ui-buttons\n",
" $( \".ui-button\" ).hover(\n",
" function() { $(this).addClass(\"ui-state-hover\");},\n",
" function() { $(this).removeClass(\"ui-state-hover\");}\n",
" );\n",
"\n",
" var status_bar = $('<span class=\"mpl-message\"/>');\n",
" nav_element.append(status_bar);\n",
" this.message = status_bar[0];\n",
"}\n",
"\n",
"mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
" // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
" // which will in turn request a refresh of the image.\n",
" this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
"}\n",
"\n",
"mpl.figure.prototype.send_message = function(type, properties) {\n",
" properties['type'] = type;\n",
" properties['figure_id'] = this.id;\n",
" this.ws.send(JSON.stringify(properties));\n",
"}\n",
"\n",
"mpl.figure.prototype.send_draw_message = function() {\n",
" if (!this.waiting) {\n",
" this.waiting = true;\n",
" this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
" }\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype.handle_save = function(fig, msg) {\n",
" var format_dropdown = fig.format_dropdown;\n",
" var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
" fig.ondownload(fig, format);\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
" var size = msg['size'];\n",
" if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
" fig._resize_canvas(size[0], size[1]);\n",
" fig.send_message(\"refresh\", {});\n",
" };\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
" var x0 = msg['x0'] / mpl.ratio;\n",
" var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
" var x1 = msg['x1'] / mpl.ratio;\n",
" var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
" x0 = Math.floor(x0) + 0.5;\n",
" y0 = Math.floor(y0) + 0.5;\n",
" x1 = Math.floor(x1) + 0.5;\n",
" y1 = Math.floor(y1) + 0.5;\n",
" var min_x = Math.min(x0, x1);\n",
" var min_y = Math.min(y0, y1);\n",
" var width = Math.abs(x1 - x0);\n",
" var height = Math.abs(y1 - y0);\n",
"\n",
" fig.rubberband_context.clearRect(\n",
" 0, 0, fig.canvas.width, fig.canvas.height);\n",
"\n",
" fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
" // Updates the figure title.\n",
" fig.header.textContent = msg['label'];\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
" var cursor = msg['cursor'];\n",
" switch(cursor)\n",
" {\n",
" case 0:\n",
" cursor = 'pointer';\n",
" break;\n",
" case 1:\n",
" cursor = 'default';\n",
" break;\n",
" case 2:\n",
" cursor = 'crosshair';\n",
" break;\n",
" case 3:\n",
" cursor = 'move';\n",
" break;\n",
" }\n",
" fig.rubberband_canvas.style.cursor = cursor;\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_message = function(fig, msg) {\n",
" fig.message.textContent = msg['message'];\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
" // Request the server to send over a new figure.\n",
" fig.send_draw_message();\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
" fig.image_mode = msg['mode'];\n",
"}\n",
"\n",
"mpl.figure.prototype.updated_canvas_event = function() {\n",
" // Called whenever the canvas gets updated.\n",
" this.send_message(\"ack\", {});\n",
"}\n",
"\n",
"// A function to construct a web socket function for onmessage handling.\n",
"// Called in the figure constructor.\n",
"mpl.figure.prototype._make_on_message_function = function(fig) {\n",
" return function socket_on_message(evt) {\n",
" if (evt.data instanceof Blob) {\n",
" /* FIXME: We get \"Resource interpreted as Image but\n",
" * transferred with MIME type text/plain:\" errors on\n",
" * Chrome. But how to set the MIME type? It doesn't seem\n",
" * to be part of the websocket stream */\n",
" evt.data.type = \"image/png\";\n",
"\n",
" /* Free the memory for the previous frames */\n",
" if (fig.imageObj.src) {\n",
" (window.URL || window.webkitURL).revokeObjectURL(\n",
" fig.imageObj.src);\n",
" }\n",
"\n",
" fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
" evt.data);\n",
" fig.updated_canvas_event();\n",
" fig.waiting = false;\n",
" return;\n",
" }\n",
" else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
" fig.imageObj.src = evt.data;\n",
" fig.updated_canvas_event();\n",
" fig.waiting = false;\n",
" return;\n",
" }\n",
"\n",
" var msg = JSON.parse(evt.data);\n",
" var msg_type = msg['type'];\n",
"\n",
" // Call the \"handle_{type}\" callback, which takes\n",
" // the figure and JSON message as its only arguments.\n",
" try {\n",
" var callback = fig[\"handle_\" + msg_type];\n",
" } catch (e) {\n",
" console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
" return;\n",
" }\n",
"\n",
" if (callback) {\n",
" try {\n",
" // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
" callback(fig, msg);\n",
" } catch (e) {\n",
" console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
" }\n",
" }\n",
" };\n",
"}\n",
"\n",
"// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
"mpl.findpos = function(e) {\n",
" //this section is from http://www.quirksmode.org/js/events_properties.html\n",
" var targ;\n",
" if (!e)\n",
" e = window.event;\n",
" if (e.target)\n",
" targ = e.target;\n",
" else if (e.srcElement)\n",
" targ = e.srcElement;\n",
" if (targ.nodeType == 3) // defeat Safari bug\n",
" targ = targ.parentNode;\n",
"\n",
" // jQuery normalizes the pageX and pageY\n",
" // pageX,Y are the mouse positions relative to the document\n",
" // offset() returns the position of the element relative to the document\n",
" var x = e.pageX - $(targ).offset().left;\n",
" var y = e.pageY - $(targ).offset().top;\n",
"\n",
" return {\"x\": x, \"y\": y};\n",
"};\n",
"\n",
"/*\n",
" * return a copy of an object with only non-object keys\n",
" * we need this to avoid circular references\n",
" * http://stackoverflow.com/a/24161582/3208463\n",
" */\n",
"function simpleKeys (original) {\n",
" return Object.keys(original).reduce(function (obj, key) {\n",
" if (typeof original[key] !== 'object')\n",
" obj[key] = original[key]\n",
" return obj;\n",
" }, {});\n",
"}\n",
"\n",
"mpl.figure.prototype.mouse_event = function(event, name) {\n",
" var canvas_pos = mpl.findpos(event)\n",
"\n",
" if (name === 'button_press')\n",
" {\n",
" this.canvas.focus();\n",
" this.canvas_div.focus();\n",
" }\n",
"\n",
" var x = canvas_pos.x * mpl.ratio;\n",
" var y = canvas_pos.y * mpl.ratio;\n",
"\n",
" this.send_message(name, {x: x, y: y, button: event.button,\n",
" step: event.step,\n",
" guiEvent: simpleKeys(event)});\n",
"\n",
" /* This prevents the web browser from automatically changing to\n",
" * the text insertion cursor when the button is pressed. We want\n",
" * to control all of the cursor setting manually through the\n",
" * 'cursor' event from matplotlib */\n",
" event.preventDefault();\n",
" return false;\n",
"}\n",
"\n",
"mpl.figure.prototype._key_event_extra = function(event, name) {\n",
" // Handle any extra behaviour associated with a key event\n",
"}\n",
"\n",
"mpl.figure.prototype.key_event = function(event, name) {\n",
"\n",
" // Prevent repeat events\n",
" if (name == 'key_press')\n",
" {\n",
" if (event.which === this._key)\n",
" return;\n",
" else\n",
" this._key = event.which;\n",
" }\n",
" if (name == 'key_release')\n",
" this._key = null;\n",
"\n",
" var value = '';\n",
" if (event.ctrlKey && event.which != 17)\n",
" value += \"ctrl+\";\n",
" if (event.altKey && event.which != 18)\n",
" value += \"alt+\";\n",
" if (event.shiftKey && event.which != 16)\n",
" value += \"shift+\";\n",
"\n",
" value += 'k';\n",
" value += event.which.toString();\n",
"\n",
" this._key_event_extra(event, name);\n",
"\n",
" this.send_message(name, {key: value,\n",
" guiEvent: simpleKeys(event)});\n",
" return false;\n",
"}\n",
"\n",
"mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
" if (name == 'download') {\n",
" this.handle_save(this, null);\n",
" } else {\n",
" this.send_message(\"toolbar_button\", {name: name});\n",
" }\n",
"};\n",
"\n",
"mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
" this.message.textContent = tooltip;\n",
"};\n",
"mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
"\n",
"mpl.extensions = [\"eps\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\"];\n",
"\n",
"mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
" // Create a \"websocket\"-like object which calls the given IPython comm\n",
" // object with the appropriate methods. Currently this is a non binary\n",
" // socket, so there is still some room for performance tuning.\n",
" var ws = {};\n",
"\n",
" ws.close = function() {\n",
" comm.close()\n",
" };\n",
" ws.send = function(m) {\n",
" //console.log('sending', m);\n",
" comm.send(m);\n",
" };\n",
" // Register the callback with on_msg.\n",
" comm.on_msg(function(msg) {\n",
" //console.log('receiving', msg['content']['data'], msg);\n",
" // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
" ws.onmessage(msg['content']['data'])\n",
" });\n",
" return ws;\n",
"}\n",
"\n",
"mpl.mpl_figure_comm = function(comm, msg) {\n",
" // This is the function which gets called when the mpl process\n",
" // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
"\n",
" var id = msg.content.data.id;\n",
" // Get hold of the div created by the display call when the Comm\n",
" // socket was opened in Python.\n",
" var element = $(\"#\" + id);\n",
" var ws_proxy = comm_websocket_adapter(comm)\n",
"\n",
" function ondownload(figure, format) {\n",
" window.open(figure.imageObj.src);\n",
" }\n",
"\n",
" var fig = new mpl.figure(id, ws_proxy,\n",
" ondownload,\n",
" element.get(0));\n",
"\n",
" // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
" // web socket which is closed, not our websocket->open comm proxy.\n",
" ws_proxy.onopen();\n",
"\n",
" fig.parent_element = element.get(0);\n",
" fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
" if (!fig.cell_info) {\n",
" console.error(\"Failed to find cell for figure\", id, fig);\n",
" return;\n",
" }\n",
"\n",
" var output_index = fig.cell_info[2]\n",
" var cell = fig.cell_info[0];\n",
"\n",
"};\n",
"\n",
"mpl.figure.prototype.handle_close = function(fig, msg) {\n",
" var width = fig.canvas.width/mpl.ratio\n",
" fig.root.unbind('remove')\n",
"\n",
" // Update the output cell to use the data from the current canvas.\n",
" fig.push_to_output();\n",
" var dataURL = fig.canvas.toDataURL();\n",
" // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
" // the notebook keyboard shortcuts fail.\n",
" IPython.keyboard_manager.enable()\n",
" $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
" fig.close_ws(fig, msg);\n",
"}\n",
"\n",
"mpl.figure.prototype.close_ws = function(fig, msg){\n",
" fig.send_message('closing', msg);\n",
" // fig.ws.close()\n",
"}\n",
"\n",
"mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
" // Turn the data on the canvas into data in the output cell.\n",
" var width = this.canvas.width/mpl.ratio\n",
" var dataURL = this.canvas.toDataURL();\n",
" this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
"}\n",
"\n",
"mpl.figure.prototype.updated_canvas_event = function() {\n",
" // Tell IPython that the notebook contents must change.\n",
" IPython.notebook.set_dirty(true);\n",
" this.send_message(\"ack\", {});\n",
" var fig = this;\n",
" // Wait a second, then push the new image to the DOM so\n",
" // that it is saved nicely (might be nice to debounce this).\n",
" setTimeout(function () { fig.push_to_output() }, 1000);\n",
"}\n",
"\n",
"mpl.figure.prototype._init_toolbar = function() {\n",
" var fig = this;\n",
"\n",
" var nav_element = $('<div/>')\n",
" nav_element.attr('style', 'width: 100%');\n",
" this.root.append(nav_element);\n",
"\n",
" // Define a callback function for later on.\n",
" function toolbar_event(event) {\n",
" return fig.toolbar_button_onclick(event['data']);\n",
" }\n",
" function toolbar_mouse_event(event) {\n",
" return fig.toolbar_button_onmouseover(event['data']);\n",
" }\n",
"\n",
" for(var toolbar_ind in mpl.toolbar_items){\n",
" var name = mpl.toolbar_items[toolbar_ind][0];\n",
" var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
" var image = mpl.toolbar_items[toolbar_ind][2];\n",
" var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
"\n",
" if (!name) { continue; };\n",
"\n",
" var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
" button.click(method_name, toolbar_event);\n",
" button.mouseover(tooltip, toolbar_mouse_event);\n",
" nav_element.append(button);\n",
" }\n",
"\n",
" // Add the status bar.\n",
" var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
" nav_element.append(status_bar);\n",
" this.message = status_bar[0];\n",
"\n",
" // Add the close button to the window.\n",
" var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
" var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
" button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
" button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
" buttongrp.append(button);\n",
" var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
" titlebar.prepend(buttongrp);\n",
"}\n",
"\n",
"mpl.figure.prototype._root_extra_style = function(el){\n",
" var fig = this\n",
" el.on(\"remove\", function(){\n",
"\tfig.close_ws(fig, {});\n",
" });\n",
"}\n",
"\n",
"mpl.figure.prototype._canvas_extra_style = function(el){\n",
" // this is important to make the div 'focusable\n",
" el.attr('tabindex', 0)\n",
" // reach out to IPython and tell the keyboard manager to turn it's self\n",
" // off when our div gets focus\n",
"\n",
" // location in version 3\n",
" if (IPython.notebook.keyboard_manager) {\n",
" IPython.notebook.keyboard_manager.register_events(el);\n",
" }\n",
" else {\n",
" // location in version 2\n",
" IPython.keyboard_manager.register_events(el);\n",
" }\n",
"\n",
"}\n",
"\n",
"mpl.figure.prototype._key_event_extra = function(event, name) {\n",
" var manager = IPython.notebook.keyboard_manager;\n",
" if (!manager)\n",
" manager = IPython.keyboard_manager;\n",
"\n",
" // Check for shift+enter\n",
" if (event.shiftKey && event.which == 13) {\n",
" this.canvas_div.blur();\n",
" event.shiftKey = false;\n",
" // Send a \"J\" for go to next cell\n",
" event.which = 74;\n",
" event.keyCode = 74;\n",
" manager.command_mode();\n",
" manager.handle_keydown(event);\n",
" }\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_save = function(fig, msg) {\n",
" fig.ondownload(fig, null);\n",
"}\n",
"\n",
"\n",
"mpl.find_output_cell = function(html_output) {\n",
" // Return the cell and output element which can be found *uniquely* in the notebook.\n",
" // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
" // IPython event is triggered only after the cells have been serialised, which for\n",
" // our purposes (turning an active figure into a static one), is too late.\n",
" var cells = IPython.notebook.get_cells();\n",
" var ncells = cells.length;\n",
" for (var i=0; i<ncells; i++) {\n",
" var cell = cells[i];\n",
" if (cell.cell_type === 'code'){\n",
" for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
" var data = cell.output_area.outputs[j];\n",
" if (data.data) {\n",
" // IPython >= 3 moved mimebundle to data attribute of output\n",
" data = data.data;\n",
" }\n",
" if (data['text/html'] == html_output) {\n",
" return [cell, data, j];\n",
" }\n",
" }\n",
" }\n",
" }\n",
"}\n",
"\n",
"// Register the function which deals with the matplotlib target/channel.\n",
"// The kernel may be null if the page has been refreshed.\n",
"if (IPython.notebook.kernel != null) {\n",
" IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
"}\n"
],
"text/plain": [
"<IPython.core.display.Javascript object>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"text/html": [
"<img src=\"\" width=\"640\">"
],
"text/plain": [
"<IPython.core.display.HTML object>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"text/plain": [
"[<matplotlib.lines.Line2D at 0x112a26d68>]"
]
},
"execution_count": 30,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"from matplotlib import pyplot as plt\n",
"plt.plot(*zip(*((t, mean_load(t)) \n",
" for t \n",
" in islice(env.time_series(), SPD))))"
]
},
{
"cell_type": "code",
"execution_count": 6,
"metadata": {
"scrolled": true
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
" 103 Plant(server=1, done=91, waiting=12, avg_freq=7.016732207571905)\n",
" 112 Plant(server=1, done=15146, waiting=909, avg_freq=0.10960345470089262)\n",
" 239 9.575596254633485 --> 2 <-- 9.575596254633485\n",
" 91 Plant(server=2, done=31042, waiting=1051, avg_freq=0.09037971228522423)\n",
" 479 2.2099856484879785 --> 1 <-- 2.2099856484879785\n",
" 109 Plant(server=2, done=47967, waiting=3, avg_freq=12.815583749839622)\n",
" 87 Plant(server=1, done=63544, waiting=337, avg_freq=0.2787409827292111)\n",
" 719 4.299246138049638 --> 1 <-- 4.299246138049638\n",
" 108 Plant(server=1, done=78607, waiting=1326, avg_freq=0.07508268480664372)\n",
" 959 9.932166576791808 --> 3 <-- 9.932166576791808\n",
" 101 Plant(server=1, done=93668, waiting=2337, avg_freq=0.04249641620569293)\n",
" 95 Plant(server=3, done=111959, waiting=2, avg_freq=13.448735019976237)\n",
"1199 1.9771975451633614 --> 2 <-- 1.9771975451633614\n",
" 107 Plant(server=3, done=127930, waiting=2, avg_freq=12.137964186997547)\n",
"1439 -2.741175486611466 --> 1 <-- -0.7411754866114659\n",
" 119 Plant(server=2, done=144171, waiting=3, avg_freq=12.218495448012229)\n",
" 95 Plant(server=1, done=159835, waiting=473, avg_freq=0.21537843873633758)\n",
"1679 4.839691503059641 --> 3 <-- 4.839691503059641\n",
" 103 Plant(server=3, done=176464, waiting=340, avg_freq=0.2727638659378863)\n",
"1919 1.590323108843443 --> 2 <-- 1.590323108843443\n",
" 113 Plant(server=3, done=193310, waiting=2, avg_freq=12.219480672074749)\n",
" 87 Plant(server=2, done=209855, waiting=0, avg_freq=13.062950982832271)\n",
"2159 -2.6718532181492254 --> 2 <-- -0.6718532181492254\n",
" 112 Plant(server=2, done=226788, waiting=0, avg_freq=12.037143184686112)\n",
"2399 -2.5746098794476127 --> 2 <-- -0.5746098794476127\n",
" 105 Plant(server=2, done=243749, waiting=1, avg_freq=12.167125803488819)\n",
" 82 Plant(server=2, done=260741, waiting=2, avg_freq=12.95870170764119)\n",
"2639 -2.542308345473082 --> 2 <-- -0.5423083454730819\n",
" 97 Plant(server=2, done=278043, waiting=2, avg_freq=12.918660287083252)\n",
"2879 -2.5332057333313 --> 2 <-- -0.5332057333312998\n",
" 129 Plant(server=2, done=295310, waiting=8, avg_freq=12.365286443559482)\n",
" 112 Plant(server=2, done=312912, waiting=6, avg_freq=12.853470437018006)\n",
"3119 -2.500091489435925 --> 2 <-- -0.500091489435925\n",
" 114 Plant(server=2, done=330835, waiting=6, avg_freq=12.49024199843605)\n",
"3359 -2.4921094562449535 --> 2 <-- -0.4921094562449535\n",
" 117 Plant(server=2, done=348694, waiting=4, avg_freq=12.295973884654728)\n",
" 120 Plant(server=2, done=366712, waiting=7, avg_freq=12.336327237310178)\n",
"3599 -2.4952656067203884 --> 2 <-- -0.49526560672038844\n",
" 112 Plant(server=2, done=385218, waiting=2, avg_freq=12.802118971412535)\n",
"3839 -2.455881125279659 --> 2 <-- -0.45588112527965885\n",
" 98 Plant(server=2, done=403671, waiting=0, avg_freq=13.153456998315031)\n",
" 104 Plant(server=2, done=422377, waiting=3, avg_freq=12.959912136188882)\n",
"4079 -2.43675314466507 --> 2 <-- -0.4367531446650701\n",
" 118 Plant(server=2, done=441458, waiting=8, avg_freq=12.951969778739269)\n",
"4319 -2.3929880807496735 --> 2 <-- -0.3929880807496735\n",
" 127 Plant(server=2, done=460692, waiting=2, avg_freq=12.17200438990416)\n",
" 128 Plant(server=2, done=480123, waiting=4, avg_freq=12.202380952378839)\n",
"4559 -2.372930215034802 --> 2 <-- -0.37293021503480217\n",
" 128 Plant(server=2, done=500095, waiting=2, avg_freq=12.069131988027456)\n",
"4799 -2.2668431476989737 --> 2 <-- -0.26684314769897366\n",
" 131 Plant(server=2, done=520350, waiting=3, avg_freq=12.094086277495052)\n",
" 110 Plant(server=2, done=540618, waiting=2, avg_freq=12.69085861591323)\n",
"5039 -2.2584635889014097 --> 2 <-- -0.25846358890140975\n",
" 131 Plant(server=2, done=561430, waiting=8, avg_freq=12.085153853306288)\n",
"5279 -2.1896619102830455 --> 2 <-- -0.18966191028304547\n",
" 127 Plant(server=2, done=582483, waiting=2, avg_freq=12.601431980905389)\n",
" 143 Plant(server=2, done=603921, waiting=4, avg_freq=12.078601045608204)\n",
"5519 -2.131138578348398 --> 2 <-- -0.13113857834839804\n",
" 135 Plant(server=2, done=625593, waiting=5, avg_freq=12.022630834510197)\n",
"5759 -2.085597599694286 --> 2 <-- -0.08559759969428615\n",
" 139 Plant(server=2, done=647671, waiting=2, avg_freq=11.627906976744692)\n",
" 148 Plant(server=2, done=669820, waiting=4, avg_freq=11.611628098491192)\n",
"5999 -1.9906966128141057 --> 2 <-- 0\n",
" 145 Plant(server=2, done=692468, waiting=7, avg_freq=12.110433604329522)\n",
"6239 -1.8841619842625872 --> 2 <-- 0\n",
" 148 Plant(server=2, done=715494, waiting=6, avg_freq=11.456111242781358)\n",
" 149 Plant(server=2, done=738759, waiting=5, avg_freq=11.562967041612016)\n",
"6479 -1.773510995413668 --> 2 <-- 0\n",
" 147 Plant(server=2, done=762300, waiting=6, avg_freq=12.174336498668996)\n",
"6719 -1.575477990396135 --> 2 <-- 0\n",
" 139 Plant(server=2, done=786642, waiting=5, avg_freq=12.50411319513377)\n",
" 146 Plant(server=2, done=811424, waiting=3, avg_freq=11.677842236119115)\n",
"6959 -1.3203453811362087 --> 2 <-- 0\n",
" 170 Plant(server=2, done=836449, waiting=7, avg_freq=11.224708658041733)\n",
"7199 -1.1148165037360178 --> 2 <-- 0\n",
" 144 Plant(server=2, done=861990, waiting=3, avg_freq=12.249272699429302)\n",
" 164 Plant(server=2, done=887830, waiting=7, avg_freq=11.239852910570033)\n",
"7439 -0.8077072957927253 --> 2 <-- 0\n",
" 163 Plant(server=2, done=914205, waiting=1, avg_freq=10.663736831906402)\n",
"7679 -0.6582569801996719 --> 2 <-- 0\n",
" 148 Plant(server=2, done=940469, waiting=4, avg_freq=11.825156612944575)\n",
" 156 Plant(server=2, done=967355, waiting=0, avg_freq=9.701577215477524)\n",
"7919 -0.37842596208303897 --> 2 <-- 0\n",
" 170 Plant(server=2, done=994678, waiting=6, avg_freq=10.953040412937533)\n",
"8159 0.7091042967294611 --> 2 <-- 0.7091042967294611\n",
" 159 Plant(server=2, done=1022816, waiting=11, avg_freq=8.162129573806945)\n",
" 196 Plant(server=2, done=1051220, waiting=26, avg_freq=5.835751312221598)\n",
"8399 1.1467815870283082 --> 2 <-- 1.1467815870283082\n",
" 193 Plant(server=2, done=1079977, waiting=23, avg_freq=8.718562874247699)\n",
"8639 3.909083117217897 --> 3 <-- 3.909083117217897\n",
" 191 Plant(server=2, done=1109628, waiting=63, avg_freq=2.664055412353511)\n",
" 186 Plant(server=3, done=1139556, waiting=1, avg_freq=12.105296867988054)\n",
"8879 -0.21086095224444398 --> 2 <-- 0\n",
" 171 Plant(server=3, done=1169953, waiting=3, avg_freq=13.02843183822943)\n",
"9119 3.513503126031352 --> 3 <-- 3.513503126031352\n",
" 183 Plant(server=2, done=1200045, waiting=751, avg_freq=0.2621101615405372)\n",
" 217 Plant(server=3, done=1232233, waiting=15, avg_freq=12.139791538945733)\n",
"9359 1.99569723510691 --> 3 <-- 1.99569723510691\n",
" 197 Plant(server=3, done=1264412, waiting=8, avg_freq=12.318440889874264)\n",
"9599 -2.2737528988321616 --> 3 <-- -0.2737528988321616\n",
" 206 Plant(server=3, done=1296899, waiting=6, avg_freq=12.20964860036598)\n",
" 211 Plant(server=3, done=1329742, waiting=9, avg_freq=12.339087619393283)\n",
"9839 -2.266419540699471 --> 3 <-- -0.26641954069947094\n",
" 212 Plant(server=3, done=1363154, waiting=8, avg_freq=11.973342369826662)\n",
"10079 -2.1392455462475715 --> 3 <-- -0.13924554624757146\n",
" 219 Plant(server=3, done=1397403, waiting=11, avg_freq=12.27028877982798)\n",
" 219 Plant(server=3, done=1432202, waiting=8, avg_freq=11.96002402927935)\n",
"10319 -2.0830786284381606 --> 3 <-- -0.0830786284381606\n",
" 220 Plant(server=3, done=1467527, waiting=6, avg_freq=11.381113503539844)\n",
"10559 -1.950868810632189 --> 3 <-- 0\n",
" 225 Plant(server=3, done=1503137, waiting=5, avg_freq=11.867254778398912)\n",
" 222 Plant(server=3, done=1539523, waiting=4, avg_freq=12.243370402067505)\n",
"10799 -1.8404629471085783 --> 3 <-- 0\n",
" 208 Plant(server=3, done=1576399, waiting=4, avg_freq=13.012398078858268)\n",
"11039 -1.7016498324367002 --> 3 <-- 0\n",
" 226 Plant(server=3, done=1613894, waiting=7, avg_freq=11.99696279422648)\n",
" 239 Plant(server=3, done=1652380, waiting=7, avg_freq=11.79406870901165)\n",
"11279 -1.3972886896815906 --> 3 <-- 0\n",
" 243 Plant(server=3, done=1691573, waiting=10, avg_freq=10.780129361546797)\n",
"11519 -1.1318285997422886 --> 3 <-- 0\n",
" 222 Plant(server=3, done=1731067, waiting=10, avg_freq=12.240264547659466)\n",
" 265 Plant(server=3, done=1771296, waiting=13, avg_freq=11.179628232993506)\n",
"11759 -0.7059993471764827 --> 3 <-- 0\n",
" 292 Plant(server=3, done=1812332, waiting=21, avg_freq=7.663982277053031)\n",
"11999 -0.2733819091123625 --> 3 <-- 0\n",
" 258 Plant(server=3, done=1853961, waiting=6, avg_freq=11.174144748158069)\n",
" 242 Plant(server=3, done=1895654, waiting=9, avg_freq=10.185185185185157)\n",
"12239 0.18526731692389392 --> 3 <-- 0.18526731692389392\n"
]
},
{
"name": "stdout",
"output_type": "stream",
"text": [
" 258 Plant(server=3, done=1938265, waiting=19, avg_freq=9.83955648565924)\n",
"12479 0.9077380310255944 --> 3 <-- 0.9077380310255944\n",
" 285 Plant(server=3, done=1981539, waiting=34, avg_freq=6.127230131555259)\n",
" 258 Plant(server=3, done=2025533, waiting=6, avg_freq=9.340751981114243)\n",
"12719 2.557735487227936 --> 3 <-- 2.557735487227936\n",
" 259 Plant(server=3, done=2069829, waiting=13, avg_freq=9.532209369374742)\n",
"12959 7.566965097298043 --> 5 <-- 7.566965097298043\n",
" 282 Plant(server=3, done=2115000, waiting=469, avg_freq=0.5667795585483608)\n",
" 282 Plant(server=5, done=2161128, waiting=5, avg_freq=12.775739357231805)\n",
"13199 1.4417024942326309 --> 4 <-- 1.4417024942326309\n",
" 277 Plant(server=5, done=2207630, waiting=1, avg_freq=12.513300702296998)\n",
"13439 -2.3009491796099217 --> 4 <-- -0.30094917960992174\n",
" 298 Plant(server=4, done=2255188, waiting=12, avg_freq=12.135526958783336)\n",
" 302 Plant(server=4, done=2303100, waiting=7, avg_freq=11.85988061577216)\n",
"13679 -2.0562925060477193 --> 4 <-- -0.05629250604771929\n",
" 281 Plant(server=4, done=2351668, waiting=12, avg_freq=12.708005629601562)\n",
"13919 -1.875387165634325 --> 4 <-- 0\n",
" 321 Plant(server=4, done=2401491, waiting=14, avg_freq=11.64009282131863)\n",
" 310 Plant(server=4, done=2451691, waiting=4, avg_freq=11.719185981621779)\n",
"14159 -1.8253591607154107 --> 4 <-- 0\n",
" 356 Plant(server=4, done=2501948, waiting=25, avg_freq=10.954777309901376)\n",
"14399 -1.677194041138334 --> 4 <-- 0\n",
" 327 Plant(server=4, done=2553421, waiting=10, avg_freq=11.435428652100839)\n",
" 356 Plant(server=4, done=2605527, waiting=21, avg_freq=9.865067466262454)\n",
"14639 -1.4830830523829 --> 4 <-- 0\n",
" 342 Plant(server=4, done=2658805, waiting=25, avg_freq=10.946871620081088)\n",
"14879 -0.9649814186066149 --> 4 <-- 0\n",
" 349 Plant(server=4, done=2713187, waiting=20, avg_freq=10.727093846202667)\n",
" 362 Plant(server=4, done=2767516, waiting=15, avg_freq=10.125760170039806)\n",
"15119 -0.8372483560549677 --> 4 <-- 0\n",
" 315 Plant(server=4, done=2822843, waiting=14, avg_freq=7.8002420764741744)\n",
"15359 -0.46779821247556275 --> 4 <-- 0\n",
" 380 Plant(server=4, done=2878652, waiting=36, avg_freq=8.4489462819732)\n",
" 326 Plant(server=4, done=2935438, waiting=17, avg_freq=12.2499399512755)\n",
"15599 0.29952791726273914 --> 4 <-- 0.29952791726273914\n",
" 380 Plant(server=4, done=2992873, waiting=33, avg_freq=8.020560996145134)\n",
"15839 1.1568634828880362 --> 4 <-- 1.1568634828880362\n",
" 365 Plant(server=4, done=3051335, waiting=48, avg_freq=5.6603773584886685)\n",
" 368 Plant(server=4, done=3110199, waiting=35, avg_freq=6.790643189226669)\n",
"16079 2.028084901666735 --> 4 <-- 2.028084901666735\n",
" 414 Plant(server=4, done=3169744, waiting=198, avg_freq=2.0529508438399517)\n",
"16319 7.439425246657725 --> 6 <-- 7.439425246657725\n",
" 361 Plant(server=4, done=3229983, waiting=223, avg_freq=1.4858667165860484)\n",
" 391 Plant(server=6, done=3291575, waiting=6, avg_freq=12.35476746787885)\n",
"16559 0.7952847069354952 --> 5 <-- 0.7952847069354952\n",
" 397 Plant(server=5, done=3354008, waiting=9, avg_freq=11.878360725440855)\n",
"16799 -2.0849420936575553 --> 5 <-- -0.08494209365755534\n",
" 407 Plant(server=5, done=3417186, waiting=16, avg_freq=11.751439254523339)\n",
" 413 Plant(server=5, done=3480750, waiting=18, avg_freq=11.91537410112813)\n",
"17039 -1.8341212019627393 --> 5 <-- 0\n",
" 416 Plant(server=5, done=3544906, waiting=22, avg_freq=11.668779532079654)\n",
"17279 -1.706927808772098 --> 5 <-- 0\n",
" 421 Plant(server=5, done=3610063, waiting=29, avg_freq=11.536297129974015)\n",
" 361 Plant(server=5, done=3676232, waiting=19, avg_freq=11.967241478717241)\n",
"17519 -1.498254239115874 --> 5 <-- 0\n",
" 401 Plant(server=5, done=3742929, waiting=14, avg_freq=11.76437634798077)\n",
"17759 -1.2446912925358582 --> 5 <-- 0\n",
" 434 Plant(server=5, done=3810492, waiting=21, avg_freq=11.262454950176709)\n",
" 436 Plant(server=5, done=3879236, waiting=14, avg_freq=10.756713586884873)\n",
"17999 -0.8691764982255255 --> 5 <-- 0\n",
" 418 Plant(server=5, done=3948499, waiting=15, avg_freq=11.644366103130086)\n",
"18239 -0.5904351105953457 --> 5 <-- 0\n",
" 450 Plant(server=5, done=4018752, waiting=42, avg_freq=11.386522075905997)\n",
" 460 Plant(server=5, done=4089281, waiting=52, avg_freq=6.393165333569128)\n",
"18479 -0.035782572684314416 --> 5 <-- 0\n",
" 430 Plant(server=5, done=4161442, waiting=19, avg_freq=11.193288990349728)\n",
"18719 0.5469191342431401 --> 5 <-- 0.5469191342431401\n",
" 452 Plant(server=5, done=4233836, waiting=28, avg_freq=8.761480229013117)\n",
" 474 Plant(server=5, done=4307274, waiting=46, avg_freq=8.207666423330128)\n",
"18959 1.781263758418839 --> 5 <-- 1.781263758418839\n",
" 463 Plant(server=5, done=4381236, waiting=44, avg_freq=6.502658275537656)\n",
"19199 4.663176676983682 --> 6 <-- 4.663176676983682\n",
" 463 Plant(server=5, done=4456204, waiting=91, avg_freq=4.370661816565395)\n",
" 491 Plant(server=6, done=4532226, waiting=18, avg_freq=11.592864433941044)\n",
"19439 1.3480804190897442 --> 6 <-- 1.3480804190897442\n",
" 507 Plant(server=6, done=4609046, waiting=26, avg_freq=11.631274131261225)\n",
"19679 -1.7920613384958628 --> 5 <-- 0\n",
" 466 Plant(server=6, done=4686852, waiting=16, avg_freq=11.772953633379927)\n",
" 505 Plant(server=5, done=4763883, waiting=914, avg_freq=0.5213029607252689)\n",
"19919 4.573658260745135 --> 7 <-- 4.573658260745135\n",
" 504 Plant(server=6, done=4840831, waiting=3038, avg_freq=0.16423937177944167)\n",
"20159 3.0724515163532353 --> 7 <-- 3.0724515163532353\n",
" 494 Plant(server=7, done=4923203, waiting=17, avg_freq=12.170877175930173)\n",
" 536 Plant(server=7, done=5003731, waiting=15, avg_freq=12.036203383375598)\n",
"20399 -2.315953370665052 --> 6 <-- -0.3159533706650519\n",
" 491 Plant(server=7, done=5085221, waiting=9, avg_freq=12.651360082841434)\n",
"20639 -1.6763424190294685 --> 6 <-- 0\n",
" 518 Plant(server=6, done=5167716, waiting=24, avg_freq=11.511878569662104)\n",
" 566 Plant(server=6, done=5250635, waiting=55, avg_freq=9.803186504247781)\n",
"20879 -0.8408868141015264 --> 6 <-- 0\n",
" 516 Plant(server=6, done=5334978, waiting=20, avg_freq=11.126535419790594)\n",
"21119 -0.2801865284293491 --> 6 <-- 0\n",
" 548 Plant(server=6, done=5420487, waiting=29, avg_freq=10.202327047639116)\n",
" 560 Plant(server=6, done=5506389, waiting=44, avg_freq=9.049697783743413)\n",
"21359 0.0029691952994324923 --> 6 <-- 0.0029691952994324923\n",
" 577 Plant(server=6, done=5593019, waiting=68, avg_freq=6.341213223301859)\n",
"21599 0.970024208048314 --> 6 <-- 0.970024208048314\n",
" 555 Plant(server=6, done=5680931, waiting=37, avg_freq=8.523960076862767)\n",
" 509 Plant(server=6, done=5769292, waiting=28, avg_freq=9.095229511144211)\n",
"21839 2.079946310301834 --> 7 <-- 2.079946310301834\n",
" 557 Plant(server=7, done=5858954, waiting=28, avg_freq=11.535688536385727)\n",
"22079 0.6213139967010655 --> 7 <-- 0.6213139967010655\n",
" 540 Plant(server=7, done=5949126, waiting=12, avg_freq=12.069554814972365)\n",
" 552 Plant(server=7, done=6040251, waiting=17, avg_freq=11.843417553145681)\n",
"22319 -1.8370756180005487 --> 6 <-- 0\n",
" 581 Plant(server=6, done=6131538, waiting=134, avg_freq=3.7561624540231526)\n",
"22559 5.936138329910393 --> 8 <-- 5.936138329910393\n",
" 541 Plant(server=6, done=6221868, waiting=2191, avg_freq=0.25849956353169595)\n",
" 590 Plant(server=8, done=6317537, waiting=22, avg_freq=12.165753197122744)\n",
"22799 1.8583655044502836 --> 8 <-- 1.8583655044502836\n",
" 601 Plant(server=8, done=6411401, waiting=20, avg_freq=12.131786923903684)\n",
"23039 -2.2406077444945987 --> 7 <-- -0.24060774449459865\n",
" 587 Plant(server=8, done=6506205, waiting=16, avg_freq=12.20858895702397)\n",
" 656 Plant(server=7, done=6602254, waiting=49, avg_freq=10.246808510631954)\n",
"23279 -1.5053694646548577 --> 7 <-- 0\n",
" 575 Plant(server=7, done=6699114, waiting=24, avg_freq=11.764249859454418)\n",
"23519 -0.9101811989487653 --> 7 <-- 0\n",
" 585 Plant(server=7, done=6796933, waiting=18, avg_freq=11.914264021613077)\n",
" 662 Plant(server=7, done=6895585, waiting=56, avg_freq=8.238090151680122)\n",
"23759 -0.6076145413230873 --> 7 <-- 0\n",
" 620 Plant(server=7, done=6994577, waiting=49, avg_freq=11.154349658358358)\n",
"23999 -0.27093920276374567 --> 7 <-- 0\n",
" 625 Plant(server=7, done=7094913, waiting=40, avg_freq=10.989395583246298)\n",
" 612 Plant(server=7, done=7196102, waiting=31, avg_freq=11.084649598992808)\n",
"24239 0.22801001658492917 --> 7 <-- 0.22801001658492917\n",
" 673 Plant(server=7, done=7297325, waiting=65, avg_freq=8.572157953419602)\n",
"24479 0.7423407609025713 --> 7 <-- 0.7423407609025713\n",
" 637 Plant(server=7, done=7399765, waiting=38, avg_freq=10.59814408859598)\n"
]
},
{
"name": "stdout",
"output_type": "stream",
"text": [
" 687 Plant(server=7, done=7503040, waiting=96, avg_freq=5.487944307524704)\n",
"24719 1.6172100213141174 --> 8 <-- 1.6172100213141174\n",
" 735 Plant(server=7, done=7606589, waiting=116, avg_freq=6.999303285264639)\n",
"24959 -0.1663075053568251 --> 7 <-- 0\n",
" 609 Plant(server=8, done=7711685, waiting=16, avg_freq=12.111172464548526)\n",
" 648 Plant(server=7, done=7817298, waiting=461, avg_freq=1.2743334255924172)\n",
"25199 5.428722473745521 --> 9 <-- 5.428722473745521\n",
" 639 Plant(server=7, done=7922691, waiting=1768, avg_freq=0.3673819799138777)\n",
"25439 3.9001344366971633 --> 9 <-- 3.9001344366971633\n",
" 683 Plant(server=9, done=8031265, waiting=19, avg_freq=11.958199528026517)\n",
" 670 Plant(server=9, done=8139821, waiting=22, avg_freq=12.202134924309524)\n",
"25679 -2.1988135079088384 --> 8 <-- -0.19881350790883845\n",
" 684 Plant(server=8, done=8248816, waiting=36, avg_freq=11.976257594551731)\n",
"25919 -1.5520542178212589 --> 8 <-- 0\n",
" 691 Plant(server=8, done=8358945, waiting=35, avg_freq=10.858259526583435)\n",
" 671 Plant(server=8, done=8469416, waiting=14, avg_freq=11.643904566950384)\n",
"26159 -1.1529272994700188 --> 8 <-- 0\n",
" 697 Plant(server=8, done=8580763, waiting=39, avg_freq=11.276798552412519)\n",
"26399 -0.8595788833982831 --> 8 <-- 0\n",
" 701 Plant(server=8, done=8692730, waiting=38, avg_freq=11.635990466076965)\n",
" 696 Plant(server=8, done=8806098, waiting=37, avg_freq=11.70364003039325)\n",
"26639 -0.6373955604587472 --> 8 <-- 0\n",
" 725 Plant(server=8, done=8919308, waiting=28, avg_freq=9.894944280214514)\n",
"26879 -0.2521411274978417 --> 8 <-- 0\n",
" 748 Plant(server=8, done=9034092, waiting=50, avg_freq=9.806599650340345)\n",
" 719 Plant(server=8, done=9148870, waiting=47, avg_freq=10.808305801798172)\n",
"27119 -0.1968249042333373 --> 8 <-- 0\n",
" 704 Plant(server=8, done=9265055, waiting=23, avg_freq=11.14189075436467)\n",
"27359 0.5912594550024093 --> 8 <-- 0.5912594550024093\n",
" 730 Plant(server=8, done=9381507, waiting=55, avg_freq=9.757201426978348)\n",
" 790 Plant(server=8, done=9498636, waiting=94, avg_freq=7.633666853098359)\n",
"27599 1.0579730888345416 --> 9 <-- 1.0579730888345416\n",
" 712 Plant(server=9, done=9616849, waiting=31, avg_freq=12.18230774280498)\n",
"27839 -0.7248285069387277 --> 8 <-- 0\n",
" 755 Plant(server=9, done=9735646, waiting=27, avg_freq=11.431282231758043)\n",
" 736 Plant(server=8, done=9854704, waiting=88, avg_freq=6.1182758030789985)\n",
"28079 1.7765520470261988 --> 9 <-- 1.7765520470261988\n",
" 792 Plant(server=8, done=9975173, waiting=537, avg_freq=1.4244262727516783)\n",
"28319 2.527726430970084 --> 9 <-- 2.527726430970084\n",
" 769 Plant(server=9, done=10096797, waiting=39, avg_freq=11.003788426489566)\n",
" 800 Plant(server=9, done=10219324, waiting=61, avg_freq=10.391056899500391)\n",
"28559 -1.4122052851650406 --> 9 <-- 0\n",
" 808 Plant(server=9, done=10342485, waiting=55, avg_freq=11.190721874198807)\n",
"28799 -1.2950627914899633 --> 9 <-- 0\n",
" 737 Plant(server=9, done=10466213, waiting=35, avg_freq=11.825459878968141)\n",
" 763 Plant(server=9, done=10589966, waiting=34, avg_freq=11.543134872394825)\n",
"29039 -1.2668280150567208 --> 9 <-- 0\n",
" 767 Plant(server=9, done=10715266, waiting=35, avg_freq=11.54656180500837)\n",
"29279 -0.9943999564409812 --> 9 <-- 0\n",
" 798 Plant(server=9, done=10840815, waiting=57, avg_freq=11.087972083060716)\n",
" 807 Plant(server=9, done=10967330, waiting=42, avg_freq=10.758092340279477)\n",
"29519 -0.8599016510554025 --> 9 <-- 0\n",
" 818 Plant(server=9, done=11094605, waiting=40, avg_freq=9.380443481904333)\n",
"29759 -0.6255852404620744 --> 9 <-- 0\n",
" 785 Plant(server=9, done=11222362, waiting=44, avg_freq=11.40603195394841)\n",
" 841 Plant(server=9, done=11350613, waiting=68, avg_freq=9.988708416590564)\n",
"29999 -0.5092571069261648 --> 9 <-- 0\n",
" 820 Plant(server=9, done=11479596, waiting=55, avg_freq=9.224041724538662)\n",
"30239 0.04635841369930582 --> 9 <-- 0.04635841369930582\n",
" 832 Plant(server=9, done=11609928, waiting=70, avg_freq=8.008027703434784)\n",
" 826 Plant(server=9, done=11740528, waiting=49, avg_freq=9.909866253148323)\n",
"30479 0.3401078413057887 --> 9 <-- 0.3401078413057887\n",
" 847 Plant(server=9, done=11872136, waiting=59, avg_freq=10.17540819230997)\n",
"30719 1.023628649911692 --> 9 <-- 1.023628649911692\n",
" 820 Plant(server=9, done=12004154, waiting=46, avg_freq=9.132873928787927)\n",
" 827 Plant(server=9, done=12136396, waiting=63, avg_freq=10.359270986550246)\n",
"30959 1.1488376434737255 --> 9 <-- 1.1488376434737255\n",
" 838 Plant(server=9, done=12268952, waiting=79, avg_freq=7.601758874030251)\n",
"31199 1.9557561407482766 --> 10 <-- 1.9557561407482766\n",
" 838 Plant(server=9, done=12402703, waiting=77, avg_freq=7.197762602515511)\n",
" 846 Plant(server=10, done=12537073, waiting=46, avg_freq=11.213983558127875)\n",
"31439 -0.20406834661491605 --> 9 <-- 0\n",
" 812 Plant(server=9, done=12672309, waiting=42, avg_freq=9.295944685280237)\n",
"31679 3.2072789548453957 --> 10 <-- 3.2072789548453957\n",
" 846 Plant(server=9, done=12807446, waiting=396, avg_freq=2.0042204030103794)\n",
" 842 Plant(server=10, done=12944729, waiting=44, avg_freq=12.111928973586519)\n",
"31919 2.1910299450129513 --> 10 <-- 2.1910299450129513\n",
" 880 Plant(server=10, done=13081988, waiting=31, avg_freq=11.228308948597293)\n",
"32159 -1.3093262495764764 --> 10 <-- 0\n",
" 824 Plant(server=10, done=13219547, waiting=48, avg_freq=12.049708542424575)\n",
" 867 Plant(server=10, done=13357933, waiting=36, avg_freq=11.008287995100702)\n",
"32399 -1.2315247877513829 --> 10 <-- 0\n",
" 901 Plant(server=10, done=13496814, waiting=47, avg_freq=10.860338542946256)\n",
"32639 -1.10227972942614 --> 10 <-- 0\n",
" 891 Plant(server=10, done=13636977, waiting=56, avg_freq=10.7548076330618)\n",
" 893 Plant(server=10, done=13777057, waiting=35, avg_freq=10.310854025588817)\n",
"32879 -1.0058025449994452 --> 10 <-- 0\n",
" 861 Plant(server=10, done=13917460, waiting=27, avg_freq=10.41851654531865)\n",
"33119 -0.8863410931781264 --> 10 <-- 0\n",
" 909 Plant(server=10, done=14058698, waiting=41, avg_freq=9.52822358989966)\n",
" 914 Plant(server=10, done=14200617, waiting=57, avg_freq=10.587884213694045)\n",
"33359 -0.6654664450953139 --> 10 <-- 0\n",
" 879 Plant(server=10, done=14342830, waiting=41, avg_freq=10.757751376414456)\n",
"33599 -0.551648414355243 --> 10 <-- 0\n",
" 911 Plant(server=10, done=14485563, waiting=40, avg_freq=9.856996372498369)\n",
" 897 Plant(server=10, done=14629088, waiting=57, avg_freq=10.237584933206186)\n",
"33839 -0.27857735945157897 --> 10 <-- 0\n",
" 876 Plant(server=10, done=14772372, waiting=33, avg_freq=11.048978490681362)\n",
"34079 -0.20171748651408486 --> 10 <-- 0\n",
" 922 Plant(server=10, done=14917005, waiting=51, avg_freq=10.304225416322652)\n",
" 958 Plant(server=10, done=15061919, waiting=90, avg_freq=9.075263652911838)\n",
"34319 0.07879491403984522 --> 10 <-- 0.07879491403984522\n",
" 932 Plant(server=10, done=15207466, waiting=59, avg_freq=8.174117689352787)\n",
"34559 0.49034760399758537 --> 10 <-- 0.49034760399758537\n",
" 906 Plant(server=10, done=15353552, waiting=60, avg_freq=10.378933263710008)\n",
" 912 Plant(server=10, done=15500086, waiting=55, avg_freq=9.345699143946755)\n",
"34799 0.663872857348863 --> 10 <-- 0.663872857348863\n",
" 934 Plant(server=10, done=15646852, waiting=77, avg_freq=10.034575657436575)\n",
"35039 1.0293069520260014 --> 10 <-- 1.0293069520260014\n",
" 902 Plant(server=10, done=15794344, waiting=64, avg_freq=7.853314047479262)\n",
" 899 Plant(server=10, done=15942304, waiting=48, avg_freq=10.058174305445057)\n",
"35279 1.5027814655642113 --> 10 <-- 1.5027814655642113\n",
" 931 Plant(server=10, done=16090273, waiting=77, avg_freq=9.739407869182667)\n",
"35519 1.950695641597693 --> 11 <-- 1.950695641597693\n",
" 900 Plant(server=10, done=16238846, waiting=42, avg_freq=9.689841798499605)\n",
" 937 Plant(server=11, done=16388015, waiting=38, avg_freq=11.547686753570561)\n",
"35759 -0.26019634972419836 --> 10 <-- 0\n",
" 994 Plant(server=11, done=16537324, waiting=55, avg_freq=11.069761946978184)\n",
"35999 1.5327813512688246 --> 11 <-- 1.5327813512688246\n",
" 984 Plant(server=10, done=16687070, waiting=190, avg_freq=4.7069556673837205)\n",
" 997 Plant(server=11, done=16837315, waiting=55, avg_freq=10.63421462599512)\n",
"36239 0.8375218495244816 --> 11 <-- 0.8375218495244816\n",
" 909 Plant(server=11, done=16988558, waiting=42, avg_freq=12.223071046617768)\n",
"36479 -1.4040252883493751 --> 10 <-- 0\n",
" 966 Plant(server=11, done=17139932, waiting=52, avg_freq=10.890440102599213)\n",
" 973 Plant(server=10, done=17290777, waiting=665, avg_freq=1.3997483697874165)\n",
"36719 3.967716356841304 --> 12 <-- 3.967716356841304\n",
" 959 Plant(server=11, done=17442203, waiting=1435, avg_freq=0.6460395468494877)\n"
]
},
{
"name": "stdout",
"output_type": "stream",
"text": [
"36959 2.5403066497395046 --> 11 <-- 2.5403066497395046\n",
" 923 Plant(server=12, done=17595359, waiting=31, avg_freq=12.653526805847802)\n",
"1024 Plant(server=11, done=17747825, waiting=74, avg_freq=9.390962671905429)\n",
"37199 -1.5778376783556383 --> 11 <-- 0\n",
" 936 Plant(server=11, done=17901653, waiting=27, avg_freq=9.591797911447093)\n",
"37439 -1.0638031835757609 --> 11 <-- 0\n",
" 935 Plant(server=11, done=18055412, waiting=30, avg_freq=10.021900093842397)\n",
" 971 Plant(server=11, done=18209632, waiting=54, avg_freq=11.268561532443849)\n",
"37679 -1.0236147583070674 --> 11 <-- 0\n",
" 925 Plant(server=11, done=18364309, waiting=38, avg_freq=11.68040475928658)\n",
"37919 -0.9208296566418948 --> 11 <-- 0\n",
"1003 Plant(server=11, done=18519140, waiting=39, avg_freq=10.577785556420697)\n",
" 963 Plant(server=11, done=18673918, waiting=46, avg_freq=11.02426703980551)\n",
"38159 -1.0425429258994412 --> 11 <-- 0\n",
"1044 Plant(server=11, done=18828283, waiting=74, avg_freq=9.440290889247828)\n",
"38399 -0.9057174370943158 --> 11 <-- 0\n",
" 988 Plant(server=11, done=18983716, waiting=42, avg_freq=10.175559812850066)\n",
" 962 Plant(server=11, done=19138540, waiting=57, avg_freq=11.640692226800633)\n",
"38639 -0.8977272114730751 --> 11 <-- 0\n",
"1019 Plant(server=11, done=19294511, waiting=65, avg_freq=9.431683110935133)\n",
"38879 -0.7580968098556203 --> 11 <-- 0\n",
" 969 Plant(server=11, done=19450585, waiting=38, avg_freq=10.909740600542674)\n",
" 957 Plant(server=11, done=19606892, waiting=49, avg_freq=11.41850754624877)\n",
"39119 -0.7058599016727386 --> 11 <-- 0\n",
"1035 Plant(server=11, done=19763992, waiting=79, avg_freq=10.81337286845385)\n",
"39359 -0.5951815310075704 --> 11 <-- 0\n",
"1022 Plant(server=11, done=19920870, waiting=63, avg_freq=9.04835618458408)\n",
"1022 Plant(server=11, done=20077777, waiting=72, avg_freq=9.872154097988682)\n",
"39599 -0.5635684121260567 --> 11 <-- 0\n",
" 960 Plant(server=11, done=20234720, waiting=46, avg_freq=9.99381093943283)\n",
"39839 -0.5429068068602846 --> 11 <-- 0\n",
"1016 Plant(server=11, done=20392151, waiting=58, avg_freq=9.31172559687122)\n",
" 926 Plant(server=11, done=20550299, waiting=36, avg_freq=11.945826222723596)\n",
"40079 -0.3808157572133228 --> 11 <-- 0\n",
" 994 Plant(server=11, done=20707828, waiting=61, avg_freq=11.26462179801056)\n",
"40319 -0.42970581323605617 --> 11 <-- 0\n",
" 978 Plant(server=11, done=20865548, waiting=41, avg_freq=10.727404726570924)\n",
" 947 Plant(server=11, done=21023567, waiting=45, avg_freq=11.340878660596555)\n",
"40559 -0.27017643260495583 --> 11 <-- 0\n",
" 943 Plant(server=11, done=21182557, waiting=22, avg_freq=9.64717781149159)\n",
"40799 -0.1034568897254141 --> 11 <-- 0\n",
" 974 Plant(server=11, done=21341876, waiting=45, avg_freq=10.492059634628173)\n",
"1032 Plant(server=11, done=21500775, waiting=72, avg_freq=8.752465483233086)\n",
"41039 -0.17982151249156664 --> 11 <-- 0\n",
"1053 Plant(server=11, done=21659643, waiting=86, avg_freq=7.915210103439321)\n",
"41279 0.02680360818274507 --> 11 <-- 0.02680360818274507\n",
"1019 Plant(server=11, done=21819053, waiting=62, avg_freq=9.667890942290798)\n",
"1028 Plant(server=11, done=21979083, waiting=71, avg_freq=9.3261046658666)\n",
"41519 0.10505505419997822 --> 11 <-- 0.10505505419997822\n",
" 966 Plant(server=11, done=22138323, waiting=50, avg_freq=11.520310909617185)\n",
"41759 0.19380024881247776 --> 11 <-- 0.19380024881247776\n",
" 989 Plant(server=11, done=22298224, waiting=56, avg_freq=8.796929456891581)\n",
"1040 Plant(server=11, done=22457124, waiting=81, avg_freq=10.446542592159814)\n",
"41999 -0.07864176995761388 --> 11 <-- 0\n",
" 956 Plant(server=11, done=22617083, waiting=39, avg_freq=11.885338636896812)\n",
"42239 0.3038824836292939 --> 11 <-- 0.3038824836292939\n",
"1045 Plant(server=11, done=22777186, waiting=92, avg_freq=8.081953273704546)\n",
"1006 Plant(server=11, done=22937150, waiting=55, avg_freq=8.95530415764083)\n",
"42479 0.18008037058149393 --> 11 <-- 0.18008037058149393\n",
" 996 Plant(server=11, done=23097254, waiting=73, avg_freq=7.198910435187914)\n",
"42719 0.26246169433886046 --> 11 <-- 0.26246169433886046\n",
"1004 Plant(server=11, done=23257371, waiting=82, avg_freq=9.787400803375846)\n",
" 977 Plant(server=11, done=23417046, waiting=46, avg_freq=11.271960012194178)\n",
"42959 0.0966355857369282 --> 11 <-- 0.0966355857369282\n",
" 997 Plant(server=11, done=23576658, waiting=75, avg_freq=10.769612229276708)\n",
"43199 0.23626424628930714 --> 11 <-- 0.23626424628930714\n",
"1000 Plant(server=11, done=23736485, waiting=70, avg_freq=11.480001836798353)\n",
"1018 Plant(server=11, done=23896103, waiting=77, avg_freq=9.043752206629286)\n",
"43439 0.07635184853910396 --> 11 <-- 0.07635184853910396\n",
" 956 Plant(server=11, done=24055528, waiting=42, avg_freq=11.695153359881077)\n",
"43679 0.12024419117184149 --> 11 <-- 0.12024419117184149\n",
"1009 Plant(server=11, done=24215699, waiting=54, avg_freq=9.265442403998575)\n",
"1011 Plant(server=11, done=24375377, waiting=94, avg_freq=9.138643931344115)\n",
"43919 0.15084115517300126 --> 11 <-- 0.15084115517300126\n",
" 994 Plant(server=11, done=24535644, waiting=60, avg_freq=10.385155153618644)\n",
"44159 0.04817319141295172 --> 11 <-- 0.04817319141295172\n",
" 981 Plant(server=11, done=24694897, waiting=46, avg_freq=10.928842068356499)\n",
"1007 Plant(server=11, done=24854485, waiting=86, avg_freq=9.628929239914074)\n",
"44399 0.07620470864514171 --> 11 <-- 0.07620470864514171\n",
"1080 Plant(server=11, done=25013988, waiting=114, avg_freq=9.321004949979509)\n",
"44639 0.19026537617342265 --> 11 <-- 0.19026537617342265\n",
" 949 Plant(server=11, done=25174026, waiting=31, avg_freq=10.573873940712883)\n",
"1045 Plant(server=11, done=25333195, waiting=100, avg_freq=7.40146245766028)\n",
"44879 0.010163160127355304 --> 11 <-- 0.010163160127355304\n",
" 947 Plant(server=11, done=25492330, waiting=41, avg_freq=11.82364253664728)\n",
"45119 -0.010517641451868849 --> 11 <-- 0\n",
" 957 Plant(server=11, done=25652081, waiting=37, avg_freq=10.751177767206483)\n",
" 946 Plant(server=11, done=25811020, waiting=50, avg_freq=11.66625588302756)\n",
"45359 -0.2112972709971808 --> 11 <-- 0\n",
"1002 Plant(server=11, done=25970334, waiting=67, avg_freq=9.824464299840361)\n",
"45599 -0.14342321432689728 --> 11 <-- 0\n",
" 972 Plant(server=11, done=26128794, waiting=46, avg_freq=10.410551035783154)\n",
"1019 Plant(server=11, done=26287788, waiting=72, avg_freq=8.555706967036654)\n",
"45839 -0.13183932290359285 --> 11 <-- 0\n",
" 986 Plant(server=11, done=26446358, waiting=46, avg_freq=10.718959903971287)\n",
"46079 -0.16268330585558052 --> 11 <-- 0\n",
"1000 Plant(server=11, done=26605663, waiting=63, avg_freq=10.151035097956015)\n",
"1023 Plant(server=11, done=26763985, waiting=71, avg_freq=9.586677523182823)\n",
"46319 -0.2513645785745126 --> 11 <-- 0\n",
"1024 Plant(server=11, done=26922438, waiting=77, avg_freq=9.96214988648068)\n",
"46559 -0.34883511709384185 --> 11 <-- 0\n",
" 954 Plant(server=11, done=27079734, waiting=43, avg_freq=11.220739021089162)\n",
"1019 Plant(server=11, done=27237813, waiting=77, avg_freq=9.850098501024807)\n",
"46799 -0.3826842880185406 --> 11 <-- 0\n",
" 945 Plant(server=11, done=27395272, waiting=39, avg_freq=11.23261686831656)\n",
"47039 -0.5131234476340041 --> 11 <-- 0\n",
" 967 Plant(server=11, done=27552560, waiting=28, avg_freq=10.07200147693312)\n",
" 962 Plant(server=11, done=27710098, waiting=41, avg_freq=10.73586061986708)\n",
"47279 -0.37513373615317985 --> 11 <-- 0\n",
" 957 Plant(server=11, done=27866915, waiting=48, avg_freq=10.883945346835745)\n",
"47519 -0.6121188504984214 --> 11 <-- 0\n",
" 948 Plant(server=11, done=28023909, waiting=62, avg_freq=12.276645472616421)\n",
"1001 Plant(server=11, done=28181100, waiting=50, avg_freq=10.654556569623656)\n",
"47759 -0.6874981800299367 --> 11 <-- 0\n",
" 996 Plant(server=11, done=28336617, waiting=57, avg_freq=11.069942945441493)\n",
"47999 -0.688809946612516 --> 11 <-- 0\n",
" 896 Plant(server=11, done=28492765, waiting=38, avg_freq=12.221495750139542)\n",
" 972 Plant(server=11, done=28648139, waiting=42, avg_freq=9.987965067839742)\n",
"48239 -0.8793781688773618 --> 11 <-- 0\n",
"1001 Plant(server=11, done=28803224, waiting=72, avg_freq=10.50657067270944)\n",
"48479 -0.927835500065796 --> 11 <-- 0\n",
" 962 Plant(server=11, done=28958172, waiting=32, avg_freq=10.852608778611286)\n",
" 968 Plant(server=11, done=29112882, waiting=41, avg_freq=11.537679790529955)\n",
"48719 -1.007771387742172 --> 11 <-- 0\n",
" 975 Plant(server=11, done=29267122, waiting=48, avg_freq=11.298705869919376)\n",
"48959 -1.0733742653424312 --> 11 <-- 0\n",
" 966 Plant(server=11, done=29420880, waiting=52, avg_freq=11.138929457294768)\n",
" 982 Plant(server=11, done=29574552, waiting=40, avg_freq=10.810688814648362)\n"
]
},
{
"name": "stdout",
"output_type": "stream",
"text": [
"49199 -1.1831713725531188 --> 11 <-- 0\n",
" 988 Plant(server=11, done=29727396, waiting=63, avg_freq=10.725544972075467)\n",
"49439 -1.1986584436145298 --> 11 <-- 0\n",
" 959 Plant(server=11, done=29880233, waiting=43, avg_freq=10.820743160480278)\n",
" 902 Plant(server=11, done=30032358, waiting=43, avg_freq=12.054600248184865)\n",
"49679 -1.258895818891574 --> 11 <-- 0\n",
" 973 Plant(server=11, done=30184713, waiting=52, avg_freq=10.801151819351372)\n",
"49919 -1.3106547100708126 --> 11 <-- 0\n",
" 963 Plant(server=11, done=30336268, waiting=52, avg_freq=11.532185391754041)\n",
" 931 Plant(server=11, done=30486898, waiting=37, avg_freq=11.922503725785718)\n",
"50159 -1.4144378250327285 --> 11 <-- 0\n",
" 986 Plant(server=11, done=30638429, waiting=38, avg_freq=10.65622914286828)\n",
"50399 -1.4174077283700095 --> 11 <-- 0\n",
" 924 Plant(server=11, done=30789216, waiting=37, avg_freq=11.715971901623718)\n",
" 974 Plant(server=11, done=30939444, waiting=51, avg_freq=11.361982829694517)\n",
"50639 -1.4767223440761839 --> 11 <-- 0\n",
" 889 Plant(server=11, done=31089739, waiting=21, avg_freq=11.528586945794235)\n",
"50879 -1.608741043572767 --> 11 <-- 0\n",
" 898 Plant(server=11, done=31238451, waiting=39, avg_freq=12.231009748027127)\n",
" 976 Plant(server=11, done=31387064, waiting=52, avg_freq=11.232555043138287)\n",
"51119 -1.6326763791576318 --> 11 <-- 0\n",
" 987 Plant(server=11, done=31535434, waiting=49, avg_freq=10.472093286548397)\n",
"51359 -1.6739147450748126 --> 11 <-- 0\n",
" 878 Plant(server=11, done=31683023, waiting=33, avg_freq=12.366354939866044)\n",
" 902 Plant(server=11, done=31829940, waiting=31, avg_freq=11.890913790886914)\n",
"51599 -1.7667282730210994 --> 11 <-- 0\n",
" 913 Plant(server=11, done=31976027, waiting=43, avg_freq=11.779062299309146)\n",
"51839 -1.7765625861980758 --> 11 <-- 0\n",
" 954 Plant(server=11, done=32122309, waiting=48, avg_freq=11.249230769251923)\n",
" 913 Plant(server=11, done=32267914, waiting=28, avg_freq=11.927699788975215)\n",
"52079 -1.8343667752603594 --> 11 <-- 0\n",
" 933 Plant(server=11, done=32412540, waiting=38, avg_freq=11.7411003236445)\n",
"52319 -1.8616641779189491 --> 11 <-- 0\n",
" 931 Plant(server=11, done=32557445, waiting=38, avg_freq=11.878169920916868)\n",
" 904 Plant(server=11, done=32702057, waiting=26, avg_freq=11.85885202103037)\n",
"52559 -1.8850450368330331 --> 11 <-- 0\n",
" 912 Plant(server=11, done=32845310, waiting=25, avg_freq=11.300288169956408)\n",
"52799 -1.9458119926646522 --> 11 <-- 0\n",
" 888 Plant(server=11, done=32988069, waiting=31, avg_freq=12.069989739207337)\n",
" 876 Plant(server=11, done=33130898, waiting=34, avg_freq=12.270361087386002)\n",
"53039 -1.9304233312332648 --> 11 <-- 0\n",
" 815 Plant(server=11, done=33273308, waiting=12, avg_freq=12.504758011135234)\n",
"53279 -2.0159656571695272 --> 11 <-- -0.015965657169527248\n",
" 880 Plant(server=11, done=33414302, waiting=28, avg_freq=12.043924902606026)\n",
" 874 Plant(server=11, done=33555383, waiting=29, avg_freq=11.896232409110846)\n",
"53519 -2.003524477112519 --> 11 <-- -0.003524477112518909\n",
" 891 Plant(server=11, done=33696331, waiting=30, avg_freq=11.84238954308624)\n",
"53759 -2.0549254245201127 --> 11 <-- -0.05492542452011273\n",
" 903 Plant(server=11, done=33835487, waiting=34, avg_freq=11.579938717851881)\n",
" 886 Plant(server=11, done=33974629, waiting=44, avg_freq=11.946775057363562)\n",
"53999 -2.0952027091794267 --> 11 <-- -0.09520270917942675\n",
" 923 Plant(server=11, done=34113543, waiting=44, avg_freq=11.626033723553167)\n",
"54239 -2.1074764082679125 --> 11 <-- -0.1074764082679125\n",
" 856 Plant(server=11, done=34250946, waiting=31, avg_freq=12.231808377838101)\n",
" 825 Plant(server=11, done=34389119, waiting=29, avg_freq=12.585627741190086)\n",
"54479 -2.115655719459449 --> 11 <-- -0.11565571945944919\n",
" 854 Plant(server=11, done=34526454, waiting=18, avg_freq=12.15502640234197)\n",
"54719 -2.1225636605308154 --> 11 <-- -0.12256366053081535\n",
" 884 Plant(server=11, done=34663468, waiting=21, avg_freq=11.868732653675652)\n",
" 801 Plant(server=11, done=34799770, waiting=22, avg_freq=12.684197915459169)\n",
"54959 -2.1668432443144567 --> 11 <-- -0.16684324431445674\n",
" 843 Plant(server=11, done=34934851, waiting=17, avg_freq=12.024133848746795)\n",
"55199 -2.208808795257772 --> 11 <-- -0.20880879525777196\n",
" 826 Plant(server=11, done=35068979, waiting=19, avg_freq=12.358408578760502)\n",
" 796 Plant(server=11, done=35202923, waiting=30, avg_freq=12.774029709199276)\n",
"55439 -2.213195357194608 --> 11 <-- -0.21319535719460792\n",
" 840 Plant(server=11, done=35336202, waiting=35, avg_freq=12.084108887874628)\n",
"55679 -2.242066261417774 --> 11 <-- -0.242066261417774\n",
" 851 Plant(server=11, done=35468444, waiting=27, avg_freq=12.106218526794729)\n",
" 805 Plant(server=11, done=35600358, waiting=29, avg_freq=12.328274041655794)\n",
"55919 -2.2522318046849614 --> 11 <-- -0.2522318046849614\n",
" 825 Plant(server=11, done=35731555, waiting=24, avg_freq=12.065252662317386)\n",
"56159 -2.2570557807909526 --> 11 <-- -0.2570557807909526\n",
" 816 Plant(server=11, done=35862956, waiting=21, avg_freq=12.153788727163663)\n",
" 815 Plant(server=11, done=35992717, waiting=24, avg_freq=12.270496273411142)\n",
"56399 -2.303821197219726 --> 11 <-- -0.303821197219726\n",
" 818 Plant(server=11, done=36122163, waiting=26, avg_freq=12.217702768373453)\n",
"56639 -2.3093176331217133 --> 11 <-- -0.30931763312171334\n",
" 794 Plant(server=11, done=36250179, waiting=26, avg_freq=12.160315773516938)\n",
" 798 Plant(server=11, done=36377396, waiting=18, avg_freq=12.183004937434358)\n",
"56879 -2.324482050821776 --> 11 <-- -0.32448205082177584\n",
" 800 Plant(server=11, done=36505012, waiting=23, avg_freq=12.089203669519689)\n",
"57119 -2.332029918552749 --> 11 <-- -0.3320299185527489\n",
" 806 Plant(server=11, done=36631687, waiting=13, avg_freq=12.25753262713004)\n",
" 779 Plant(server=11, done=36756565, waiting=28, avg_freq=12.446617663412772)\n",
"57359 -2.359362220630056 --> 11 <-- -0.35936222063005596\n",
" 826 Plant(server=11, done=36882017, waiting=32, avg_freq=12.211179734779328)\n",
"57599 -2.35737557788442 --> 11 <-- -0.3573755778844201\n",
" 794 Plant(server=11, done=37005991, waiting=17, avg_freq=12.250446548551169)\n",
" 823 Plant(server=11, done=37130351, waiting=17, avg_freq=12.22765673635521)\n",
"57839 -2.362902212142568 --> 11 <-- -0.362902212142568\n",
" 768 Plant(server=11, done=37252712, waiting=18, avg_freq=12.480015661225242)\n",
"58079 -2.3753928818108316 --> 11 <-- -0.37539288181083164\n",
" 768 Plant(server=11, done=37374744, waiting=27, avg_freq=12.22961463053124)\n",
" 738 Plant(server=11, done=37496111, waiting=20, avg_freq=12.383698073699593)\n",
"58319 -2.3983938663883064 --> 11 <-- -0.39839386638830643\n",
" 744 Plant(server=11, done=37616221, waiting=23, avg_freq=12.346490867556174)\n",
"58559 -2.4270993357718926 --> 11 <-- -0.42709933577189263\n",
" 778 Plant(server=11, done=37735754, waiting=30, avg_freq=12.329174093897056)\n",
" 726 Plant(server=11, done=37854936, waiting=21, avg_freq=12.522784041055706)\n",
"58799 -2.424125733119369 --> 11 <-- -0.42412573311936885\n",
" 748 Plant(server=11, done=37973433, waiting=32, avg_freq=12.20703933748736)\n",
"59039 -2.414009194682636 --> 11 <-- -0.41400919468263586\n",
" 749 Plant(server=11, done=38091159, waiting=18, avg_freq=12.342352961039884)\n",
" 782 Plant(server=11, done=38207845, waiting=25, avg_freq=12.395287066679593)\n",
"59279 -2.4640250553087375 --> 11 <-- -0.4640250553087375\n",
" 717 Plant(server=11, done=38323490, waiting=15, avg_freq=12.310154600612613)\n",
"59519 -2.4537157609270808 --> 10 <-- -0.45371576092708077\n",
" 751 Plant(server=11, done=38438685, waiting=23, avg_freq=12.411623364278658)\n",
" 696 Plant(server=10, done=38553273, waiting=13, avg_freq=12.280188078072447)\n",
"59759 -2.4075163352161835 --> 10 <-- -0.40751633521618347\n",
" 699 Plant(server=10, done=38667026, waiting=19, avg_freq=12.505077980104303)\n",
"59999 -2.361334643593322 --> 10 <-- -0.361334643593322\n",
" 630 Plant(server=10, done=38779515, waiting=14, avg_freq=12.87592952129696)\n",
" 695 Plant(server=10, done=38892280, waiting=19, avg_freq=12.436304030255565)\n",
"60239 -2.37642346099839 --> 10 <-- -0.3764234609983901\n",
" 680 Plant(server=10, done=39003272, waiting=20, avg_freq=12.470351469846296)\n",
"60479 -2.3867954256821142 --> 10 <-- -0.3867954256821142\n",
" 702 Plant(server=10, done=39113998, waiting=22, avg_freq=12.401454336004955)\n",
" 687 Plant(server=10, done=39223939, waiting=12, avg_freq=12.301715765660418)\n",
"60719 -2.410617410814039 --> 10 <-- -0.410617410814039\n",
" 702 Plant(server=10, done=39332600, waiting=8, avg_freq=12.272045401173772)\n",
"60959 -2.403934982591663 --> 10 <-- -0.40393498259166316\n",
" 681 Plant(server=10, done=39440872, waiting=9, avg_freq=12.299494516359427)\n"
]
},
{
"name": "stdout",
"output_type": "stream",
"text": [
" 664 Plant(server=10, done=39549165, waiting=15, avg_freq=12.321540561534823)\n",
"61199 -2.3996937205188567 --> 10 <-- -0.39969372051885665\n",
" 656 Plant(server=10, done=39656044, waiting=19, avg_freq=12.601448311238775)\n",
"61439 -2.4279957368984073 --> 10 <-- -0.4279957368984073\n",
" 676 Plant(server=10, done=39762067, waiting=22, avg_freq=12.302284710039986)\n",
" 652 Plant(server=10, done=39866276, waiting=19, avg_freq=12.321917162014415)\n",
"61679 -2.4722839237660508 --> 10 <-- -0.4722839237660508\n",
" 610 Plant(server=10, done=39970760, waiting=16, avg_freq=12.643162351492599)\n",
"61919 -2.4538917196002643 --> 10 <-- -0.4538917196002643\n",
" 649 Plant(server=10, done=40074230, waiting=18, avg_freq=12.205307315628588)\n",
" 601 Plant(server=10, done=40177174, waiting=17, avg_freq=12.968534027230545)\n",
"62159 -2.46821873774866 --> 10 <-- -0.4682187377486602\n",
" 679 Plant(server=10, done=40278867, waiting=30, avg_freq=12.371013133228127)\n",
"62399 -2.4921451433836554 --> 10 <-- -0.49214514338365545\n",
" 636 Plant(server=10, done=40379531, waiting=14, avg_freq=12.273535677286462)\n",
" 585 Plant(server=10, done=40479864, waiting=9, avg_freq=12.763687105019521)\n",
"62639 -2.4800955605264687 --> 10 <-- -0.48009556052646873\n",
" 591 Plant(server=10, done=40579713, waiting=14, avg_freq=12.773533734985898)\n",
"62879 -2.4836390693273276 --> 10 <-- -0.4836390693273276\n",
" 676 Plant(server=10, done=40678836, waiting=14, avg_freq=12.292612381022964)\n",
" 627 Plant(server=10, done=40776282, waiting=8, avg_freq=12.299400226977685)\n",
"63119 -2.5338939229765596 --> 10 <-- -0.5338939229765596\n",
" 597 Plant(server=10, done=40873119, waiting=16, avg_freq=12.529398297502611)\n",
"63359 -2.5058007331497807 --> 10 <-- -0.5058007331497807\n",
" 640 Plant(server=10, done=40969495, waiting=22, avg_freq=12.410868345037104)\n",
" 574 Plant(server=10, done=41064687, waiting=14, avg_freq=12.61688228514524)\n",
"63599 -2.5340041082446905 --> 10 <-- -0.5340041082446905\n",
" 576 Plant(server=10, done=41159212, waiting=13, avg_freq=12.687827480234358)\n",
"63839 -2.5450810064220053 --> 10 <-- -0.5450810064220053\n",
" 546 Plant(server=10, done=41252222, waiting=13, avg_freq=13.029242913515235)\n",
" 573 Plant(server=10, done=41344936, waiting=14, avg_freq=12.392160237535865)\n",
"64079 -2.5455962219447645 --> 10 <-- -0.5455962219447645\n",
" 594 Plant(server=10, done=41436589, waiting=6, avg_freq=12.378656590023828)\n",
"64319 -2.5509002140101145 --> 10 <-- -0.5509002140101145\n",
" 571 Plant(server=10, done=41527584, waiting=8, avg_freq=12.42358942788229)\n",
" 601 Plant(server=10, done=41617849, waiting=12, avg_freq=12.445274129387577)\n",
"64559 -2.5685259779480103 --> 10 <-- -0.5685259779480103\n",
" 525 Plant(server=10, done=41707024, waiting=1, avg_freq=12.845735447318125)\n",
"64799 -2.5788538190431427 --> 10 <-- -0.5788538190431427\n",
" 559 Plant(server=10, done=41795523, waiting=9, avg_freq=12.361772903036703)\n",
" 554 Plant(server=10, done=41883183, waiting=18, avg_freq=12.446518864271116)\n",
"65039 -2.6103017019303194 --> 9 <-- -0.6103017019303194\n",
" 482 Plant(server=10, done=41969490, waiting=5, avg_freq=13.386980602601538)\n",
"65279 -2.5833030791052147 --> 9 <-- -0.5833030791052147\n",
" 509 Plant(server=9, done=42054930, waiting=12, avg_freq=12.841168690642897)\n",
" 558 Plant(server=9, done=42140305, waiting=12, avg_freq=12.349425716713313)\n",
"65519 -2.536673554161917 --> 9 <-- -0.5366735541619172\n",
" 496 Plant(server=9, done=42224170, waiting=9, avg_freq=12.950032189387002)\n",
"65759 -2.549054326326337 --> 9 <-- -0.549054326326337\n",
" 520 Plant(server=9, done=42307679, waiting=8, avg_freq=12.373695148439673)\n",
" 495 Plant(server=9, done=42390053, waiting=9, avg_freq=12.520134719582112)\n",
"65999 -2.5716969346982728 --> 9 <-- -0.5716969346982728\n",
" 464 Plant(server=9, done=42472191, waiting=4, avg_freq=13.1551688419525)\n",
"66239 -2.554980979010639 --> 9 <-- -0.5549809790106388\n",
" 499 Plant(server=9, done=42553174, waiting=9, avg_freq=12.506851362760113)\n",
" 476 Plant(server=9, done=42633358, waiting=7, avg_freq=12.887667254386063)\n",
"66479 -2.5745327794858808 --> 9 <-- -0.5745327794858808\n",
" 492 Plant(server=9, done=42712866, waiting=4, avg_freq=12.402006503508758)\n",
"66719 -2.5749258514422024 --> 9 <-- -0.5749258514422024\n",
" 494 Plant(server=9, done=42791181, waiting=9, avg_freq=12.471190781039711)\n",
" 488 Plant(server=9, done=42868522, waiting=5, avg_freq=12.445132971890484)\n",
"66959 -2.59736258109793 --> 9 <-- -0.5973625810979302\n",
" 442 Plant(server=9, done=42945261, waiting=6, avg_freq=12.935944025653091)\n",
"67199 -2.6086835304248863 --> 9 <-- -0.6086835304248863\n",
" 475 Plant(server=9, done=43021282, waiting=3, avg_freq=12.37194641442167)\n",
" 461 Plant(server=9, done=43096182, waiting=8, avg_freq=12.769572246716201)\n",
"67439 -2.645033714078138 --> 9 <-- -0.6450337140781381\n",
" 502 Plant(server=9, done=43170476, waiting=8, avg_freq=12.428891105600423)\n",
"67679 -2.6218255991410833 --> 9 <-- -0.6218255991410833\n",
" 446 Plant(server=9, done=43243753, waiting=2, avg_freq=12.613410046419038)\n",
" 442 Plant(server=9, done=43315857, waiting=11, avg_freq=12.932641298471738)\n",
"67919 -2.6559262321112596 --> 9 <-- -0.6559262321112596\n",
" 465 Plant(server=9, done=43387377, waiting=5, avg_freq=12.689922039468527)\n",
"68159 -2.669346388277791 --> 9 <-- -0.6693463882777908\n",
" 464 Plant(server=9, done=43458189, waiting=9, avg_freq=12.579154543902275)\n",
" 441 Plant(server=9, done=43528115, waiting=7, avg_freq=12.313253692528738)\n",
"68399 -2.678130815951269 --> 9 <-- -0.6781308159512691\n",
" 446 Plant(server=9, done=43597592, waiting=5, avg_freq=12.407519359804311)\n",
"68639 -2.6585532813542496 --> 9 <-- -0.6585532813542496\n",
" 415 Plant(server=9, done=43666359, waiting=12, avg_freq=12.889724614752975)\n",
" 452 Plant(server=9, done=43734374, waiting=8, avg_freq=12.511543388287324)\n",
"68879 -2.657573776387252 --> 9 <-- -0.657573776387252\n",
" 445 Plant(server=9, done=43801681, waiting=16, avg_freq=12.587200485294767)\n",
"69119 -2.7074509342654536 --> 8 <-- -0.7074509342654536\n",
" 399 Plant(server=9, done=43867673, waiting=5, avg_freq=12.80049953159646)\n",
" 429 Plant(server=8, done=43933098, waiting=4, avg_freq=12.505017445281544)\n",
"69359 -2.6735213085645833 --> 8 <-- -0.6735213085645833\n",
" 413 Plant(server=8, done=43997425, waiting=12, avg_freq=12.441052370302588)\n",
"69599 -2.6510812515857465 --> 8 <-- -0.6510812515857465\n",
" 393 Plant(server=8, done=44061002, waiting=5, avg_freq=12.445003142663445)\n",
" 344 Plant(server=8, done=44123777, waiting=7, avg_freq=13.21705033295557)\n",
"69839 -2.6391636182552394 --> 8 <-- -0.6391636182552394\n",
" 372 Plant(server=8, done=44186438, waiting=6, avg_freq=12.78569062600331)\n",
"70079 -2.6496985792690912 --> 8 <-- -0.6496985792690912\n",
" 378 Plant(server=8, done=44248019, waiting=4, avg_freq=12.530421627225339)\n",
" 372 Plant(server=8, done=44308110, waiting=4, avg_freq=12.57356875325436)\n",
"70319 -2.7055939985574926 --> 8 <-- -0.7055939985574926\n",
" 363 Plant(server=8, done=44367927, waiting=3, avg_freq=12.860064473598799)\n",
"70559 -2.7584461153653237 --> 8 <-- -0.7584461153653237\n",
" 382 Plant(server=8, done=44426506, waiting=4, avg_freq=12.460847065224737)\n",
" 385 Plant(server=8, done=44484479, waiting=3, avg_freq=12.523351553303268)\n",
"70799 -2.7205747423350704 --> 8 <-- -0.7205747423350704\n",
" 368 Plant(server=8, done=44541476, waiting=4, avg_freq=12.476846188764641)\n",
"71039 -2.7290881148094592 --> 8 <-- -0.7290881148094592\n",
" 329 Plant(server=8, done=44598227, waiting=7, avg_freq=13.284522776176415)\n",
" 347 Plant(server=8, done=44653999, waiting=7, avg_freq=12.765489160414557)\n",
"71279 -2.740912180114978 --> 8 <-- -0.7409121801149778\n",
" 352 Plant(server=8, done=44709569, waiting=0, avg_freq=12.594088489076286)\n",
"71519 -2.709097532191193 --> 8 <-- -0.7090975321911932\n",
" 338 Plant(server=8, done=44764503, waiting=2, avg_freq=12.538952366830943)\n",
" 330 Plant(server=8, done=44818151, waiting=5, avg_freq=12.645767075663901)\n",
"71759 -2.7445510874672983 --> 8 <-- -0.7445510874672983\n",
" 323 Plant(server=8, done=44870707, waiting=2, avg_freq=12.29263189358375)\n",
"71999 -2.786727089331028 --> 8 <-- -0.7867270893310279\n",
" 311 Plant(server=8, done=44922999, waiting=3, avg_freq=13.350312191861478)\n",
" 284 Plant(server=8, done=44974423, waiting=2, avg_freq=13.163848780219556)\n",
"72239 -2.7811864910145236 --> 8 <-- -0.7811864910145236\n",
" 281 Plant(server=8, done=45025176, waiting=0, avg_freq=13.184329482692196)\n",
"72479 -2.806803298816324 --> 8 <-- -0.8068032988163241\n",
" 298 Plant(server=8, done=45074828, waiting=2, avg_freq=12.707362915852075)\n"
]
},
{
"name": "stdout",
"output_type": "stream",
"text": [
" 323 Plant(server=8, done=45124184, waiting=3, avg_freq=12.337740626064543)\n",
"72719 -2.7831246139643913 --> 7 <-- -0.7831246139643913\n",
" 315 Plant(server=7, done=45172812, waiting=6, avg_freq=12.606445149430042)\n",
"72959 -2.753340396088655 --> 7 <-- -0.7533403960886549\n",
" 324 Plant(server=7, done=45220823, waiting=8, avg_freq=12.624978817216135)\n",
" 274 Plant(server=7, done=45267837, waiting=1, avg_freq=12.925917784122756)\n",
"73199 -2.751575022709594 --> 7 <-- -0.7515750227095941\n",
" 316 Plant(server=7, done=45314428, waiting=9, avg_freq=12.869611684994773)\n",
"73439 -2.7352247827407763 --> 7 <-- -0.7352247827407763\n",
" 289 Plant(server=7, done=45360552, waiting=4, avg_freq=12.716969345431346)\n",
" 312 Plant(server=7, done=45406016, waiting=0, avg_freq=12.417145382177521)\n",
"73679 -2.7548959131622834 --> 7 <-- -0.7548959131622834\n",
" 257 Plant(server=7, done=45450601, waiting=2, avg_freq=13.20242123819924)\n",
"73919 -2.733767463108735 --> 7 <-- -0.7337674631087352\n",
" 274 Plant(server=7, done=45494773, waiting=1, avg_freq=12.534562212033682)\n",
" 267 Plant(server=7, done=45538012, waiting=2, avg_freq=12.362193828134778)\n",
"74159 -2.7929777630866313 --> 7 <-- -0.7929777630866313\n",
" 239 Plant(server=7, done=45580611, waiting=1, avg_freq=13.401695517464354)\n",
"74399 -2.7795476196228273 --> 7 <-- -0.7795476196228273\n",
" 291 Plant(server=7, done=45622606, waiting=3, avg_freq=12.518054887020226)\n",
" 292 Plant(server=7, done=45663863, waiting=2, avg_freq=12.711654004651983)\n",
"74639 -2.840391284193778 --> 7 <-- -0.8403912841937782\n",
" 237 Plant(server=7, done=45704343, waiting=0, avg_freq=12.813342146695037)\n",
"74879 -2.7798653396544113 --> 7 <-- -0.7798653396544113\n",
" 240 Plant(server=7, done=45744424, waiting=2, avg_freq=13.120998888807623)\n",
" 218 Plant(server=7, done=45784292, waiting=4, avg_freq=13.476347634930459)\n",
"75119 -2.7809707780959125 --> 7 <-- -0.7809707780959125\n",
" 245 Plant(server=7, done=45823155, waiting=0, avg_freq=12.523383911807876)\n",
"75359 -2.807779430802376 --> 7 <-- -0.807779430802376\n",
" 209 Plant(server=7, done=45861314, waiting=0, avg_freq=13.545179173626597)\n",
" 219 Plant(server=7, done=45898661, waiting=1, avg_freq=13.391574228366569)\n",
"75599 -2.8595008913969147 --> 7 <-- -0.8595008913969147\n",
" 239 Plant(server=7, done=45935572, waiting=0, avg_freq=12.482965385722288)\n",
"75839 -2.8200060972043364 --> 7 <-- -0.8200060972043364\n",
" 225 Plant(server=7, done=45971885, waiting=2, avg_freq=12.774857271823604)\n",
" 233 Plant(server=7, done=46007745, waiting=5, avg_freq=12.600749233757455)\n",
"76079 -2.8151705513813954 --> 6 <-- -0.8151705513813954\n",
" 212 Plant(server=6, done=46042951, waiting=4, avg_freq=12.563102340417798)\n",
"76319 -2.794103914687962 --> 6 <-- -0.794103914687962\n",
" 218 Plant(server=6, done=46077840, waiting=3, avg_freq=12.631455261066526)\n",
" 217 Plant(server=6, done=46112019, waiting=1, avg_freq=12.512542052787163)\n",
"76559 -2.82576635801201 --> 6 <-- -0.82576635801201\n",
" 216 Plant(server=6, done=46145607, waiting=1, avg_freq=12.494743797639671)\n",
"76799 -2.786851447363101 --> 6 <-- -0.7868514473631012\n",
" 178 Plant(server=6, done=46178695, waiting=0, avg_freq=13.716962194507197)\n",
" 201 Plant(server=6, done=46211278, waiting=2, avg_freq=12.559360159788074)\n",
"77039 -2.810393431387729 --> 6 <-- -0.810393431387729\n",
" 202 Plant(server=6, done=46243286, waiting=0, avg_freq=12.326464545798988)\n",
"77279 -2.7916591356229272 --> 6 <-- -0.7916591356229272\n",
" 189 Plant(server=6, done=46274723, waiting=0, avg_freq=12.495994873278125)\n",
" 186 Plant(server=6, done=46305514, waiting=1, avg_freq=12.811102955999996)\n",
"77519 -2.856189178019972 --> 6 <-- -0.8561891780199722\n",
" 189 Plant(server=6, done=46335915, waiting=0, avg_freq=12.87290559872994)\n",
"77759 -2.8900410845861155 --> 6 <-- -0.8900410845861155\n",
" 192 Plant(server=6, done=46365960, waiting=1, avg_freq=12.480604465894409)\n",
" 201 Plant(server=6, done=46395245, waiting=2, avg_freq=12.725492938041196)\n",
"77999 -2.8199494903909526 --> 6 <-- -0.8199494903909526\n",
" 174 Plant(server=6, done=46424035, waiting=3, avg_freq=13.265154883531602)\n",
"78239 -2.857882615160128 --> 6 <-- -0.8578826151601282\n",
" 162 Plant(server=6, done=46452698, waiting=0, avg_freq=13.248024087342063)\n",
" 174 Plant(server=6, done=46480525, waiting=1, avg_freq=12.757533543505447)\n",
"78479 -2.8887355183532795 --> 6 <-- -0.8887355183532795\n",
" 164 Plant(server=6, done=46507976, waiting=0, avg_freq=13.270215737726952)\n",
"78719 -2.818390383604905 --> 6 <-- -0.8183903836049051\n",
" 162 Plant(server=6, done=46535361, waiting=0, avg_freq=12.745618693563053)\n",
" 151 Plant(server=6, done=46562086, waiting=0, avg_freq=13.905275577047295)\n",
"78959 -2.8387678540161643 --> 6 <-- -0.8387678540161643\n",
" 172 Plant(server=6, done=46588180, waiting=0, avg_freq=12.427124884996399)\n",
"79199 -2.9181974554161245 --> 5 <-- -0.9181974554161245\n",
" 151 Plant(server=6, done=46613889, waiting=0, avg_freq=12.962812930351614)\n",
" 163 Plant(server=5, done=46639040, waiting=2, avg_freq=12.457351424261303)\n",
"79439 -2.874451983613183 --> 5 <-- -0.874451983613183\n",
" 189 Plant(server=5, done=46664045, waiting=2, avg_freq=13.084585514075984)\n",
"79679 -2.867515113152655 --> 5 <-- -0.8675151131526548\n",
" 172 Plant(server=5, done=46688671, waiting=0, avg_freq=13.151064197952959)\n",
" 172 Plant(server=5, done=46712791, waiting=2, avg_freq=12.91100017212804)\n",
"79919 -2.863348970256638 --> 5 <-- -0.8633489702566379\n",
" 125 Plant(server=5, done=46736345, waiting=0, avg_freq=13.657902071701933)\n",
"80159 -2.8401821794628295 --> 5 <-- -0.8401821794628295\n",
" 132 Plant(server=5, done=46759913, waiting=1, avg_freq=12.967268824913221)\n",
" 166 Plant(server=5, done=46783187, waiting=0, avg_freq=12.782694198584029)\n",
"80399 -2.839870644103429 --> 5 <-- -0.8398706441034292\n",
" 144 Plant(server=5, done=46805943, waiting=2, avg_freq=12.218370883904337)\n",
"80639 -2.8370209066142005 --> 5 <-- -0.8370209066142005\n",
" 142 Plant(server=5, done=46828250, waiting=0, avg_freq=12.455997833709143)\n",
" 162 Plant(server=5, done=46850170, waiting=1, avg_freq=12.396317564400327)\n",
"80879 -2.885038897981968 --> 5 <-- -0.8850388979819681\n",
" 136 Plant(server=5, done=46872036, waiting=0, avg_freq=12.080778939787699)\n",
"81119 -2.888272084189698 --> 5 <-- -0.888272084189698\n",
" 135 Plant(server=5, done=46893404, waiting=3, avg_freq=13.096537354880132)\n",
" 141 Plant(server=5, done=46914233, waiting=1, avg_freq=12.654531295538401)\n",
"81359 -2.8820196784376937 --> 5 <-- -0.8820196784376937\n",
" 143 Plant(server=5, done=46934798, waiting=0, avg_freq=11.99625117155995)\n",
"81599 -2.8749247331307592 --> 5 <-- -0.8749247331307592\n",
" 117 Plant(server=5, done=46955236, waiting=1, avg_freq=13.443421191829778)\n",
" 106 Plant(server=5, done=46975293, waiting=0, avg_freq=13.787778512895274)\n",
"81839 -2.922044925383206 --> 5 <-- -0.9220449253832061\n",
" 121 Plant(server=5, done=46995245, waiting=0, avg_freq=12.506354855045648)\n",
"82079 -2.841553167427408 --> 5 <-- -0.8415531674274082\n",
" 130 Plant(server=5, done=47014942, waiting=0, avg_freq=12.638557961343363)\n",
" 102 Plant(server=5, done=47034144, waiting=0, avg_freq=13.474062429950635)\n",
"82319 -2.8669158308259823 --> 4 <-- -0.8669158308259823\n",
" 116 Plant(server=5, done=47053470, waiting=0, avg_freq=12.94569391104538)\n",
"82559 -2.910175672256567 --> 4 <-- -0.910175672256567\n",
" 112 Plant(server=4, done=47072121, waiting=0, avg_freq=13.504155124647026)\n",
" 120 Plant(server=4, done=47090754, waiting=2, avg_freq=12.71650953743879)\n",
"82799 -2.9261639694357258 --> 4 <-- -0.9261639694357258\n",
" 123 Plant(server=4, done=47109189, waiting=0, avg_freq=12.6934639795949)\n",
"83039 -2.851655972781698 --> 4 <-- -0.8516559727816979\n",
" 117 Plant(server=4, done=47127574, waiting=0, avg_freq=12.673844773320534)\n",
" 132 Plant(server=4, done=47145535, waiting=0, avg_freq=12.570145903392191)\n",
"83279 -2.8597662344339336 --> 4 <-- -0.8597662344339336\n",
" 106 Plant(server=4, done=47163181, waiting=0, avg_freq=12.939654158417067)\n",
"83519 -2.8175428860232032 --> 4 <-- -0.8175428860232032\n",
" 113 Plant(server=4, done=47180567, waiting=1, avg_freq=12.193757690959405)\n",
" 95 Plant(server=4, done=47198083, waiting=0, avg_freq=13.89782524764966)\n",
"83759 -2.904219397090011 --> 4 <-- -0.904219397090011\n",
" 110 Plant(server=4, done=47214981, waiting=1, avg_freq=12.47231612061495)\n",
"83999 -2.8533386010545616 --> 4 <-- -0.8533386010545616\n",
" 121 Plant(server=4, done=47232255, waiting=0, avg_freq=12.455934195093597)\n",
" 105 Plant(server=4, done=47249168, waiting=1, avg_freq=12.200790146451073)\n",
"84239 -2.88334329573523 --> 4 <-- -0.8833432957352301\n",
" 96 Plant(server=4, done=47265920, waiting=0, avg_freq=13.367281986126935)\n"
]
},
{
"name": "stdout",
"output_type": "stream",
"text": [
"84479 -2.942941107901366 --> 4 <-- -0.9429411079013659\n",
" 113 Plant(server=4, done=47282494, waiting=2, avg_freq=13.055485814664259)\n",
" 115 Plant(server=4, done=47299162, waiting=0, avg_freq=12.450139006361006)\n",
"84719 -2.869720239314999 --> 4 <-- -0.869720239314999\n",
" 109 Plant(server=4, done=47315729, waiting=0, avg_freq=12.881440720361493)\n",
"84959 -2.908296743248788 --> 4 <-- -0.9082967432487878\n",
" 99 Plant(server=4, done=47332227, waiting=1, avg_freq=13.25536062381978)\n",
" 92 Plant(server=4, done=47348345, waiting=0, avg_freq=13.23375262064984)\n",
"85199 -2.87542691991699 --> 3 <-- -0.8754269199169902\n",
" 96 Plant(server=3, done=47364567, waiting=2, avg_freq=13.319266781113013)\n",
"85439 -2.8340505135795877 --> 3 <-- -0.8340505135795877\n",
" 105 Plant(server=3, done=47380683, waiting=0, avg_freq=12.229083424092163)\n",
" 90 Plant(server=3, done=47396438, waiting=0, avg_freq=13.437248051659779)\n",
"85679 -2.800640398038458 --> 3 <-- -0.8006403980384582\n",
" 92 Plant(server=3, done=47412432, waiting=0, avg_freq=13.029315960709482)\n",
"85919 -2.8594718597967015 --> 3 <-- -0.8594718597967015\n",
" 78 Plant(server=3, done=47428477, waiting=1, avg_freq=12.416190712571437)\n",
" 87 Plant(server=3, done=47444384, waiting=0, avg_freq=13.297872340315395)\n",
"86159 -2.815268692600656 --> 3 <-- -0.815268692600656\n",
" 91 Plant(server=3, done=47460359, waiting=1, avg_freq=12.518778167003845)\n",
"86399 -2.781361271926008 --> 3 <-- -0.7813612719260079\n"
]
}
],
"source": [
"def load(t) -> List[Task]:\n",
" \"\"\" The generation times of tasks between [t, t+1] and the \"size\" of each task in terms\n",
" of how many ms it takes to do one task.\n",
" \"\"\"\n",
" ml = mean_load(t)\n",
" a=np.random.exponential(scale=1/ml, size=(ml)*2).cumsum()\n",
" a=np.round(t + a[:bisect_left(a, 1.0)], 3)\n",
" b=np.round(np.random.uniform(0.070, 0.100, len(a)), 3)\n",
" return [Task(e1, None, e2, e2) for e1, e2 in zip(a,b)]\n",
"\n",
"class EmptyQ(Exception):\n",
" pass\n",
"\n",
"class Plant:\n",
" def __init__(self):\n",
" self.active_servers = 1\n",
" self.thread_per_server = 8\n",
" self.wait_q = deque()\n",
" self.log = deque([], 10000)\n",
" self.done = 0\n",
" self.requests = defaultdict(int)\n",
" return\n",
" \n",
" def __repr__(self):\n",
" return (f'Plant(server={self.active_servers}, '\n",
" f'done={self.done}, waiting={len(self.wait_q)}, '\n",
" f'avg_freq={1 / self.local_average_waiting_time()}'\n",
" ')')\n",
" \n",
" def request_server(self, t, n):\n",
" \"\"\" At time `t` request to add `n` servers to the plant.\n",
" \"\"\"\n",
" if n == self.active_servers:\n",
" pass\n",
" elif n > self.active_servers:\n",
" for _ in range(self.active_servers, n):\n",
" self.requests[t + int(np.random.uniform(60, 120))] += 1\n",
" else:\n",
" for _ in range(n, self.active_servers):\n",
" self.requests[t + int(np.random.uniform(60, 120))] -= 1\n",
" return\n",
" \n",
" def local_average_waiting_time(self):\n",
" t = int(self.log[-1].creation_time)\n",
" return np.mean([(e.end_time - e.creation_time) \n",
" for e \n",
" in islice(self.log, max(0, len(self.log) - mean_load(t)), len(self.log))])\n",
" \n",
" def process(self, t, tasks):\n",
" \"\"\" Run the plant from [t, t+1]\n",
" \"\"\"\n",
" self.wait_q.extend(tasks)\n",
" self.active_servers += self.requests.get(t, 0)\n",
" offset = {}\n",
" for server in range(self.active_servers): \n",
" for thread in range(self.thread_per_server):\n",
" offset[server, thread] = 0\n",
" try:\n",
" some_thread_is_empty = True\n",
" while self.wait_q and some_thread_is_empty:\n",
" some_thread_is_empty = False\n",
" for server in range(self.active_servers): \n",
" for thread in range(self.thread_per_server):\n",
" # st()\n",
" if offset[server, thread] < 1:\n",
" some_thread_is_empty = True\n",
" try:\n",
" task = self.wait_q.popleft()\n",
" except IndexError:\n",
" raise EmptyQ\n",
" offset[server, thread] = max(\n",
" offset[server, thread], task.creation_time - t)\n",
" if offset[server, thread] <= 1 - task.proc_time_remaining:\n",
" offset[server, thread] += task.proc_time_remaining\n",
" task.proc_time_remaining = 0\n",
" task.end_time = t + offset[server, thread]\n",
" task.server = server\n",
" task.thread = thread\n",
" self.log.append(task)\n",
" self.done += 1\n",
" else:\n",
" task.proc_time_remaining -= (1 - offset[server, thread])\n",
" offset[server, thread] = 1\n",
" self.wait_q.appendleft(task)\n",
" else:\n",
" pass\n",
" #if not some_thread_is_empty:\n",
" # st()\n",
" except EmptyQ:\n",
" pass\n",
" return\n",
"\n",
"def pid_factory(a, b, c):\n",
" xp, ix = None, 0\n",
" def f(x):\n",
" nonlocal xp, ix\n",
" xp = x if xp is None else xp\n",
" ix += x\n",
" return a * x + b * (x - xp) + c * ix\n",
" return f\n",
"\n",
"def shrinkage(err):\n",
" if -2 <= err <= 0:\n",
" return 0\n",
" elif err < -2:\n",
" return err + 2\n",
" else:\n",
" return err\n",
" \n",
"env = Env()\n",
"plant = Plant()\n",
"pid_controller = pid_factory(.5 * 100/550, .5 * 100/550, .5 * 100/550)\n",
"error_sum = 0\n",
"subsample = 240\n",
"for t in range(0, SPD): # range(SPD//2 - 20, SPD//2+20):\n",
" tasks = load(t)\n",
" plant.process(t, tasks)\n",
" if t % 160 == 0:\n",
" print(f'{len(tasks):4}', plant)\n",
" error = (10.0 - 1 / plant.local_average_waiting_time())\n",
" error_sum += error\n",
" if t % subsample == subsample - 1:\n",
" C = max(1, int(np.round(pid_controller(shrinkage(error_sum / subsample)))))\n",
" plant.request_server(t, C)\n",
" print(f'{t:4}', error_sum / subsample, '-->', C,'<--', shrinkage(error_sum / subsample))\n",
" error_sum = 0"
]
}
],
"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.6.8"
}
},
"nbformat": 4,
"nbformat_minor": 2
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment