Maestro 0.2.5
Unified interface for quantum circuit simulation
Loading...
Searching...
No Matches
Simulators::QcsimPauliPropagator Class Reference

#include <QcsimPauliPropagator.h>

+ Inheritance diagram for Simulators::QcsimPauliPropagator:
+ Collaboration diagram for Simulators::QcsimPauliPropagator:

Public Member Functions

void ApplyCCX (int controlQubit1, int controlQubit2, int targetQubit)
 
void ApplyCH (int controlQubit, int targetQubit)
 
void ApplyCP (int controlQubit, int targetQubit, double lambda)
 
void ApplyCRX (int controlQubit, int targetQubit, double angle)
 
void ApplyCRY (int controlQubit, int targetQubit, double angle)
 
void ApplyCRZ (int controlQubit, int targetQubit, double angle)
 
void ApplyCS (int controlQubit, int targetQubit)
 
void ApplyCSDAG (int controlQubit, int targetQubit)
 
void ApplyCSwap (int controlQubit, int targetQubit1, int targetQubit2)
 
void ApplyCSX (int controlQubit, int targetQubit)
 
void ApplyCSXDAG (int controlQubit, int targetQubit)
 
void ApplyCU (int controlQubit, int targetQubit, double theta, double phi, double lambda, double gamma=0.0)
 
void ApplyP (int qubit, double lambda)
 
void ApplyT (int qubit)
 
void ApplyTDG (int qubit)
 
void ApplyU (int qubit, double theta, double phi, double lambda, double gamma=0.0)
 
std::unique_ptr< QcsimPauliPropagatorClone () const
 

Static Public Member Functions

static double GetCost (const std::shared_ptr< Circuits::Circuit<> > &circuit)
 
static double GetSamplingCost (const std::shared_ptr< Circuits::Circuit<> > &circuit, size_t nrQubitsSampled, size_t samples)
 

Detailed Description

Definition at line 22 of file QcsimPauliPropagator.h.

Member Function Documentation

◆ ApplyCCX()

void Simulators::QcsimPauliPropagator::ApplyCCX ( int  controlQubit1,
int  controlQubit2,
int  targetQubit 
)
inline

Definition at line 150 of file QcsimPauliPropagator.h.

References ApplyCSX(), ApplyCSXDAG(), and ApplyCX().

◆ ApplyCH()

void Simulators::QcsimPauliPropagator::ApplyCH ( int  controlQubit,
int  targetQubit 
)
inline

Definition at line 37 of file QcsimPauliPropagator.h.

References ApplyCX(), ApplyH(), ApplyS(), ApplySDG(), ApplyT(), and ApplyX().

◆ ApplyCP()

void Simulators::QcsimPauliPropagator::ApplyCP ( int  controlQubit,
int  targetQubit,
double  lambda 
)
inline

Definition at line 93 of file QcsimPauliPropagator.h.

References ApplyCX(), and ApplyP().

◆ ApplyCRX()

void Simulators::QcsimPauliPropagator::ApplyCRX ( int  controlQubit,
int  targetQubit,
double  angle 
)
inline

Definition at line 65 of file QcsimPauliPropagator.h.

References ApplyCX(), and ApplyH().

◆ ApplyCRY()

void Simulators::QcsimPauliPropagator::ApplyCRY ( int  controlQubit,
int  targetQubit,
double  angle 
)
inline

Definition at line 76 of file QcsimPauliPropagator.h.

References ApplyCX().

◆ ApplyCRZ()

void Simulators::QcsimPauliPropagator::ApplyCRZ ( int  controlQubit,
int  targetQubit,
double  angle 
)
inline

Definition at line 84 of file QcsimPauliPropagator.h.

References ApplyCX().

◆ ApplyCS()

void Simulators::QcsimPauliPropagator::ApplyCS ( int  controlQubit,
int  targetQubit 
)
inline

Definition at line 102 of file QcsimPauliPropagator.h.

References ApplyCX(), ApplyT(), and ApplyTDG().

Referenced by ApplyCSX().

◆ ApplyCSDAG()

void Simulators::QcsimPauliPropagator::ApplyCSDAG ( int  controlQubit,
int  targetQubit 
)
inline

Definition at line 110 of file QcsimPauliPropagator.h.

References ApplyCX(), ApplyT(), and ApplyTDG().

Referenced by ApplyCSXDAG().

◆ ApplyCSwap()

void Simulators::QcsimPauliPropagator::ApplyCSwap ( int  controlQubit,
int  targetQubit1,
int  targetQubit2 
)
inline

Definition at line 130 of file QcsimPauliPropagator.h.

References ApplyCSX(), ApplyCX(), and ApplyP().

◆ ApplyCSX()

void Simulators::QcsimPauliPropagator::ApplyCSX ( int  controlQubit,
int  targetQubit 
)
inline

Definition at line 118 of file QcsimPauliPropagator.h.

References ApplyCS(), and ApplyH().

Referenced by ApplyCCX(), and ApplyCSwap().

◆ ApplyCSXDAG()

void Simulators::QcsimPauliPropagator::ApplyCSXDAG ( int  controlQubit,
int  targetQubit 
)
inline

Definition at line 124 of file QcsimPauliPropagator.h.

References ApplyCSDAG(), and ApplyH().

Referenced by ApplyCCX().

◆ ApplyCU()

void Simulators::QcsimPauliPropagator::ApplyCU ( int  controlQubit,
int  targetQubit,
double  theta,
double  phi,
double  lambda,
double  gamma = 0.0 
)
inline

Definition at line 51 of file QcsimPauliPropagator.h.

References ApplyCX(), ApplyP(), and ApplyU().

◆ ApplyP()

void Simulators::QcsimPauliPropagator::ApplyP ( int  qubit,
double  lambda 
)
inline

Definition at line 24 of file QcsimPauliPropagator.h.

Referenced by ApplyCP(), ApplyCSwap(), and ApplyCU().

◆ ApplyT()

void Simulators::QcsimPauliPropagator::ApplyT ( int  qubit)
inline

Definition at line 26 of file QcsimPauliPropagator.h.

Referenced by ApplyCH(), ApplyCS(), and ApplyCSDAG().

◆ ApplyTDG()

void Simulators::QcsimPauliPropagator::ApplyTDG ( int  qubit)
inline

Definition at line 28 of file QcsimPauliPropagator.h.

Referenced by ApplyCS(), and ApplyCSDAG().

◆ ApplyU()

void Simulators::QcsimPauliPropagator::ApplyU ( int  qubit,
double  theta,
double  phi,
double  lambda,
double  gamma = 0.0 
)
inline

Definition at line 30 of file QcsimPauliPropagator.h.

Referenced by ApplyCU().

◆ Clone()

std::unique_ptr< QcsimPauliPropagator > Simulators::QcsimPauliPropagator::Clone ( ) const
inline

Definition at line 162 of file QcsimPauliPropagator.h.

◆ GetCost()

static double Simulators::QcsimPauliPropagator::GetCost ( const std::shared_ptr< Circuits::Circuit<> > &  circuit)
inlinestatic

◆ GetSamplingCost()

static double Simulators::QcsimPauliPropagator::GetSamplingCost ( const std::shared_ptr< Circuits::Circuit<> > &  circuit,
size_t  nrQubitsSampled,
size_t  samples 
)
inlinestatic

Definition at line 180 of file QcsimPauliPropagator.h.

References GetCost().

Referenced by Estimators::ExecutionCost::EstimateSamplingCost().


The documentation for this class was generated from the following file: