imblearn.under_sampling
.CondensedNearestNeighbour¶
-
class
imblearn.under_sampling.
CondensedNearestNeighbour
(sampling_strategy='auto', return_indices=False, random_state=None, n_neighbors=None, n_seeds_S=1, n_jobs=1, ratio=None)[source][source]¶ Class to perform under-sampling based on the condensed nearest neighbour method.
Read more in the User Guide.
Parameters: - sampling_strategy : str, list or callable
Sampling information to sample the data set.
When
str
, specify the class targeted by the resampling. Note the the number of samples will not be equal in each. Possible choices are:'majority'
: resample only the majority class;'not minority'
: resample all classes but the minority class;'not majority'
: resample all classes but the majority class;'all'
: resample all classes;'auto'
: equivalent to'not minority'
.When
list
, the list contains the classes targeted by the resampling.When callable, function taking
y
and returns adict
. The keys correspond to the targeted classes. The values correspond to the desired number of samples for each class.
- return_indices : bool, optional (default=False)
Whether or not to return the indices of the samples randomly selected.
Deprecated since version 0.4:
return_indices
is deprecated. Use the attributesample_indices_
instead.- random_state : int, RandomState instance or None, optional (default=None)
Control the randomization of the algorithm.
- If int,
random_state
is the seed used by the random number generator; - If
RandomState
instance, random_state is the random number generator; - If
None
, the random number generator is theRandomState
instance used bynp.random
.
- If int,
- n_neighbors : int or object, optional (default=KNeighborsClassifier(n_neighbors=1))
If
int
, size of the neighbourhood to consider to compute the nearest neighbors. If object, an estimator that inherits fromsklearn.neighbors.base.KNeighborsMixin
that will be used to find the nearest-neighbors.- n_seeds_S : int, optional (default=1)
Number of samples to extract in order to build the set S.
- n_jobs : int, optional (default=1)
The number of threads to open if possible.
- ratio : str, dict, or callable
Deprecated since version 0.4: Use the parameter
sampling_strategy
instead. It will be removed in 0.6.
Notes
The method is based on [1].
Supports multi-class resampling. A one-vs.-rest scheme is used when sampling a class as proposed in [1].
References
[1] (1, 2, 3) P. Hart, “The condensed nearest neighbor rule,” In Information Theory, IEEE Transactions on, vol. 14(3), pp. 515-516, 1968. Examples
>>> from collections import Counter # doctest: +SKIP >>> from sklearn.datasets import fetch_mldata # doctest: +SKIP >>> from imblearn.under_sampling import CondensedNearestNeighbour # doctest: +SKIP >>> pima = fetch_mldata('diabetes_scale') # doctest: +SKIP >>> X, y = pima['data'], pima['target'] # doctest: +SKIP >>> print('Original dataset shape %s' % Counter(y)) # doctest: +SKIP Original dataset shape Counter({1: 500, -1: 268}) # doctest: +SKIP >>> cnn = CondensedNearestNeighbour(random_state=42) # doctest: +SKIP >>> X_res, y_res = cnn.fit_resample(X, y) #doctest: +SKIP >>> print('Resampled dataset shape %s' % Counter(y_res)) # doctest: +SKIP Resampled dataset shape Counter({-1: 268, 1: 227}) # doctest: +SKIP
Attributes: - sample_indices_ : ndarray, shape (n_new_samples)
Indices of the samples selected.
New in version 0.4:
sample_indices_
used instead ofreturn_indices=True
.
-
__init__
(sampling_strategy='auto', return_indices=False, random_state=None, n_neighbors=None, n_seeds_S=1, n_jobs=1, ratio=None)[source][source]¶ Initialize self. See help(type(self)) for accurate signature.
-
fit
(X, y)[source]¶ Check inputs and statistics of the sampler.
You should use
fit_resample
in all cases.Parameters: - X : {array-like, sparse matrix}, shape (n_samples, n_features)
Data array.
- y : array-like, shape (n_samples,)
Target array.
Returns: - self : object
Return the instance itself.
-
fit_resample
(X, y)[source]¶ Resample the dataset.
Parameters: - X : {array-like, sparse matrix}, shape (n_samples, n_features)
Matrix containing the data which have to be sampled.
- y : array-like, shape (n_samples,)
Corresponding label for each sample in X.
Returns: - X_resampled : {array-like, sparse matrix}, shape (n_samples_new, n_features)
The array containing the resampled data.
- y_resampled : array-like, shape (n_samples_new,)
The corresponding label of X_resampled.
-
fit_sample
(X, y)[source]¶ Resample the dataset.
Parameters: - X : {array-like, sparse matrix}, shape (n_samples, n_features)
Matrix containing the data which have to be sampled.
- y : array-like, shape (n_samples,)
Corresponding label for each sample in X.
Returns: - X_resampled : {array-like, sparse matrix}, shape (n_samples_new, n_features)
The array containing the resampled data.
- y_resampled : array-like, shape (n_samples_new,)
The corresponding label of X_resampled.
-
get_params
(deep=True)[source]¶ Get parameters for this estimator.
Parameters: - deep : boolean, optional
If True, will return the parameters for this estimator and contained subobjects that are estimators.
Returns: - params : mapping of string to any
Parameter names mapped to their values.
-
set_params
(**params)[source]¶ Set the parameters of this estimator.
The method works on simple estimators as well as on nested objects (such as pipelines). The latter have parameters of the form
<component>__<parameter>
so that it’s possible to update each component of a nested object.Returns: - self