--- layout: doc_page --- # Aggregations Aggregations are specifications of processing over metrics available in Druid. Available aggregations are: ### Count aggregator `count` computes the row count that match the filters ```json { "type" : "count", "name" : } ``` ### Sum aggregators #### `longSum` aggregator computes the sum of values as a 64-bit, signed integer ```json { "type" : "longSum", "name" : , "fieldName" : } ``` `name` – output name for the summed value `fieldName` – name of the metric column to sum over #### `doubleSum` aggregator Computes the sum of values as 64-bit floating point value. Similar to `longSum` ```json { "type" : "doubleSum", "name" : , "fieldName" : } ``` ### Min / Max aggregators #### `min` aggregator `min` computes the minimum metric value ```json { "type" : "min", "name" : , "fieldName" : } ``` #### `max` aggregator `max` computes the maximum metric value ```json { "type" : "max", "name" : , "fieldName" : } ``` ### JavaScript aggregator Computes an arbitrary JavaScript function over a set of columns (both metrics and dimensions). All JavaScript functions must return numerical values. ```json { "type": "javascript", "name": "", "fieldNames" : [ , , ... ], "fnAggregate" : "function(current, column1, column2, ...) { return }", "fnCombine" : "function(partialA, partialB) { return ; }", "fnReset" : "function() { return ; }" } ``` **Example** ```json { "type": "javascript", "name": "sum(log(x)/y) + 10", "fieldNames": ["x", "y"], "fnAggregate" : "function(current, a, b) { return current + (Math.log(a) * b); }", "fnCombine" : "function(partialA, partialB) { return partialA + partialB; }", "fnReset" : "function() { return 10; }" } ``` ### Complex aggregators #### `hyperUnique` aggregator `hyperUnique` uses [Hyperloglog](http://algo.inria.fr/flajolet/Publications/FlFuGaMe07.pdf) to compute the estimated cardinality of a dimension. ```json { "type" : "hyperUnique", "name" : , "fieldName" : } ```