Changelog for hasklepias
0.4.4
- Adds the FFFoption toFeatureDefinitionto define(Feature f -> Feature e -> Feature d)along with correspondingdefineFFFandapplyFFF.
- Adds zipWith,id, andIntegerto re-exports.
0.4.3
- Exports Featureconstructor.
- Adds defineFEF2function for creating a feature definition where the provided function returns aFeature drather than just ad.
- Generalizes allPairsfrom type[a] -> [a] -> [(a, a)]to[a] -> [b] -> [(a, b)].
- Reexports a few functions and types from Data.Time.Calendar. Also reexportsconstfromData.Function.
0.4.2
- Updates interval-algebrato 0.8.0
0.4.1
- Modifies the example in example/ExampleFeatures3to use the pipe|>operator.
- Adds the hasAllConceptsfunction to theHasConceptsclass.
- Adds a Reexportsmodule with the goal to re-export everything one might need from other Haskell libraries to build a cohort.
- Removes a number of unneeded/unused functions from the Functionsmodule.
- Adds the Safelanguage extension to modules where possible.
0.4.0
- Adds the FeatureDefinitionto represent common patterns for buildingFeatures:
data FeatureDefinition e a d =
    EF  (Events a -> Feature d)
  | FEF (Feature e -> Events a -> Feature d)
- Provides an initial set of functions designed to make defining Features easier, namelydefineEFanddefineFEF. These functions constructFeatureDefinitions of usingEFandFEFconstructors, respectively. The example features inexamples/ExampleFeatures1demonstrate their use.
- Adds the allPairsfunction to form all pairs of elements of two lists.
- Adds the splitByConceptsto split a container of events into a pair such that first element contains
events have any of the first argument's concepts, and similarly for the second element.
- Demonstrates how allPairsandsplitByConceptsmight be used in theexamples/ExampleFeatures3module.
- Adds a rudimentary ToJSONinstance forFeatures so that data can be encoded and output from the software. This is pretty rough; e.g. encoding anInterval Intfeature produces:"{\"end\":10,\"begin\":0}".
- Removes the Transformationsmodule andtransformToMeetingSequencefunction. The same functionality is available by using theformMeetingSequencefunction frominterval-algebra. Seeexamples/ExampleFeatures2for the updated example.
- Adds the toConceptEventOffunction which creates aConceptEventbut takes theintersectionofConceptsin the first argument and concepts in the context of theEventin the second argument to form the newConceptEvent. This is a way to keep only those concepts you need in the event.
0.3.0
- Updates code as needed to work with interval-algebra v0.6.2. In particular, the Event ais now a synonym forPairedInterval Context a, hence any methods that work on thePairedIntervalalso work for theEventtype.
- Adds the ConceptEvent atype which is a synonym forPairedInterval Concept a; i.e, this is an event without facts or a source.
- Adds the toConceptEventfunction for dropping from anEvent ato aConceptEvent a, andmkConceptEventfunction for directly making aConceptEventfrom concepts and an interval.
- Adds generators for lists of arbitrary events. The generator for Conceptsis limited at this point; it simply takes a subsample of the first 10 letters of the alphabet. Currently, only generators forEvent Intare provided by thegenerateEventsInt. For example, in thereplgenerateEventsInt 2produces two randomly generated events:
*Hasklepias> generateEventsInt 2
[{(-33, -16), Context {getConcepts = fromList ["G","I"], getFacts = Nothing, getSource = Nothing}},{(12, 13), Context {getConcepts = fromList ["A","C","D","E","G","I"], getFacts = Nothing, getSource = Nothing}}]
- Adds the transformToMeetingSequencefunction which takes a set of concepts and a list of possibly non-disjointConceptEventss and returns a list ofConceptEvents, where each consecutive event meets the next. Moreover, only those concepts selected (in the first argument) are kept in the output list of events. In the case that none of the events have the chosen concepts during an interval, anConceptEventwith an empty set of concept is returned. A few examples might make this more clear.
*Hasklepias> :set -XOverloadedStrings
*Hasklepias> x <- fmap (map toConceptEvent) (generateEventsInt 1)
*Hasklepias> x
[{(3, 4), fromList ["B","C"]}]
*Hasklepias> transformToMeetingSequence (map packConcept ["A"]) x
[{(3, 4), fromList []}]
*Hasklepias> transformToMeetingSequence (map packConcept ["B"]) x
[{(3, 4), fromList ["B"]}]
*Hasklepias> x <- fmap (map toConceptEvent) (generateEventsInt 10)
*Hasklepias> x
[{(-44, 7), fromList ["C","D","E","F","H","J"]},{(-30, -29), fromList ["A","B","F","G","H","I","J"]},{(-25, 5), fromList ["C","D","E","I"]},{(-20, -19), fromList ["A","C","E","G","I","J"]},{(-17, -16), fromList ["B","D","F","J"]},{(-6, -5), fromList ["E","F","H","J"]},{(2, 21), fromList ["A","F","J"]},{(18, 19), fromList ["D","F","G","H","I"]},{(19, 20), fromList ["B","C","D","E","F","H"]},{(30, 31), fromList ["B","C","D","H","J"]}]
*Hasklepias> transformToMeetingSequence (map packConcept ["B", "I"]) x
[{(-44, -30), fromList []},{(-30, -29), fromList ["B","I"]},{(-29, -25), fromList []},{(-25, -17), fromList ["I"]},{(-17, -16), fromList ["B","I"]},{(-16, 5), fromList ["I"]},{(5, 18), fromList []},{(18, 19), fromList ["I"]},{(19, 20), fromList ["B"]},{(20, 30), fromList []},{(30, 31), fromList ["B"]}]
- Adds an example of transformToMeetingSequencecould be used to derive a feature that is the list of durations that a subject was both hospitalized and on antibiotics at the same time in theexamples/ExampleFeatures2module.