-
-
Notifications
You must be signed in to change notification settings - Fork 373
GSoC 2018 MST and Mincut
PgRouting wiki page for MST and Mincut
- Brief Description
- State of the project before GSOC
- Project
- Log of Pull Requests
- Biography
- Weekly Report
- Community Bonding Period
- References
Graph connectivity is one of the classical subjects in graph theory and has many practical applications. A Minimum Spanning Tree in an undirected connected weighted graph is a spanning tree of minimum weight. For this I will implement two Functions that are Prim Algorithms and Kruskal Algorithms.
Finding the minimum cut of an edge weighted graph is a fundamental algorithmic problem. Stoer–Wagner algorithm is a recursive algorithm to solve the minimum cut problem in undirected weighted graphs with non-negative weights. The essential idea of this algorithm is to shrink the graph by merging the most intensive vertices, until the graph only contains two combined vertex sets. I will implement Min-Cut by Stoer Wagner function.
Current state of PgRouting do not support Minimum Spanning Tree And MinCut. My project goal is to implement Prim algotithm, Kruskal algorithms and mincut by Stoer Wagner.
Pull Request | Description | Date | Status |
---|---|---|---|
#1031 | [WIP]Implementation of PRIM Algorithm | 19 May 2018 | Merged |
#997 | Doxygen documentation of get_check_data | 3 Feb 2018 | Merged |
#975 | Improve code of Class Pgr_allpairs | 15 Dec 2017 | Merged |
- Name : Aditya Pratap Singh
- Country : India
- School : IIT Bhubaneswar
- Degree : B.Tech in Electronics & Communication Engineering
- Email : [email protected]
-
What did you get done this week? Get more familiar with pgRouting architecture and implemented pgr_prim function. I tested with pgRouting sample data and with other data and now it is working. Detailed can be found here [1].
- Include Directory
- Create
pgr_prim.hpp
- Create
pgr_prim_t.h
- Deleted
pgr_primGraph.hpp
- Fix
pgr_prim.hpp
- Create
- Include Directory
-
What am I going to achieve for next week?
- Fix some bug of pgr_prim if found
- Create test, documentation and pgTAP of pgr_prim function.
-
Is there any blocking issue?
No, at the moment I’m not blocked.
- The wiki page can be found in [2]
- The repository can be found in [3]
[1] https://github.com/pgRouting/pgrouting/pull/1035
[2] https://github.com/pgRouting/pgrouting/wiki/GSoC-2018-MST-and-Mincut#week-2
[3] https://github.com/pgRouting/pgrouting/tree/gsoc/mincut
-
What did you get done this week? I generated the initial code for pgr_prim using the template pgr_dijkstra code and fix these files. And detailed can be found here [1].
- Src Directory
- Create
CMakeLists.txt
&prim.c
&prim_driver.cpp
- Create
- Include Directory
- Create
prim_driver.h
- Create
- Sql Directory
- Create
CMakeLists.txt
&prim.sql
- Create
- Src Directory
-
What am I going to achieve for next week?
- Full Implementation of pgr_prim
- Create
pgr_prim.hpp
&pgr_prim_t.h
-
Is there any blocking issue?
No, at the moment I’m not blocked.
- The wiki page can be found in [2]
- The repository can be found in [3]
[1] https://github.com/pgRouting/pgrouting/pull/1031
[2] https://github.com/pgRouting/pgrouting/wiki/GSoC-2018-MST-and-Mincut#week-1
[3] https://github.com/pgRouting/pgrouting/tree/gsoc/mincut
- Set up Wiki Page
- Edit all info related to your project in OSGeo wiki.
- Get to know your mentors
- Introduce yourself and your project in SOC mailing list and your software mailing list
- Familiarize with the community practices and processes.
- Hand-Written copy of OSGeo mail (Issue #6)
- Team Work
- Detailed explanation how PostgreSQL is connected to C function.
- Working of C/C++ Driver
- Become familiar with the developer manuals.
- Practice pgTAP
-
Watch C++ video for better understanding (Issue #5)
-
Create demo function pgr_naziiDijkstra (Issue #4)
- Edit the create.sh (in tools/template directory) according to need
- Create file in src, pgtap, sql, doc, include, test of my function
-
Study git branching model & commands (Issue #2)
-
- Fork PgRouting
- Install Dependencies
- Build and Compile pgRouting
- Create account on Travis and AppVeyor
- Read https://summerofcode.withgoogle.com/terms/student
- Read https://wiki.osgeo.org/wiki/Google_Summer_of_Code_Recommendations_for_Students
- Write Proposal
- Create a wiki page for TODO tasks and weekly reports.
- Learn more about fork.
- Getting familiar with the community, the BGL docs.
- Get familiar with the PgRouting architecture.
- Develop a better understanding of postGIS, postgreSQL and PL/pgsql. Get familiar with postgreSQL procedural language.
- Watch C++ videos for better understanding of C++ and STL.
- Go through pgTap for creating unit tests for PostgreSQL.
-
Week 1 ( May 14 to May 21 )
- Learn and create initial documentation of implementing functions.
- Learn more about Boost C++ graph library using in this project.
-
Week 2 ( May 22 to May 28 )
- Learn how to implement functions for pgRouting by the BGL.
- Go through boost related work in pgRouting for a better understanding and skills on the implementation.
-
Week 3 to 4 ( May 29 to June 11 )
- Implement pgr_prim() function.
- Create documentation and test of pgr_prim() function.
- Create pgTap unit test for pgr_prim() function.
- Mentors evaluate me and I evaluate mentors of officially coding period phase 1.
- Deliver pgr_prim() function and its documentation, test and pgTap.
-
Week 5 to 7 ( June 11 to July 1 )
- Work on the feedback as provided after the first evaluation.
- Implement pgr_kruskal() function.
- Create documentation and test of pgr_kruskal() function.
- Create pgTap unit test for pgr_kruskal() function.
-
Week 8 ( July 2 to July 8 )
- Implement pgr_stoerWagnerMinCut().
- Mentors evaluate me and I evaluate the mentors of coding period phase 2.
- Deliver pgr_kruskal function and its documentation, test, pgTap and pgr_stoerWagnerMinCut() functions.
-
Week 9 to 10 ( July 9 to July 23 )
- Work on the feedback as provided after the second evaluation.
- Create documentation of pgr_stoerWagnerMinCut() function.
- Create test for the pgr_stoerWagnerMinCut() function.
- Create pgTAp for the pgr_stoerWagnerMinCut() function.
-
Week 11 to 12 ( July 24 to August 5 )
- Work on the final submission report.
- Rigorous bug fixes and improve documentation.
- Prepare for the final delivery.
- Wrap up the project and submit final evaluation of my mentors of Coding Period Phase 3.
- Deliver pgr_stoerWagnerMinCut() documentation, test, pgTap.
- ICS 161: Design and Analysis of Algorithms Lecture notes for February 6, 1996 https://www.ics.uci.edu/~eppstein/161/960206.html
- Mechtild Stoer and Frank Wagner, A Simple Min Cut Algorithm
- Minimum Spanning Trees and Prim's Algorithm
- https://algs4.cs.princeton.edu/43mst/
- Minimum Spanning Tree, https://www.scribd.com/presentation/368401579/19PrimKruskal-ppt
- Min_cut, www.cse.iitd.ernet.in/~naveen/courses/CSL758/mfmc.ppt