Skip to content
Snippets Groups Projects
Code owners
Assign users and groups as approvers for specific file changes. Learn more.
ImprovedScaffoldCompilerTester.cpp 3.99 KiB

/***********************************************************************************
 * Copyright (c) 2016, UT-Battelle
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *   * Redistributions of source code must retain the above copyright
 *     notice, this list of conditions and the following disclaimer.
 *   * Redistributions in binary form must reproduce the above copyright
 *     notice, this list of conditions and the following disclaimer in the
 *     documentation and/or other materials provided with the distribution.
 *   * Neither the name of the xacc nor the
 *     names of its contributors may be used to endorse or promote products
 *     derived from this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY
 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 *
 * Contributors:
 *   Initial API and implementation - Alex McCaskey
 *
 **********************************************************************************/
#define BOOST_TEST_DYN_LINK
#define BOOST_TEST_MODULE ImprovedScaffoldCompilerTester

#include <boost/test/included/unit_test.hpp>
#include "ImprovedScaffold.hpp"
#include "GateQIR.hpp"

using namespace xacc::quantum;

struct F {
	F() :
			compiler(
					xacc::CompilerRegistry::instance()->create(
							"improvedscaffold")) {
		BOOST_TEST_MESSAGE("setup fixture");
		BOOST_VERIFY(compiler);
	}
	~F() {
		BOOST_TEST_MESSAGE("teardown fixture");
	}

	std::shared_ptr<xacc::Compiler> compiler;
};

//____________________________________________________________________________//

BOOST_FIXTURE_TEST_SUITE( s, F )

BOOST_AUTO_TEST_CASE(checkSimpleCompile) {

	const std::string src("__qpu__ teleport (qbit qreg[3]) {\n"
		"   cbit creg[2];\n"
		"   // Init qubit 0 to 1\n"
		"   X(qreg[0]);\n"
		"   // Now teleport...\n"
		"   H(qreg[1]);\n"
		"   CNOT(qreg[1],qreg[2]);\n"
		"   CNOT(qreg[0],qreg[1]);\n"
		"   H(qreg[0]);\n"
		"}\n");

	auto qir = compiler->compile(src);

	auto gateqir = std::dynamic_pointer_cast<GateQIR>(qir);

	BOOST_VERIFY(gateqir->numberOfKernels() == 1);


	auto k = gateqir->getKernel("teleport");
	BOOST_VERIFY(k->nInstructions() == 5);

	std::cout << "STR: \n\n" << k->toString("qreg") << "\n";
}

BOOST_AUTO_TEST_CASE(checkWithRzParameterized) {
	const std::string src("__qpu__ teleport (qbit qreg[3]) {\n"
		"   Rz(qreg[0], 3.1415);\n"
		"}\n");

	auto qir = compiler->compile(src);
	auto gateqir = std::dynamic_pointer_cast<GateQIR>(qir);

	BOOST_VERIFY(gateqir->numberOfKernels() == 1);


	auto k = gateqir->getKernel("teleport");
	BOOST_VERIFY(k->nInstructions() == 1);
}

BOOST_AUTO_TEST_CASE(checkWithMeasurementIf) {

	const std::string src("module teleport (qbit qreg[3]) {\n"
		"   cbit creg[2];\n"
		"   // Init qubit 0 to 1\n"
		"   X(qreg[0]);\n"
		"   // Now teleport...\n"
		"   H(qreg[1]);\n"
		"   CNOT(qreg[1],qreg[2]);\n"
		"   CNOT(qreg[0],qreg[1]);\n"
		"   H(qreg[0]);\n"
		"   creg[0] = MeasZ(qreg[0]);\n"
		"   creg[1] = MeasZ(qreg[1]);\n"
		"   if (creg[0] == 1) Z(qreg[2]);\n"
		"   if (creg[1] == 1) X(qreg[2]);\n"
		"}\n");

	auto qir = compiler->compile(src);
	auto gateqir = std::dynamic_pointer_cast<GateQIR>(qir);

	BOOST_VERIFY(gateqir->numberOfKernels() == 1);

	auto k = gateqir->getKernel("teleport");

}

BOOST_AUTO_TEST_SUITE_END()