Hi Steve,<br>Thanks for your comments. Here are my feedbacks:<br><br>- I completely agree with you with the commenting issue. I will add more comments in the code, specially what each of the function does. I think it will be very helpful to people reading the code.<br>
<br>- Actually I do have a test code that reads input from text file call the function in the same manner the sql does, get the result and writes it back to another text file. I did this for my own debugging purpose, never thought it will be helpful for others. But from your remark, I am thinking that this can be easily turned into a nice testing tool and can be added with the main codes. I need to clean up and modify the existing code and I think then I can add it with my project. Currently I am busy with the A* implementation. Once it is finished, I will give one or two days on the testing code. <br>
<br>- Please let me know the results of your test and your experience on it.<br><br>- Razegul<br><br><br><br><div class="gmail_quote">On Sun, Jul 1, 2012 at 1:09 AM, 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">Hi Razequl,<br>
<br>
(Jinfu, I have not had a chance to look over your code yet, but to the extent that the comments below might apply to your code, you might want to consider this as input to you also.)<br>
<br>
I am not going to try and review you actual algorithm, because I'm not sure I can add any value or insights to it. The following are observations and recommendations as opposed to requirements.<br>
<br>
Regarding your project, the code looks very clean and easy to read, but it does not have many/any comments describing what it is doing or how it works. I am equally negligent in this area with a lot of my code, but have found that over time a regret not adding the comments when I write the code originally because it requires more work to figure it out later. Also when others have to read it and make changes for any reason it is great to have the comments to help understand the code. Also since this code will be publicly available to a very wide audience this says a lot about you to these people.<br>
<br>
We have not really figured out how we want to do testing yet. I know Jay did some initial test infrastructure, I have taken a couple of stabs at trying to work out some method for doing this. There are multiple levels of testing and it might mean that we have different infrastructure for each. When Roni developed the core TRSP algorithm, he had a local test bed which consisted of a C/C++ main commandline tool, that could read in a text file that defined a graph, restrictions, test cases and results. Basically these very much followed the output of the SQL needed to feed the SQL function to invoke the command. So the main would read in the text file, run the algorithm and display the results and exit. This worked totally outside the postgresql environment. This made it easy to run in the debugger and made it easy to verify the correctness of the core algorithm. Unfortunately this never got checked into the source tree so we don't have it today. One of the advantages of this approach, was that when a bug was reported, we could easily run the SQL commands to create the text files for input, then run the test program. If the results were the same as the SQL results then we knew the problem was in the core algorithm and it could easily be debugged. If the test results were good then we knew that the problem was in the wrapper code that I wrote and I could then tackle debugging that.<br>
<br>
It would be nice to have a directory like extra/bdsp/test/ that contained test files, and a target to build extra/bdsp/src/dotest and a a target for make test that would run all the tests in the test directory using dotest and would report pass/fail for each test.<br>
<br>
This might be something that you and jinfu and maybe Jay would get involved to collaborate for some extra karma points :). Before you commit to something like this make sure you can meet the requirements of your projects. If you can work it into your own project then that would be fine also and we can review and refactor what you have done for pgRouting as a whole later after GSoC.<br>
<br>
Next I will install you code and try to run it against some of my graphs.<br>
<br>
Great job so far, keep up the good work.<br>
<br>
Thanks,<br>
-Steve<div class="im"><br>
<br>
<br>
On 6/29/2012 9:46 PM, Razequl Islam wrote:<br>
</div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="im">
Hi Steve,<br>
It is great that you got some time to review the code. I have trsp in my<br>
local folder but I found it is not in the git. I will commit that again.<br>
And yes, commenting trsp subdirs should work. Also as I have not done<br>
any work on that folder, you should be able to review my work. All my<br>
codes are in the bdsp folder.<br>
Thanks for your time. I am waiting to learn more from you.<br>
<br>
- Razequl<br>
<br>
On Fri, Jun 29, 2012 at 11:10 PM, Stephen Woodbridge<br></div><div class="im">
<<a href="mailto:woodbri@swoodbridge.com" target="_blank">woodbri@swoodbridge.com</a> <mailto:<a href="mailto:woodbri@swoodbridge.com" target="_blank">woodbri@swoodbridge.<u></u>com</a>>> wrote:<br>
<br>
OK, my temporary fix was to comment out the subdir:<br>
<br>
#SUBDIRS(extra/trsp)<br>
<br>
-Steve<br>
<br>
<br>
On 6/29/2012 12:59 PM, Stephen Woodbridge wrote:<br>
<br>
Hi Razequl,<br>
<br>
I finally have some time to look at your code, but have run into<br>
a small<br>
build problem.<br>
<br>
woodbri@mappy:~/work/ pgrouting-git/gsoc-bdsp$ git clone<br>
git://<a href="http://github.com/zibon/" target="_blank">github.com/zibon/</a> pgrouting.git<br></div>
<<a href="http://github.com/zibon/pgrouting.git" target="_blank">http://github.com/zibon/<u></u>pgrouting.git</a>><div class="im"><br>
Initialized empty Git repository in<br>
/u/work/pgrouting-git/gsoc- bdsp/pgrouting/.git/<br>
remote: Counting objects: 1930, done.<br>
remote: Compressing objects: 100% (743/743), done.<br>
remote: Total 1930 (delta 1189), reused 1882 (delta 1151)<br>
Receiving objects: 100% (1930/1930), 685.37 KiB | 1112 KiB/s, done.<br>
Resolving deltas: 100% (1189/1189), done.<br></div>
woodbri@mappy:~/work/ pgrouting-git/gsoc-bdsp/ pgrouting$ cmake .<div><div class="h5"><br>
-- The C compiler identification is GNU<br>
-- The CXX compiler identification is GNU<br>
-- Check for working C compiler: /usr/bin/gcc<br>
-- Check for working C compiler: /usr/bin/gcc -- works<br>
-- Detecting C compiler ABI info<br>
-- Detecting C compiler ABI info - done<br>
-- Check for working CXX compiler: /usr/bin/c++<br>
-- Check for working CXX compiler: /usr/bin/c++ -- works<br>
-- Detecting CXX compiler ABI info<br>
-- Detecting CXX compiler ABI info - done<br>
-- POSTGRESQL_EXECUTABLE is POSTGRESQL_EXECUTABLE-NOTFOUND<br>
-- Found PostgreSQL: /usr/include/postgresql/8.3/ server,<br>
/usr/lib/libpq.so<br>
-- Boost version: 1.34.1<br>
-- Found the following Boost libraries:<br>
Boost headers were found here: /usr/include<br>
Output directory for libraries is set to /usr/lib/postgresql/8.4/lib<br>
-- Found PGROUTING_CORE core:<br>
/home/woodbri/work/pgrouting- git/gsoc-bdsp/pgrouting/core/ src<br>
Installation directory for libraries is set to<br>
/usr/lib/postgresql/8.4/lib and for SQL files is set to<br>
/usr/share/pgrouting<br>
CMake Error at CMakeLists.txt:117 (SUBDIRS):<br>
subdirs Incorrect SUBDIRS command. Directory: extra/trsp<br>
does not<br>
exists.<br>
<br>
<br>
-- Configuring done<br></div></div>
woodbri@mappy:~/work/ pgrouting-git/gsoc-bdsp/ pgrouting$ ls extra/<div class="im"><br>
bdsp CMakeLists.txt driving_distance tsp<br>
<br>
<br>
So you can see that there is no extra/trsp directory in your<br>
repository.<br>
Do you need to add, commit and push that to your remote?<br>
<br>
Also don't forget your report, its Friday again. :)<br>
<br>
Thanks,<br>
-Steve<br>
______________________________ _________________<br>
pgrouting-dev mailing list<br></div>
<a href="mailto:pgrouting-dev@lists.osgeo.org" target="_blank">pgrouting-dev@lists.osgeo.org</a> <mailto:<a href="mailto:pgrouting-dev@lists.osgeo.org" target="_blank">pgrouting-dev@lists.<u></u>osgeo.org</a>><br>
<a href="http://lists.osgeo.org/" target="_blank">http://lists.osgeo.org/</a> mailman/listinfo/pgrouting-dev<br>
<<a href="http://lists.osgeo.org/mailman/listinfo/pgrouting-dev" target="_blank">http://lists.osgeo.org/<u></u>mailman/listinfo/pgrouting-dev</a><u></u>><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> <mailto:<a href="mailto:pgrouting-dev@lists.osgeo.org" target="_blank">pgrouting-dev@lists.<u></u>osgeo.org</a>><br>
<a href="http://lists.osgeo.org/" target="_blank">http://lists.osgeo.org/</a> mailman/listinfo/pgrouting-dev<div class="im"><br>
<<a href="http://lists.osgeo.org/mailman/listinfo/pgrouting-dev" target="_blank">http://lists.osgeo.org/<u></u>mailman/listinfo/pgrouting-dev</a><u></u>><br>
<br>
<br>
<br>
<br>
______________________________<u></u>_________________<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/<u></u>mailman/listinfo/pgrouting-dev</a><br>
<br>
</div></blockquote><div class="HOEnZb"><div class="h5">
<br>
<br>
______________________________<u></u>_________________<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/<u></u>mailman/listinfo/pgrouting-dev</a><br>
</div></div></blockquote></div><br>