Changelog for interval-algebra-0.7.0
Changelog for interval-algebra
0.7.0
- Adds a Bifunctorinstance forPairedIntervals.
- Adds the two new functions to IntervalUtilites:
- foldMeetingSafe: Folds over a list of Paired Intervals and in the case that the 'getPairData' is equal between two sequential meeting intervals, these two intervals are combined into one. This function is "safe" in the sense that if the input is invalid and contains any sequential pairs of intervals with an- IntervalRelation, other than- Meets, then the function returns an empty list.
- formMeetingSequence: Converts an ordered sequence of- PairedInterval b athat may have any interval relation
('before', 'starts', etc) into a sequence of sequentially meeting- PairedInterval b a.  That is, a sequence where one the end of one interval meets the beginning of the subsequent interval. The- getPairDataof the input- PairedIntervals are
combined using the Monoid- <>function, hence the pair data must be a- Monoidinstance.
 
- Renames pairDataaccessor function togetPairDatain PairedInterval module.
- Removes the unsafeIntervalfunction.
0.6.3
- Extends the IntervalCombinableclass to operate on generalIntervalcontainers.
- Removes all usage of unsafeIntervalfrom the testing suite in preparation of removing this function.
- Modifies internals of the combineIntervalsfunction to use safe (exception-free) functions rather than footguns likeheadandtail.
0.6.2
- Fixes bug in equalswhich was checking for equality of the interval container, not just the interval.
0.6.1
- Removes the deriving Showinstance forPairedIntervals so people can customize their own instances.
0.6.0
- Generalizes the IntervalAlgebraicclass to work on any data structure that contains an interval (not just intervals themselves). This is possible by modification to theIntervallicclass, which now works in part as lens withgetIntervalandsetIntervalfunctions. This change allows users to define their own type which contains an interval get all the interval algebraic operation on that new type. The utility of this generalization can be seen in thePairedIntervalmodule, which defines a parameterized type for interval paired with some other data.
- Eliminates the Momentclass and combined it with theIntervalSizeableclass. Like theIntervalAlgebraicclass, theIntervalSizeableclass no longer depends on theIntervaltype, but its functions likedurationnow work on anyIntervallic i atype.
- Removes the expand,expandl, andexpandrfunctions from theIntervalSizeableclass are now just general functions. These function now work to modify the interval within anyIntervallic i atype.  Similarlybeginerval,enderval, andextentervalwere removed from the class; however, these functions only return theIntervaltype.
- Generalizes the filter*functions in the utilities module to operate on potentially different interval algebraic types. For example, infilterOverlaps x [ys],xcould be anInterval aand theyscould be a list ofPairedInterval b a, so you can filter a container of one interval algebraic type with another interval algebraic type.
0.5.0
- Adds the composefunction toIntervalAlgebraictypeclass, thus now all the algebraic operations are available: complement, composition, converse, intersection, and union.
- In the IntervalAlgebraictypeclass, addsconcuras a synonym fornotDisjoint;enclosedByas a synonym forwithin; andencloseas the converse ofenclosedBy.
- Generalizes the utilities combineIntervals,gaps,gapsWithin, andrelationsto work with anyApplicative,FoldableMonoid(of whichListis a case).
- Changes the signature of gapsWithinto returnMaybe (f (Interval a)), so that in the case that there are no gapsNothingis returned.
- Renames the emptyIf*function tonothingIf*. LikegapsWithin, these now returnMaybe (f (Interval a))so thatNothingis returned if the quantified predicated is true.
- Removes the IntervalFilterabletypeclass and these functions are now available in the utilities module without needing to specify instances for each container type you want to filter.
0.4.0
- Adds utilities emptyIfNone,emptyIfAny, andemptyIfAllthat apply predicates to a list of inputs. If none, any, or all of the inputs meet the predicate, then the empty list is returned. Otherwise, the input is returned unmodified. These functions are generalized toMonoids, so they work on structures other than lists.
- Adds gapsWithinfunction toIntervalUtilitiesmodule that appliesgapsto all intervals in the input list that are non-disjoint from the interval in the first argument.
- Fixed bug in combineIntervalswhere intervals could fail to be combined properly becausefoldrwas being used instead offoldl'.
- Adds intersectfunction toIntervalCombinableclass that returns the (maybe) intersection of two intervals.
- Adds relationsutility function which returns a list of theIntervalRelationsbetween each consecutive pair of intervals in the input list.
- Renames in'predicate towithin. Also, renamesfilterIn'tofilterWithin.
- Adds predicatefunction toIntervalAlgebraicclass to map anIntervalRelationto its corresponding predicate function. Also addspredicatesto map a set ofIntervalRelations to a list of predicate functions.
- Adds intersection,union,converse, andcomplementmethods toIntervalAlgebraicfor taking the respective operation onSet IntervalRelation.
- Instantiates Bounded,Enum, andOrdforIntervalRelation, so that, for one, interval relations can be ordered and used inData.Set. Uses the total ordering defined here, though in general, interval relations only have a partial order.
- Renames composeRelationsto the more accurateunionPredicates.
- Adds <|>as operator for "union"ingComparativePredicateOf (Interval a), as instarts <|> overlaps === unionPredicates [starts, overlaps].
- Adds a clip x yfunction which clips the intervalyto the extent ofx, providedxandyare not disjoint.
0.3.3
- Fixes bug in expandfunction
0.3.2
- Fixes bug in filterNotDisjoint
0.3.1
- Adds the difffunction to theIntervalSizeableto make comparisons of endpoints easier.
- Adds the notDisjointrelation to determine if two intervals share any support.
- Adds filterDisjoint,filterNotDisjoint, andfilterIn'to theIntervalFilterableclass.
0.3.0
- Adds beginervalandendervalfunction toIntervalSizeableclass for safely creatingIntervals given a begin (or end) and a duration.
- Moves momentto its own typeclassMoment, which is now a constraint onIntervalSizeable.
- Removes function exports from the IntervalAlgebra.Arbitrarymodule which where only meant to exported for the testing modules anyway.
0.2.0
- Adds IntervalSizeableclass.
- Moves IntervalFilterableclass to main module and generalizes the container to anyFilterabletype.
- Adds IntervalAlgebra.IntervalAlgebraUtilitiesmodule to collect various useful functions.
- Adds IntervalAlgebra.Arbitrarymodule to provide functions for generating arbitrary intervals.