Hi,<br><br>As initially discussed, I was trying to reuse the boost&#39;s dijkstra code to write the core time dependent dijkstra algorithm. <br>Since Boost makes extensive use of generic programming, and I have no prior experience with such deep generic programming concepts, I was wondering if we really need all these features that boost provides.<br>
<br>Another option would be to write the time-dependent dijkstra on our own. <br><br>This will be a light-weight code without extensive use of generic programming like boost.<br>So, i was thinking of using following:<br><br>
<b>1. </b>Boost::AdjecencyList - for storing graph.<br><b>2. </b>Std::Map - for storing distanceMap, predecessorMap.<br><br><b>3. </b>For weightMap:<br><br>typedef struct weight_map_element<br>{<br>        pair&lt;int,double&gt; edge;<br>
        double travel_time;<br>} <br>weight_map_element_t;<br><br>class weight_map<br>{<br>    <br>    vector&lt;weight_map_element_t&gt; weight_map_set;<br>        <br>    public:<br>    void insert(weight_map_element_t element);<br>
    double get_travel_time(int edge_id, double start_time);<br><br>};<br><br><br><b>4. </b>std::priority_queue  for the priority queue that will be used for dijkstra search.<br><br><br>Will this be sufficient for our implementation?  If yes, I will come up with the detailed internal function prototypes soon.<br>
<br><br><div class="gmail_quote">On Wed, May 18, 2011 at 8:09 PM, Stephen Woodbridge <span dir="ltr">&lt;<a href="mailto:woodbri@swoodbridge.com">woodbri@swoodbridge.com</a>&gt;</span> wrote:<br><blockquote class="gmail_quote" style="margin: 0pt 0pt 0pt 0.8ex; border-left: 1px solid rgb(204, 204, 204); padding-left: 1ex;">
<div><div></div><div class="h5">On 5/18/2011 8:08 AM, Jay Mahadeokar wrote:<br>
<blockquote class="gmail_quote" style="margin: 0pt 0pt 0pt 0.8ex; border-left: 1px solid rgb(204, 204, 204); padding-left: 1ex;">
Hi,<br>
<br>
I think what we need is a function on following lines:<br>
<br>
Given a query_start_time, it should query the TimeDepCosts table, and<br>
return the set of entries which have their start_time within<br>
query_start_time + delta. This delta might be x hours, depending on the<br>
upper bound of the expected journey time.<br>
<br>
We need following things handled in our model:<br>
<br>
If query_start_time is 11PM Sunday and delta is 10 hours, we will need<br>
to query entries with start time between 11PM Sunday and 9AM Monday. So,<br>
basically the function needs to be periodic in terms of time_of_day and<br>
day_of_week.<br>
<br>
As Steve suggested, we can maintain conventions for day_of_week like:<br>
<br>
-3   - holidays<br>
-2   - weekend days<br>
-1   - week days<br>
0    - all days<br>
1-7 Mon - Sun.<br>
<br>
If we just assume entries for -3,-2,-1,0 and ignore each entry for Sun -<br>
Sat, that would reduce the space required assuming that the entries for<br>
weekdays is same. If times for different weekdays is different then we<br>
would have separate entries for each day.<br>
<br>
So, the query should properly examine the query_day_of_week and select<br>
the proper entries. Ex: For above query, if it is sunday, then after<br>
12AM, next entries will be queried with time_of_day as -1, but if it was<br>
Saturday, next entries will be queried with time_of_day as -2.<br>
<br>
We can have a boolean parameter like *isHoliday* in query itself, which<br>
will tell if a given day (may be weekday) is holiday or not.Then again<br>
the query will have to be modified accordingly (query for -3). This will<br>
take care of query for local holiday etc and we do not have to worry<br>
about calenders. The user will have to worry about that.. :-)<br>
</blockquote>
<br></div></div>
This (isHoliday) might work for a single day, but will not work if the query crosses into the next day(s). Holidays are an input convenience to describe recurring events. So say we have a convenient way to input that data and store it into tables as we have described, then the query for costs would need to decide is a given day is a holiday or not and then select the correct entries to return based on that. For ease of implementation, we could just start with a stub function the returns false and later implement a table lookup based on the date or day of year that determines if isHoliday=t/f for any given start_time+offset.<br>

