Add Kibana visualizations examples for NDR result
[nfvbench.git] / kibana / visualizations / ndr_capacity_gbps_line_chart.json
diff --git a/kibana/visualizations/ndr_capacity_gbps_line_chart.json b/kibana/visualizations/ndr_capacity_gbps_line_chart.json
new file mode 100644 (file)
index 0000000..cb696ba
--- /dev/null
@@ -0,0 +1,95 @@
+{
+  $schema: https: //vega.github.io/schema/vega-lite/v2.json
+  title: "Capacity in Gbps - 0,001% loss ratio"
+  data: {
+    url: {
+      %context%: true
+      %timefield%: "@timestamp"
+      index: resu*
+      body: {
+        _source: ["@timestamp", "_source", "offered_tx_rate_bps", "flow_count", "frame_size", "user_label"]
+      },
+      size: 10000
+    },
+    format: { property: "hits.hits" }
+  },
+  transform: [
+        { calculate: "datum._source['offered_tx_rate_bps'] / 1000000000" as: "offered_load_gbps"},
+        { calculate: "datum._source['flow_count']" as: "flow_count"},
+        { calculate: "isNaN(toNumber(datum._source['frame_size'])) ? 362 : toNumber(datum._source['frame_size'])" as: "frame_size"},
+        { calculate: "datum._source['user_label'] + '-' + datum._source['flow_count']" as: "label"}
+        { aggregate: [{op: "max", field: "offered_load_gbps", as: "max_offered_load_gbps"}], groupby: ["frame_size", "label","flow_count"]}
+  ],
+  center: true,
+  hconcat: [
+    {
+      width:10,
+      selection: {
+        legendSel: {
+          type: "multi",
+          encodings: [ "color", "shape" ],
+          toggle: "event.shiftKey"
+        }
+      },
+      encoding: {
+        y: {
+          field: "label",
+          type: "nominal",
+          axis: {
+            title: "",
+            domain: false,
+            ticks: false,
+            offset: 10
+          },
+        },
+        color: {
+          condition: {
+            selection: "legendSel",
+            field: "label",
+            type: "nominal",
+            legend: null
+          },
+          value: "lightgrey"
+        }
+      },
+      mark: {
+        type: "square",
+        size: 120,
+        opacity: 1
+      }
+    },
+    {
+      width:500,
+      height:280,
+      transform: [
+        {filter: { selection: "legendSel"}}
+      ],
+      mark: {
+        type: "line",
+        tooltip: true,
+        point: true
+      },
+      selection: {
+          grid: {
+            type: "interval",
+            resolve: "global",
+            bind: "scales",
+            translate: "[mousedown[!event.shiftKey], window:mouseup] > window:mousemove!",
+            zoom: "wheel![!event.shiftKey]"
+          },
+          pts: {
+            type: "single",
+            fields: ["label"]
+          }
+      },
+      encoding: {
+        x: { field: "frame_size", type: "quantitative", title: "Frame size (bytes)", axis: {offset: 10} }
+        y: { field: "max_offered_load_gbps", type: "quantitative", title: "Offered load (Gbps)" , axis: {offset: 10}  }
+        color: {field: "label", "type": "nominal",
+              "legend": null}
+       shape: {field: "flow_count", type: "nominal"}
+        tooltip: {"field": "max_offered_load_gbps", "type": "quantitative"}
+      }
+    }
+  ]
+}
\ No newline at end of file