2020-12-10 19:04:33 +01:00
|
|
|
from data import LabelledCollection
|
2020-12-11 19:28:17 +01:00
|
|
|
from quapy.method.aggregative import AggregativeQuantifier, AggregativeProbabilisticQuantifier
|
2020-12-10 19:04:33 +01:00
|
|
|
from method.base import BaseQuantifier
|
|
|
|
from utils.util import temp_seed
|
|
|
|
import numpy as np
|
|
|
|
from joblib import Parallel, delayed
|
|
|
|
from tqdm import tqdm
|
|
|
|
|
|
|
|
|
|
|
|
def artificial_sampling_prediction(
|
|
|
|
model: BaseQuantifier,
|
|
|
|
test: LabelledCollection,
|
|
|
|
sample_size,
|
2020-12-11 19:28:17 +01:00
|
|
|
n_prevpoints=210,
|
|
|
|
n_repetitions=1,
|
2020-12-10 19:04:33 +01:00
|
|
|
n_jobs=-1,
|
|
|
|
random_seed=42):
|
|
|
|
"""
|
|
|
|
Performs the predictions for all samples generated according to the artificial sampling protocol.
|
|
|
|
:param model: the model in charge of generating the class prevalence estimations
|
|
|
|
:param test: the test set on which to perform arificial sampling
|
|
|
|
:param sample_size: the size of the samples
|
2020-12-11 19:28:17 +01:00
|
|
|
:param n_prevpoints: the number of different prevalences to sample
|
|
|
|
:param n_repetitions: the number of repetitions for each prevalence
|
2020-12-10 19:04:33 +01:00
|
|
|
:param n_jobs: number of jobs to be run in parallel
|
|
|
|
:param random_seed: allows to replicate the samplings. The seed is local to the method and does not affect
|
|
|
|
any other random process.
|
2020-12-11 19:28:17 +01:00
|
|
|
:return: two ndarrays of [m,n] with m the number of samples (n_prevpoints*n_repetitions) and n the
|
2020-12-10 19:04:33 +01:00
|
|
|
number of classes. The first one contains the true prevalences for the samples generated while the second one
|
|
|
|
containing the the prevalences estimations
|
|
|
|
"""
|
|
|
|
|
|
|
|
with temp_seed(random_seed):
|
2020-12-11 19:28:17 +01:00
|
|
|
indexes = list(test.artificial_sampling_index_generator(sample_size, n_prevpoints, n_repetitions))
|
|
|
|
|
|
|
|
if isinstance(model, AggregativeQuantifier):
|
|
|
|
quantification_func = model.aggregate
|
|
|
|
if isinstance(model, AggregativeProbabilisticQuantifier):
|
|
|
|
print('\tpreclassifying with soft')
|
|
|
|
preclassified_instances = model.posterior_probabilities(test.instances)
|
|
|
|
else:
|
|
|
|
print('\tpreclassifying with hard')
|
|
|
|
preclassified_instances = model.classify(test.instances)
|
|
|
|
test = LabelledCollection(preclassified_instances, test.labels)
|
|
|
|
else:
|
|
|
|
quantification_func = model.quantify
|
|
|
|
print('not an aggregative')
|
2020-12-10 19:04:33 +01:00
|
|
|
|
|
|
|
def _predict_prevalences(index):
|
|
|
|
sample = test.sampling_from_index(index)
|
|
|
|
true_prevalence = sample.prevalence()
|
2020-12-11 19:28:17 +01:00
|
|
|
estim_prevalence = quantification_func(sample.instances)
|
2020-12-10 19:04:33 +01:00
|
|
|
return true_prevalence, estim_prevalence
|
|
|
|
|
|
|
|
results = Parallel(n_jobs=n_jobs)(
|
2020-12-11 19:28:17 +01:00
|
|
|
delayed(_predict_prevalences)(index) for index in tqdm(indexes, desc='[artificial sampling protocol] predicting')
|
2020-12-10 19:04:33 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
true_prevalences, estim_prevalences = zip(*results)
|
|
|
|
true_prevalences = np.asarray(true_prevalences)
|
|
|
|
estim_prevalences = np.asarray(estim_prevalences)
|
|
|
|
|
|
|
|
return true_prevalences, estim_prevalences
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|