<br>
Then when querying schedules, for example, we would select holiday schedules if they exist and its a holiday otherwise search the regular tables.<div class="im"><br>
<br>
<blockquote class="gmail_quote" style="margin: 0pt 0pt 0pt 0.8ex; border-left: 1px solid rgb(204, 204, 204); padding-left: 1ex;">
There can be time_from and time_to entries as well. But, if we just have<br>
entries like:<br>
<br>
  day_of_week: -1, time_of_day: 00:01, 55mph<br>
  day_of_week: -1, time_of_day: 07:00, 30mph<br>
  day_of_week: -1, time_of_day: 10:01, 55mph<br>
  day_of_week: -1, time_of_day: 16:31, 30mph<br>
<br>
we can assume that the entry with time_of_day 00:01 is valid upto<br>
07:00.  And if query_start_time is 02:00 and delta is 10 hours, we can<br>
query entries which have time_of_day &lt; query_start_time + delta (taking<br>
care of change of day).<br>
<br>
Is this assumption reasonable?<br>
</blockquote>
<br></div>
This sounds reasonable if the response is in units of time (offset) from query_start_time. Assuming we use a resolution of seconds, then the response would be in seconds from start time.<br>
<br>
<blockquote class="gmail_quote" style="margin: 0pt 0pt 0pt 0.8ex; border-left: 1px solid rgb(204, 204, 204); padding-left: 1ex;">
*weightMap Abstraction*<div class="im"><br>
<br>
I think the design would be more modular if we keep the weightMap<br>
independent of the underlying time conventions. Since as Daniel pointed<br>
out, this algorithm can also be used for non-road networks.<br>
<br>
So, whatever the underlying time conventions, we can assume that in the<br>
end the query should return pairs like:<br>
<br>
&lt; &lt;edgeId, offset_time&gt; , travel_time/speed &gt;<br>
<br>
We will assume that query_start_time is 0, i.e we offset every thing by<br>
query_start_time.<br>
The offset_time will be as follows:<br>
<br>
As in above example,<br>
If start_tme is 02:00 and day_of_week is -1, and delta as 10 hours.<br>
<br>
Then, edge entries for edgeId 1 will be:<br>
&lt; &lt;1, 05:00 &gt; , 30 mph&gt;<br>
&lt; &lt;1, 08:01 &gt; , 55 mph&gt;<br>
&lt; &lt;1, 14:31 &gt; , 30 mph&gt;<br>
<br>
Basically, the offset_time will abstract out any internal details of<br>
weekdays, change of days etc and it will just contain the offset from<br>
start_time.<br>
</div></blockquote>
<br>
I suggested seconds above, but if someone is modeling events in say glacier flow, geological times or the big bang, they might need other units of time. I would say that because we are talking about time based schedules and need to deal with days, hours minutes we should probably not worry about these other timeframes as the solver will be offset based it will work with any units and then only the wrappers for extracting the costs from the schedules would need to change to deal with other timeframes. So lets not get hung up on this, I think this is a sound plan.<br>

<br>
-Steve<br>
<br>
<blockquote class="gmail_quote" style="margin: 0pt 0pt 0pt 0.8ex; border-left: 1px solid rgb(204, 204, 204); padding-left: 1ex;"><div class="im">
This will greatly simplify the core time dependent dijkstra implementation.<br>
<br>
Thoughts?<br>
<br>
On Wed, May 18, 2011 at 10:46 AM, Stephen Woodbridge<br></div><div><div></div><div class="h5">
&lt;<a href="mailto:woodbri@swoodbridge.com" target="_blank">woodbri@swoodbridge.com</a> &lt;mailto:<a href="mailto:woodbri@swoodbridge.com" target="_blank">woodbri@swoodbridge.com</a>&gt;&gt; wrote:<br>
<br>
    Hi Daniel,<br>
<br>
    These are good points.<br>
<br>
    I agree that turn restrictions should be thought about but only<br>
    implemented if there is time. I think we should take the discussion<br>
    of turn restriction into a separate thread. I&#39;m interested in what<br>
    you think is a limitation that can&#39;t be modeled in Dijkstra or A*.<br>
