This repository contains all of the primitives developed by the teams at KUNGFU.AI, Yonder, and New Knowledge for the D3M program.
kf-d3m-primitives requires Python 3.6, and the easiest
way to install it is via pip
:
pip install kf-d3m-primitives
The latest versions of D3M datasets can be downloaded by running the following script from inside the cloned directory. D3M Gitlab credentials are required.
python download_datasets.py
To make a docker image with kf-d3m-primitives installed on top of the D3M program image run:
make build
To download the large static volumes that are necessary to run and test some of the primitives run:
make volumes
To run the image with the downloaded datasets and static volumes mounted run:
make run
To test that each primitive's produce
method, and, where applicable, its set_training_data
, fit
, get_params
, and set_params
methods can be called sucessfully within D3M pipelines, run the following command. This will also test that the predictions produced on test sets by each pipeline that can be scored by the D3M runtime
.
make test
To generate json
annotations for all primitives with the required directory structure for D3M submission run:
make annotations
To generate yml.gz
pipeline run documents for all CPU-dependent pipelines with the required directory structure for D3M submission run:
make pipelines-cpu
To generate yml.gz
pipeline run documents for all GPU-dependent pipelines with the required directory structure for D3M submission run:
make pipelines-gpu
-
DataCleaningPrimitive: This primitive standardizes columns that represent dates or numbers, including missing values. It is based on the punk library.
-
DukePrimitive: This primitive produces abstractive summarization tags based on a word2vec model trained on Wikipedia data and a corresponding Wikipedia ontology. It is based on the Duke library.
-
SimonPrimitive: This primitive infers the semantic type of each column using a pre-trained LSTM-CNN model. The model was trained on simulated data of different semantic types using the python Faker library. Base library here.
-
GoatForwardPrimitive: This primitive geocodes location names in specified columns into longitude/latitude coordinates. It uses a large downloaded search index: the photon geocoding server (based on OpenStreetMap).
-
GoatReversePrimitive: This primitive converts longitude/latitude coordinates into geographic location names. It uses a large downloaded search index: the photon geocoding server (based on OpenStreetMap).
-
HdbscanPrimitive: This primitive applies hierarchical density-based (HDBSCAN) and density-based (DBSCAN) clustering algorithms.
-
StorcPrimitive: This primitive applies tslearn's kmeans clustering implementations to time series data.
-
SpectralClustering: This primitive applies scikit-learn's Spectral Clustering algorithm to unsupervised, supervised or semi-supervised datasets.
-
PcaFeaturesPrimitive: This primitive implements a two-step feature selection process. First, it performs prinicipal component analysis on all numeric data in the dataset. Second, it uses each original feature's contribution to the first principal component as a proxy for the 'score' of that feature. Base library here.
-
RfFeaturesPrimitive This primitive performs supervised recursive feature elimination using random forests to generate an ordered list of features. Base library here.
- TsnePrimitive: This primitive applies scikit-learn's T-distributed stochastic neighbour embedding (TSNE) algorithm.
- Sent2VecPrimitive: This primitive produces numerical representations of text data using a model that was pre-trained on English Twitter bi-grams. Base library here.
- ObjectDetectionRNPrimitive: This primitive utilizes RetinaNet, a convolutional neural network (CNN), for object detection. It wraps the Keras implementation of Retinanet from this repo. The original Retinanet paper can be found here.
-
KaninePrimitive: This primitive applies the k-nearest neighbors (KNeighborsTimeSeriesClassifier) classification algorithm to time series data.
-
LstmFcnPrimitive: This primitive applies a LSTM fully convolutional neural network for time series classification. It wraps the implementation here LSTM Fully Convolutional Networks for Time Series Classification.
-
DeepArPrimitive: This primitive applies the DeepAR (deep, autoregressive) forecasting methodology for time series prediction. It trains a global model on related time series to produce probabilistic forecasts. It wraps the implementation from GluonTS.
-
NBEATSPrimitive: This primitive applies the Neural basis expansion analysis for interpretable time series forecasting (N-BEATS) method for time series forecasting. It wraps the implementation from GluonTS.
-
VarPrimitive: This primitive applies a vector autoregression (VAR) multivariate forecasting model to time series data. It defaults to an ARIMA model if the time series is univariate.
shap_explainers: wrapper of Lundberg's shapley values implementation for tree models. Currently integrated into d3m.primitives.learner.random_forest.DistilEnsembleForest as produce_shap_values().
-
RemoteSensingPretrainedPrimitive: This primitive featurizes remote sensing imagery using a pre-trained model. The pre-trained model was learned on a sample of Sentinel-2 imagery and optimized using a self-supervised objective. There are two inference models that correspond to two pretext tasks: Augmented Multiscale Deep InfoMax and Momentum Contrast. The implementation of the inference models comes from this repo.
-
MlpClassifierPrimitive: This primitive trains a two-layer neural network classifier on featurized remote sensing imagery. It also produces heatmap visualizations for predictions using the gradient-based GradCam technique.
-
ImageRetrievalPrimitive: This primitive retrieves semantically similar images from an index of un-annotated images using heuristics. It is useful for supporting an iterative, human-in-the-loop, retrieval pipeline
-
ImageSegmentationPrimitive: This primitive trains a binary image segmentation model using image-level weak supervision (see 1). Furthermore, the pre-trained featurizer is used the initialize the parameters of segmentation encoder. Thus, the training process is also an instance of transfer learning (see 2).
-
CorrectAndSmoothPrimitive: This primitive applies the Correct and Smooth procedure for semi-supervised learning. It combines a simple classification model with two label propagation post-processing steps - one that spreads residual errors and one that smooths predictions.
-
TabularSemiSupervisedPrimitive: This primitive applies one of three methods (PseudoLabel, VAT, and ICT) for semi-supervised learning on tabular data.