Skip to content

Commit

Permalink
Improve documentation
Browse files Browse the repository at this point in the history
  • Loading branch information
TrAyZeN authored and kingofpayne committed Jul 15, 2024
1 parent a6cb5ac commit d3606db
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 13 deletions.
17 changes: 13 additions & 4 deletions src/cpa.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ use rayon::{
};
use std::{iter::zip, ops::Add};

/// Computes the [`Cpa`] of the given traces using [`CpaProcessor`].
/// Compute the [`Cpa`] of the given traces using [`CpaProcessor`].
///
/// # Panics
/// - Panic if `leakages.shape()[0] != plaintexts.shape()[0]`
Expand Down Expand Up @@ -47,6 +47,9 @@ where
.finalize()
}

/// Result of the CPA[^1] on some traces.
///
/// [^1]: <https://www.iacr.org/archive/ches2004/31560016/31560016.pdf>
#[derive(Debug)]
pub struct Cpa {
/// Guess range upper excluded bound
Expand All @@ -56,16 +59,19 @@ pub struct Cpa {
}

impl Cpa {
/// Rank guesses.
pub fn rank(&self) -> Array1<usize> {
let rank = argsort_by(&self.max_corr().to_vec()[..], f32::total_cmp);

Array1::from_vec(rank)
}

/// Return the Pearson correlation coefficients.
pub fn corr(&self) -> ArrayView2<f32> {
self.corr.view()
}

/// Return the guess with the highest Pearson correlation coefficient.
pub fn best_guess(&self) -> usize {
let max_corr = self.max_corr();

Expand All @@ -81,14 +87,17 @@ impl Cpa {
best_guess
}

/// Return the maximum Pearson correlation coefficient for each guess.
pub fn max_corr(&self) -> Array1<f32> {
max_per_row(self.corr.view())
}
}

/// A processor that computes the [`Cpa`] of the given traces.
///
/// It implements Algorithm 4 of https://eprint.iacr.org/2013/794.pdf
/// It implements algorithm 4 from [^1].
///
/// [^1]: <https://eprint.iacr.org/2013/794.pdf>
pub struct CpaProcessor<F>
where
F: Fn(usize, usize) -> usize,
Expand All @@ -108,7 +117,7 @@ where
/// Sum of square of traces per key guess
guess_sum_squares_leakages: Array1<usize>,
/// Sum of traces per plaintext used
/// See 4.3 in https://eprint.iacr.org/2013/794.pdf
/// See 4.3 in <https://eprint.iacr.org/2013/794.pdf>
plaintext_sum_leakages: Array2<usize>,
/// Leakage model
leakage_func: F,
Expand Down Expand Up @@ -165,7 +174,7 @@ where
self.num_traces += 1;
}

/// Finalizes the calculation after feeding the overall traces.
/// Finalize the calculation after feeding the overall traces.
pub fn finalize(&self) -> Cpa {
let mut modeled_leakages = Array1::zeros(self.guess_range);

Expand Down
10 changes: 5 additions & 5 deletions src/cpa_normal.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ use std::{iter::zip, ops::Add};

use crate::cpa::Cpa;

/// Computes the [`Cpa`] of the given traces using [`CpaProcessor`].
/// Compute the [`Cpa`] of the given traces using [`CpaProcessor`].
///
/// # Panics
/// - Panic if `leakages.shape()[0] != plaintexts.shape()[0]`
Expand Down Expand Up @@ -42,6 +42,9 @@ where
.finalize()
}

/// A processor that computes the [`Cpa`] of the given traces.
///
/// [^1]: <https://www.iacr.org/archive/ches2004/31560016/31560016.pdf>
pub struct CpaProcessor<F>
where
F: Fn(ArrayView1<usize>, usize) -> usize,
Expand All @@ -68,9 +71,6 @@ where
num_traces: usize,
}

/* This class implements the CPA algorithm shown in:
https://www.iacr.org/archive/ches2004/31560016/31560016.pdf */

impl<F> CpaProcessor<F>
where
F: Fn(ArrayView1<usize>, usize) -> usize,
Expand Down Expand Up @@ -144,7 +144,7 @@ where
}
}

/// Finalizes the calculation after feeding the overall traces.
/// Finalize the calculation after feeding the overall traces.
pub fn finalize(&self) -> Cpa {
let cov_n = self.cov.clone() / self.num_traces as f32;
let avg_keys = self.guess_sum_leakages.clone() / self.num_traces as f32;
Expand Down
16 changes: 12 additions & 4 deletions src/dpa.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,10 @@ use std::{iter::zip, marker::PhantomData, ops::Add};

use crate::util::{argsort_by, max_per_row};

/// Compute the [`Dpa`] of the given traces using [`DpaProcessor`].
///
/// # Panics
/// Panics if `chunk_size` is not strictly positive.
/// Panic if `chunk_size` is not strictly positive.
pub fn dpa<M, T, F>(
leakages: ArrayView2<T>,
metadata: ArrayView1<M>,
Expand Down Expand Up @@ -40,6 +42,9 @@ where
.finalize()
}

/// Result of the DPA[^1] on some traces.
///
/// [^1]: <https://paulkocher.com/doc/DifferentialPowerAnalysis.pdf>
#[derive(Debug)]
pub struct Dpa {
/// Guess range upper excluded bound
Expand All @@ -48,16 +53,19 @@ pub struct Dpa {
}

impl Dpa {
/// Return the rank of guesses
pub fn rank(&self) -> Array1<usize> {
let rank = argsort_by(&self.max_differential_curves().to_vec()[..], f32::total_cmp);

Array1::from_vec(rank)
}

/// Return the differential curves
pub fn differential_curves(&self) -> ArrayView2<f32> {
self.differential_curves.view()
}

/// Return the guess with the highest differential peak.
pub fn best_guess(&self) -> usize {
let max_corr = self.max_differential_curves();

Expand All @@ -73,16 +81,16 @@ impl Dpa {
best_guess
}

/// Return the maximum differential peak for each guess.
pub fn max_differential_curves(&self) -> Array1<f32> {
max_per_row(self.differential_curves.view())
}
}

/// A processor that computes the [`Dpa`] of the given traces.
///
/// It implements algorithm from:
/// https://paulkocher.com/doc/DifferentialPowerAnalysis.pdf
/// https://web.mit.edu/6.857/OldStuff/Fall03/ref/kocher-DPATechInfo.pdf
/// [^1]: <https://paulkocher.com/doc/DifferentialPowerAnalysis.pdf>
/// [^2]: <https://web.mit.edu/6.857/OldStuff/Fall03/ref/kocher-DPATechInfo.pdf>
pub struct DpaProcessor<M, F>
where
F: Fn(M, usize) -> bool,
Expand Down

0 comments on commit d3606db

Please sign in to comment.