<div dir="ltr">Steve, thank you very much for your help!<div><br></div><div style>your guys are doing fantastic work, and i really appreciate your help!</div></div><div class="gmail_extra"><br><br><div class="gmail_quote">
On Tue, Jul 23, 2013 at 5:01 PM, Stephen Woodbridge <span dir="ltr"><<a href="mailto:woodbri@swoodbridge.com" target="_blank">woodbri@swoodbridge.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<div class="im">On 7/23/2013 9:43 AM, Yaron Lev wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
thanks a lot for your in-depth explanation, it helped me a lot and indeed i<br>
was referring to the c/c++ part.<br>
<br>
the basic question i am  trying to understand, how beneficial it will be to<br>
increase the DB instance size (cpu wise) (i am using AWS).<br>
<br>
just to be clear, and re-iterating, each request has two basic parts:<br>
<br>
1. grab data, and build the graph on the db - this is done on the<br>
PostgreSQL db, and therefor will benefit from multi-core environment.<br>
</blockquote>
<br></div>
correct<div class="im"><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
2. solving and returning the answer  -<br>
here i am a little lost. PostgreSQL allow integration of C, i would expect<br>
then, that these extensions(pgRouting code) will also benefit from<br>
multi-core environment.<br>
(i.e each request will use a different thread if needed, and on different<br>
core if needed)<br>
</blockquote>
<br></div>
yes, each request runs in a separate db instance or thread.<div class="im"><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
so in short, will part 2, also benefit from increasing the instance size(i<br>
understand it consumes roughly 30% of resources needed to complete the<br>
request)?<br>
</blockquote>
<br></div>
The C/C++ code *mostly* does its own memory allocation and does not rely on the memory pooling that postgresql provides. some parts of the progress to use this but the graphs and solution memory is allocated outside the postgresql memory pooling.<br>

<br>
In general if you are not running a lot of other processes on the server you can allocate more memory to postgresql, how much memory the graphs use depends on the typical size of a graph. I have never tried to figure this out. I would go with the standard memory sizing suggestions you can find for postgresql tuning. If you need a number to start with, on an 8GB memory system you might try 4GB in shared buffers and watch it under load with top to see how memory is being used and how much swap is getting used, how large the processes are getting, etc. and then make adjustments from there.<br>

<br>
Also you can optimize your data storage by clustering on the edge table spatial index. This will minimize IO when selecting edges for a graph because edges that are spatially close together will get clustered on pages, and once you need one edge on a page it is likely you will need multiple edges on that page and page caching is done in the shared buffers.<br>

<br>
-steve<br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="im">
again, many thanks for your help.<br>
<br>
<br>
<br>
<br>
On Tue, Jul 23, 2013 at 3:39 PM, Stephen Woodbridge <<a href="mailto:woodbri@swoodbridge.com" target="_blank">woodbri@swoodbridge.com</a><br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
wrote:<br>
</blockquote>
<br>
</div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="im">
On 7/23/2013 7:55 AM, Yaron Lev wrote:<br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Hi,<br>
<br>
i was looking for some information about weather or not pgRouting is<br>
utilizing more than one core if available.<br>
<br>
from the limited testing i made, and from googling (i found very little<br>
refrences), i think pgRouting does not support multi-core processing as of<br>
now.<br>
<br>
i will appreciate if anyone can confirm it, or give any information about<br>
it.<br>
<br>
</blockquote>
<br>
PgRouting is built on top of Postgresql so to the extent that postgresql<br>
can use multiple cores to process multiple requests we do. I you are asking<br>
if the routing algorithm itself is run in threads or using something like<br>
parallel graph algorithms? the answer is no.<br>
<br>
Also you should be aware the solving the graph is less then 50% of the<br>
cost of answering a query because we have to query the database for the<br>
edges, build the graph, solve the graph and return the results back to the<br>
client. selecting the edges and building the graph likely take 2/3rds of<br>
the processing time for a given query. The edge selection is probably done<br>
in a separate core/thread/process by the database from that that the rest<br>
of the processing is taking place in.<br>
<br>
-Steve<br>
<br>
<br></div>
______________________________<u></u>**_________________<br>
Pgrouting-users mailing list<br>
Pgrouting-users@lists.osgeo.**<u></u>org <<a href="mailto:Pgrouting-users@lists.osgeo.org" target="_blank">Pgrouting-users@lists.osgeo.<u></u>org</a>><br>
<a href="http://lists.osgeo.org/**mailman/listinfo/pgrouting-**users" target="_blank">http://lists.osgeo.org/**<u></u>mailman/listinfo/pgrouting-**<u></u>users</a><<a href="http://lists.osgeo.org/mailman/listinfo/pgrouting-users" target="_blank">http://lists.osgeo.org/<u></u>mailman/listinfo/pgrouting-<u></u>users</a>><br>

<br>
</blockquote><div class="im">
<br>
<br>
<br>
______________________________<u></u>_________________<br>
Pgrouting-users mailing list<br>
<a href="mailto:Pgrouting-users@lists.osgeo.org" target="_blank">Pgrouting-users@lists.osgeo.<u></u>org</a><br>
<a href="http://lists.osgeo.org/mailman/listinfo/pgrouting-users" target="_blank">http://lists.osgeo.org/<u></u>mailman/listinfo/pgrouting-<u></u>users</a><br>
<br>
</div></blockquote><div class="HOEnZb"><div class="h5">
<br>
______________________________<u></u>_________________<br>
Pgrouting-users mailing list<br>
<a href="mailto:Pgrouting-users@lists.osgeo.org" target="_blank">Pgrouting-users@lists.osgeo.<u></u>org</a><br>
<a href="http://lists.osgeo.org/mailman/listinfo/pgrouting-users" target="_blank">http://lists.osgeo.org/<u></u>mailman/listinfo/pgrouting-<u></u>users</a><br>
</div></div></blockquote></div><br></div>