<br>
    Regarding the time modeling, my point was just that we needed more<br>
    thought there and a richer model developed. The crontab model is a<br>
    good idea. I&#39;m not opposed to modeling monthly or yearly events, but<br>
    they rarely exist other than holidays which I tried to capture. I<br>
    suppose you could model something like the Boston Marathon and model<br>
    all the road closures and restrictions, but it seems to be a lot of<br>
    work for a one day event, but I can see city government&#39;s deploying<br>
    the resources to model something like this.<br>
<br>
    Regarding timezones: Times need to be entered with zones for models<br>
    that cross zones but all the data should be converted to UTC<br>
    internally so it runs in a consistent time model. Timezones are for<br>
    input and output, but the solver should be ignorant of them, in my<br>
    opinion.<br>
<br>
    I have carried my GPS from the Eastern to central time zone, and it<br>
    knew the local time when I powered it up. So my guess is that it<br>
    would auto correct when crossing the time zone.<br>
<br>
    -Steve<br>
<br>
<br>
    On 5/17/2011 10:42 PM, Daniel Kastl wrote:<br>
<br>
        Hi Jay and Steve,<br>
<br>
        This looks really nice, but let me give some comments regarding<br>
        how to<br>
        model time, because this is really tricky in my opinion.<br>
        Especially when<br>
        thinking about an abstract network that isn&#39;t a road network.<br>
<br>
<br>
<br>
            Would it be possible to support turn restrictions in the static<br>
            Dijkstra also? I&#39;m thinking just use all the same structures but<br>
            ignore the the time components to keep things simple. So if<br>
        the the<br>
            turn restrictions table is present we use it, otherwise<br>
        assume no<br>
            restrictions. If doing static shortest path with turn<br>
        restrictions<br>
            then ignore the time components otherwise we use them. And<br>
        it is up<br>
            to the user to make sure the turn restriction table is valid<br>
        for the<br>
            analysis being requested.<br>
<br>
<br>
        Currently in pgRouting Dijkstra and A* don&#39;t support turn<br>
        restrictions<br>
        modelling. What I actually like on Shooting Star is, that it<br>
        routes from<br>
        edge to edge instead of node to node. So it allows to model<br>
        relations<br>
        between edges rather than nodes, which I think is more close to how<br>
        humans would think of this.<br>
        Dijkstra can only visit one node one times (as Shooting star<br>
        only visits<br>
        an edge once). Well, there can be turn restriction cases where a<br>
        node is<br>
        passed twice and which can&#39;t be done correctly with Dijkstra as<br>
        far as I<br>
        know.<br>
<br>
        In the beginning I wouldn&#39;t think about the turn restrictions<br>
        too much.<br>
        Let&#39;s take it as an extra when we see we still have enough time.<br>
        Of course if you have a good idea to implement it all at once<br>
        with only<br>
        little extra work, then that&#39;s fine.<br>
<br>
<br>
            For time definitions in your tables I think you need to probably<br>
            define some common structure for handling a time entry.<br>
<br>
<br>
        Another problem might be time zones. Plain day field + time<br>
        field might<br>
        not be able to allow driving from one time zone to another (or just<br>
        think about a flight network). I never went from one timezone to<br>
        another<br>
        by car or train, but Steve and Anton, you might have this<br>
        experience.<br>
        How does car navigation software handle this when you cross the<br>
        timezone<br>
        border? ;-)<br>
<br>
        So taking &quot;timestamp with timezone&quot; for those fields might be a good<br>
        idea to be able to support such a functionality.<br>
<br>
<br>
            For example time_from and time_to might need to be defined as a<br>
            structure that includes day_of_week. day_of week might take<br>
        values like:<br>
<br>
            -3   - holidays<br>
            -2   - weekend days<br>
            -1   - week days<br>
            0    - all days<br>
            1..7 - Sun,...,Sat<br>
<br>
<br>
        I think the problem here is how to model recurring time<br>
        dependent costs,<br>
        right?<br>
        If you think about weekdays, then you can&#39;t for example model<br>
        monthly or<br>
        yearly events.<br>
