State:
-
basic csa without footpaths is functional
-
timespan csa without footpaths is functional
-
merger that combines different streams of connections is functional
The Connection Scan Algorithm (CSA) for Javascript takes a stream of "connections" and transforms it into a stream of solutions to get from a certain stop to a certain stop. The algorithm will find the earliest arrival times first, and will return alternatives as long as the stream runs.
You can install the library using npm:
npm install csa
And include it in your nodejs application
var csa = require('csa');
var planner = new csa.BasicCSA({departureStop: "...", arrivalStop: "...",departureTime:new Date()});
connectionsReadStream.pipe(planner);
planner.on("result", function (result) {
console.log("Path found:",result);
connectionsReadStream.close();
});
planner.on("data", function (connection) {
//Access to a minimum spanning tree of connections being built up
//May be useful for e.g., creating isochrone maps
});
Instead of using one stream of connections, you can combine multiple streams as input by using MergeStream
var connectionsStreams = [
[ 'stream1', connectionsReadStream1 ],
[ 'stream2', connectionsReadStream2 ],
...
];
var connectionsReadStream = new csa.MergeStream(connectionsStreams, query.departureTime);
You can add streams by setting an eventlistener on the MergeStream instance. To remove a stream, just end the stream itself.
connectionsReadStream.on("data", function (connection) {
connectionsReadStream.addConnectionsStream('newStream', newConnectionsReadStream);
});
An expansion on basic csa is timespan csa, this creates an array of minimum spanning trees to create every possible route from a depart to destination within a certain departure timespan. (starting at departureTime to latestDepartTime)
var csa = require('csa');
var planner = new csa.TimespanCSA({
"departureStop": "...",
"arrivalStop": "...",
"departureTime": new Date(),
"latestDepartTime": new Date(new Date().valueOf() + 720000),
"minimumTransferTime": 6 * 60
});
connectionsReadStream.pipe(planner);
planner.on("result", function (result) {
// This gets emitted for every found route
console.log("Path found:",result);
connectionsReadStream.close();
});
planner.on("data", function (connection) {
// Access to a minimum spanning tree of connections being built up
// May be useful for e.g., creating isochrone maps
});
To specify the minimum transfer time you should add the ''minimumTransferTime'' argument to the query:
var query = {
"arrivalStop":"..." ,
"departureStop": "...",
"departureTime": "...",
"minimumTransferTime": ...
}
var planner = new csa.BasicCSA(query);
To specify transfer times depending on the stops of the transfers you should create a transfer time fetcher:
//Define a class
var transferTimesFetcher = function() {};
//Define the get function
transferTimesFetcher.get = function (previousConnection, connection) {
return new Promise(function (fulfill) {
var transferTime = ...
fulfill(transferTime)
});
};
var planner = new csa.BasicCSA(query,transferTimesFetcher);
Protip: you can use browserify on this repo to use CSA in the browser