Skip to content

Latest commit

 

History

History
238 lines (219 loc) · 15.4 KB

CHANGELOG.md

File metadata and controls

238 lines (219 loc) · 15.4 KB

Changelog

0.3.4

Performance improvements:

  • Added featureLabelCorrOnly parameter in SanityChecker to only compute correlations between features and label (defaults to false)
  • Added ignoreHashCorrelations parameter in SanityChecker that ignores correlations from hashed text features (defaults to false)
  • Parallelize OP cross validation and set default validation parallelism to 8
  • Added warmup in concurrent checks

New features and bug fixes:

  • Replace deprecated 'forceSharedHashSpace' param with HashingStrategy
  • Added explicit annotations for all classes with generic collections that use JsonUtils
  • Added .transmogrify shortcut for arrays of features
  • Removed referencing UID from a case object
  • DecisionTree & DropIndices stages tests now use the OP spec base classes
  • Added map features removed by RFF to model insights
  • Pretty print model summaries
  • Ensure OP Models are portable across environments
  • Ignore _ in simple streaming avro file reader
  • Updated evaluators so they can work with either Prediction type feature or three input featues
  • Added Algebird kryo registrar
  • Make Sure that SmartTextVectorizerModel can be serialized to/from json

Dependency upgrades:

  • Upgraded to Scala 2.11.12
  • Updated Gradle to 4.9 & bump Scalastyle plugin to 1.0.1

Archived Releases

