User loginNavigation |
Ruling out nonsensical data type definitionsIn a language that enforces a separation between data and codata, it seems like (with a Haskell-esque syntax):
should be statically disallowed, since the resulting type Silly is uninhabited. First, is this intuition correct? Or does defining types of this kind have some utility? Second, what's the dual concept for codata? I think that if we are ruling out Silly as uninhabited, we should probably also rule out both of:
for a related reason. I'm thinking that the rule is something like this: A data definition must contain at least one alternative which is not recursive. A codata definition must not contain any alternative which is "only recursive" (meaning that it is a product of only recursive references to the codata type being defined). Am I even close? I am unaware of the correct terminology here, because searching is getting me nowhere. I've read a few overviews of total functional programming, including Turner's "Total Functional Programming", and learned of other syntactically reasonable data type definitions that have to be rejected because the reintroduce bottom, but didn't find a discussion of types of this kind (which seem merely useless in the data case, but also seem like an enemy of productivity proofs in the codata case). By Douglas McClean at 2009-02-02 00:41 | LtU Forum | previous forum topic | next forum topic | other blogs | 7289 reads
|
Browse archives
Active forum topics |
Recent comments
31 weeks 4 days ago
31 weeks 4 days ago
31 weeks 4 days ago
1 year 1 week ago
1 year 6 weeks ago
1 year 7 weeks ago
1 year 7 weeks ago
1 year 10 weeks ago
1 year 14 weeks ago
1 year 14 weeks ago