diff --git a/include/cinolib/dijkstra.cpp b/include/cinolib/dijkstra.cpp index 6f27d8df..69e5bc0f 100644 --- a/include/cinolib/dijkstra.cpp +++ b/include/cinolib/dijkstra.cpp @@ -181,6 +181,48 @@ void dijkstra_exhaustive_srf_only(const AbstractPolyhedralMesh & m, //:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::: +template +CINO_INLINE +void dijkstra_exhaustive_mask_on_edges(const AbstractMesh & m, + const uint & source, + const std::vector & mask, // if mask[e] = true, path cannot pass through edge e + std::vector & dist) +{ + dist = std::vector(m.num_verts(), inf_double); + dist.at(source) = 0.0; + + std::set> q; + q.insert(std::make_pair(0.0,source)); + + while(!q.empty()) + { + uint vid = q.begin()->second; + q.erase(q.begin()); + + for(uint eid : m.adj_v2e(vid)) + { + if(mask.at(eid)) continue; + + uint nbr = m.vert_opposite_to(eid,vid); + double new_dist = dist.at(vid) + m.edge_length(eid); + + if(dist.at(nbr) > new_dist) + { + if(dist.at(nbr) < inf_double) // otherwise it won't be found (one order of magnitude faster than initializing the queue with all the elements with inf dist) + { + auto it = q.find(std::make_pair(dist.at(nbr),nbr)); + assert(it!=q.end()); + q.erase(it); + } + dist.at(nbr) = new_dist; + q.insert(std::make_pair(new_dist,nbr)); + } + } + } +} + +//:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::: + template CINO_INLINE void dijkstra_exhaustive_mask_on_edges(const AbstractMesh & m, diff --git a/include/cinolib/dijkstra.h b/include/cinolib/dijkstra.h index e9e14879..b04fb9fa 100644 --- a/include/cinolib/dijkstra.h +++ b/include/cinolib/dijkstra.h @@ -74,6 +74,15 @@ void dijkstra_exhaustive_srf_only(const AbstractPolyhedralMesh & m, //:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::: +template +CINO_INLINE +void dijkstra_exhaustive_mask_on_edges(const AbstractMesh & m, + const uint & source, + const std::vector & mask, // if mask[e] = true, path cannot pass through edge e + std::vector & dist); + +//:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::: + template CINO_INLINE void dijkstra_exhaustive_mask_on_edges(const AbstractMesh & m,