Hi Jay,<div><br></div><div>First of all I want to say welcome to the community and that it&#39;s great you want to join development of pgRouting!</div><div>To others on the list I want to say, that Jay contacted me already a few weeks ago asking for the possibility and conditions to participate in GSoC 2011 and do some contribution to pgRouting. I really appreciate that Jay contacted us so much in advance and I&#39;m glad that he wants to bring in his skills and contribute to the project.</div>

<div><br></div><div>Well, Anton knows a lot better about the internals how pgRouting works. My comments won&#39;t be very technical.</div><div>I mostly follow the discussion with interest and just wanted to add a few remarks:</div>

<div><br></div><div>Distance matrix:</div><div><br></div><div>I think the current problem is, that for calculating a distance matrix you would make a huge amount of single pgRouting shortest path queries. Each of these queries would involve to select a bounding box, load the data and find the shortest path. That is not very efficient and takes too much time for many points. Maybe it doesn&#39;t need to be a second per query but still too slow.</div>

<div>With APSP you would just make one bounding box select and load the data to memory once, where you do then the calculation of all paths you need. This should be a lot faster, right? And it would also ensure that all paths are calculated based on the same road network status at a the time of the select by the way. </div>

<div><br></div><div>TSP</div><div><br></div><div>TSP currently doesn&#39;t calculate a matrix with real distances, but APSP would make this possible then.</div><div>The new DARP solver takes as a third parameter a distance matrix, so it would be another function that would have a huge benefit from a APSP function. I think TSP could be rewritten in a similar way as DARP to be able to chose the way you want to calculate the distance matrix.</div>

<div><br></div><div>I think in general we also need to talk about</div><div><ul><li>which parameters we want to pass to the APSP function</li><li>how the result of the function should look like</li></ul><div>pgRouting&#39;s speciality is that you can make SQL statements be a parameter and also can later post-process your result in a SQL query. </div>

</div><div>Anton, this is probably the part someone new to PostgreSQL/PostGIS/pgRouting needs some advice.</div><div><br></div><div>Hope this makes sense.</div><div><br></div><div>Daniel</div><div><br></div><div><br></div>

<div><br><br><div class="gmail_quote">2010/12/2 Stephen Woodbridge <span dir="ltr">&lt;<a href="mailto:woodbri@swoodbridge.com">woodbri@swoodbridge.com</a>&gt;</span><br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">

Jay,<br>
<br>
Sounds like you have a good handle on all the pieces to this problem.<br>
What do you need to get started :)<br>
<br>
-Steve<div><div></div><div class="h5"><br>
<br>
On 12/1/2010 6:21 PM, Jay Mahadeokar wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
When (v^2 log n) &gt; n^2 we can use Warshall algo. Extracting paths will<br>
<br>
        be complicated task.<br>
<br>
            I think some thought needs to go into:<br>
<br>
            1. what are the results? just a V^2 table of costs?<br>
<br>
            2. can we extract the paths? In pgRouting, this has some<br>
        additional<br>
            implications beyond is it physically possible to extract<br>
        paths from<br>
            the algorithm.<br>
              a. typically queries do not store results, they only<br>
        return sets<br>
              b. extracting paths, implies computing assembling a graph,<br>
            computing the results and holding the results for additional<br>
        queries<br>
            against them to extract paths.<br>
              c. while this is potentially possible using temp tables,<br>
        we do not<br>
            currently do that<br>
<br>
<br>
        I did not properly understand point b above.<br>
<br>
<br>
    OK, I will try to explain. Typically the process of running a<br>
    pgRouting query follows something along this pseudo code:<br>
<br>
    1. select a subset of all node that we think will be enough to solve<br>
    our problem. This is done via a bounding box of the start and end<br>
    nodes inw question and expanded somewhat in case the route wanders<br>
    out of the bounding box.<br>
<br>
    2. these nodes and the edges connected to them are built into a<br>
    boost graph<br>
<br>
    3. the boost graph is solved<br>
<br>
    4. the results are return to the SQL caller as a set of database<br>
    records.<br>
<br>
    5. the boost graph is destroyed<br>
<br>
    So basically one input, one process, one output. Nothing is saved.<br>
    If on the other hand we had a process like:<br>
<br>
    1. build graph<br>
    2. solve graph<br>
    3. return matrix of distances<br>
    4. hold onto graph because these might be addition requests the need<br>
    the matrix<br>
    5. request path A-B from graph<br>
    6. request path D-H from graph<br>
    7. request ...<br>
    8. we are done with the graph so destroy it<br>
<br>
    Which is my assumption that we would need to do to extract paths,<br>
    then we do not have a paradigm for this in SQL.<br>
<br>
    Now we may not need to do that, but I was assuming that there was<br>
    information in the graph that was easy to extract about the paths<br>
    that gave the distance returned in the distance matrix.<br>
