[pgrouting-dev] [pgrouting-users] TRSP Problem

Christophe Damour sigeal at sigeal.com
Fri Mar 7 10:41:45 PST 2014


Hi,

No answer... I am stuck with this one.

Is it possible that there is a conflict between the where clause 
processing and the cost / rev_cost ?

I have the same behaviour with edge start / target instead of vertex 
start / target.

Here is the wrong query result :
seq 	id1 	id2 	cost
0 	19314 	23805 	25.2230680696244
1 	16327 	15869 	200.551744693165
2 	16328 	30606 	1000000
3 	22180 	30607 	12.1375967381755
4 	14374 	28286 	249.361944927019
5 	14371 	18295 	111.604786405456
6 	10776 	-1 	0


In my understanding, it shouldn't be possible to have an edge with cost 
1000000 in the resulting path (it is the only one in the network to have 
such a cost, and the network is very small) !

Thanks for any hint,

-- 
Christophe DAMOUR

Le 03/03/2014 20:20, Christophe Damour a écrit :
> Hi,
>
> Sorry to post twice, I forgot the attached file...
>
> I use pgRouting to calculate accessible routes for disabled pedestrians.
> Network edges have some attributes that are used to filter the 
> accessible network in both ways depending on the user capacities 
> (where clause).
> Network edges have also attributes that are used to update cost / 
> rev_cost depending on the routing way : If an edge is forbidden in the 
> digitizing way, cost is set to 1 000 000. If it is forbidden in the 
> reverse way, rev_cost is set to 1 000 000. If it is forbidden in both 
> ways, cost and rev_cost are set to  1 000 000.
>
> Now, in some cases, despite there is no accessible route according to 
> the where clause, pgr_trsp() returns a route going through edges with 
> cost / rev_cost set to 1 000 000.
> If I change the where clause so that there is actually an alternative 
> route, same edges with cost / rev_cost set to 1 000 000 are taken into 
> account, and the calculated route is correct.
>
> I attached to this message images of both results (forbidden edges in 
> red, returned paths in blue).
> Routing is calculated from edge n°18295 (vertex n°19314) to edge 
> n°23805 (vertex n°10776).
> Wrong edge is n°30606 in test 2.
>
> Here is the sql code of the first test :
> SELECT * FROM pgr_trsp(
> 'SELECT id_tron::integer AS id, source::integer, target::integer,
> cost::double precision, rev_cost::double precision AS reverse_cost
> FROM rp_test
> WHERE type_tron NOT IN(3, 8, 9) AND largeur_c > 90 AND largeur_p > 75 
> AND etat_revet >= 2',
> 19314::INTEGER, 10776::INTEGER, true, true,
> 'SELECT to_cost::double precision, target_id::integer, via_path::text 
> FROM reseau_global_rest');
>
> And here is the sql code of the second test :
> SELECT * FROM pgr_trsp(
> 'SELECT id_tron::integer AS id, source::integer, target::integer,
> cost::double precision, rev_cost::double precision AS reverse_cost
> FROM rp_test
> WHERE type_tron NOT IN(3, 8, 9) AND largeur_c > 90 AND largeur_p > 75',
> 19314::INTEGER, 10776::INTEGER, true, true,
> 'SELECT to_cost::double precision, target_id::integer, via_path::text 
> FROM reseau_global_rest');
>
> I also attach to this message a shape file of the network.
>
> Do I miss something, or is it a bug ?
>
> Thanks for any help,
> -- 
> Christophe DAMOUR
>
>
>
>
> _______________________________________________
> Pgrouting-users mailing list
> Pgrouting-users at lists.osgeo.org
> http://lists.osgeo.org/mailman/listinfo/pgrouting-users

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.osgeo.org/pipermail/pgrouting-dev/attachments/20140307/70579f7f/attachment-0001.html>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: bug_trsp.zip
Type: application/x-zip-compressed
Size: 90330 bytes
Desc: not available
URL: <http://lists.osgeo.org/pipermail/pgrouting-dev/attachments/20140307/70579f7f/attachment-0001.bin>


More information about the pgrouting-dev mailing list