Struct roqoqo::noise_models::ImperfectReadoutModel
source · pub struct ImperfectReadoutModel {
prob_detect_0_as_1: HashMap<usize, f64>,
prob_detect_1_as_0: HashMap<usize, f64>,
}
Expand description
Noise model representing readout errors.
Readout errors are modeled by two probabilities in this simple model. One probability to detect a 1 instead of a 0 when the quantum measurement gives 0 and one probability to detect a 0 instead of a 1 when the quantum measurement gives 1.
§Example
use roqoqo::noise_models::ImperfectReadoutModel;
let model = ImperfectReadoutModel::new_with_uniform_error(3, 0.5, 0.5).unwrap();
let model = model.set_error_probabilites(2, 0.3, 0.7).unwrap();
let uniform_prob = model.prob_detect_0_as_1(&0);
assert_eq!(uniform_prob, 0.5);
let lower_prob = model.prob_detect_0_as_1(&2);
assert_eq!(lower_prob, 0.3);
let higher_prob = model.prob_detect_1_as_0(&2);
assert_eq!(higher_prob, 0.7);
Fields§
§prob_detect_0_as_1: HashMap<usize, f64>
Decoherence rates for all qubits
prob_detect_1_as_0: HashMap<usize, f64>
Implementations§
source§impl ImperfectReadoutModel
impl ImperfectReadoutModel
sourcepub fn new_with_uniform_error(
number_qubits: usize,
prob_detect_0_as_1: f64,
prob_detect_1_as_0: f64,
) -> Result<Self, RoqoqoBackendError>
pub fn new_with_uniform_error( number_qubits: usize, prob_detect_0_as_1: f64, prob_detect_1_as_0: f64, ) -> Result<Self, RoqoqoBackendError>
Convenience function to create uniform error probabilities
§Arguments
number_qubits
- The number of qubits the uniform error probabilites should be initialized for.prob_detect_0_as_1
- The error probability to detect a 1 instead of a 0 when measuring 0prob_detect_1_as_0
- The error probability to detect a 0 instead of a 1 when measuring 1
§Returns
Ok(ImperfectReadoutModel)
- The new error modelErr(RoqoqoError)
- Probabilities are not valid (< 0 or > 1)
sourcepub fn set_error_probabilites(
self,
qubit: usize,
prob_detect_0_as_1: f64,
prob_detect_1_as_0: f64,
) -> Result<Self, RoqoqoBackendError>
pub fn set_error_probabilites( self, qubit: usize, prob_detect_0_as_1: f64, prob_detect_1_as_0: f64, ) -> Result<Self, RoqoqoBackendError>
Set and overwrite the measurement error probabilities
§Arguments
qubits
- The qubits for which error rates are set.prob_detect_0_as_1
- The error probability to detect a 1 instead of a 0 when measuring 0prob_detect_1_as_0
- The error probability to detect a 0 instead of a 1 when measuring 1
§Returns
Ok(ImperfectReadoutModel)
- The new error modelErr(RoqoqoError)
- Probabilities are not valid (< 0 or > 1)
sourcepub fn prob_detect_0_as_1(&self, qubit: &usize) -> f64
pub fn prob_detect_0_as_1(&self, qubit: &usize) -> f64
Trait Implementations§
source§impl Clone for ImperfectReadoutModel
impl Clone for ImperfectReadoutModel
source§fn clone(&self) -> ImperfectReadoutModel
fn clone(&self) -> ImperfectReadoutModel
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§impl Debug for ImperfectReadoutModel
impl Debug for ImperfectReadoutModel
source§impl Default for ImperfectReadoutModel
impl Default for ImperfectReadoutModel
source§fn default() -> ImperfectReadoutModel
fn default() -> ImperfectReadoutModel
Returns the “default value” for a type. Read more
source§impl<'de> Deserialize<'de> for ImperfectReadoutModel
impl<'de> Deserialize<'de> for ImperfectReadoutModel
source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
source§impl From<ImperfectReadoutModel> for NoiseModel
impl From<ImperfectReadoutModel> for NoiseModel
source§fn from(value: ImperfectReadoutModel) -> Self
fn from(value: ImperfectReadoutModel) -> Self
Converts to this type from the input type.
source§impl PartialEq for ImperfectReadoutModel
impl PartialEq for ImperfectReadoutModel
source§fn eq(&self, other: &ImperfectReadoutModel) -> bool
fn eq(&self, other: &ImperfectReadoutModel) -> bool
This method tests for
self
and other
values to be equal, and is used
by ==
.source§impl Serialize for ImperfectReadoutModel
impl Serialize for ImperfectReadoutModel
impl StructuralPartialEq for ImperfectReadoutModel
Auto Trait Implementations§
impl Freeze for ImperfectReadoutModel
impl RefUnwindSafe for ImperfectReadoutModel
impl Send for ImperfectReadoutModel
impl Sync for ImperfectReadoutModel
impl Unpin for ImperfectReadoutModel
impl UnwindSafe for ImperfectReadoutModel
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self
from the equivalent element of its
superset. Read moresource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self
is actually part of its subset T
(and can be converted to it).source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset
but without any property checks. Always succeeds.source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self
to the equivalent element of its superset.