From a02c011790ac94e2195f0337a3d8cb3599e1b6d9 Mon Sep 17 00:00:00 2001 From: Vinson Chuong Date: Thu, 12 Dec 2019 15:42:16 -0800 Subject: [PATCH] fix(join): Make join robust against time series with different times --- time-series/join/index.js | 23 ++++++++++++++++--- time-series/join/index.test.js | 20 ++++++++-------- time-series/merge/index.js | 2 +- .../{merge => }/tournament-tree/index.js | 0 .../{merge => }/tournament-tree/initialize.js | 0 .../{merge => }/tournament-tree/next.js | 0 .../tournament-tree/tournament-tree.js | 0 7 files changed, 32 insertions(+), 13 deletions(-) rename time-series/{merge => }/tournament-tree/index.js (100%) rename time-series/{merge => }/tournament-tree/initialize.js (100%) rename time-series/{merge => }/tournament-tree/next.js (100%) rename time-series/{merge => }/tournament-tree/tournament-tree.js (100%) diff --git a/time-series/join/index.js b/time-series/join/index.js index 3aa8482..4aff5df 100644 --- a/time-series/join/index.js +++ b/time-series/join/index.js @@ -1,5 +1,6 @@ /* @flow */ import type { TimeSeries, TimeSeriesPoint } from 'ikeru/time-series' +import { initialize, next } from '../tournament-tree' export default function( timeSeriesList: Array>, @@ -9,7 +10,23 @@ export default function( return [] } - return timeSeriesList[0].map(({ time }, i) => - combine(time.valueOf(), timeSeriesList.map(timeSeries => timeSeries[i])) - ) + const getTime = item => item.time + + let tournamentTree = initialize(timeSeriesList, getTime) + const groups = [] + let currentGroup = [] + + while (tournamentTree.value) { + if (currentGroup[0] && tournamentTree.value.time !== currentGroup[0].time) { + groups.push(currentGroup) + currentGroup = [] + } + + currentGroup.push(tournamentTree.value) + tournamentTree = next(tournamentTree, getTime) + } + + groups.push(currentGroup) + + return groups.map(group => combine(group[0].time.valueOf(), group)) } diff --git a/time-series/join/index.test.js b/time-series/join/index.test.js index e53bdda..5d2e51c 100644 --- a/time-series/join/index.test.js +++ b/time-series/join/index.test.js @@ -1,29 +1,31 @@ /* @flow */ import test from 'ava' +import { sumBy } from 'lodash' import { join } from 'ikeru/time-series' test('combining multiple time series by time', t => { const series1 = [ { time: Date.parse('2019-01-01'), value: 1 }, { time: Date.parse('2019-01-02'), value: 2 }, - { time: Date.parse('2019-01-03'), value: 3 } + { time: Date.parse('2019-01-03'), value: 3 }, + { time: Date.parse('2019-01-04'), value: 4 } ] const series2 = [ - { time: Date.parse('2019-01-01'), value: 4 }, - { time: Date.parse('2019-01-02'), value: 5 }, - { time: Date.parse('2019-01-03'), value: 6 } + { time: Date.parse('2019-01-02'), value: 2 }, + { time: Date.parse('2019-01-03'), value: 3 } ] t.deepEqual( - join([series1, series2], (time, [p1, p2]) => ({ + join([series1, series2], (time, points) => ({ time, - value: p1.value + p2.value + value: sumBy(points, 'value') })), [ - { time: Date.parse('2019-01-01'), value: 5 }, - { time: Date.parse('2019-01-02'), value: 7 }, - { time: Date.parse('2019-01-03'), value: 9 } + { time: Date.parse('2019-01-01'), value: 1 }, + { time: Date.parse('2019-01-02'), value: 4 }, + { time: Date.parse('2019-01-03'), value: 6 }, + { time: Date.parse('2019-01-04'), value: 4 } ] ) }) diff --git a/time-series/merge/index.js b/time-series/merge/index.js index 6014188..37f02df 100644 --- a/time-series/merge/index.js +++ b/time-series/merge/index.js @@ -1,6 +1,6 @@ /* @flow */ import type { TimeSeries } from 'ikeru/time-series' -import { initialize, next } from './tournament-tree' +import { initialize, next } from '../tournament-tree' export default function( ...timeSeriesList: Array> diff --git a/time-series/merge/tournament-tree/index.js b/time-series/tournament-tree/index.js similarity index 100% rename from time-series/merge/tournament-tree/index.js rename to time-series/tournament-tree/index.js diff --git a/time-series/merge/tournament-tree/initialize.js b/time-series/tournament-tree/initialize.js similarity index 100% rename from time-series/merge/tournament-tree/initialize.js rename to time-series/tournament-tree/initialize.js diff --git a/time-series/merge/tournament-tree/next.js b/time-series/tournament-tree/next.js similarity index 100% rename from time-series/merge/tournament-tree/next.js rename to time-series/tournament-tree/next.js diff --git a/time-series/merge/tournament-tree/tournament-tree.js b/time-series/tournament-tree/tournament-tree.js similarity index 100% rename from time-series/merge/tournament-tree/tournament-tree.js rename to time-series/tournament-tree/tournament-tree.js