Comments (11)
Or even go for
data SCC vertex = SCC vertex [vertex]
and AcyclicSCC
/ CyclicSCC
become pattern synonyms for backward compatibility.
from containers.
Yes, let's do something of this sort. Your second representation doesn't seem to distinguish properly between vertices with no edges and ones with a single edge to themselves.
import Data.Graph
main :: IO ()
main = do
print $ stronglyConnComp [((), (), [()])]
print $ stronglyConnComp [((), (), [])]
This gives
[CyclicSCC [()]]
[AcyclicSCC ()]
As I understand it, your SCC
would represent these two the same.
from containers.
Your second representation doesn't seem to distinguish properly between vertices with no edges and ones with a single edge to themselves.
Ah, excellent point.
How about this? Any better naming than CyclicSCC'
?
data SCC vertex = AcyclicSCC vertex
| CyclicSCC' (NonEmpty vertex)
pattern CyclicSCC :: [vertex] -> SCC vertex
pattern CyclicSCC xs <- CyclicSCC' (NE.toList -> xs) where
CyclicSCC xs = CyclicSCC' (NE.fromList xs)
{-# COMPLETE AcyclicSCC, CyclicSCC #-}
from containers.
I must admit to some trepidation about committing to NonEmpty
given the current lack of a plan for improving its laziness story. If we do use it, I imagine it should be strict and unpacked.
from containers.
Do you mean CyclicSCC' !vertex ![vertex]
?
from containers.
I meant if you want NonEmpty
it should probably be {-# UNPACK #-} !(NonEmpty vertex)
. But unpacking by hand wouldn't be unreasonable either.
from containers.
{-# UNPACK #-}
and a bang are more readable, I'd rather keep NonEmpty
. Shall I prepare a PR? @meooow25 any comments?
from containers.
I'd like to see how this affects the code, yeah.
from containers.
Can we maybe skip introducing the partial CyclicSCC
-> CyclicSCC'
pattern? It's unlikely someone would be making their own SCC
s. And even with the pattern it's a breaking change if they do CyclicSCC []
.
from containers.
@meooow25 , we can just make it unidirectional, right?
from containers.
Yes, that's what I meant, should have stated explicitly.
Also this is only a suggestion, it comes down to whether we really don't want to break some code out there that is constructing CyclicSCC
s and always with non-empty lists.
from containers.
Related Issues (20)
- Set difference and union in one HOT 4
- foldTree does not optimize well HOT 2
- Tree fusion HOT 16
- Fusible Set.fromDistinctAscList definition HOT 10
- Fusible IntSet.fromDistinctAscList definition HOT 3
- better instance Hashable IntSet? HOT 8
- Unusual definition of foldrBits and foldlBits HOT 3
- Unnecessary CPP and C header in `Data.Map.Internal.Debug.html`?
- Release for GHC 9.8.1 HOT 17
- feat request: Add `popLeftWithValue` and `popWithValue` in `Data.Sequence` HOT 5
- Data.Graph: detect cycles utility functions HOT 2
- Data.Map.mergeWithKey doesn't match documentation
- Flag to introduce pedantic invariant checks? HOT 2
- Map.unionWith is over specialized and not consistent with intersectionWith HOT 10
- Add `flattenSCC1 : SCC vertex -> Data.List.NonEmpty.NonEmpty vertex` HOT 2
- Data.Map.Internal does not export insertMin
- Repo: remove merged branches?
- Contribution guide outdated?
- Potential memory optimization for IntMap and IntSet HOT 8
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from containers.