Source code for lale.lib.sklearn.min_max_scaler

# Copyright 2019 IBM Corporation
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

import lale.helpers
import lale.operators
import sklearn.preprocessing

[docs]class MinMaxScalerImpl: def __init__(self, **hyperparams): self._hyperparams = hyperparams
[docs] def fit(self, X, y=None): self._sklearn_model = sklearn.preprocessing.MinMaxScaler( **self._hyperparams) self._sklearn_model.fit(X) return self
[docs] def transform(self, X): return self._sklearn_model.transform(X)
[docs] def partial_fit(self, X, y=None): if not hasattr(self, "_sklearn_model"): self._sklearn_model = sklearn.preprocessing.MinMaxScaler( **self._hyperparams) self._sklearn_model.partial_fit(X) return self
_input_schema_fit = { '$schema': 'http://json-schema.org/draft-04/schema#', 'description': 'Input data schema for training.', 'type': 'object', 'required': ['X'], 'additionalProperties': False, 'properties': { 'X': { 'description': 'Features; the outer array is over samples.', 'type': 'array', 'items': {'type': 'array', 'items': {'type': 'number'}}}, 'y': { 'description': 'Target class labels (ignored).', 'type': 'array', 'items': {'type': 'number', 'minimum': 0}}}} _input_schema_predict = { '$schema': 'http://json-schema.org/draft-04/schema#', 'description': 'Input data schema for predictions.', 'type': 'object', 'required': ['X'], 'additionalProperties': False, 'properties': { 'X': { 'description': 'Features; the outer array is over samples.', 'type': 'array', 'items': {'type': 'array', 'items': {'type': 'number'}}}}} _output_schema = { '$schema': 'http://json-schema.org/draft-04/schema#', 'description': 'Output data schema for transformed data.', 'type': 'array', 'items': {'type': 'array', 'items': {'type': 'number'}}} _hyperparams_schema = { '$schema': 'http://json-schema.org/draft-04/schema#', 'description': 'Hyperparameter schema.', 'allOf': [ { 'description': 'This first sub-object lists all constructor arguments with their ' 'types, one at a time, omitting cross-argument constraints.', 'type': 'object', 'additionalProperties': False, 'required': ['feature_range', 'copy'], 'relevantToOptimizer': [], #['feature_range'], 'properties': { 'feature_range': { 'description': 'Desired range of transformed data.', 'type': 'array', 'typeForOptimizer': 'tuple', 'minItems': 2, 'maxItems': 2, 'default': [0, 1]}, 'copy': { 'description': 'Set to False to perform inplace row normalization and avoid ' 'a copy (if the input is already a numpy array).', 'type': 'boolean', 'default': True}}}]} _combined_schemas = { '$schema': 'http://json-schema.org/draft-04/schema#', 'description': 'Combined schema for expected data and hyperparameters.', 'documentation_url': 'https://scikit-learn.org/stable/modules/generated/sklearn.preprocessing.MinMaxScaler.html', 'type': 'object', 'tags': { 'pre': ['~categoricals'], 'op': ['transformer', 'interpretable'], 'post': []}, 'properties': { 'input_fit': _input_schema_fit, 'input_predict': _input_schema_predict, 'output': _output_schema, 'hyperparams': _hyperparams_schema } } if __name__ == "__main__": lale.helpers.validate_is_schema(_combined_schemas) MinMaxScaler = lale.operators.make_operator(MinMaxScalerImpl, _combined_schemas)