<br>
<br>
<br>
Hey.. Again, during  step 3 above, if we build the path matrix along<br>
with the distance matrix for Warshall Algo, we can use that to extract<br>
all paths, we will not need any more queries to database. We also need<br>
not hold on to the graph! And the overall time is still O(n^3)  :)<br>
<br>
<br>
<br>
        I am not sure if the boost implementation of Warshall returns a path<br>
        matrix,<br>
        <a href="http://www.boost.org/doc/libs/1_45_0/libs/graph/doc/floyd_warshall_shortest.html" target="_blank">http://www.boost.org/doc/libs/1_45_0/libs/graph/doc/floyd_warshall_shortest.html</a><br>
        says that it will just return the distance matrix.<br>
<br>
        In theory, we can simultaneously create a n^2 path matrix along<br>
        with the<br>
        distance matrix and use that to extract paths. Pseudo code is<br>
        present<br>
        here:<br>
        <a href="http://en.wikipedia.org/wiki/Floyd%E2%80%93Warshall_algorithm" target="_blank">http://en.wikipedia.org/wiki/Floyd%E2%80%93Warshall_algorithm</a>. So,<br>
        if we want to build the path matrix, we need to code Warshall from<br>
        scratch, using maybe boost data structures.<br>
<br>
<br>
    I guess this is up to the use cases for this and maybe we should ask<br>
    others to chime in based on their needs.<br>
<br>
    I think this really depends on the number of nodes that a user needs<br>
    to work with. If you assume asymmetric directed graph, the you need<br>
    to compute n^2 distances. for small say n&lt;20 that is 400 routes and<br>
    if at 1 sec per route it takes 6.67 minutes; n=100 it takes about<br>
    2.78 hours.<br>
<br>
<br>
I guess assuming 1 sec per route is too slow for modern processors! If<br>
you are including the database query latency, then again Path Matrix<br>
will make sure we need to query database only once, so the rest of the<br>
work should be fast.<br>
<br>
    My use case would be to feed the results into TSP solver to order<br>
    the nodes, then to extract the routes between the ordered nodes. I<br>
    have used simulated annealing to solve TSP very fast.<br>
<br>
    <a href="http://imaptools.com/cgi-bin/tsp.cgi" target="_blank">http://imaptools.com/cgi-bin/tsp.cgi</a><br>
<br>
    Copy and paste the cities into the text area and compute the TSP.<br>
    This demo application geocodes all the cities and comput the<br>
    straight line distance between them and then solves the TSP problem.<br>
    It would really be grate to compute the network paths before solving<br>
    the TSP.<br>
<br>
    I know pgRouting has a TSP solver, but it requires the CGAL package<br>
    I think which is hard to find and build on many systems.<br>
<br>
<br>
Nice Application! I am not sure what is complexity of your algorithm.<br>
But if you want to compute actual paths before feeding the algo, I guess<br>
the number of nodes in the path will increase by a big factor which will<br>
slow down APSP significantly. (You may just consider Highways to get<br>
around this, could discuss this on a separate topic!)<br>
<br>
<br>
        If we have vertex ids of whole graph, the path matrix is<br>
        sufficient to<br>
        extract all paths (extracting one path will take O(n) time), and<br>
        I think<br>
        there is no need for additional queries to database.<br>
<br>
<br>
    I saw the path extraction code in the wiki page , but I need to go<br>
    back over it in more detail.<br>
<br>
    Best regards,<br>
      -Steve W<br>
<br>
        Please correct me if I am missing something.<br>
<br>
            Anyway, these are some things to start a discussion and<br>
        provoke some<br>
            thoughts. I do not want to grow the scope of this project to the<br>
            point that it is problematic, so we should focus on what can<br>
        be done<br>
            and plan for future additions if they are needed.<br>
<br>
            I look forward to working with you. Thank you for your<br>
        interest in<br>
            pgRouting.<br>
<br>
            Best regards,<br>
              -Steve W<br>
            _______________________________________________<br>
            pgrouting-dev mailing list<br>
        <a href="mailto:pgrouting-dev@lists.osgeo.org" target="_blank">pgrouting-dev@lists.osgeo.org</a><br>
        &lt;mailto:<a href="mailto:pgrouting-dev@lists.osgeo.org" target="_blank">pgrouting-dev@lists.osgeo.org</a>&gt;<br>
        &lt;mailto:<a href="mailto:pgrouting-dev@lists.osgeo.org" target="_blank">pgrouting-dev@lists.osgeo.org</a><br>
        &lt;mailto:<a href="mailto:pgrouting-dev@lists.osgeo.org" target="_blank">pgrouting-dev@lists.osgeo.org</a>&gt;&gt;<br>
<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> &lt;mailto:<a href="mailto:pgrouting-dev@lists.osgeo.org" target="_blank">pgrouting-dev@lists.osgeo.org</a>&gt;<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>
    <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;<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>
</blockquote>
<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><span style="font-family:arial, sans-serif;font-size:13px;border-collapse:collapse">Georepublic UG &amp; Georepublic Japan<br>eMail: <a href="mailto:daniel.kastl@georepublic.de" style="color:rgb(66, 99, 171)" target="_blank">daniel.kastl@georepublic.de</a><br>

Web: <a href="http://georepublic.de/" style="color:rgb(66, 99, 171)" target="_blank">http://georepublic.de</a></span><br>
</div>