Hi. Im new here. Im also new to python.
I had an idea to try and make a peice of art that was a TFL poster with addressable LEDs for each station.
When a train is less than 25 seconds from a station it lights the LED in the correct colour for the line. It’s a thing of beauty and i have enjoyed creating it.
However… every line works, aprart from the DLR. If i say time to staion is less than 59 seconds, no LEDs light (pretty much, somtimes one comes on every 10 mins…). If i say 60 seconds, it works, but inevitably most are lit as most stations will have a train due on one platform or the other in 60 seconds.
Is there somthing about the arrivals api for the dlr that is different? It works for all tube lines and overground and trams.
The output - which is always at GMT by the way (they end in Z) - has a slightly different way of working from the tube data.
For each train it shows up multiple times.
You can spot the arrivals by using the “naptanId”: “940GZZDLCGT” and “expectedArrival”: “2024-03-29T07:24:43Z”
You can use these to work out the arrivals time for the upcoming trains. You don’t need to keep calling because the expectedArrival times don’t change that much - the DLR is driven by computers not humans - so you can work out your own “timeToStation”: 762 values and flash them when they would be within your 25 seconds.
Of course the DLR many trains at the node stations (Poplar, Canary Wharf, Canning Town and Stratford) so you might, in peak, have lights that flash all the time).
Of course, the DLR info, like all TfL info is ARRIVALS and not departures but you can see the starting points in the above link.
So, basically consume the above API every minute and then work from there.
The program then looks at the “timeToStation” data, displayed in seconds. If the timeToStation < 25 seconds, the relevant LED lights up.
If you call the dlr api and do a quick search for ’ “timeToStation”:30 ’ or 29, or 28… or 3 or 2 or 1 you will never* see a result.
*Very very rarely, like once every 10 mins, but the reality is DLR trains arrive and leave more frequently, I think the api data is not returning.
On all the other lines (including overground and trams), you will have maybe 5 results where timeToStation is less than 25s. But the dlr never* returns this.
My question was, why is this?
Is there somthing different about the DLR data?
The DLR data comes from a different source so it could well be different.
My guess would be it’s something to do with the refresh rate and resolution of the predictions.
Knowing ‘why’ isn’t going to help you in any case so you’re best bet is to look at Brian’s suggestion; that is, use the most recent value of expectedArrival and compare that to the current time. When the difference becomes less that 30s bingo.
The expectedArrival prediction can be assumed to be valid until the timeToLive has expired or a new prediction arrives.
Rather more complicated programming but it should work I think.
I wanted to advise on how we get DLR predictions from the source systems and the limitations on these.
We currently take a feed called Daisy, which is essentially the data the powers the station boards. i.e. this is the departure prediction in minutes for each platform at each station. We then try to calculate the time of the prediction and convert that value (1 MIN, 3 MIN) into our prediction model.
There’s no data currently available that shows vehicle details (vehicle ID, track positions etc.).
There is a desire within TfL to get better data out of the DLR signalling system, not only to benefit the richness or our data available for our own products and open data consumers, but also management information for DLR performance.
This is quiet early days, so I can’t give any real detail, but hopefully this will improve in the future.