adapt.instance_based.LDM
- class adapt.instance_based.LDM(estimator=None, Xt=None, copy=True, verbose=1, random_state=None, **params)[source]
- LDM : Linear Discrepancy Minimization - LDM reweights the source instances in order to minimize the linear discrepancy between the reweighted source and the target data. - The objective function is the following: \[\min_{||w||_1 = 1, w>0} \max_{||u||=1} |u^T M(w) u|\]- Where: - \(M(w) = (1/n) X_T^T X_T - X^T_S diag(w) X_S\) 
- \(X_S, X_T\) are respectively the source dataset and the target dataset of size \(m\) and \(n\) 
 - Parameters
- estimatorsklearn estimator or tensorflow Model (default=None)
- Estimator used to learn the task. If estimator is - None, a- LinearRegressioninstance is used as estimator.
- Xtnumpy array (default=None)
- Target input data. 
- copyboolean (default=True)
- Whether to make a copy of - estimatoror not.
- verboseint (default=1)
- Verbosity level. 
- random_stateint (default=None)
- Seed of random generator. 
- paramskey, value arguments
- Arguments given at the different level of the adapt object. It can be, for instance, compile or fit parameters of the estimator or kernel parameters etc… Accepted parameters can be found by calling the method - _get_legal_params(params).
 
 - References - 1
- [1] Y. Mansour, M. Mohri, and A. Rostamizadeh. “Domain adaptation: Learning bounds and algorithms”. In COLT, 2009. 
 - Examples - >>> from sklearn.linear_model import RidgeClassifier >>> from adapt.utils import make_classification_da >>> from adapt.instance_based import LDM >>> Xs, ys, Xt, yt = make_classification_da() >>> model = LDM(RidgeClassifier(), Xt=Xt, random_state=0) >>> model.fit(Xs, ys) Fit weights... Initial Discrepancy : 0.328483 Final Discrepancy : -0.000000 Fit Estimator... >>> model.score(Xt, yt) 0.5 - Attributes
- weights_numpy array
- Training instance weights. 
- estimator_object
- Estimator. 
 
 - Methods - __init__([estimator, Xt, copy, verbose, ...])- fit(X, y[, Xt, yt, domains])- Fit Adapt Model. - fit_estimator(X, y[, sample_weight, ...])- Fit estimator on X, y. - fit_weights(Xs, Xt, **kwargs)- Fit importance weighting. - Get metadata routing of this object. - get_params([deep])- Get parameters for this estimator. - predict(X[, domain])- Return estimator predictions after adaptation. - predict_estimator(X, **predict_params)- Return estimator predictions for X. - Return fitted source weights - score(X, y[, sample_weight, domain])- Return the estimator score. - set_fit_request(*[, domains])- Request metadata passed to the - fitmethod.- set_params(**params)- Set the parameters of this estimator. - set_predict_request(*[, domain])- Request metadata passed to the - predictmethod.- set_score_request(*[, domain, sample_weight])- Request metadata passed to the - scoremethod.- unsupervised_score(Xs, Xt)- Return unsupervised score. - fit(X, y, Xt=None, yt=None, domains=None, **fit_params)[source]
- Fit Adapt Model. - For feature-based models, the transformation of the input features - Xsand- Xtis first fitted. In a second stage, the- estimator_is fitted on the transformed features.- For instance-based models, source importance weights are first learned based on - Xs, ysand- Xt. In a second stage, the- estimator_is fitted on- Xs, yswith the learned importance weights.- Parameters
- Xnumpy array
- Source input data. 
- ynumpy array
- Source output data. 
- Xtarray (default=None)
- Target input data. If None, the Xt argument given in init is used. 
- ytarray (default=None)
- Target input data. Only needed for supervised and semi-supervised Adapt model. If None, the yt argument given in init is used. 
- domainsarray (default=None)
- Vector giving the domain for each source data. Can be used for multisource purpose. 
- fit_paramskey, value arguments
- Arguments given to the fit method of the estimator. 
 
- Returns
- selfreturns an instance of self
 
 
 - fit_estimator(X, y, sample_weight=None, random_state=None, warm_start=True, **fit_params)[source]
- Fit estimator on X, y. - Parameters
- Xarray
- Input data. 
- yarray
- Output data. 
- sample_weightarray
- Importance weighting. 
- random_stateint (default=None)
- Seed of the random generator 
- warm_startbool (default=True)
- If True, continue to fit - estimator_, else, a new estimator is fitted based on a copy of- estimator. (Be sure to set- copy=Trueto use- warm_start=False)
- fit_paramskey, value arguments
- Arguments given to the fit method of the estimator and to the compile method for tensorflow estimator. 
 
- Returns
- estimator_fitted estimator
 
 
 - fit_weights(Xs, Xt, **kwargs)[source]
- Fit importance weighting. - Parameters
- Xsarray
- Input source data. 
- Xtarray
- Input target data. 
- kwargskey, value argument
- Not used, present here for adapt consistency. 
 
- Returns
- weights_sample weights
 
 
 - get_metadata_routing()[source]
- Get metadata routing of this object. - Please check User Guide on how the routing mechanism works. - Returns
- routingMetadataRequest
- A - MetadataRequestencapsulating routing information.
 
 
 - get_params(deep=True)[source]
- Get parameters for this estimator. - Parameters
- deepbool, default=True
- Not used, here for scikit-learn compatibility. 
 
- Returns
- paramsdict
- Parameter names mapped to their values. 
 
 
 - predict(X, domain=None, **predict_params)[source]
