privkit.metrics package#
- class privkit.metrics.AccuracyFD(probe_path: str, baseline_path: str, iou_threshold: float = 0.5)#
Bases:
Metric
- DATA_TYPE_ID = ['facial_data']#
- METRIC_ID = 'accuracy_face_detection'#
- METRIC_INFO = 'The face detection accuracy measures the ratio of correctly detected faces to the total number of faces of a face detection model.'#
- METRIC_NAME = 'Face Detection Accuracy'#
- execute()#
Executes the Face Detection Accuracy metric
- Returns:
dictionary with the detection accuracy and the Intersection Over Union (IoU) of the detection
- static get_iou(ground_truth: torch.tensor, pred: torch.tensor)#
Returns the IoU value of a bounding box prediction
- Parameters:
ground_truth (tensor) – a tensor with the ground truth bounding box coordinates
pred (tensor) – a tensor with the predicted bounding box coordinates
- Returns:
IoU value
- plot()#
Plots the results of the metric. This is specific to the metric.
- class privkit.metrics.AdversaryError#
Bases:
Metric
- DATA_TYPE_ID = ['location_data']#
- METRIC_ID = 'adv_error'#
- METRIC_INFO = 'The adversary error measures the error between the data obtained by an adversary after applying an attack and the original data. '#
- METRIC_NAME = 'Adversary Error'#
- execute(location_data: LocationData)#
Executes the adversary error metric.
- Parameters:
location_data (privkit.LocationData) – data where adversary error will be computed
- Returns:
data with the computed metric
- plot()#
Plot adversary error metric
- class privkit.metrics.CMC(probe_path: str, gallery_path: str, model_name: str = 'ArcFace', detector_backend: str = 'retinaface')#
Bases:
Metric
- DATA_TYPE_ID = ['facial_data']#
- METRIC_ID = 'cmc_curve'#
- METRIC_INFO = "CMC quantifies the likelihood of successful identification by indicating the proportion of queries where the correct match is found within the top N ranked results, providing insights into the system's overall recognition accuracy across different rank levels. It is assumed that both probe and gallery images associated with the same identity share identical names, and each identity is represented by only a single image in both the probe and gallery datasets. "#
- METRIC_NAME = 'Cumulative Matching Characteristics Curve'#
- execute()#
Executes the CMC metric
- Returns:
dictionary with the computed metric
- plot()#
Plots the results of the metric. This is specific to the metric.
- class privkit.metrics.F1ScoreMM#
Bases:
Metric
- DATA_TYPE_ID = ['location_data']#
- METRIC_ID = 'f1_score_mm'#
- METRIC_INFO = 'F1 Score can be defined as the harmonic mean between precision and recall calculated as follows: F1 = 2 * (precision * recall) / (precision + recall). In the context of Map-Matching (MM), precision is defined as precision = Length_correct / Length_matched and Recall is defined as recall = Length_correct / Length_truth. '#
- METRIC_NAME = 'F1 Score MM'#
- compute_f1_score(G: networkx.MultiDiGraph, gt_path: List, mm_path: List, length_truth: int, length_matched: int)#
Compute the F1 Score metric.
- Parameters:
G (networkx.MultiDiGraph) – road network represented as a directed graph
gt_path (List) – ground-truth path
mm_path (List) – map-matched path
length_truth (int) – length of the ground-truth path
length_matched (int) – length of the map-matched path
- Returns:
f1 score value
- execute(location_data: LocationData, G: networkx.MultiDiGraph | None = None)#
Executes the F1 Score metric.
- Parameters:
location_data (privkit.LocationData) – data where F1 Score will be computed
G (networkx.MultiDiGraph) – road network represented as a directed graph
- Returns:
data with the computed metric
- static get_length_path(G: networkx.MultiDiGraph, nearest_nodes: List[int])#
Compute the length of the path
- Parameters:
G (networkx.MultiDiGraph) – road network represented as a directed graph
nearest_nodes (List[int]) – list with the identifiers of the nearest nodes
- Returns:
path and length of the path
- static matches(list1: List, list2: List)#
Computes where two lists match
- Parameters:
list1 (List) – list to match
list2 (List) – list to match
- plot()#
Plot F1 Score metric
- class privkit.metrics.FID(probe_path: str, baseline_path: str)#
Bases:
Metric
- DATA_TYPE_ID = ['facial_data']#
- METRIC_ID = 'frechet_inception_distance'#
- METRIC_INFO = 'The FID measures the quality of generated images quantitatively with the similarity between the distribution of features extracted from real and generated images. This implementation is based on [https://machinelearningmastery.com/how-to-implement-the-frechet-inception-distance-fid-from-scratch/].'#
- METRIC_NAME = 'Frechét Inception Distance'#
- static calculate_fid(images1: pandas.core.frame.DataFrame, images2: pandas.core.frame.DataFrame)#
Returns the FID value between two image collections with the InceptionV3 model
- Parameters:
images1 (pd.DataFrame) – the first image collection
images2 (pd.DataFrame) – the second image collection
- Returns:
the FID value
- execute()#
Executes the FID metric
- Returns:
dictionary with the computed metric
- plot()#
Plots the results of the metric. This is specific to the metric.
- static scale_images(images: list, new_shape: tuple)#
Returns a list of resized images
- Parameters:
images (list) – the images to be resized
new_shape (tuple) – the shape of the new resized images
- Returns:
a list with resized images
- class privkit.metrics.MatchingScores(probe_path: str, gallery_path: str, model_name: str = 'ArcFace', detector_backend: str = 'retinaface')#
Bases:
Metric
- DATA_TYPE_ID = ['facial_data']#
- METRIC_ID = 'matching_scores'#
- METRIC_INFO = 'Matching scores are the numerical values assigned to pairs of facial images to quantify the similarity between them.'#
- METRIC_NAME = 'Matching Scores'#
- execute()#
Executes the ROC curve and AUC value.
- Parameters:
facial_data (privkit.FacialData) – data where ROC curve and AUC will be computed
df_pairs (pd.DataFrame) – data frame with the identities (#####)
- Returns:
data with the computed metric
- plot()#
Plots the results of the metric. This is specific to the metric.
- class privkit.metrics.Metric#
Bases:
ABC
Metric is an abstract class for a generic metric. Defines a series of methods common to all metrics. Provides a general method to execute, to plot and to print statistics of the metric. Requires the definition of a METRIC_ID, METRIC_NAME, METRIC_INFO, METRIC_REF, and DATA_TYPE_ID (of the data types this metric can be applied to).
- property DATA_TYPE_ID: List[str]#
Identifiers of the data types that the metric is applied to
- property METRIC_ID: str#
Identifier of the metric
- property METRIC_INFO: str#
Information about the metric and how it works
- property METRIC_NAME: str#
Name of the metric
- abstract execute(*args)#
Executes the metric. This is specific to the metric.
- abstract plot(*args)#
Plots the results of the metric. This is specific to the metric.
- class privkit.metrics.QualityLoss#
Bases:
Metric
- DATA_TYPE_ID = ['location_data']#
- METRIC_ID = 'quality_loss'#
- METRIC_INFO = 'Quality loss measures the loss of data quality, resulting from the application of a privacy-preserving mechanism.'#
- METRIC_NAME = 'Quality Loss'#
- execute(location_data: LocationData)#
Executes the quality loss metric.
- Parameters:
location_data (privkit.LocationData) – data where quality loss will be computed
- Returns:
data with the computed metric
- static get_quality_loss_point(latitude: float, longitude: float, obf_latitude: float, obf_longitude: float)#
Executes the quality loss metric at a given the ground-truth and the obfuscated report. :param latitude: original latitude :param longitude: original longitude :param obf_latitude: obfuscated latitude :param obf_longitude: obfuscated longitudes :returns: quality loss between original and obfuscated data
- plot()#
Plot quality loss metric
- class privkit.metrics.ROC_find(df_pairs: pandas.core.frame.DataFrame)#
Bases:
Metric
- DATA_TYPE_ID = ['facial_data']#
- METRIC_ID = 'roc_find'#
- METRIC_INFO = "ROC curve visually represents the trade-off between a face recognition (for verification) binary classification model's ability to correctly identify positive instances (true matches) and its tendency to make false positive errors. Faster than the ROC_verify implementation for a large number of identities. "#
- METRIC_NAME = 'Receiver Operating Characteristic (ROC) curve'#
- execute()#
Executes the Receiver Operating Characteristic (ROC) curve and calculates the Area Under the Curve (AUC) value
- Returns:
A dictionary containing the True Positive Rate (TPR), False Positive Rate (FPR), and corresponding thresholds values for the ROC curve along with the AUC value
- plot()#
Plots the results of the metric. This is specific to the metric.
- class privkit.metrics.ROC_verify(df_pairs: pandas.core.frame.DataFrame, model_name: str = 'ArcFace', detector_backend: str = 'retinaface')#
Bases:
Metric
- DATA_TYPE_ID = ['facial_data']#
- METRIC_ID = 'roc_verify'#
- METRIC_INFO = "ROC curve visually represents the trade-off between a face recognition (for verification) binary classification model's ability to correctly identify positive instances (true matches) and its tendency to make false positive errors."#
- METRIC_NAME = 'Receiver Operating Characteristic (ROC) Curve'#
- execute()#
Executes the Receiver Operating Characteristic (ROC) curve and calculates the Area Under the Curve (AUC) value
- Returns:
A dictionary containing the True Positive Rate (TPR), False Positive Rate (FPR), and corresponding thresholds values for the ROC curve along with the AUC value
- plot()#
Plots the results of the metric. This is specific to the metric.
- class privkit.metrics.SSIM(probe_path: str, baseline_path: str)#
Bases:
Metric
- DATA_TYPE_ID = ['facial_data']#
- METRIC_ID = 'ssim'#
- METRIC_INFO = 'SSIM quantifies the similarity between two images by assessing their structural information and pixel-wise content. '#
- METRIC_NAME = 'Structure Similarity Index (SSIM)'#
- execute()#
Executes the SSIM metric.
- Returns:
dictionary with the SSIM values
- plot()#
Plots the results of the metric. This is specific to the metric.