3.3.3

  1. Convert some more stages tests to use OP stages specs (#241)
  2. Changed error to occur only when all labels are removed (#237)
  3. Fixes for writing/reading stages in OpPipelineStageSpec tests (#235)
  4. Add files via upload (#233) workflow description figures
  5. Stop words changes to text analyzers and bug fixes (#230)
  6. Update README.md (#229)
  7. Remove null leakage checks for text features from sanity checker (#228) Update sanity checker shortcut with protectTextSharedHash param (#234)
  8. Remove JSD check for date + datetime features in RFF (#227)
  9. Introduced FeatureBuilder.fromDataFrame function allowing materializing features from a DataFrame (#226)
  10. Get rid of ClassTags in OP models (#225)
  11. Test if transformer transforms the data correctly after being loaded (#223)
  12. Update to BSD-3 license (#218) Some more licenses (#221)
  13. Changed from extending to wrapping spark models. wrapped spark model classed using reflection (part 1 of 2) (#216) wrapped spark estimators so that they return op wrapped models with prediction return type (part 2a of 2) (#222) wrapped spark estimators for new models added (part 2b of 2) (#238) Moved code out of spark ml workspace and added comments - no code changes after tickets (#239)
  14. Change ootb transformers to use OPTransformerSpec for tests (#215)
  15. Move base stages to features sub project + test classes and specs (#214)
  16. Better clues when asserting stages (#213)
  17. Implement multi-class threshold metrics (#212)
  18. NameEntityRecognizer (NER) transformer (#209)
  19. Allow customizing feature type equality in op test transformer/estimator specs (#207)
  20. Threshold metrics bug fix (#204) use prediction rather than raw prediction
  21. Added an extra OpEstimatorBaseSpec base class with loosen model type boundaries to allow testing Spark wrapped estimators (#203) Fix package access level on OpEstimatorBaseSpec (#205) internal OP test base class
  22. Fast materializer method FeatureTypeSparkConverter by full feature type name (#202)
  23. Added UID.reset() before tests so that all workflows will generate the same feature names (#201)
  24. Added add/subtract operations for Spark ml Vector types (#200)
  25. workflow cleanup (#199)
  26. Fix TextMapNullEstimator to count a null when text entirely removed by tokenizer (#198) fix the issue that certain text strings can be entirely removed by our tokenizers, but null tracking step for text map vectorizers just checks for the presence of a key
  27. Workflow CV Fixes (#196) fix dead lock in OpCrossValidation.findBestModel happened due to the fact that when running splits processing in parallel these threads would try to access spake stage params on the same stages.
  28. Update ternary, quaternary and sequence transformer/estimator bases tests (#195)
  29. Enabling null-label leakage detection in RawFeatureFilter (#191, #192, #193)
  30. Feature Type values docs (#190)
  31. Bump up lucene version and add lucene-opennlp package (#188)
  32. Minor README cleanup (#187, #189)
  33. Test specs for OP stages (#186)
  34. Adding pr_curve, roc_curve metrics (#184)
  35. Create hash space strategy param (#182)
  36. Make new Cross Validation (#181)
  37. Avoid reseting UID in every test, but only do it when necessary (#180)
  38. Upgrade to gradle 4.7 (#179)
  39. Added OpTransformer.transformKeyValue to allow transforming Map and any other key/value types (#178) in preparation for sparkless scoring
  40. Adding autoBucketize to transmogrify for numerics & numeric maps + pass in optional label #159
  41. Autobucketizing for numeric maps should not fail if map is empty, instead we generate empty column for empty numeric map #231

Migration guide:

  1. OpLogisticRegression() is in progress (evaluator needs updates) may use BinaryClassificationModelSelector() instead
  2. Need to add .setProbabilityCol($probCol) to evaluator in workflow definition to make sure that the evaluator will get the correct probability column to do the calculation

3.3.1

  • SanityChecker performance improvements
  • Introduced FeatureBuilder.fromDataFrame function allowing materializing features from a DataFrame. Example usage:
case class MyClass(s: String, l: Long, label: Double)
val data: DataFrame = Seq(MyClass("blah1", 10, label = 2.0)).toDS.toDF()
val (label, Array(fs, fl)) = FeatureBuilder.fromDataFrame[RealNN](data, response = "label")
  • Helloworld: added a minimalistic classifier based on the Titanic dataset com.salesforce.hw.titanic.OpTitanicMini

3.3.0

  1. Json4s extension to serialize Joda time arguments with op stages
  2. Correctly produce json for OpWorkflowRunnerConfig
  3. Added SmartTextVectorizer and SmartTextMapVectorizer
  4. Update OP type hierarchy image
  5. Name update bug fix in SwThreeStageBinaryEstimator
  6. Added feature type conversion shortcuts for floats
  7. Smart bucketizer for numeric map values based on a Decision Tree classifier
  8. Allow serializing HashAlgorithm enum in a stage argument
  9. Update Model Insights to have features excluded by raw feature filter
  10. Redesign DataCutter for new Cross-Validation/Train-Validation-Split
  11. Allow setting log level in Sanity Checker
  12. Move reference data out of OPMapVectorizerModelArgs
  13. Made maps params needed for feature parity in builder + increase defaultNumOfFeatures and maxNumOfFeatures for hashing
  14. Association rule confidence/support checks
    1. Added maxConfidences function to OpStatistics that calculates the max confidence per row of the contingency matrix, along with the support of that row. Refactored SanityCheckerSummary metadata so that everything coming from the same feature group (contingency matrix) are grouped together.
  15. anity checker summary metadata redesign
  16. Tests indicator group collapsing for sanity checker
  17. Added loco record insights
  18. Redesign DataBalancer
    1. (Internal optimization) With new Cross Validation, the same DataBalancer (i.e. with the same fractions) will run many times. Estimation is not necessary, hence no need to count over and over again.
  19. Model selector modified in order to have cross validation and train-split validation called on it rather than running them internally.
  20. Added ability to set output name on all stages
  21. Allow suppressing arg parse errors
  22. Modify workflow to run cv on all stages with label mixed in
    1. New Restriction: OpWorkflows can only contain at most 1 Model Selector, an error will be thrown otherwise.
  23. Updated default for binary model selector evaluator
    1. New Default: Area under PR curve is default value.
  24. Added FeatureBuilder.fromRow and FeatureLike.asRaw methods.
  25. Added constructor parameter stratify in cross-validation and train-validation split for stratification.
  26. Added ability to use raw feature filter to workflow.
  27. Added RawFeatureFilter class
  28. Extend Cramer's V to work with MultiPickLists
    1. Added calculation of Cramer's V on MultiPickList fields, computed from the max of all the 2x2 Cramer's V values on each individual choice of the MultiPickList. Updated methods in OpStatistics to return chi squared statistic and p value.
  29. Added Prediction feature type
    1. Prediction is a new NonNullable feature type that inherits from RealMap. It requires at least a prediction: Double to be provided, otherwise the error is thrown at construction.
    2. Prediction can also contain the rawPrediction: Array[Double] and probability: Array[Double] values.
  30. Added UID.reset and UID.count + tests
  31. Modify OpParams to provide read locations for two readers in Assessor (RawFeatureFilter) stage
  32. Error on null/empty in RealNN + make OPVector nullable
    1. RealNN now throws an exception on null/empty values at construction
    2. OPVector is now a nullable type
    3. Removed OpNumeric.``map and OpNumber.toDouble(default)
  33. Make param settings take priority over code settings and allow setting params that do not correspond to an underlying spark param
  34. Drop indices transformer
  35. Bug fix in calculating max sibling correlation
  36. Added Date To Unit Circle Transformer
    1. Implements a transformer of a Date or DateTime field into a cartesian coordinate representation of an extracted time period on the unit circle.

Migration guide:

  1. Use com.salesforce.op.utils.json.EnumEntrySerializer.json4s instead of EnumEntrySerializer.apply for creating JSON4S formats.
  2. Make sure to specify OpParams.alternateReaderParams when using main constructor (can default to Map.empty).
  3. RealNN now can only be created from an actual Double/Long/Int value or with a default value/behavior provided:
RealNN(0.0) // ok
1.0.toRealNN // ok
Real(None).value.toRealNN(-1.0) // ok, but default value is a requirement now
Real(None).value.toRealNN(throw new RuntTimeException("RealNN cannot be empty")) // ok
Real(None).value.toRealNN // NOT ok
  1. OP pipeline stage operationName was renames to getOperationName

3.2.4

  • OpVectorColumnMetadata.hasParentOfType should be using exists
  • Made Splitter methods public and not final so can extend classes
  • Date time map now has reference date
  • Make TestFeatureBuilder correctly generate originStage
  • Allow specifying cutOff logic for conditional readers
  • Moved stage fit into trait that can be reused in CV and TS
  • Use array when applying op transformers
  • Change minInfoGain Param default in DecisionTreeBucketizer
  • Aggregator fixes
  • Fixed max modeling default
  • Call stage.setInputSchema before transformSchema is called
  • Delete the cli test dir recursively
  • Refactored op read/write stage tests
  • Bumped the minimum sample size up to 1000 for SanityChecker
  • Added internal ValidatedModel type for to hold intermediate in ModelSelector
  • Flattened cross validation classes so can make workflow level CV
  • Upgrade to gradle 4.5.1 + fix date time utils tz
  • Added persist in sanity checker after sample
  • Fixed catalyst issue when training very wide datasets
  • Added MaxRealNN, MinRealNN, MeanRealNN + cleanup some aggregator tests
  • CLI fixes
  • Allow disable version props generation
  • Add Scalastyle check for license header
  • Strip HTML tags for text features

3.2.3

  • Upgraded to Spark 2.2.1
  • Numeric bucketizers fixes: including metadata and integration with sanity checker.
  • Introduced split inclusion parameter for numerical bucketizers controlling should the splits be left or right inclusive (numeric.bucketize(splitInclusion) and numeric.autoBucketize(splitInclusion)).
  • Introduced an option for numerical bucketizers to allow tracking invalid values such as NaN, -Inf, Inf or values that fall outside the buckets. (numeric.bucketize(trackInvalid) and numeric.autoBucketize(trackInvalid)).
  • Finalized the unification of vectorization for ALL the OP types, including Text, TextArea, Base64, Phone, URL and Geolocation.
  • Fixed track null behavior of vectorization for MulitPicklistMap to match MultiPicklist
  • OP cli --auto properly identifies the input csv schema as expected
  • OP cli generated code is now prettier
  • Minor bug fixes in vectorizers metadata and ctor args for sanity checker model
  • Added null tracking for map vectorizers
  • Added null tracking for hashed text features
  • Sanity Checker: fixed issue in feature removal for sibling features when one has a correlation of NaN with the label
  • Fixes for Decision Tree bucketizer vector metadata to allow it working with Sanity Checker
  • Correlation based record level insights
  • All model classes are now made public with private[op] ctors
  • Added inclusion indicators in bucket labels
  • Workflow now creates holdout during fitting after raw data creation and applies eval
  • Simplified OP CLI generated template
  • Added VersionInfo - which allows access to project version and git info at runtime and include it in AppMetrics
  • Make most OpWorkflowRunner ctor params optional and deprecate old ctors
  • OpWorkflowRunner.run now requires spark StreamingContext to be present
  • Implemented a new run type allowing streaming score (--run-type=streamingScore)

3.2.0

  • Implemented Model Insights (acessible through model.modelInsights(feature))
  • Better hyperpameter defaults for model selectors
  • Implemented smart binning estimator for continuous variables based on a decision tree classifier (accessible through numeric.autoBucketize(label, trackNulls), while regular bucketizer is available as numeric.bucketize(trackNulls, splits, bucketLabels))
  • Added data cutter for multiclass model selectors - creates a data splitter that will split data into training and test set filtering out any labels that don't meet the minimum fraction cutoff or fall in the top N labels specified.
  • Base64 features vectorization - that uses detectMimeTypes underneath, then converts the results into PickList and vectorizes it
  • Unified vectorization behaviour between numerical maps and numerical base feature types
  • Unified vectorization behaviour between text maps and text base feature types that are pivoted
  • Added an option to sanity checker to remove all features descended from a parent feature (parent is direct parent before vectorization) which has derived features that meet the exclusion criteria (sanityChecker.setRemoveFeatureGroup)
  • Renamed sampleLimit to sampleUpperLimit and added sampleLowerLimit options for sanity checker
  • Collect and expose spark stage metrics - OpSparkListener now allows to collect and expose stage metrics and it's controlled using OpParams.collectStageMetrics parameter (false by default). The metrics are available through OpWorkflowRunner.addApplicationEndHandler.
  • OP CLI gen: allows providing answers file, auto detecting schemas and autogeneration of avro schema from data.

Minor fixes:

  • Add null tracking to NumericBucketizer
  • Add sequence aggregator for calculating means by key of RealMaps
  • Added commutative group aggregator - It is good for sliding window aggregation - can subtract expired data. As an example, ExtendedMultiset - it counts words, and can subtract. So, it also can have negative counters, for borrowed words or something.
  • Fixing random phones generator: US phone numbers are now correctly generated

Migration Guide:

  • TextMapVectorizer has been renamed to TextMapPivotVectorizer to make its behavior more apparent. A new TextMapHashingVectorizer will be released in a future version.