用dc.js / crossfilter绘制平均值

我有这样的一些数据

[
    {type:"a", series:[0.1, 0.2, 0.2, 0.1, -0.1]},
    {type:"b", series:[0.3, 0.4, 0.5, 0.6, 0.7]},
]

有一个维度的类型,然后我正在做一个组,并平均每个类型的每个系列。

有没有一种很好的方式来绘制每种类型的平均系列? 很显然,我希望它可以使用任何新的过滤器进行更新。

我尝试将数据展平

[
    {type:"a", index:0, value:0.1},
    {type:"a", index:1, value:0.2},
    ...
]

并使索引成为一个维度。 但是当我添加更多数据时,它会变得有点慢; 我从不过滤索引维度,因此将其添加到交叉过滤器只是额外的成本; 最后它会为每种类型弄虚作假。


尝试这个:

var group = typeDimension.group().reduce(reduceAdd, reduceRemove, reduceInitial);

function reduceAdd(p, v) {
    ++p.count
    p.sum += calculateAverage(v['series']);
    p.avg = p.sum / p.count;
    return p;
}

function reduceRemove(p, v) {
    --p.count
    p.sum -= calculateAverage(v['series']);
    p.avg = p.sum / p.count;
    return p;
}

function reduceInitial() {
    return {count: 0, sum: 0, avg: 0};
}

function calculateAverage(numbers) {
    var sum = 0;
    number.forEach(function(num) {
        sum += num;
    });
    return sum / numbers.length;
}
链接地址: http://www.djcxy.com/p/32713.html

上一篇: Plotting averages with dc.js / crossfilter

下一篇: series line chart in dc.js