- Return estimator predictions after adaptation. - For feature-based method (object which implements a - transformmethod), the input feature- Xare first transformed. Then the- predictmethod of the fitted estimator- estimator_is applied on the transformed- X.- Parameters
- Xarray
- input data 
- domainstr (default=None)
- For antisymetric feature-based method, different transformation of the input X are applied for different domains. The domain should then be specified between “src” and “tgt”. If - Nonethe default transformation is the target one.
 
- Returns
- y_predarray
- prediction of the Adapt Model. 
 
 
 - predict_estimator(X, **predict_params)[source]
- Return estimator predictions for X. - Parameters
- Xarray
- input data 
 
- Returns
- y_predarray
- prediction of estimator. 
 
 
 - score(X, y, sample_weight=None, domain=None)[source]
- Return the estimator score. - If the object has a - transformmethod, the estimator is applied on the transformed features X. For antisymetric transformation, a parameter domain can be set to specified between source and target transformation.- Call score on sklearn estimator and evaluate on tensorflow Model. - Parameters
- Xarray
- input data 
- yarray
- output data 
- sample_weightarray (default=None)
- Sample weights 
- domainstr (default=None)
- This parameter specifies for antisymetric feature-based method which transformation will be applied between “source” and “target”. If - Nonethe transformation by default is the target one.
 
- Returns
- scorefloat
- estimator score. 
 
 
 - set_fit_request(*, domains: Union[bool, None, str] = '$UNCHANGED$') adapt.instance_based._ldm.LDM[source]
- Request metadata passed to the - fitmethod.- Note that this method is only relevant if - enable_metadata_routing=True(see- sklearn.set_config()). Please see User Guide on how the routing mechanism works.- The options for each parameter are: - True: metadata is requested, and passed to- fitif provided. The request is ignored if metadata is not provided.
- False: metadata is not requested and the meta-estimator will not pass it to- fit.
- None: metadata is not requested, and the meta-estimator will raise an error if the user provides it.
- str: metadata should be passed to the meta-estimator with this given alias instead of the original name.
 - The default ( - sklearn.utils.metadata_routing.UNCHANGED) retains the existing request. This allows you to change the request for some parameters and not others.- New in version 1.3. - Note - This method is only relevant if this estimator is used as a sub-estimator of a meta-estimator, e.g. used inside a - Pipeline. Otherwise it has no effect.- Parameters
- domainsstr, True, False, or None, default=sklearn.utils.metadata_routing.UNCHANGED
- Metadata routing for - domainsparameter in- fit.
 
- Returns
- selfobject
- The updated object. 
 
 
 - set_params(**params)[source]
- Set the parameters of this estimator. - Parameters
- **paramsdict
- Estimator parameters. 
 
- Returns
- selfestimator instance
- Estimator instance. 
 
 
 - set_predict_request(*, domain: Union[bool, None, str] = '$UNCHANGED$') adapt.instance_based._ldm.LDM[source]
- Request metadata passed to the - predictmethod.- Note that this method is only relevant if - enable_metadata_routing=True(see- sklearn.set_config()). Please see User Guide on how the routing mechanism works.- The options for each parameter are: - True: metadata is requested, and passed to- predictif provided. The request is ignored if metadata is not provided.
- False: metadata is not requested and the meta-estimator will not pass it to- predict.
- None: metadata is not requested, and the meta-estimator will raise an error if the user provides it.
- str: metadata should be passed to the meta-estimator with this given alias instead of the original name.
 - The default ( - sklearn.utils.metadata_routing.UNCHANGED) retains the existing request. This allows you to change the request for some parameters and not others.- New in version 1.3. - Note - This method is only relevant if this estimator is used as a sub-estimator of a meta-estimator, e.g. used inside a - Pipeline. Otherwise it has no effect.- Parameters
- domainstr, True, False, or None, default=sklearn.utils.metadata_routing.UNCHANGED
- Metadata routing for - domainparameter in- predict.
 
- Returns
- selfobject
- The updated object. 
 
 
 - set_score_request(*, domain: Union[bool, None, str] = '$UNCHANGED$', sample_weight: Union[bool, None, str] = '$UNCHANGED$') adapt.instance_based._ldm.LDM[source]
- Request metadata passed to the - scoremethod.- Note that this method is only relevant if - enable_metadata_routing=True(see- sklearn.set_config()). Please see User Guide on how the routing mechanism works.- The options for each parameter are: - True: metadata is requested, and passed to- scoreif provided. The request is ignored if metadata is not provided.
- False: metadata is not requested and the meta-estimator will not pass it to- score.
- None: metadata is not requested, and the meta-estimator will raise an error if the user provides it.
- str: metadata should be passed to the meta-estimator with this given alias instead of the original name.
 - The default ( - sklearn.utils.metadata_routing.UNCHANGED) retains the existing request. This allows you to change the request for some parameters and not others.- New in version 1.3. - Note - This method is only relevant if this estimator is used as a sub-estimator of a meta-estimator, e.g. used inside a - Pipeline. Otherwise it has no effect.- Parameters
- domainstr, True, False, or None, default=sklearn.utils.metadata_routing.UNCHANGED
- Metadata routing for - domainparameter in- score.
- sample_weightstr, True, False, or None, default=sklearn.utils.metadata_routing.UNCHANGED
- Metadata routing for - sample_weightparameter in- score.
 
- Returns
- selfobject
- The updated object.