UNPKG

raptor-journey-planner

Version:

Implementation of the Round bAsed Public Transit Optimized Router (Raptor) journey planning algorithm.

55 lines (54 loc) 2.63 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const GTFSLoader_1 = require("../src/gtfs/GTFSLoader"); const JourneyFactory_1 = require("../src/results/JourneyFactory"); const fs = require("fs"); const RaptorAlgorithmFactory_1 = require("../src/raptor/RaptorAlgorithmFactory"); const MultipleCriteriaFilter_1 = require("../src/results/filter/MultipleCriteriaFilter"); const GroupStationDepartAfterQuery_1 = require("../src/query/GroupStationDepartAfterQuery"); async function run() { const filename = process.argv[2] || "/home/linus/Downloads/gb-rail-latest.zip"; console.log("Loading " + filename); console.time("initial load"); const stream = fs.createReadStream(filename); const [trips, transfers, interchange] = await (0, GTFSLoader_1.loadGTFS)(stream); console.timeEnd("initial load"); console.time("pre-processing"); const raptor = RaptorAlgorithmFactory_1.RaptorAlgorithmFactory.create(trips, transfers, interchange); const query = new GroupStationDepartAfterQuery_1.GroupStationDepartAfterQuery(raptor, new JourneyFactory_1.JourneyFactory(), 3, [new MultipleCriteriaFilter_1.MultipleCriteriaFilter()]); console.timeEnd("pre-processing"); // for (let i = 0; i < 15; i++) { // console.time("planning"); // const o = process.argv[3] ? [process.argv[3]] : ["BHM", "BMO", "BSW", "BHI"]; // const d = process.argv[4] ? [process.argv[4]] : ["MCO", "MAN", "MCV", "EXD"]; // query.plan(o, d, new Date(), 10 * 60 * 60); // console.timeEnd("planning"); // } const origins = process.argv[3] ? [process.argv[3]] : ["NUN"]; const destinations = process.argv[4] ? [process.argv[4]] : ["LIV"]; const results = query.plan(origins, destinations, new Date(), 7.5 * 60 * 60); console.log("Results:"); results.map(journeyToString).forEach(s => console.log(s)); console.log(`Memory usage: ${Math.round((process.memoryUsage().heapUsed / 1024 / 1024) * 100) / 100} MB`); } function journeyToString(j) { return toTime(j.departureTime) + ", " + toTime(j.arrivalTime) + ", " + [j.legs[0].origin, ...j.legs.map(l => l.destination)].join("-"); } function toTime(time) { let hours = Math.floor(time / 3600); let minutes = Math.floor((time - (hours * 3600)) / 60); let seconds = time - (hours * 3600) - (minutes * 60); if (hours < 10) { hours = "0" + hours; } if (minutes < 10) { minutes = "0" + minutes; } if (seconds < 10) { seconds = "0" + seconds; } return hours + ":" + minutes + ":" + seconds; } run().catch(e => console.error(e));