<br>
        I&#39;m not really sure this is useful information here, but I once saw<br>
        about how the &quot;iCal&quot; format models recurring calendar events:<br>
        <a href="http://ext.ensible.com/deploy/dev/examples/calendar/recurrence-widget.html" target="_blank">http://ext.ensible.com/deploy/dev/examples/calendar/recurrence-widget.html</a><br>
<br>
        Maybe we can learn something from there. The example needed to be<br>
        extended with some duration probably. But looking about calendar<br>
        formats<br>
        might be a good idea to model holidays etc.<br>
<br>
        Or another (stupid) example would be cron job syntax. Something<br>
        I always<br>
        need to google for as I can&#39;t remember it ;-)<br>
<br>
        All this time dependent stuff, events and schedules is also an<br>
        issue in<br>
        Darp solver.<br>
        And it probably is important also for the multi-modal routing,<br>
        so if we<br>
        can find some clever way how to model this and can share it between<br>
        algorihtms, that would be great.<br>
<br>
        Daniel<br>
<br>
<br>
        --<br>
        Georepublic UG &amp; Georepublic Japan<br>
        eMail: <a href="mailto:daniel.kastl@georepublic.de" target="_blank">daniel.kastl@georepublic.de</a><br>
        &lt;mailto:<a href="mailto:daniel.kastl@georepublic.de" target="_blank">daniel.kastl@georepublic.de</a>&gt;<br>
        &lt;mailto:<a href="mailto:daniel.kastl@georepublic.de" target="_blank">daniel.kastl@georepublic.de</a><br>
        &lt;mailto:<a href="mailto:daniel.kastl@georepublic.de" target="_blank">daniel.kastl@georepublic.de</a>&gt;&gt;<br>
        Web: <a href="http://georepublic.de" target="_blank">http://georepublic.de</a> &lt;<a href="http://georepublic.de/" target="_blank">http://georepublic.de/</a>&gt;<br>
<br>
<br>
<br>
<br>
        _______________________________________________<br>
        pgrouting-dev mailing list<br></div></div>
        <a href="mailto:pgrouting-dev@lists.osgeo.org" target="_blank">pgrouting-dev@lists.osgeo.org</a> &lt;mailto:<a href="mailto:pgrouting-dev@lists.osgeo.org" target="_blank">pgrouting-dev@lists.osgeo.org</a>&gt;<div class="im">
<br>
        <a href="http://lists.osgeo.org/mailman/listinfo/pgrouting-dev" target="_blank">http://lists.osgeo.org/mailman/listinfo/pgrouting-dev</a><br>
<br>
<br>
    _______________________________________________<br>
    pgrouting-dev mailing list<br></div>
    <a href="mailto:pgrouting-dev@lists.osgeo.org" target="_blank">pgrouting-dev@lists.osgeo.org</a> &lt;mailto:<a href="mailto:pgrouting-dev@lists.osgeo.org" target="_blank">pgrouting-dev@lists.osgeo.org</a>&gt;<div class="im">
<br>
    <a href="http://lists.osgeo.org/mailman/listinfo/pgrouting-dev" target="_blank">http://lists.osgeo.org/mailman/listinfo/pgrouting-dev</a><br>
<br>
<br>
<br>
<br>
--<br>
Regards,<br>
-Jay Mahadeokar<br>
<br>
<br>
<br>
_______________________________________________<br>
pgrouting-dev mailing list<br>
<a href="mailto:pgrouting-dev@lists.osgeo.org" target="_blank">pgrouting-dev@lists.osgeo.org</a><br>
<a href="http://lists.osgeo.org/mailman/listinfo/pgrouting-dev" target="_blank">http://lists.osgeo.org/mailman/listinfo/pgrouting-dev</a><br>
</div></blockquote><div><div></div><div class="h5">
<br>
_______________________________________________<br>
pgrouting-dev mailing list<br>
<a href="mailto:pgrouting-dev@lists.osgeo.org" target="_blank">pgrouting-dev@lists.osgeo.org</a><br>
<a href="http://lists.osgeo.org/mailman/listinfo/pgrouting-dev" target="_blank">http://lists.osgeo.org/mailman/listinfo/pgrouting-dev</a><br>
</div></div></blockquote></div><br><br clear="all"><br>-- <br>Regards,<br>-Jay Mahadeokar<br><br>