Program Listing for File QubitRegisterMetric.hpp

Return to documentation for file (/home/docs/checkouts/readthedocs.org/user_builds/intel-qs/checkouts/docs/include/QubitRegisterMetric.hpp)

#ifndef QUBIT_REGISTER_METRIC_HPP
#define QUBIT_REGISTER_METRIC_HPP

#include <vector>

using namespace std;

template <class Type = ComplexDP>
class QubitRegisterMetric: public QubitRegister<Type> {
  int iTotalQubitGateCount=0;
  int iOneQubitGateCount=0;
  int iTwoQubitGateCount=0;
  std::vector<int> vParallelDepth;
  void OneQubitIncrements(int);
  void TwoQubitIncrements(int,int);

public:
  //Constructor
  QubitRegisterMetric<Type>(int iNQubits):QubitRegister<Type>(iNQubits){
    vParallelDepth.resize(iNQubits);
  }

  //Get stats
  int GetTotalQubitGateCount();
  int GetOneQubitGateCount();
  int GetTwoQubitGateCount();
  int GetParallelDepth();

  //Perform gates
  void ApplyHadamard(int);
  void ApplyRotationX(int, double);
  void ApplyRotationY(int, double);
  void ApplyRotationZ(int, double);
  void ApplyCPauliX(int, int);
  void ApplyControlled1QubitGate(int, int, qhipster::TinyMatrix<Type, 2, 2, 32>);
};

template <class Type>
int QubitRegisterMetric<Type>::GetOneQubitGateCount(){
  return iOneQubitGateCount;
}

template <class Type>
int QubitRegisterMetric<Type>::GetTwoQubitGateCount(){
  return iTwoQubitGateCount;
}

template <class Type>
int QubitRegisterMetric<Type>::GetTotalQubitGateCount(){
  return iTotalQubitGateCount;
}

template <class Type>

int QubitRegisterMetric<Type>::GetParallelDepth(){
  return *std::max_element(std::begin(vParallelDepth), std::end(vParallelDepth));
}

template <class Type>
void QubitRegisterMetric<Type>::OneQubitIncrements(int q){
  iTotalQubitGateCount++;
  iOneQubitGateCount++;
  vParallelDepth[q]++;
}

template <class Type>
void QubitRegisterMetric<Type>::TwoQubitIncrements(int q1, int q2){
  iTotalQubitGateCount++;
  iTwoQubitGateCount++;
  int iNewDepth = max(vParallelDepth[q1],vParallelDepth[q2])+1;
  vParallelDepth[q1]=iNewDepth;
  vParallelDepth[q2]=iNewDepth;
}

template <class Type>
void QubitRegisterMetric<Type>::ApplyHadamard(int q){
  QubitRegister<Type>::ApplyHadamard(q);
  OneQubitIncrements(q);
}

template <class Type>
void QubitRegisterMetric<Type>::ApplyRotationX(int q, double theta){
  QubitRegister<Type>::ApplyRotationX(q,theta);
  OneQubitIncrements(q);
}

template <class Type>
void QubitRegisterMetric<Type>::ApplyRotationY(int q, double theta){
  QubitRegister<Type>::ApplyRotationY(q,theta);
  OneQubitIncrements(q);
}

template <class Type>
void QubitRegisterMetric<Type>::ApplyRotationZ(int q, double theta){
  QubitRegister<Type>::ApplyRotationZ(q,theta);
  OneQubitIncrements(q);
}

template <class Type>
void QubitRegisterMetric<Type>::ApplyCPauliX(int q1, int q2){
  QubitRegister<Type>::ApplyCPauliX(q1,q2);
  TwoQubitIncrements(q1,q2);
}

template <class Type>
void QubitRegisterMetric<Type>::ApplyControlled1QubitGate(int q1, int q2, qhipster::TinyMatrix<Type, 2, 2, 32> V){
  QubitRegister<Type>::ApplyControlled1QubitGate(q1,q2,V);
  TwoQubitIncrements(q1,q2);
}

#endif  // header guard QUBIT_REGISTER_METRIC_HPP