NOTICE
The upcoming release of Featuretools 1.0.0 contains several breaking changes. Users are encouraged to test this version prior to release by installing from GitHub:
pip install https://github.com/alteryx/featuretools/archive/woodwork-integration.zip
For details on migrating to the new version, refer to Transitioning to Featuretools Version 1.0. Please report any issues in the Featuretools GitHub repo or by messaging in Alteryx Open Source Slack.
Note
Support for Koalas EntitySets is still in Beta. While the key functionality has been implemented, development is ongoing to add the remaining functionality.
All planned improvements to the Featuretools/Koalas integration are documented on Github. If you see an open issue that is important for your application, please let us know by upvoting or commenting on the issue. If you encounter any errors using Koalas entities, or find missing functionality that does not yet have an open issue, please create a new issue on Github.
Creating a feature matrix from a very large dataset can be problematic if the underlying pandas dataframes that make up the entities cannot easily fit in memory. To help get around this issue, Featuretools supports creating Entity and EntitySet objects from Koalas dataframes. A Koalas EntitySet can then be passed to featuretools.dfs or featuretools.calculate_feature_matrix to create a feature matrix, which will be returned as a Koalas dataframe. In addition to working on larger than memory datasets, this approach also allows users to take advantage of the parallel and distributed processing capabilities offered by Koalas and Spark.
Entity
EntitySet
featuretools.dfs
featuretools.calculate_feature_matrix
This guide will provide an overview of how to create a Koalas EntitySet and then generate a feature matrix from it. If you are already familiar with creating a feature matrix starting from pandas dataframes, this process will seem quite familiar, as there are no differences in the process. There are, however, some limitations when using Koalas dataframes, and those limitations are reviewed in more detail below.
Koalas EntitySets require Koalas and PySpark. Both can be installed directly with pip install featuretools[koalas]. Java is also required for PySpark and may need to be installed, see the Spark documentation for more details. We will create a very small Koalas dataframe for this example. Koalas dataframes can also be created from pandas dataframes, Spark dataframes, or read in directly from a file.
EntitySets
pip install featuretools[koalas]
In [1]: import featuretools as ft In [2]: import databricks.koalas as ks In [3]: id = [0, 1, 2, 3, 4] In [4]: values = [12, -35, 14, 103, -51] In [5]: koalas_df = ks.DataFrame({"id": id, "values": values}) In [6]: koalas_df Out[6]: id values 0 0 12 1 1 -35 2 2 14 3 3 103 4 4 -51
Now that we have our Koalas dataframe, we can start to create the EntitySet. The current implementation does not support variable type inference for Koalas entities, so we must pass a dictionary of variable types using the variable_types parameter when calling es.entity_from_dataframe(). Aside from needing to supply the variable types, the rest of the process of creating an EntitySet is the same as if we were using pandas dataframes.
variable_types
es.entity_from_dataframe()
In [7]: es = ft.EntitySet(id="koalas_es") In [8]: es = es.entity_from_dataframe(entity_id="koalas_entity", ...: dataframe=koalas_df, ...: index="id", ...: variable_types={"id": ft.variable_types.Id, ...: "values": ft.variable_types.Numeric}) ...: In [9]: es Out[9]: Entityset: koalas_es Entities: koalas_entity [Rows: 5, Columns: 2] Relationships: No relationships
We can pass the EntitySet we created above to featuretools.dfs in order to create a feature matrix. If the EntitySet we pass to dfs is made of Koalas entities, the feature matrix we get back will be a Koalas dataframe.
dfs
In [10]: feature_matrix, features = ft.dfs(entityset=es, ....: target_entity="koalas_entity", ....: trans_primitives=["negate"], ....: max_depth=1) ....: In [11]: feature_matrix Out[11]: values -(values) id 0 14 -14 2 1 -51 51 4 2 12 -12 0 3 -35 35 1 4 103 -103 3
This feature matrix can be saved to disk or converted to a pandas dataframe and brought into memory, using the appropriate Koalas dataframe methods.
While this is a simple example to illustrate the process of using Koalas dataframes with Featuretools, this process will also work with an EntitySet containing multiple entities, as well as with aggregation primitives.
The key functionality of Featuretools is available for use with a Koalas EntitySet, and work is ongoing to add the remaining functionality that is available when using a pandas EntitySet. There are, however, some limitations to be aware of when creating a Koalas Entityset and then using it to generate a feature matrix. The most significant limitations are reviewed in more detail in this section.
Entityset
If the limitations of using a Koalas EntitySet are problematic for your problem, you may still be able to compute a larger-than-memory feature matrix by partitioning your data as described in Improving Computational Performance.
When creating a feature matrix from a Koalas EntitySet, only certain primitives can be used. Primitives that rely on the order of the entire dataframe or require an entire column for computation are currently not supported when using a Koalas EntitySet. Multivariable and time-dependent aggregation primitives also are not currently supported.
To obtain a list of the primitives that can be used with a Koalas EntitySet, you can call featuretools.list_primitives(). This will return a table of all primitives. Any primitive that can be used with a Koalas EntitySet will have a value of True in the koalas_compatible column.
featuretools.list_primitives()
True
koalas_compatible
In [12]: primitives_df = ft.list_primitives() In [13]: koalas_compatible_df = primitives_df[primitives_df["koalas_compatible"] == True] In [14]: koalas_compatible_df.head() Out[14]: name type dask_compatible koalas_compatible description valid_inputs return_type 4 sum aggregation True True Calculates the total addition, ignoring `NaN`. Numeric Numeric 7 count aggregation True True Determines the total number of values, excludi... Index Numeric 8 num_unique aggregation True True Determines the number of distinct values, igno... Discrete Numeric 9 min aggregation True True Calculates the smallest value, ignoring `NaN` ... Numeric Numeric 10 std aggregation True True Computes the dispersion relative to the mean v... Numeric Numeric In [15]: koalas_compatible_df.tail() Out[15]: name type dask_compatible koalas_compatible description valid_inputs return_type 78 minute transform True True Determines the minutes value of a datetime. Datetime Numeric 79 subtract_numeric_scalar transform True True Subtract a scalar from each element in the list. Numeric Numeric 81 modulo_by_feature transform True True Return the modulo of a scalar by each element ... Numeric Numeric 82 equal transform True True Determines if values in one list are equal to ... Variable Boolean 83 hour transform True True Determines the hour value of a datetime. Datetime Ordinal
At this time, custom primitives created with featuretools.primitives.make_trans_primitive() or featuretools.primitives.make_agg_primitive() cannot be used for running deep feature synthesis on a Koalas EntitySet. While it is possible to create custom primitives for use with a Koalas EntitySet by extending the proper primitive class, there are several potential problems in doing so, and those issues are beyond the scope of this guide.
featuretools.primitives.make_trans_primitive()
featuretools.primitives.make_agg_primitive()
When creating a Featuretools Entity from Koalas dataframes, variable type inference is not performed as it is when creating entities from pandas dataframes. This is done to improve speed as sampling the data to infer the variable types could require expensive computation on the underlying Koalas dataframe. As a consequence, users must define the variable types for each column in the supplied Dataframe. This step is needed so that the deep feature synthesis process can build the proper features based on the column types. A list of available variable types can be obtained by running featuretools.variable_types.find_variable_types().
featuretools.variable_types.find_variable_types()
By default, Featuretools checks that entities created from pandas dataframes have unique index values. Because performing this same check with Koalas could be computationally expensive, this check is not performed when creating an entity from a Koalas dataframe. When using Koalas dataframes, users must ensure that the supplied index values are unique.
When an Entity is created from a pandas dataframe, the ordering of the underlying dataframe rows is maintained. For a Koalas Entity, the ordering of the dataframe rows is not guaranteed, and Featuretools does not attempt to maintain row order in a Koalas Entity. If ordering is important, close attention must be paid to any output to avoid issues.
The Entity.add_interesting_values() method is not supported when using a Koalas Entity. If needed, users can manually set interesting_values on entities by assigning them directly with syntax similar to this: es["entity_name"]["variable_name"].interesting_values = ["Value 1", "Value 2"].
Entity.add_interesting_values()
interesting_values
es["entity_name"]["variable_name"].interesting_values = ["Value 1", "Value 2"]
When creating a Featuretools EntitySet that will be made of Koalas entities, all of the entities used to create the EntitySet must be of the same type, either all Koalas entities, all Dask entities, or all pandas entities. Featuretools does not support creating an EntitySet containing a mix of Koalas, Dask, and pandas entities.
Additionally, the EntitySet.add_interesting_values() method is not supported when using a Koalas EntitySet. Users can manually set interesting_values on entities, as described above.
EntitySet.add_interesting_values()
There are a few key limitations when generating a feature matrix from a Koalas EntitySet.
If a cutoff_time parameter is passed to featuretools.dfs() it should be a single cutoff time value, or a pandas dataframe. The current implementation will still work if a Koalas dataframe is supplied for cutoff times, but a .to_pandas() call will be made on the dataframe to convert it into a pandas dataframe. This conversion will result in a warning, and the process could take a considerable amount of time to complete depending on the size of the supplied dataframe.
cutoff_time
featuretools.dfs()
.to_pandas()
Additionally, Featuretools does not currently support the use of the approximate or training_window parameters when working with Koalas entitiysets, but should in future releases.
approximate
training_window
Finally, if the output feature matrix contains a boolean column with NaN values included, the column type may have a different datatype than the same feature matrix generated from a pandas EntitySet. If feature matrix column data types are critical, the feature matrix should be inspected to make sure the types are of the proper types, and recast as necessary.
NaN
Currently featuretools.encode_features() does not work with a Koalas dataframe as input. This will hopefully be resolved in a future release of Featuretools.
featuretools.encode_features()
The utility function featuretools.make_temporal_cutoffs() will not work properly with Koalas inputs for instance_ids or cutoffs. However, as noted above, if a cutoff_time dataframe is supplied to dfs, the supplied dataframe should be a pandas dataframe, and this can be generated by supplying pandas inputs to make_temporal_cutoffs().
featuretools.make_temporal_cutoffs()
instance_ids
cutoffs
make_temporal_cutoffs()
The use of featuretools.remove_low_information_features() cannot currently be used with a Koalas feature matrix.
featuretools.remove_low_information_features()
When manually defining a Feature, the use_previous parameter cannot be used if this feature will be applied to calculate a feature matrix from a Koalas EntitySet.
Feature
use_previous