quizx 0.3.0

Quantum Circuit Optimisation and Compilation using the ZX-calculus
Documentation
// QuiZX - Rust library for quantum circuit rewriting and optimisation
//         using the ZX-calculus
// Copyright (C) 2021 - Vlad-mihai Moldoveanu, Aleks Kissinger
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//    http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

use quizx::circuit::*;
use quizx::extract::*;
use quizx::hash_graph::*;
use quizx::simplify::*;
use std::time::Instant;
use std::{thread, time};

fn main() -> Result<(), Box<dyn std::error::Error>> {
    let f = "circuits/large/gf2^64_mult.qasm";
    let time = Instant::now();
    println!("{}", f);
    let c =
        Circuit::from_file(f).unwrap_or_else(|e| panic!("circuit failed to parse: {}. {}", f, e));
    println!("...done reading in {:.2?}", time.elapsed());

    // println!("Computing tensor");
    // let t = c.to_tensor4();
    // println!("Done");
    // assert!(Tensor4::scalar_eq(&c.to_tensor4(), &c.to_basic_gates().to_tensor4()));

    println!("Simplifying circuit...");
    let time = Instant::now();
    let mut g: Graph = c.to_graph();
    full_simp(&mut g);
    println!("Done simplifying in {:.2?}", time.elapsed());

    // h.plug(&g.to_adjoint());
    // println!("Checking");
    // full_simp(&mut h);
    // fuse_gadgets(&mut h);
    // println!("Is identity: {}", h.is_identity());
    // println!("{}", h.to_dot());
    // thread::sleep(time::Duration::from_secs(2));
    // println!("done");
    // return Ok(());

    // println!("{}", g.to_dot());

    println!("Extracting circuit...");
    let time = Instant::now();
    let result = g
        .extractor()
        .gflow()
        // .up_to_perm()
        .extract();

    match result {
        Ok(_c1) => {
            println!("Done in {:.2?}", time.elapsed());
            println!("extracted ok");
        }
        Err(ExtractError(msg, _c, _g)) => {
            println!("extract failed: {}", msg);
            // println!("\n\n{}", _g.to_dot());
        }
    }

    thread::sleep(time::Duration::from_millis(100));
    Ok(())
}