[INFO] cloning repository https://github.com/Kim8584/BulletProofs_arg
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Kim8584/BulletProofs_arg" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FKim8584%2FBulletProofs_arg", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FKim8584%2FBulletProofs_arg'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] fbb180b58b25985d38615affd6ab4dbd6eb9633d
[INFO] testing Kim8584/BulletProofs_arg against master#d98a5da813da67eb189387b8ccfb73cf481275d8+rustflags=-Copt-level=3 for pr-138759
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FKim8584%2FBulletProofs_arg" "/workspace/builds/worker-0-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/Kim8584/BulletProofs_arg
[INFO] finished tweaking git repo https://github.com/Kim8584/BulletProofs_arg
[INFO] tweaked toml for git repo https://github.com/Kim8584/BulletProofs_arg written to /workspace/builds/worker-0-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/Kim8584/BulletProofs_arg on toolchain d98a5da813da67eb189387b8ccfb73cf481275d8
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/Kim8584/BulletProofs_arg already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded enum-ordinalize v4.3.0
[INFO] [stderr]   Downloaded ark-serialize-derive v0.5.0
[INFO] [stderr]   Downloaded ark-curve25519 v0.5.0
[INFO] [stderr]   Downloaded ark-serialize v0.5.0
[INFO] [stderr]   Downloaded ark-ff-asm v0.5.0
[INFO] [stderr]   Downloaded ark-std v0.5.0
[INFO] [stderr]   Downloaded once_cell v1.21.1
[INFO] [stderr]   Downloaded ark-poly v0.5.0
[INFO] [stderr]   Downloaded ark-ff v0.5.0
[INFO] [stderr]   Downloaded zerocopy-derive v0.8.23
[INFO] [stderr]   Downloaded educe v0.6.0
[INFO] [stderr]   Downloaded itertools v0.13.0
[INFO] [stderr]   Downloaded ark-ec v0.5.0
[INFO] [stderr]   Downloaded ark-ff-macros v0.5.0
[INFO] [stderr]   Downloaded zerocopy v0.8.23
[INFO] [stderr]   Downloaded enum-ordinalize-derive v4.3.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 0e76cbaa5701e11ea7755fce2718661e8dfed6a5323be65379c3e0351267f8da
[INFO] running `Command { std: "docker" "start" "-a" "0e76cbaa5701e11ea7755fce2718661e8dfed6a5323be65379c3e0351267f8da", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "0e76cbaa5701e11ea7755fce2718661e8dfed6a5323be65379c3e0351267f8da", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0e76cbaa5701e11ea7755fce2718661e8dfed6a5323be65379c3e0351267f8da", kill_on_drop: false }`
[INFO] [stdout] 0e76cbaa5701e11ea7755fce2718661e8dfed6a5323be65379c3e0351267f8da
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Copt-level=3" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 18f62514a03bcaffdcf8b782517b93d2788fac0fa30142ff30877b1753746454
[INFO] running `Command { std: "docker" "start" "-a" "18f62514a03bcaffdcf8b782517b93d2788fac0fa30142ff30877b1753746454", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.94
[INFO] [stderr]    Compiling unicode-ident v1.0.18
[INFO] [stderr]    Compiling version_check v0.9.5
[INFO] [stderr]    Compiling autocfg v1.4.0
[INFO] [stderr]    Compiling libc v0.2.171
[INFO] [stderr]    Compiling typenum v1.18.0
[INFO] [stderr]    Compiling zerocopy v0.8.23
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling paste v1.0.15
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]    Compiling semver v1.0.26
[INFO] [stderr]    Compiling arrayvec v0.7.6
[INFO] [stderr]    Compiling once_cell v1.21.1
[INFO] [stderr]    Compiling allocator-api2 v0.2.21
[INFO] [stderr]    Compiling zerocopy v0.7.35
[INFO] [stderr]    Compiling cpufeatures v0.2.17
[INFO] [stderr]    Compiling subtle v2.6.1
[INFO] [stderr]    Compiling itertools v0.13.0
[INFO] [stderr]    Compiling itertools v0.10.5
[INFO] [stderr]    Compiling hashbrown v0.15.2
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling generic-array v0.14.7
[INFO] [stderr]    Compiling ahash v0.8.11
[INFO] [stderr]    Compiling rustc_version v0.4.1
[INFO] [stderr]    Compiling quote v1.0.40
[INFO] [stderr]    Compiling syn v2.0.100
[INFO] [stderr]    Compiling curve25519-dalek v4.1.3
[INFO] [stderr]    Compiling getrandom v0.2.15
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling num-integer v0.1.46
[INFO] [stderr]    Compiling num-bigint v0.4.6
[INFO] [stderr]    Compiling crypto-common v0.1.6
[INFO] [stderr]    Compiling block-buffer v0.10.4
[INFO] [stderr]    Compiling digest v0.10.7
[INFO] [stderr]    Compiling sha2 v0.10.8
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling ark-std v0.5.0
[INFO] [stderr]    Compiling ark-std v0.4.0
[INFO] [stderr]    Compiling ark-serialize v0.4.2
[INFO] [stderr]    Compiling ark-ff-asm v0.4.2
[INFO] [stderr]    Compiling derivative v2.2.0
[INFO] [stderr]    Compiling ark-ff-macros v0.4.2
[INFO] [stderr]    Compiling zeroize_derive v1.4.2
[INFO] [stderr]    Compiling enum-ordinalize-derive v4.3.1
[INFO] [stderr]    Compiling ark-serialize-derive v0.5.0
[INFO] [stderr]    Compiling ark-ff-macros v0.5.0
[INFO] [stderr]    Compiling ark-ff-asm v0.5.0
[INFO] [stderr]    Compiling curve25519-dalek-derive v0.1.1
[INFO] [stderr]    Compiling ark-serialize v0.5.0
[INFO] [stderr]    Compiling enum-ordinalize v4.3.0
[INFO] [stderr]    Compiling educe v0.6.0
[INFO] [stderr]    Compiling zeroize v1.8.1
[INFO] [stderr]    Compiling ark-ff v0.4.2
[INFO] [stderr]    Compiling ark-ff v0.5.0
[INFO] [stderr]    Compiling ark-poly v0.5.0
[INFO] [stderr]    Compiling ark-ec v0.5.0
[INFO] [stderr]    Compiling ark-curve25519 v0.5.0
[INFO] [stderr]    Compiling BulletProofs_arg v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/transcript/mod.rs:53:86
[INFO] [stdout]    |
[INFO] [stdout] 53 |                         let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add((x as u16)));
[INFO] [stdout]    |                                                                                      ^        ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 53 -                         let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add((x as u16)));
[INFO] [stdout] 53 +                         let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add(x as u16));
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/transcript/mod.rs:65:78
[INFO] [stdout]    |
[INFO] [stdout] 65 |                 let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add((x as u16)));
[INFO] [stdout]    |                                                                              ^        ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 65 -                 let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add((x as u16)));
[INFO] [stdout] 65 +                 let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add(x as u16));
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ErrorKind` and `Error`
[INFO] [stdout]  --> src/traits.rs:8:22
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::io::{Result,Error,ErrorKind};
[INFO] [stdout]   |                      ^^^^^ ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `self` and `self`
[INFO] [stdout]  --> src/traits.rs:9:25
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::transcript::{self, fiat_shamir::{self, FiatShamir}, Transcript};
[INFO] [stdout]   |                         ^^^^                ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sha2::digest::typenum::tarr`
[INFO] [stdout]   --> src/traits.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use sha2::digest::typenum::tarr;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: crate `BulletProofs_arg` should have a snake case name
[INFO] [stdout]   |
[INFO] [stdout]   = help: convert the identifier to snake case: `bullet_proofs_arg`
[INFO] [stdout]   = note: `#[warn(non_snake_case)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `is_power_of_two`
[INFO] [stdout]   --> src/main.rs:11:42
[INFO] [stdout]    |
[INFO] [stdout] 11 |     use BulletProofs_arg::{log2_helper::{is_power_of_two, round_up_to_power_of_two}};
[INFO] [stdout]    |                                          ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `self` and `self`
[INFO] [stdout]   --> src/main.rs:12:40
[INFO] [stdout]    |
[INFO] [stdout] 12 |     use BulletProofs_arg::transcript::{self, fiat_shamir::{self, FiatShamir}, Transcript};
[INFO] [stdout]    |                                        ^^^^                ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/main.rs:173:29
[INFO] [stdout]     |
[INFO] [stdout] 173 |             let ab_tagged = (self.a_tag *self.b_tag);
[INFO] [stdout]     |                             ^                      ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 173 -             let ab_tagged = (self.a_tag *self.b_tag);
[INFO] [stdout] 173 +             let ab_tagged = self.a_tag *self.b_tag;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ab`
[INFO] [stdout]    --> src/main.rs:202:13
[INFO] [stdout]     |
[INFO] [stdout] 202 |         let ab = get_inner_product(a.clone(), b.clone());
[INFO] [stdout]     |             ^^ help: if this is intentional, prefix it with an underscore: `_ab`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `a_tag`
[INFO] [stdout]    --> src/main.rs:428:15
[INFO] [stdout]     |
[INFO] [stdout] 428 |     fn unfold(a_tag: Scalar,b_tag : Scalar , challenges : Vec<Scalar>) -> (Vec<Scalar>, Vec<Scalar>) {
[INFO] [stdout]     |               ^^^^^ help: if this is intentional, prefix it with an underscore: `_a_tag`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b_tag`
[INFO] [stdout]    --> src/main.rs:428:29
[INFO] [stdout]     |
[INFO] [stdout] 428 |     fn unfold(a_tag: Scalar,b_tag : Scalar , challenges : Vec<Scalar>) -> (Vec<Scalar>, Vec<Scalar>) {
[INFO] [stdout]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_b_tag`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `challenges`
[INFO] [stdout]    --> src/main.rs:428:46
[INFO] [stdout]     |
[INFO] [stdout] 428 |     fn unfold(a_tag: Scalar,b_tag : Scalar , challenges : Vec<Scalar>) -> (Vec<Scalar>, Vec<Scalar>) {
[INFO] [stdout]     |                                              ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_challenges`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:439:13
[INFO] [stdout]     |
[INFO] [stdout] 439 |         let mut inner_product = Scalar::ZERO;
[INFO] [stdout]     |             ----^^^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n`
[INFO] [stdout]    --> src/main.rs:449:13
[INFO] [stdout]     |
[INFO] [stdout] 449 |         let n = a.len();
[INFO] [stdout]     |             ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `title` is never read
[INFO] [stdout]   --> src/main.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 17 |     pub struct PublicParameters {
[INFO] [stdout]    |                ---------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 20 |         title: String,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `transcript` is never read
[INFO] [stdout]   --> src/main.rs:72:9
[INFO] [stdout]    |
[INFO] [stdout] 71 |     pub struct InnerProductProof <F:FiatShamir,S:Setup>{
[INFO] [stdout]    |                ----------------- field in this struct
[INFO] [stdout] 72 |         transcript :Transcript<F>,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `unfold` is never used
[INFO] [stdout]    --> src/main.rs:428:8
[INFO] [stdout]     |
[INFO] [stdout] 428 |     fn unfold(a_tag: Scalar,b_tag : Scalar , challenges : Vec<Scalar>) -> (Vec<Scalar>, Vec<Scalar>) {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_lookup_vector` is never used
[INFO] [stdout]    --> src/main.rs:266:8
[INFO] [stdout]     |
[INFO] [stdout] 266 | pub fn get_lookup_vector(challenges: Vec<Scalar>) -> Vec<Scalar> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `G` should have a snake case name
[INFO] [stdout]   --> src/main.rs:22:13
[INFO] [stdout]    |
[INFO] [stdout] 22 |         pub G: Vec<RistrettoPoint>,
[INFO] [stdout]    |             ^ help: convert the identifier to snake case: `g`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `H` should have a snake case name
[INFO] [stdout]   --> src/main.rs:23:13
[INFO] [stdout]    |
[INFO] [stdout] 23 |         pub H: Vec<RistrettoPoint>,
[INFO] [stdout]    |             ^ help: convert the identifier to snake case: `h`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `U` should have a snake case name
[INFO] [stdout]   --> src/main.rs:24:13
[INFO] [stdout]    |
[INFO] [stdout] 24 |         pub U : RistrettoPoint
[INFO] [stdout]    |             ^ help: convert the identifier to snake case (notice the capitalization): `u`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `G` should have a snake case name
[INFO] [stdout]   --> src/main.rs:34:21
[INFO] [stdout]    |
[INFO] [stdout] 34 |             let mut G = Vec::with_capacity(lambda);
[INFO] [stdout]    |                     ^ help: convert the identifier to snake case: `g`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `H` should have a snake case name
[INFO] [stdout]   --> src/main.rs:35:21
[INFO] [stdout]    |
[INFO] [stdout] 35 |             let mut H = Vec::with_capacity(lambda);
[INFO] [stdout]    |                     ^ help: convert the identifier to snake case: `h`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `U` should have a snake case name
[INFO] [stdout]   --> src/main.rs:53:17
[INFO] [stdout]    |
[INFO] [stdout] 53 |             let U = RistrettoPoint::from_uniform_bytes(&u_hash[..64].
[INFO] [stdout]    |                 ^ help: convert the identifier to snake case (notice the capitalization): `u`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `P` should have a snake case name
[INFO] [stdout]   --> src/main.rs:74:13
[INFO] [stdout]    |
[INFO] [stdout] 74 |         pub P : RistrettoPoint,
[INFO] [stdout]    |             ^ help: convert the identifier to snake case: `p`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `L` should have a snake case name
[INFO] [stdout]   --> src/main.rs:75:13
[INFO] [stdout]    |
[INFO] [stdout] 75 |         pub L: Vec<RistrettoPoint>,
[INFO] [stdout]    |             ^ help: convert the identifier to snake case: `l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `R` should have a snake case name
[INFO] [stdout]   --> src/main.rs:76:13
[INFO] [stdout]    |
[INFO] [stdout] 76 |         pub R: Vec<RistrettoPoint>,
[INFO] [stdout]    |             ^ help: convert the identifier to snake case: `r`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `L_vec` should have a snake case name
[INFO] [stdout]    --> src/main.rs:103:17
[INFO] [stdout]     |
[INFO] [stdout] 103 |         let mut L_vec:Vec<RistrettoPoint> = Vec::new();
[INFO] [stdout]     |                 ^^^^^ help: convert the identifier to snake case: `l_vec`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `R_vec` should have a snake case name
[INFO] [stdout]    --> src/main.rs:104:17
[INFO] [stdout]     |
[INFO] [stdout] 104 |         let mut R_vec :Vec<RistrettoPoint> = Vec::new();
[INFO] [stdout]     |                 ^^^^^ help: convert the identifier to snake case: `r_vec`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `P` should have a snake case name
[INFO] [stdout]    --> src/main.rs:108:13
[INFO] [stdout]     |
[INFO] [stdout] 108 |         let P = inner_product_hash(g_vec.clone(), h_vec.clone(), ux, a.clone(), b.clone(), ab)?;
[INFO] [stdout]     |             ^ help: convert the identifier to snake case: `p`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `L` should have a snake case name
[INFO] [stdout]    --> src/main.rs:115:18
[INFO] [stdout]     |
[INFO] [stdout] 115 |             let (L,R,G_new,H_new,a_new,b_new) = fold(
[INFO] [stdout]     |                  ^ help: convert the identifier to snake case: `l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `R` should have a snake case name
[INFO] [stdout]    --> src/main.rs:115:20
[INFO] [stdout]     |
[INFO] [stdout] 115 |             let (L,R,G_new,H_new,a_new,b_new) = fold(
[INFO] [stdout]     |                    ^ help: convert the identifier to snake case: `r`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `G_new` should have a snake case name
[INFO] [stdout]    --> src/main.rs:115:22
[INFO] [stdout]     |
[INFO] [stdout] 115 |             let (L,R,G_new,H_new,a_new,b_new) = fold(
[INFO] [stdout]     |                      ^^^^^ help: convert the identifier to snake case: `g_new`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `H_new` should have a snake case name
[INFO] [stdout]    --> src/main.rs:115:28
[INFO] [stdout]     |
[INFO] [stdout] 115 |             let (L,R,G_new,H_new,a_new,b_new) = fold(
[INFO] [stdout]     |                            ^^^^^ help: convert the identifier to snake case: `h_new`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `P_tag` should have a snake case name
[INFO] [stdout]    --> src/main.rs:137:9
[INFO] [stdout]     |
[INFO] [stdout] 137 |     let P_tag = inner_product_hash(g_vec.clone(), h_vec.clone(), ux, a.clone(), b.clone(), ab)?;
[INFO] [stdout]     |         ^^^^^ help: convert the identifier to snake case: `p_tag`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `expected_P_tag` should have a snake case name
[INFO] [stdout]    --> src/main.rs:176:17
[INFO] [stdout]     |
[INFO] [stdout] 176 |             let expected_P_tag = inner_product_hash(g, h, ux, a_tagged, b_tagged, ab_tagged)?;
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `expected_p_tag`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `P_tag` should have a snake case name
[INFO] [stdout]    --> src/main.rs:179:17
[INFO] [stdout]     |
[INFO] [stdout] 179 |             let P_tag = inner_product_hash(self.L.clone(), self.R.clone(), self.P.clone(), x_squared, x_inv_squared, Scalar::ONE)?;
[INFO] [stdout]     |                 ^^^^^ help: convert the identifier to snake case: `p_tag`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `a_L` should have a snake case name
[INFO] [stdout]    --> src/main.rs:194:14
[INFO] [stdout]     |
[INFO] [stdout] 194 |         let (a_L, a_R) = a.split_at(n / 2);
[INFO] [stdout]     |              ^^^ help: convert the identifier to snake case: `a_l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `a_R` should have a snake case name
[INFO] [stdout]    --> src/main.rs:194:19
[INFO] [stdout]     |
[INFO] [stdout] 194 |         let (a_L, a_R) = a.split_at(n / 2);
[INFO] [stdout]     |                   ^^^ help: convert the identifier to snake case: `a_r`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `b_L` should have a snake case name
[INFO] [stdout]    --> src/main.rs:196:14
[INFO] [stdout]     |
[INFO] [stdout] 196 |         let (b_L, b_R) = b.split_at(n / 2);
[INFO] [stdout]     |              ^^^ help: convert the identifier to snake case: `b_l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `b_R` should have a snake case name
[INFO] [stdout]    --> src/main.rs:196:19
[INFO] [stdout]     |
[INFO] [stdout] 196 |         let (b_L, b_R) = b.split_at(n / 2);
[INFO] [stdout]     |                   ^^^ help: convert the identifier to snake case: `b_r`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `g_L` should have a snake case name
[INFO] [stdout]    --> src/main.rs:198:14
[INFO] [stdout]     |
[INFO] [stdout] 198 |         let (g_L, g_R) = g_vec.split_at(n / 2);
[INFO] [stdout]     |              ^^^ help: convert the identifier to snake case: `g_l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `g_R` should have a snake case name
[INFO] [stdout]    --> src/main.rs:198:19
[INFO] [stdout]     |
[INFO] [stdout] 198 |         let (g_L, g_R) = g_vec.split_at(n / 2);
[INFO] [stdout]     |                   ^^^ help: convert the identifier to snake case: `g_r`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `h_L` should have a snake case name
[INFO] [stdout]    --> src/main.rs:200:14
[INFO] [stdout]     |
[INFO] [stdout] 200 |         let (h_L, h_R) = h_vec.split_at(n / 2);
[INFO] [stdout]     |              ^^^ help: convert the identifier to snake case: `h_l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `h_R` should have a snake case name
[INFO] [stdout]    --> src/main.rs:200:19
[INFO] [stdout]     |
[INFO] [stdout] 200 |         let (h_L, h_R) = h_vec.split_at(n / 2);
[INFO] [stdout]     |                   ^^^ help: convert the identifier to snake case: `h_r`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `a_L_b_R` should have a snake case name
[INFO] [stdout]    --> src/main.rs:205:13
[INFO] [stdout]     |
[INFO] [stdout] 205 |         let a_L_b_R = get_inner_product(a_L.to_vec(), b_R.to_vec())?;
[INFO] [stdout]     |             ^^^^^^^ help: convert the identifier to snake case: `a_l_b_r`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `L` should have a snake case name
[INFO] [stdout]    --> src/main.rs:206:13
[INFO] [stdout]     |
[INFO] [stdout] 206 |         let L = inner_product_hash(g_R.to_vec(), h_L.to_vec(), ux, a_L.to_vec(), b_R.to_vec(), 
[INFO] [stdout]     |             ^ help: convert the identifier to snake case: `l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `a_R_b_L` should have a snake case name
[INFO] [stdout]    --> src/main.rs:210:13
[INFO] [stdout]     |
[INFO] [stdout] 210 |         let a_R_b_L = get_inner_product(a_R.to_vec(), b_L.to_vec())?;
[INFO] [stdout]     |             ^^^^^^^ help: convert the identifier to snake case: `a_r_b_l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `R` should have a snake case name
[INFO] [stdout]    --> src/main.rs:211:13
[INFO] [stdout]     |
[INFO] [stdout] 211 |         let R = inner_product_hash(g_L.to_vec(), h_R.to_vec(), ux, a_R.to_vec(),
[INFO] [stdout]     |             ^ help: convert the identifier to snake case: `r`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `GLx_inv` should have a snake case name
[INFO] [stdout]    --> src/main.rs:239:25
[INFO] [stdout]     |
[INFO] [stdout] 239 |                     let GLx_inv = &g_L[i] * &x_inv;
[INFO] [stdout]     |                         ^^^^^^^ help: convert the identifier to snake case: `glx_inv`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `GRx` should have a snake case name
[INFO] [stdout]    --> src/main.rs:240:25
[INFO] [stdout]     |
[INFO] [stdout] 240 |                     let GRx = &g_R[i] * &x;
[INFO] [stdout]     |                         ^^^ help: convert the identifier to snake case: `grx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `G_new` should have a snake case name
[INFO] [stdout]    --> src/main.rs:237:13
[INFO] [stdout]     |
[INFO] [stdout] 237 |         let G_new = (0..n)
[INFO] [stdout]     |             ^^^^^ help: convert the identifier to snake case: `g_new`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `HLx` should have a snake case name
[INFO] [stdout]    --> src/main.rs:247:25
[INFO] [stdout]     |
[INFO] [stdout] 247 |                     let HLx = &h_L[i] * &x;
[INFO] [stdout]     |                         ^^^ help: convert the identifier to snake case: `hlx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `HRx_inv` should have a snake case name
[INFO] [stdout]    --> src/main.rs:248:25
[INFO] [stdout]     |
[INFO] [stdout] 248 |                     let HRx_inv = &h_R[i] * &x_inv;
[INFO] [stdout]     |                         ^^^^^^^ help: convert the identifier to snake case: `hrx_inv`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `H_new` should have a snake case name
[INFO] [stdout]    --> src/main.rs:245:13
[INFO] [stdout]     |
[INFO] [stdout] 245 |         let H_new = (0..n)
[INFO] [stdout]     |             ^^^^^ help: convert the identifier to snake case: `h_new`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `LookUp_vector` should have a snake case name
[INFO] [stdout]    --> src/main.rs:255:5
[INFO] [stdout]     |
[INFO] [stdout] 255 | mod LookUp_vector{
[INFO] [stdout]     |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `look_up_vector`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `L_vec` should have a snake case name
[INFO] [stdout]    --> src/main.rs:408:9
[INFO] [stdout]     |
[INFO] [stdout] 408 |         L_vec: Vec<RistrettoPoint>,
[INFO] [stdout]     |         ^^^^^ help: convert the identifier to snake case: `l_vec`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `R_vec` should have a snake case name
[INFO] [stdout]    --> src/main.rs:409:9
[INFO] [stdout]     |
[INFO] [stdout] 409 |         R_vec: Vec<RistrettoPoint>,
[INFO] [stdout]     |         ^^^^^ help: convert the identifier to snake case: `r_vec`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `aG` should have a snake case name
[INFO] [stdout]    --> src/main.rs:456:13
[INFO] [stdout]     |
[INFO] [stdout] 456 |         let aG =RistrettoPoint::vartime_multiscalar_mul(a, g);
[INFO] [stdout]     |             ^^ help: convert the identifier to snake case: `a_g`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `bH` should have a snake case name
[INFO] [stdout]    --> src/main.rs:458:13
[INFO] [stdout]     |
[INFO] [stdout] 458 |         let bH = RistrettoPoint::vartime_multiscalar_mul(b,h);
[INFO] [stdout]     |             ^^ help: convert the identifier to snake case: `b_h`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 25s
[INFO] running `Command { std: "docker" "inspect" "18f62514a03bcaffdcf8b782517b93d2788fac0fa30142ff30877b1753746454", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "18f62514a03bcaffdcf8b782517b93d2788fac0fa30142ff30877b1753746454", kill_on_drop: false }`
[INFO] [stdout] 18f62514a03bcaffdcf8b782517b93d2788fac0fa30142ff30877b1753746454
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Copt-level=3" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] d12e054fd2b20d46d4781c5f44570e21f634d9b3bbe3f9ddefa56e22f04e1872
[INFO] running `Command { std: "docker" "start" "-a" "d12e054fd2b20d46d4781c5f44570e21f634d9b3bbe3f9ddefa56e22f04e1872", kill_on_drop: false }`
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/transcript/mod.rs:53:86
[INFO] [stdout]    |
[INFO] [stdout] 53 |                         let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add((x as u16)));
[INFO] [stdout]    |                                                                                      ^        ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 53 -                         let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add((x as u16)));
[INFO] [stdout] 53 +                         let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add(x as u16));
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/transcript/mod.rs:65:78
[INFO] [stdout]    |
[INFO] [stdout] 65 |                 let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add((x as u16)));
[INFO] [stdout]    |                                                                              ^        ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 65 -                 let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add((x as u16)));
[INFO] [stdout] 65 +                 let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add(x as u16));
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ErrorKind` and `Error`
[INFO] [stdout]  --> src/traits.rs:8:22
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::io::{Result,Error,ErrorKind};
[INFO] [stdout]   |                      ^^^^^ ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `self` and `self`
[INFO] [stdout]  --> src/traits.rs:9:25
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::transcript::{self, fiat_shamir::{self, FiatShamir}, Transcript};
[INFO] [stdout]   |                         ^^^^                ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sha2::digest::typenum::tarr`
[INFO] [stdout]   --> src/traits.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use sha2::digest::typenum::tarr;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: crate `BulletProofs_arg` should have a snake case name
[INFO] [stdout]   |
[INFO] [stdout]   = help: convert the identifier to snake case: `bullet_proofs_arg`
[INFO] [stdout]   = note: `#[warn(non_snake_case)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling BulletProofs_arg v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `is_power_of_two`
[INFO] [stdout]   --> src/main.rs:11:42
[INFO] [stdout]    |
[INFO] [stdout] 11 |     use BulletProofs_arg::{log2_helper::{is_power_of_two, round_up_to_power_of_two}};
[INFO] [stdout]    |                                          ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `self` and `self`
[INFO] [stdout]   --> src/main.rs:12:40
[INFO] [stdout]    |
[INFO] [stdout] 12 |     use BulletProofs_arg::transcript::{self, fiat_shamir::{self, FiatShamir}, Transcript};
[INFO] [stdout]    |                                        ^^^^                ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/main.rs:173:29
[INFO] [stdout]     |
[INFO] [stdout] 173 |             let ab_tagged = (self.a_tag *self.b_tag);
[INFO] [stdout]     |                             ^                      ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 173 -             let ab_tagged = (self.a_tag *self.b_tag);
[INFO] [stdout] 173 +             let ab_tagged = self.a_tag *self.b_tag;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::rngs::ThreadRng`
[INFO] [stdout]    --> src/main.rs:324:9
[INFO] [stdout]     |
[INFO] [stdout] 324 |     use rand::rngs::ThreadRng;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::inner_product_argument::LookUp_vector::get_lookup_vector`
[INFO] [stdout]    --> src/main.rs:467:9
[INFO] [stdout]     |
[INFO] [stdout] 467 |     use crate::inner_product_argument::LookUp_vector::get_lookup_vector;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ark_ec::bls12::g1`
[INFO] [stdout]    --> src/main.rs:470:9
[INFO] [stdout]     |
[INFO] [stdout] 470 |     use ark_ec::bls12::g1;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Sha512`
[INFO] [stdout]    --> src/main.rs:472:24
[INFO] [stdout]     |
[INFO] [stdout] 472 |     use sha2::{Sha256, Sha512, Digest};
[INFO] [stdout]     |                        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]    --> src/main.rs:473:36
[INFO] [stdout]     |
[INFO] [stdout] 473 |     use curve25519_dalek::scalar::{self, Scalar};
[INFO] [stdout]     |                                    ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]    --> src/main.rs:475:9
[INFO] [stdout]     |
[INFO] [stdout] 475 |     use std::collections::HashMap;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::result`
[INFO] [stdout]    --> src/main.rs:476:9
[INFO] [stdout]     |
[INFO] [stdout] 476 |     use std::result;
[INFO] [stdout]     |         ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `curve25519_dalek::traits::MultiscalarMul`
[INFO] [stdout]    --> src/main.rs:477:9
[INFO] [stdout]     |
[INFO] [stdout] 477 |     use curve25519_dalek::traits::MultiscalarMul;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/transcript/mod.rs:53:86
[INFO] [stdout]    |
[INFO] [stdout] 53 |                         let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add((x as u16)));
[INFO] [stdout]    |                                                                                      ^        ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 53 -                         let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add((x as u16)));
[INFO] [stdout] 53 +                         let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add(x as u16));
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around method argument
[INFO] [stdout]   --> src/transcript/mod.rs:65:78
[INFO] [stdout]    |
[INFO] [stdout] 65 |                 let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add((x as u16)));
[INFO] [stdout]    |                                                                              ^        ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 65 -                 let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add((x as u16)));
[INFO] [stdout] 65 +                 let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add(x as u16));
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ErrorKind` and `Error`
[INFO] [stdout]  --> src/traits.rs:8:22
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::io::{Result,Error,ErrorKind};
[INFO] [stdout]   |                      ^^^^^ ^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `self` and `self`
[INFO] [stdout]  --> src/traits.rs:9:25
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::transcript::{self, fiat_shamir::{self, FiatShamir}, Transcript};
[INFO] [stdout]   |                         ^^^^                ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `sha2::digest::typenum::tarr`
[INFO] [stdout]   --> src/traits.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use sha2::digest::typenum::tarr;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ab`
[INFO] [stdout]    --> src/main.rs:202:13
[INFO] [stdout]     |
[INFO] [stdout] 202 |         let ab = get_inner_product(a.clone(), b.clone());
[INFO] [stdout]     |             ^^ help: if this is intentional, prefix it with an underscore: `_ab`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `a_tag`
[INFO] [stdout]    --> src/main.rs:428:15
[INFO] [stdout]     |
[INFO] [stdout] 428 |     fn unfold(a_tag: Scalar,b_tag : Scalar , challenges : Vec<Scalar>) -> (Vec<Scalar>, Vec<Scalar>) {
[INFO] [stdout]     |               ^^^^^ help: if this is intentional, prefix it with an underscore: `_a_tag`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `b_tag`
[INFO] [stdout]    --> src/main.rs:428:29
[INFO] [stdout]     |
[INFO] [stdout] 428 |     fn unfold(a_tag: Scalar,b_tag : Scalar , challenges : Vec<Scalar>) -> (Vec<Scalar>, Vec<Scalar>) {
[INFO] [stdout]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_b_tag`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `challenges`
[INFO] [stdout]    --> src/main.rs:428:46
[INFO] [stdout]     |
[INFO] [stdout] 428 |     fn unfold(a_tag: Scalar,b_tag : Scalar , challenges : Vec<Scalar>) -> (Vec<Scalar>, Vec<Scalar>) {
[INFO] [stdout]     |                                              ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_challenges`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:439:13
[INFO] [stdout]     |
[INFO] [stdout] 439 |         let mut inner_product = Scalar::ZERO;
[INFO] [stdout]     |             ----^^^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `n`
[INFO] [stdout]    --> src/main.rs:449:13
[INFO] [stdout]     |
[INFO] [stdout] 449 |         let n = a.len();
[INFO] [stdout]     |             ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `p_tag`
[INFO] [stdout]    --> src/main.rs:550:21
[INFO] [stdout]     |
[INFO] [stdout] 550 |         let (result,p_tag): (InnerProductProof<ShaFiat, PublicParameters>, RistrettoPoint) = result.unwrap();
[INFO] [stdout]     |                     ^^^^^ help: if this is intentional, prefix it with an underscore: `_p_tag`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `title` is never read
[INFO] [stdout]   --> src/main.rs:20:9
[INFO] [stdout]    |
[INFO] [stdout] 17 |     pub struct PublicParameters {
[INFO] [stdout]    |                ---------------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 20 |         title: String,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `unfold` is never used
[INFO] [stdout]    --> src/main.rs:428:8
[INFO] [stdout]     |
[INFO] [stdout] 428 |     fn unfold(a_tag: Scalar,b_tag : Scalar , challenges : Vec<Scalar>) -> (Vec<Scalar>, Vec<Scalar>) {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `unfold` is never used
[INFO] [stdout]    --> src/main.rs:350:162
[INFO] [stdout]     |
[INFO] [stdout] 350 | ...and only computes the s[0] and from there reuses work done");fn unfold(a_tag: Scalar, b_tag: Scalar, challenges: Vec<Scalar>) -> (Vec<...
[INFO] [stdout]     |                                                                    ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `G` should have a snake case name
[INFO] [stdout]   --> src/main.rs:22:13
[INFO] [stdout]    |
[INFO] [stdout] 22 |         pub G: Vec<RistrettoPoint>,
[INFO] [stdout]    |             ^ help: convert the identifier to snake case: `g`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `H` should have a snake case name
[INFO] [stdout]   --> src/main.rs:23:13
[INFO] [stdout]    |
[INFO] [stdout] 23 |         pub H: Vec<RistrettoPoint>,
[INFO] [stdout]    |             ^ help: convert the identifier to snake case: `h`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `U` should have a snake case name
[INFO] [stdout]   --> src/main.rs:24:13
[INFO] [stdout]    |
[INFO] [stdout] 24 |         pub U : RistrettoPoint
[INFO] [stdout]    |             ^ help: convert the identifier to snake case (notice the capitalization): `u`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `G` should have a snake case name
[INFO] [stdout]   --> src/main.rs:34:21
[INFO] [stdout]    |
[INFO] [stdout] 34 |             let mut G = Vec::with_capacity(lambda);
[INFO] [stdout]    |                     ^ help: convert the identifier to snake case: `g`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `H` should have a snake case name
[INFO] [stdout]   --> src/main.rs:35:21
[INFO] [stdout]    |
[INFO] [stdout] 35 |             let mut H = Vec::with_capacity(lambda);
[INFO] [stdout]    |                     ^ help: convert the identifier to snake case: `h`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `U` should have a snake case name
[INFO] [stdout]   --> src/main.rs:53:17
[INFO] [stdout]    |
[INFO] [stdout] 53 |             let U = RistrettoPoint::from_uniform_bytes(&u_hash[..64].
[INFO] [stdout]    |                 ^ help: convert the identifier to snake case (notice the capitalization): `u`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `P` should have a snake case name
[INFO] [stdout]   --> src/main.rs:74:13
[INFO] [stdout]    |
[INFO] [stdout] 74 |         pub P : RistrettoPoint,
[INFO] [stdout]    |             ^ help: convert the identifier to snake case: `p`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `L` should have a snake case name
[INFO] [stdout]   --> src/main.rs:75:13
[INFO] [stdout]    |
[INFO] [stdout] 75 |         pub L: Vec<RistrettoPoint>,
[INFO] [stdout]    |             ^ help: convert the identifier to snake case: `l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: structure field `R` should have a snake case name
[INFO] [stdout]   --> src/main.rs:76:13
[INFO] [stdout]    |
[INFO] [stdout] 76 |         pub R: Vec<RistrettoPoint>,
[INFO] [stdout]    |             ^ help: convert the identifier to snake case: `r`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `L_vec` should have a snake case name
[INFO] [stdout]    --> src/main.rs:103:17
[INFO] [stdout]     |
[INFO] [stdout] 103 |         let mut L_vec:Vec<RistrettoPoint> = Vec::new();
[INFO] [stdout]     |                 ^^^^^ help: convert the identifier to snake case: `l_vec`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `R_vec` should have a snake case name
[INFO] [stdout]    --> src/main.rs:104:17
[INFO] [stdout]     |
[INFO] [stdout] 104 |         let mut R_vec :Vec<RistrettoPoint> = Vec::new();
[INFO] [stdout]     |                 ^^^^^ help: convert the identifier to snake case: `r_vec`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `P` should have a snake case name
[INFO] [stdout]    --> src/main.rs:108:13
[INFO] [stdout]     |
[INFO] [stdout] 108 |         let P = inner_product_hash(g_vec.clone(), h_vec.clone(), ux, a.clone(), b.clone(), ab)?;
[INFO] [stdout]     |             ^ help: convert the identifier to snake case: `p`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `L` should have a snake case name
[INFO] [stdout]    --> src/main.rs:115:18
[INFO] [stdout]     |
[INFO] [stdout] 115 |             let (L,R,G_new,H_new,a_new,b_new) = fold(
[INFO] [stdout]     |                  ^ help: convert the identifier to snake case: `l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `R` should have a snake case name
[INFO] [stdout]    --> src/main.rs:115:20
[INFO] [stdout]     |
[INFO] [stdout] 115 |             let (L,R,G_new,H_new,a_new,b_new) = fold(
[INFO] [stdout]     |                    ^ help: convert the identifier to snake case: `r`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `G_new` should have a snake case name
[INFO] [stdout]    --> src/main.rs:115:22
[INFO] [stdout]     |
[INFO] [stdout] 115 |             let (L,R,G_new,H_new,a_new,b_new) = fold(
[INFO] [stdout]     |                      ^^^^^ help: convert the identifier to snake case: `g_new`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `H_new` should have a snake case name
[INFO] [stdout]    --> src/main.rs:115:28
[INFO] [stdout]     |
[INFO] [stdout] 115 |             let (L,R,G_new,H_new,a_new,b_new) = fold(
[INFO] [stdout]     |                            ^^^^^ help: convert the identifier to snake case: `h_new`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `P_tag` should have a snake case name
[INFO] [stdout]    --> src/main.rs:137:9
[INFO] [stdout]     |
[INFO] [stdout] 137 |     let P_tag = inner_product_hash(g_vec.clone(), h_vec.clone(), ux, a.clone(), b.clone(), ab)?;
[INFO] [stdout]     |         ^^^^^ help: convert the identifier to snake case: `p_tag`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `expected_P_tag` should have a snake case name
[INFO] [stdout]    --> src/main.rs:176:17
[INFO] [stdout]     |
[INFO] [stdout] 176 |             let expected_P_tag = inner_product_hash(g, h, ux, a_tagged, b_tagged, ab_tagged)?;
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `expected_p_tag`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `P_tag` should have a snake case name
[INFO] [stdout]    --> src/main.rs:179:17
[INFO] [stdout]     |
[INFO] [stdout] 179 |             let P_tag = inner_product_hash(self.L.clone(), self.R.clone(), self.P.clone(), x_squared, x_inv_squared, Scalar::ONE)?;
[INFO] [stdout]     |                 ^^^^^ help: convert the identifier to snake case: `p_tag`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `a_L` should have a snake case name
[INFO] [stdout]    --> src/main.rs:194:14
[INFO] [stdout]     |
[INFO] [stdout] 194 |         let (a_L, a_R) = a.split_at(n / 2);
[INFO] [stdout]     |              ^^^ help: convert the identifier to snake case: `a_l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `a_R` should have a snake case name
[INFO] [stdout]    --> src/main.rs:194:19
[INFO] [stdout]     |
[INFO] [stdout] 194 |         let (a_L, a_R) = a.split_at(n / 2);
[INFO] [stdout]     |                   ^^^ help: convert the identifier to snake case: `a_r`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `b_L` should have a snake case name
[INFO] [stdout]    --> src/main.rs:196:14
[INFO] [stdout]     |
[INFO] [stdout] 196 |         let (b_L, b_R) = b.split_at(n / 2);
[INFO] [stdout]     |              ^^^ help: convert the identifier to snake case: `b_l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `b_R` should have a snake case name
[INFO] [stdout]    --> src/main.rs:196:19
[INFO] [stdout]     |
[INFO] [stdout] 196 |         let (b_L, b_R) = b.split_at(n / 2);
[INFO] [stdout]     |                   ^^^ help: convert the identifier to snake case: `b_r`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `g_L` should have a snake case name
[INFO] [stdout]    --> src/main.rs:198:14
[INFO] [stdout]     |
[INFO] [stdout] 198 |         let (g_L, g_R) = g_vec.split_at(n / 2);
[INFO] [stdout]     |              ^^^ help: convert the identifier to snake case: `g_l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `g_R` should have a snake case name
[INFO] [stdout]    --> src/main.rs:198:19
[INFO] [stdout]     |
[INFO] [stdout] 198 |         let (g_L, g_R) = g_vec.split_at(n / 2);
[INFO] [stdout]     |                   ^^^ help: convert the identifier to snake case: `g_r`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `h_L` should have a snake case name
[INFO] [stdout]    --> src/main.rs:200:14
[INFO] [stdout]     |
[INFO] [stdout] 200 |         let (h_L, h_R) = h_vec.split_at(n / 2);
[INFO] [stdout]     |              ^^^ help: convert the identifier to snake case: `h_l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `h_R` should have a snake case name
[INFO] [stdout]    --> src/main.rs:200:19
[INFO] [stdout]     |
[INFO] [stdout] 200 |         let (h_L, h_R) = h_vec.split_at(n / 2);
[INFO] [stdout]     |                   ^^^ help: convert the identifier to snake case: `h_r`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `a_L_b_R` should have a snake case name
[INFO] [stdout]    --> src/main.rs:205:13
[INFO] [stdout]     |
[INFO] [stdout] 205 |         let a_L_b_R = get_inner_product(a_L.to_vec(), b_R.to_vec())?;
[INFO] [stdout]     |             ^^^^^^^ help: convert the identifier to snake case: `a_l_b_r`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `L` should have a snake case name
[INFO] [stdout]    --> src/main.rs:206:13
[INFO] [stdout]     |
[INFO] [stdout] 206 |         let L = inner_product_hash(g_R.to_vec(), h_L.to_vec(), ux, a_L.to_vec(), b_R.to_vec(), 
[INFO] [stdout]     |             ^ help: convert the identifier to snake case: `l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `a_R_b_L` should have a snake case name
[INFO] [stdout]    --> src/main.rs:210:13
[INFO] [stdout]     |
[INFO] [stdout] 210 |         let a_R_b_L = get_inner_product(a_R.to_vec(), b_L.to_vec())?;
[INFO] [stdout]     |             ^^^^^^^ help: convert the identifier to snake case: `a_r_b_l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `R` should have a snake case name
[INFO] [stdout]    --> src/main.rs:211:13
[INFO] [stdout]     |
[INFO] [stdout] 211 |         let R = inner_product_hash(g_L.to_vec(), h_R.to_vec(), ux, a_R.to_vec(),
[INFO] [stdout]     |             ^ help: convert the identifier to snake case: `r`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `GLx_inv` should have a snake case name
[INFO] [stdout]    --> src/main.rs:239:25
[INFO] [stdout]     |
[INFO] [stdout] 239 |                     let GLx_inv = &g_L[i] * &x_inv;
[INFO] [stdout]     |                         ^^^^^^^ help: convert the identifier to snake case: `glx_inv`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `GRx` should have a snake case name
[INFO] [stdout]    --> src/main.rs:240:25
[INFO] [stdout]     |
[INFO] [stdout] 240 |                     let GRx = &g_R[i] * &x;
[INFO] [stdout]     |                         ^^^ help: convert the identifier to snake case: `grx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `G_new` should have a snake case name
[INFO] [stdout]    --> src/main.rs:237:13
[INFO] [stdout]     |
[INFO] [stdout] 237 |         let G_new = (0..n)
[INFO] [stdout]     |             ^^^^^ help: convert the identifier to snake case: `g_new`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `HLx` should have a snake case name
[INFO] [stdout]    --> src/main.rs:247:25
[INFO] [stdout]     |
[INFO] [stdout] 247 |                     let HLx = &h_L[i] * &x;
[INFO] [stdout]     |                         ^^^ help: convert the identifier to snake case: `hlx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `HRx_inv` should have a snake case name
[INFO] [stdout]    --> src/main.rs:248:25
[INFO] [stdout]     |
[INFO] [stdout] 248 |                     let HRx_inv = &h_R[i] * &x_inv;
[INFO] [stdout]     |                         ^^^^^^^ help: convert the identifier to snake case: `hrx_inv`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `H_new` should have a snake case name
[INFO] [stdout]    --> src/main.rs:245:13
[INFO] [stdout]     |
[INFO] [stdout] 245 |         let H_new = (0..n)
[INFO] [stdout]     |             ^^^^^ help: convert the identifier to snake case: `h_new`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: module `LookUp_vector` should have a snake case name
[INFO] [stdout]    --> src/main.rs:255:5
[INFO] [stdout]     |
[INFO] [stdout] 255 | mod LookUp_vector{
[INFO] [stdout]     |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `look_up_vector`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `L_vec` should have a snake case name
[INFO] [stdout]    --> src/main.rs:408:9
[INFO] [stdout]     |
[INFO] [stdout] 408 |         L_vec: Vec<RistrettoPoint>,
[INFO] [stdout]     |         ^^^^^ help: convert the identifier to snake case: `l_vec`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `R_vec` should have a snake case name
[INFO] [stdout]    --> src/main.rs:409:9
[INFO] [stdout]     |
[INFO] [stdout] 409 |         R_vec: Vec<RistrettoPoint>,
[INFO] [stdout]     |         ^^^^^ help: convert the identifier to snake case: `r_vec`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `aG` should have a snake case name
[INFO] [stdout]    --> src/main.rs:456:13
[INFO] [stdout]     |
[INFO] [stdout] 456 |         let aG =RistrettoPoint::vartime_multiscalar_mul(a, g);
[INFO] [stdout]     |             ^^ help: convert the identifier to snake case: `a_g`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `bH` should have a snake case name
[INFO] [stdout]    --> src/main.rs:458:13
[INFO] [stdout]     |
[INFO] [stdout] 458 |         let bH = RistrettoPoint::vartime_multiscalar_mul(b,h);
[INFO] [stdout]     |             ^^ help: convert the identifier to snake case: `b_h`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `P` should have a snake case name
[INFO] [stdout]    --> src/main.rs:520:13
[INFO] [stdout]     |
[INFO] [stdout] 520 |         let P = result.P.clone();
[INFO] [stdout]     |             ^ help: convert the identifier to snake case: `p`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `L` should have a snake case name
[INFO] [stdout]    --> src/main.rs:521:13
[INFO] [stdout]     |
[INFO] [stdout] 521 |         let L = result.L.clone();
[INFO] [stdout]     |             ^ help: convert the identifier to snake case: `l`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `R` should have a snake case name
[INFO] [stdout]    --> src/main.rs:522:13
[INFO] [stdout]     |
[INFO] [stdout] 522 |         let R = result.R.clone();
[INFO] [stdout]     |             ^ help: convert the identifier to snake case: `r`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `expected_P` should have a snake case name
[INFO] [stdout]    --> src/main.rs:527:13
[INFO] [stdout]     |
[INFO] [stdout] 527 |         let expected_P = inner_product_hash(L, R, P, x_squared, x_inverser, Scalar::ONE).unwrap();
[INFO] [stdout]     |             ^^^^^^^^^^ help: convert the identifier to snake case: `expected_p`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `test_reconstruction_of_P` should have a snake case name
[INFO] [stdout]    --> src/main.rs:557:8
[INFO] [stdout]     |
[INFO] [stdout] 557 |     fn test_reconstruction_of_P(){
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_reconstruction_of_p`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 3.16s
[INFO] running `Command { std: "docker" "inspect" "d12e054fd2b20d46d4781c5f44570e21f634d9b3bbe3f9ddefa56e22f04e1872", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d12e054fd2b20d46d4781c5f44570e21f634d9b3bbe3f9ddefa56e22f04e1872", kill_on_drop: false }`
[INFO] [stdout] d12e054fd2b20d46d4781c5f44570e21f634d9b3bbe3f9ddefa56e22f04e1872
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid -Copt-level=3" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] efcf934d8a78b187fc287e40a0ed59aba5dc7fed35042d7b7ad5f2f2e44a4016
[INFO] running `Command { std: "docker" "start" "-a" "efcf934d8a78b187fc287e40a0ed59aba5dc7fed35042d7b7ad5f2f2e44a4016", kill_on_drop: false }`
[INFO] [stderr] warning: unnecessary parentheses around method argument
[INFO] [stderr]   --> src/transcript/mod.rs:53:86
[INFO] [stderr]    |
[INFO] [stderr] 53 |                         let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add((x as u16)));
[INFO] [stderr]    |                                                                                      ^        ^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 53 -                         let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add((x as u16)));
[INFO] [stderr] 53 +                         let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add(x as u16));
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around method argument
[INFO] [stderr]   --> src/transcript/mod.rs:65:78
[INFO] [stderr]    |
[INFO] [stderr] 65 |                 let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add((x as u16)));
[INFO] [stderr]    |                                                                              ^        ^
[INFO] [stderr]    |
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr] 65 -                 let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add((x as u16)));
[INFO] [stderr] 65 +                 let key = input.iter().fold(0u16, |acc, &x| acc.wrapping_add(x as u16));
[INFO] [stderr]    |
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `ErrorKind` and `Error`
[INFO] [stderr]  --> src/traits.rs:8:22
[INFO] [stderr]   |
[INFO] [stderr] 8 | use std::io::{Result,Error,ErrorKind};
[INFO] [stderr]   |                      ^^^^^ ^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `self` and `self`
[INFO] [stderr]  --> src/traits.rs:9:25
[INFO] [stderr]   |
[INFO] [stderr] 9 | use crate::transcript::{self, fiat_shamir::{self, FiatShamir}, Transcript};
[INFO] [stderr]   |                         ^^^^                ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `sha2::digest::typenum::tarr`
[INFO] [stderr]   --> src/traits.rs:13:5
[INFO] [stderr]    |
[INFO] [stderr] 13 | use sha2::digest::typenum::tarr;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: crate `BulletProofs_arg` should have a snake case name
[INFO] [stderr]   |
[INFO] [stderr]   = help: convert the identifier to snake case: `bullet_proofs_arg`
[INFO] [stderr]   = note: `#[warn(non_snake_case)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `BulletProofs_arg` (lib) generated 6 warnings (run `cargo fix --lib -p BulletProofs_arg` to apply 5 suggestions)
[INFO] [stderr] warning: `BulletProofs_arg` (lib test) generated 5 warnings (5 duplicates)
[INFO] [stderr] warning: unused import: `is_power_of_two`
[INFO] [stderr]   --> src/main.rs:11:42
[INFO] [stderr]    |
[INFO] [stderr] 11 |     use BulletProofs_arg::{log2_helper::{is_power_of_two, round_up_to_power_of_two}};
[INFO] [stderr]    |                                          ^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `self` and `self`
[INFO] [stderr]   --> src/main.rs:12:40
[INFO] [stderr]    |
[INFO] [stderr] 12 |     use BulletProofs_arg::transcript::{self, fiat_shamir::{self, FiatShamir}, Transcript};
[INFO] [stderr]    |                                        ^^^^                ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around assigned value
[INFO] [stderr]    --> src/main.rs:173:29
[INFO] [stderr]     |
[INFO] [stderr] 173 |             let ab_tagged = (self.a_tag *self.b_tag);
[INFO] [stderr]     |                             ^                      ^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stderr] help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr] 173 -             let ab_tagged = (self.a_tag *self.b_tag);
[INFO] [stderr] 173 +             let ab_tagged = self.a_tag *self.b_tag;
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `rand::rngs::ThreadRng`
[INFO] [stderr]    --> src/main.rs:324:9
[INFO] [stderr]     |
[INFO] [stderr] 324 |     use rand::rngs::ThreadRng;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `crate::inner_product_argument::LookUp_vector::get_lookup_vector`
[INFO] [stderr]    --> src/main.rs:467:9
[INFO] [stderr]     |
[INFO] [stderr] 467 |     use crate::inner_product_argument::LookUp_vector::get_lookup_vector;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `ark_ec::bls12::g1`
[INFO] [stderr]    --> src/main.rs:470:9
[INFO] [stderr]     |
[INFO] [stderr] 470 |     use ark_ec::bls12::g1;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Sha512`
[INFO] [stderr]    --> src/main.rs:472:24
[INFO] [stderr]     |
[INFO] [stderr] 472 |     use sha2::{Sha256, Sha512, Digest};
[INFO] [stderr]     |                        ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `self`
[INFO] [stderr]    --> src/main.rs:473:36
[INFO] [stderr]     |
[INFO] [stderr] 473 |     use curve25519_dalek::scalar::{self, Scalar};
[INFO] [stderr]     |                                    ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::collections::HashMap`
[INFO] [stderr]    --> src/main.rs:475:9
[INFO] [stderr]     |
[INFO] [stderr] 475 |     use std::collections::HashMap;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::result`
[INFO] [stderr]    --> src/main.rs:476:9
[INFO] [stderr]     |
[INFO] [stderr] 476 |     use std::result;
[INFO] [stderr]     |         ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `curve25519_dalek::traits::MultiscalarMul`
[INFO] [stderr]    --> src/main.rs:477:9
[INFO] [stderr]     |
[INFO] [stderr] 477 |     use curve25519_dalek::traits::MultiscalarMul;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `ab`
[INFO] [stderr]    --> src/main.rs:202:13
[INFO] [stderr]     |
[INFO] [stderr] 202 |         let ab = get_inner_product(a.clone(), b.clone());
[INFO] [stderr]     |             ^^ help: if this is intentional, prefix it with an underscore: `_ab`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `a_tag`
[INFO] [stderr]    --> src/main.rs:428:15
[INFO] [stderr]     |
[INFO] [stderr] 428 |     fn unfold(a_tag: Scalar,b_tag : Scalar , challenges : Vec<Scalar>) -> (Vec<Scalar>, Vec<Scalar>) {
[INFO] [stderr]     |               ^^^^^ help: if this is intentional, prefix it with an underscore: `_a_tag`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `b_tag`
[INFO] [stderr]    --> src/main.rs:428:29
[INFO] [stderr]     |
[INFO] [stderr] 428 |     fn unfold(a_tag: Scalar,b_tag : Scalar , challenges : Vec<Scalar>) -> (Vec<Scalar>, Vec<Scalar>) {
[INFO] [stderr]     |                             ^^^^^ help: if this is intentional, prefix it with an underscore: `_b_tag`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `challenges`
[INFO] [stderr]    --> src/main.rs:428:46
[INFO] [stderr]     |
[INFO] [stderr] 428 |     fn unfold(a_tag: Scalar,b_tag : Scalar , challenges : Vec<Scalar>) -> (Vec<Scalar>, Vec<Scalar>) {
[INFO] [stderr]     |                                              ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_challenges`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/main.rs:439:13
[INFO] [stderr]     |
[INFO] [stderr] 439 |         let mut inner_product = Scalar::ZERO;
[INFO] [stderr]     |             ----^^^^^^^^^^^^^
[INFO] [stderr]     |             |
[INFO] [stderr]     |             help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `n`
[INFO] [stderr]    --> src/main.rs:449:13
[INFO] [stderr]     |
[INFO] [stderr] 449 |         let n = a.len();
[INFO] [stderr]     |             ^ help: if this is intentional, prefix it with an underscore: `_n`
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `p_tag`
[INFO] [stderr]    --> src/main.rs:550:21
[INFO] [stderr]     |
[INFO] [stderr] 550 |         let (result,p_tag): (InnerProductProof<ShaFiat, PublicParameters>, RistrettoPoint) = result.unwrap();
[INFO] [stderr]     |                     ^^^^^ help: if this is intentional, prefix it with an underscore: `_p_tag`
[INFO] [stderr] 
[INFO] [stderr] warning: field `title` is never read
[INFO] [stderr]   --> src/main.rs:20:9
[INFO] [stderr]    |
[INFO] [stderr] 17 |     pub struct PublicParameters {
[INFO] [stderr]    |                ---------------- field in this struct
[INFO] [stderr] ...
[INFO] [stderr] 20 |         title: String,
[INFO] [stderr]    |         ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `unfold` is never used
[INFO] [stderr]    --> src/main.rs:428:8
[INFO] [stderr]     |
[INFO] [stderr] 428 |     fn unfold(a_tag: Scalar,b_tag : Scalar , challenges : Vec<Scalar>) -> (Vec<Scalar>, Vec<Scalar>) {
[INFO] [stderr]     |        ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `unfold` is never used
[INFO] [stderr]    --> src/main.rs:350:162
[INFO] [stderr]     |
[INFO] [stderr] 350 | ...and only computes the s[0] and from there reuses work done");fn unfold(a_tag: Scalar, b_tag: Scalar, challenges: Vec<Scalar>) -> (Vec<...
[INFO] [stderr]     |                                                                    ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `G` should have a snake case name
[INFO] [stderr]   --> src/main.rs:22:13
[INFO] [stderr]    |
[INFO] [stderr] 22 |         pub G: Vec<RistrettoPoint>,
[INFO] [stderr]    |             ^ help: convert the identifier to snake case: `g`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(non_snake_case)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `H` should have a snake case name
[INFO] [stderr]   --> src/main.rs:23:13
[INFO] [stderr]    |
[INFO] [stderr] 23 |         pub H: Vec<RistrettoPoint>,
[INFO] [stderr]    |             ^ help: convert the identifier to snake case: `h`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `U` should have a snake case name
[INFO] [stderr]   --> src/main.rs:24:13
[INFO] [stderr]    |
[INFO] [stderr] 24 |         pub U : RistrettoPoint
[INFO] [stderr]    |             ^ help: convert the identifier to snake case (notice the capitalization): `u`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `G` should have a snake case name
[INFO] [stderr]   --> src/main.rs:34:21
[INFO] [stderr]    |
[INFO] [stderr] 34 |             let mut G = Vec::with_capacity(lambda);
[INFO] [stderr]    |                     ^ help: convert the identifier to snake case: `g`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `H` should have a snake case name
[INFO] [stderr]   --> src/main.rs:35:21
[INFO] [stderr]    |
[INFO] [stderr] 35 |             let mut H = Vec::with_capacity(lambda);
[INFO] [stderr]    |                     ^ help: convert the identifier to snake case: `h`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `U` should have a snake case name
[INFO] [stderr]   --> src/main.rs:53:17
[INFO] [stderr]    |
[INFO] [stderr] 53 |             let U = RistrettoPoint::from_uniform_bytes(&u_hash[..64].
[INFO] [stderr]    |                 ^ help: convert the identifier to snake case (notice the capitalization): `u`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `P` should have a snake case name
[INFO] [stderr]   --> src/main.rs:74:13
[INFO] [stderr]    |
[INFO] [stderr] 74 |         pub P : RistrettoPoint,
[INFO] [stderr]    |             ^ help: convert the identifier to snake case: `p`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `L` should have a snake case name
[INFO] [stderr]   --> src/main.rs:75:13
[INFO] [stderr]    |
[INFO] [stderr] 75 |         pub L: Vec<RistrettoPoint>,
[INFO] [stderr]    |             ^ help: convert the identifier to snake case: `l`
[INFO] [stderr] 
[INFO] [stderr] warning: structure field `R` should have a snake case name
[INFO] [stderr]   --> src/main.rs:76:13
[INFO] [stderr]    |
[INFO] [stderr] 76 |         pub R: Vec<RistrettoPoint>,
[INFO] [stderr]    |             ^ help: convert the identifier to snake case: `r`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `L_vec` should have a snake case name
[INFO] [stderr]    --> src/main.rs:103:17
[INFO] [stderr]     |
[INFO] [stderr] 103 |         let mut L_vec:Vec<RistrettoPoint> = Vec::new();
[INFO] [stderr]     |                 ^^^^^ help: convert the identifier to snake case: `l_vec`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `R_vec` should have a snake case name
[INFO] [stderr]    --> src/main.rs:104:17
[INFO] [stderr]     |
[INFO] [stderr] 104 |         let mut R_vec :Vec<RistrettoPoint> = Vec::new();
[INFO] [stderr]     |                 ^^^^^ help: convert the identifier to snake case: `r_vec`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `P` should have a snake case name
[INFO] [stderr]    --> src/main.rs:108:13
[INFO] [stderr]     |
[INFO] [stderr] 108 |         let P = inner_product_hash(g_vec.clone(), h_vec.clone(), ux, a.clone(), b.clone(), ab)?;
[INFO] [stderr]     |             ^ help: convert the identifier to snake case: `p`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `L` should have a snake case name
[INFO] [stderr]    --> src/main.rs:115:18
[INFO] [stderr]     |
[INFO] [stderr] 115 |             let (L,R,G_new,H_new,a_new,b_new) = fold(
[INFO] [stderr]     |                  ^ help: convert the identifier to snake case: `l`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `R` should have a snake case name
[INFO] [stderr]    --> src/main.rs:115:20
[INFO] [stderr]     |
[INFO] [stderr] 115 |             let (L,R,G_new,H_new,a_new,b_new) = fold(
[INFO] [stderr]     |                    ^ help: convert the identifier to snake case: `r`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `G_new` should have a snake case name
[INFO] [stderr]    --> src/main.rs:115:22
[INFO] [stderr]     |
[INFO] [stderr] 115 |             let (L,R,G_new,H_new,a_new,b_new) = fold(
[INFO] [stderr]     |                      ^^^^^ help: convert the identifier to snake case: `g_new`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `H_new` should have a snake case name
[INFO] [stderr]    --> src/main.rs:115:28
[INFO] [stderr]     |
[INFO] [stderr] 115 |             let (L,R,G_new,H_new,a_new,b_new) = fold(
[INFO] [stderr]     |                            ^^^^^ help: convert the identifier to snake case: `h_new`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `P_tag` should have a snake case name
[INFO] [stderr]    --> src/main.rs:137:9
[INFO] [stderr]     |
[INFO] [stderr] 137 |     let P_tag = inner_product_hash(g_vec.clone(), h_vec.clone(), ux, a.clone(), b.clone(), ab)?;
[INFO] [stderr]     |         ^^^^^ help: convert the identifier to snake case: `p_tag`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `expected_P_tag` should have a snake case name
[INFO] [stderr]    --> src/main.rs:176:17
[INFO] [stderr]     |
[INFO] [stderr] 176 |             let expected_P_tag = inner_product_hash(g, h, ux, a_tagged, b_tagged, ab_tagged)?;
[INFO] [stderr]     |                 ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `expected_p_tag`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `P_tag` should have a snake case name
[INFO] [stderr]    --> src/main.rs:179:17
[INFO] [stderr]     |
[INFO] [stderr] 179 |             let P_tag = inner_product_hash(self.L.clone(), self.R.clone(), self.P.clone(), x_squared, x_inv_squared, Scalar::ONE)?;
[INFO] [stderr]     |                 ^^^^^ help: convert the identifier to snake case: `p_tag`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `a_L` should have a snake case name
[INFO] [stderr]    --> src/main.rs:194:14
[INFO] [stderr]     |
[INFO] [stderr] 194 |         let (a_L, a_R) = a.split_at(n / 2);
[INFO] [stderr]     |              ^^^ help: convert the identifier to snake case: `a_l`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `a_R` should have a snake case name
[INFO] [stderr]    --> src/main.rs:194:19
[INFO] [stderr]     |
[INFO] [stderr] 194 |         let (a_L, a_R) = a.split_at(n / 2);
[INFO] [stderr]     |                   ^^^ help: convert the identifier to snake case: `a_r`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `b_L` should have a snake case name
[INFO] [stderr]    --> src/main.rs:196:14
[INFO] [stderr]     |
[INFO] [stderr] 196 |         let (b_L, b_R) = b.split_at(n / 2);
[INFO] [stderr]     |              ^^^ help: convert the identifier to snake case: `b_l`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `b_R` should have a snake case name
[INFO] [stderr]    --> src/main.rs:196:19
[INFO] [stderr]     |
[INFO] [stderr] 196 |         let (b_L, b_R) = b.split_at(n / 2);
[INFO] [stderr]     |                   ^^^ help: convert the identifier to snake case: `b_r`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `g_L` should have a snake case name
[INFO] [stderr]    --> src/main.rs:198:14
[INFO] [stderr]     |
[INFO] [stderr] 198 |         let (g_L, g_R) = g_vec.split_at(n / 2);
[INFO] [stderr]     |              ^^^ help: convert the identifier to snake case: `g_l`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `g_R` should have a snake case name
[INFO] [stderr]    --> src/main.rs:198:19
[INFO] [stderr]     |
[INFO] [stderr] 198 |         let (g_L, g_R) = g_vec.split_at(n / 2);
[INFO] [stderr]     |                   ^^^ help: convert the identifier to snake case: `g_r`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `h_L` should have a snake case name
[INFO] [stderr]    --> src/main.rs:200:14
[INFO] [stderr]     |
[INFO] [stderr] 200 |         let (h_L, h_R) = h_vec.split_at(n / 2);
[INFO] [stderr]     |              ^^^ help: convert the identifier to snake case: `h_l`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `h_R` should have a snake case name
[INFO] [stderr]    --> src/main.rs:200:19
[INFO] [stderr]     |
[INFO] [stderr] 200 |         let (h_L, h_R) = h_vec.split_at(n / 2);
[INFO] [stderr]     |                   ^^^ help: convert the identifier to snake case: `h_r`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `a_L_b_R` should have a snake case name
[INFO] [stderr]    --> src/main.rs:205:13
[INFO] [stderr]     |
[INFO] [stderr] 205 |         let a_L_b_R = get_inner_product(a_L.to_vec(), b_R.to_vec())?;
[INFO] [stderr]     |             ^^^^^^^ help: convert the identifier to snake case: `a_l_b_r`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `L` should have a snake case name
[INFO] [stderr]    --> src/main.rs:206:13
[INFO] [stderr]     |
[INFO] [stderr] 206 |         let L = inner_product_hash(g_R.to_vec(), h_L.to_vec(), ux, a_L.to_vec(), b_R.to_vec(), 
[INFO] [stderr]     |             ^ help: convert the identifier to snake case: `l`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `a_R_b_L` should have a snake case name
[INFO] [stderr]    --> src/main.rs:210:13
[INFO] [stderr]     |
[INFO] [stderr] 210 |         let a_R_b_L = get_inner_product(a_R.to_vec(), b_L.to_vec())?;
[INFO] [stderr]     |             ^^^^^^^ help: convert the identifier to snake case: `a_r_b_l`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `R` should have a snake case name
[INFO] [stderr]    --> src/main.rs:211:13
[INFO] [stderr]     |
[INFO] [stderr] 211 |         let R = inner_product_hash(g_L.to_vec(), h_R.to_vec(), ux, a_R.to_vec(),
[INFO] [stderr]     |             ^ help: convert the identifier to snake case: `r`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `GLx_inv` should have a snake case name
[INFO] [stderr]    --> src/main.rs:239:25
[INFO] [stderr]     |
[INFO] [stderr] 239 |                     let GLx_inv = &g_L[i] * &x_inv;
[INFO] [stderr]     |                         ^^^^^^^ help: convert the identifier to snake case: `glx_inv`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `GRx` should have a snake case name
[INFO] [stderr]    --> src/main.rs:240:25
[INFO] [stderr]     |
[INFO] [stderr] 240 |                     let GRx = &g_R[i] * &x;
[INFO] [stderr]     |                         ^^^ help: convert the identifier to snake case: `grx`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `G_new` should have a snake case name
[INFO] [stderr]    --> src/main.rs:237:13
[INFO] [stderr]     |
[INFO] [stderr] 237 |         let G_new = (0..n)
[INFO] [stderr]     |             ^^^^^ help: convert the identifier to snake case: `g_new`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `HLx` should have a snake case name
[INFO] [stderr]    --> src/main.rs:247:25
[INFO] [stderr]     |
[INFO] [stderr] 247 |                     let HLx = &h_L[i] * &x;
[INFO] [stderr]     |                         ^^^ help: convert the identifier to snake case: `hlx`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `HRx_inv` should have a snake case name
[INFO] [stderr]    --> src/main.rs:248:25
[INFO] [stderr]     |
[INFO] [stderr] 248 |                     let HRx_inv = &h_R[i] * &x_inv;
[INFO] [stderr]     |                         ^^^^^^^ help: convert the identifier to snake case: `hrx_inv`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `H_new` should have a snake case name
[INFO] [stderr]    --> src/main.rs:245:13
[INFO] [stderr]     |
[INFO] [stderr] 245 |         let H_new = (0..n)
[INFO] [stderr]     |             ^^^^^ help: convert the identifier to snake case: `h_new`
[INFO] [stderr] 
[INFO] [stderr] warning: module `LookUp_vector` should have a snake case name
[INFO] [stderr]    --> src/main.rs:255:5
[INFO] [stderr]     |
[INFO] [stderr] 255 | mod LookUp_vector{
[INFO] [stderr]     |     ^^^^^^^^^^^^^ help: convert the identifier to snake case: `look_up_vector`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `L_vec` should have a snake case name
[INFO] [stderr]    --> src/main.rs:408:9
[INFO] [stderr]     |
[INFO] [stderr] 408 |         L_vec: Vec<RistrettoPoint>,
[INFO] [stderr]     |         ^^^^^ help: convert the identifier to snake case: `l_vec`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `R_vec` should have a snake case name
[INFO] [stderr]    --> src/main.rs:409:9
[INFO] [stderr]     |
[INFO] [stderr] 409 |         R_vec: Vec<RistrettoPoint>,
[INFO] [stderr]     |         ^^^^^ help: convert the identifier to snake case: `r_vec`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `aG` should have a snake case name
[INFO] [stderr]    --> src/main.rs:456:13
[INFO] [stderr]     |
[INFO] [stderr] 456 |         let aG =RistrettoPoint::vartime_multiscalar_mul(a, g);
[INFO] [stderr]     |             ^^ help: convert the identifier to snake case: `a_g`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `bH` should have a snake case name
[INFO] [stderr]    --> src/main.rs:458:13
[INFO] [stderr]     |
[INFO] [stderr] 458 |         let bH = RistrettoPoint::vartime_multiscalar_mul(b,h);
[INFO] [stderr]     |             ^^ help: convert the identifier to snake case: `b_h`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `P` should have a snake case name
[INFO] [stderr]    --> src/main.rs:520:13
[INFO] [stderr]     |
[INFO] [stderr] 520 |         let P = result.P.clone();
[INFO] [stderr]     |             ^ help: convert the identifier to snake case: `p`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `L` should have a snake case name
[INFO] [stderr]    --> src/main.rs:521:13
[INFO] [stderr]     |
[INFO] [stderr] 521 |         let L = result.L.clone();
[INFO] [stderr]     |             ^ help: convert the identifier to snake case: `l`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `R` should have a snake case name
[INFO] [stderr]    --> src/main.rs:522:13
[INFO] [stderr]     |
[INFO] [stderr] 522 |         let R = result.R.clone();
[INFO] [stderr]     |             ^ help: convert the identifier to snake case: `r`
[INFO] [stderr] 
[INFO] [stderr] warning: variable `expected_P` should have a snake case name
[INFO] [stderr]    --> src/main.rs:527:13
[INFO] [stderr]     |
[INFO] [stderr] 527 |         let expected_P = inner_product_hash(L, R, P, x_squared, x_inverser, Scalar::ONE).unwrap();
[INFO] [stderr]     |             ^^^^^^^^^^ help: convert the identifier to snake case: `expected_p`
[INFO] [stderr] 
[INFO] [stderr] warning: function `test_reconstruction_of_P` should have a snake case name
[INFO] [stderr]    --> src/main.rs:557:8
[INFO] [stderr]     |
[INFO] [stderr] 557 |     fn test_reconstruction_of_P(){
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `test_reconstruction_of_p`
[INFO] [stderr] 
[INFO] [stderr] warning: `BulletProofs_arg` (bin "BulletProofs_arg" test) generated 68 warnings (run `cargo fix --bin "BulletProofs_arg" --tests` to apply 12 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.10s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/BulletProofs_arg-ff0cbd34abd68ad3)
[INFO] [stdout] 
[INFO] [stdout] running 3 tests
[INFO] [stdout] test transcript::tests::test_interactive_duplicate_insert ... ok
[INFO] [stdout] test transcript::tests::test_non_interactive_determinism ... ok
[INFO] [stdout] test transcript::tests::test_interactive_value_consistency ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 3 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/BulletProofs_arg-dbbc81ff69dea7bd)
[INFO] [stdout] 
[INFO] [stdout] running 6 tests
[INFO] [stdout] test inner_product_argument::LookUp_vector::tests::test_get_lookup_vector ... ok
[INFO] [stdout] test inner_product_argument::LookUp_vector::tests::benchmark_lookup_vector ... ok
[INFO] [stdout] test inner_product_argument::LookUp_vector::tests::test_lookup_vector_equality ... ok
[INFO] [stdout] test inner_product_argument::tests::test_prove_does_not_fail ... ok
[INFO] [stdout] test inner_product_argument::tests::test_prove_and_verify ... FAILED
[INFO] [stdout] test inner_product_argument::tests::test_reconstruction_of_P ... FAILED
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout] 
[INFO] [stdout] ---- inner_product_argument::tests::test_prove_and_verify stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'inner_product_argument::tests::test_prove_and_verify' panicked at src/main.rs:554:9:
[INFO] [stdout] assertion failed: ansa
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5796c8c87ea2 - std::backtrace_rs::backtrace::libunwind::trace::hd39b1f53d3cf9745
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5796c8c87ea2 - std::backtrace_rs::backtrace::trace_unsynchronized::he91d9a75d4e3972b
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5796c8c87ea2 - std::sys::backtrace::_print_fmt::hca46938f8c6e22cf
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x5796c8c87ea2 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::ha499add612cccf8e
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x5796c8cad5c3 - core::fmt::rt::Argument::fmt::hd21145b75a833b7a
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x5796c8cad5c3 - core::fmt::write::hb10c956f5235c8a4
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/core/src/fmt/mod.rs:1465:25
[INFO] [stdout]    6:     0x5796c8c85083 - std::io::default_write_fmt::hdb7615052be2ba4d
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5796c8c85083 - std::io::Write::write_fmt::he1bcd251ec6e4153
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x5796c8c87cf2 - std::sys::backtrace::BacktraceLock::print::hb47c770ef659fd10
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x5796c8c8940c - std::panicking::default_hook::{{closure}}::hdda8afb9d457a22c
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panicking.rs:300:27
[INFO] [stdout]   10:     0x5796c8c89262 - std::panicking::default_hook::h7c46b44874fe5c9a
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panicking.rs:324:9
[INFO] [stdout]   11:     0x5796c8c35694 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h178a5fcedee41e2f
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   12:     0x5796c8c35694 - test::test_main_with_exit_callback::{{closure}}::h951a41e0149d6d5d
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5796c8c89deb - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h13602080f5b63276
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   14:     0x5796c8c89deb - std::panicking::rust_panic_with_hook::ha6cb99ed099eb1c5
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panicking.rs:841:13
[INFO] [stdout]   15:     0x5796c8c89b86 - std::panicking::begin_panic_handler::{{closure}}::he11808bc797ee921
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panicking.rs:699:13
[INFO] [stdout]   16:     0x5796c8c88399 - std::sys::backtrace::__rust_end_short_backtrace::h9418807cb7346258
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/sys/backtrace.rs:168:18
[INFO] [stdout]   17:     0x5796c8c8984d - __rustc[18fb429eef004894]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panicking.rs:697:5
[INFO] [stdout]   18:     0x5796c8cac110 - core::panicking::panic_fmt::hd890aeb12c3a3fc3
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/core/src/panicking.rs:75:14
[INFO] [stdout]   19:     0x5796c8cac17c - core::panicking::panic::h318cb8731d7e290d
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/core/src/panicking.rs:145:5
[INFO] [stdout]   20:     0x5796c8bf6460 - BulletProofs_arg::inner_product_argument::tests::test_prove_and_verify::h6947bebdabb46efc
[INFO] [stdout]                                at /opt/rustwide/workdir/src/main.rs:554:9
[INFO] [stdout]   21:     0x5796c8bf7d39 - BulletProofs_arg::inner_product_argument::tests::test_prove_and_verify::{{closure}}::h10f520c6be2a3ca4
[INFO] [stdout]                                at /opt/rustwide/workdir/src/main.rs:532:31
[INFO] [stdout]   22:     0x5796c8bf7d39 - core::ops::function::FnOnce::call_once::h40fa8b4826dcaf9e
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   23:     0x5796c8c3ae1b - core::ops::function::FnOnce::call_once::h2869fb5b0a2b0bdc
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x5796c8c3ae1b - test::__rust_begin_short_backtrace::h7dd7142bd62fa711
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/test/src/lib.rs:648:18
[INFO] [stdout]   25:     0x5796c8c3a00e - test::run_test_in_process::{{closure}}::h43a753f038d36b3f
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/test/src/lib.rs:671:74
[INFO] [stdout]   26:     0x5796c8c3a00e - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h0ca95dd3e12d1e16
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   27:     0x5796c8c3a00e - std::panicking::catch_unwind::do_call::he308587d70ac34ba
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panicking.rs:589:40
[INFO] [stdout]   28:     0x5796c8c3a00e - std::panicking::catch_unwind::h30dcba31973e8fb0
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panicking.rs:552:19
[INFO] [stdout]   29:     0x5796c8c3a00e - std::panic::catch_unwind::hfb68364e5621fbee
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panic.rs:359:14
[INFO] [stdout]   30:     0x5796c8c3a00e - test::run_test_in_process::hcdcc2977903b998a
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/test/src/lib.rs:671:27
[INFO] [stdout]   31:     0x5796c8c3a00e - test::run_test::{{closure}}::h544a6550958c5d14
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/test/src/lib.rs:592:43
[INFO] [stdout]   32:     0x5796c8bfdb84 - test::run_test::{{closure}}::hb172e48ebe2b92c7
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/test/src/lib.rs:622:41
[INFO] [stdout]   33:     0x5796c8bfdb84 - std::sys::backtrace::__rust_begin_short_backtrace::h7e79d8706638bea0
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/sys/backtrace.rs:152:18
[INFO] [stdout]   34:     0x5796c8c0155a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hc4a275f1e71b8ab0
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/thread/mod.rs:559:17
[INFO] [stdout]   35:     0x5796c8c0155a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h01ed0d242df78cfd
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   36:     0x5796c8c0155a - std::panicking::catch_unwind::do_call::h052f373fb905fee0
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panicking.rs:589:40
[INFO] [stdout]   37:     0x5796c8c0155a - std::panicking::catch_unwind::hb425d20c8ffb09c8
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panicking.rs:552:19
[INFO] [stdout]   38:     0x5796c8c0155a - std::panic::catch_unwind::ha0d5dfbf18fdeda5
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panic.rs:359:14
[INFO] [stdout]   39:     0x5796c8c0155a - std::thread::Builder::spawn_unchecked_::{{closure}}::hbe79182bd37949c7
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/thread/mod.rs:557:30
[INFO] [stdout]   40:     0x5796c8c0155a - core::ops::function::FnOnce::call_once{{vtable.shim}}::hc096c4a06972fde5
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   41:     0x5796c8c8cd47 - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h47377e27fb938a26
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/alloc/src/boxed.rs:1971:9
[INFO] [stdout]   42:     0x5796c8c8cd47 - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h72f1fe5d095abf57
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/alloc/src/boxed.rs:1971:9
[INFO] [stdout]   43:     0x5796c8c8cd47 - std::sys::pal::unix::thread::Thread::new::thread_start::h0a4d8e1b9c0d38cf
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/sys/pal/unix/thread.rs:97:17
[INFO] [stdout]   44:     0x780dcaa12aa4 - <unknown>
[INFO] [stdout]   45:     0x780dcaa9fa34 - clone
[INFO] [stdout]   46:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] ---- inner_product_argument::tests::test_reconstruction_of_P stdout ----
[INFO] [stdout] 
[INFO] [stdout] thread 'inner_product_argument::tests::test_reconstruction_of_P' panicked at src/main.rs:596:9:
[INFO] [stdout] assertion `left == right` failed
[INFO] [stdout]   left: RistrettoPoint: coset 
[INFO] [stdout] EdwardsPoint{
[INFO] [stdout] 	X: FieldElement51([28541879439025, 399199152375828, 1653932994612157, 1664617808252092, 1323921103035515]),
[INFO] [stdout] 	Y: FieldElement51([1370201933723134, 118429292568976, 264991747463411, 1427400759139985, 1790678532831509]),
[INFO] [stdout] 	Z: FieldElement51([910914219981768, 509511167846299, 687797342400186, 1861988099777738, 1348747869091061]),
[INFO] [stdout] 	T: FieldElement51([2227853618669638, 1187224492132791, 1698559643451129, 1170474371842465, 252282081905857])
[INFO] [stdout] }
[INFO] [stdout] EdwardsPoint{
[INFO] [stdout] 	X: FieldElement51([1781573044453703, 970586431498056, 1096962488755859, 1292322006306614, 1122288429258643]),
[INFO] [stdout] 	Y: FieldElement51([448834286638508, 549903205838753, 663880923736292, 1187737222351622, 1423441362411483]),
[INFO] [stdout] 	Z: FieldElement51([898445681492805, 1376643309555281, 40312032966645, 1791890817625834, 630719825290575]),
[INFO] [stdout] 	T: FieldElement51([2205168143293835, 2224941325304968, 2079798561061083, 712296403283520, 1811243887183299])
[INFO] [stdout] }
[INFO] [stdout] EdwardsPoint{
[INFO] [stdout] 	X: FieldElement51([1612491679543272, 1740545141168440, 720147932384413, 818763924404417, 708792643497997]),
[INFO] [stdout] 	Y: FieldElement51([870600985902636, 2007397667049379, 1361133723539810, 1599035295440208, 1318313844884767]),
[INFO] [stdout] 	Z: FieldElement51([898445681492805, 1376643309555281, 40312032966645, 1791890817625834, 630719825290575]),
[INFO] [stdout] 	T: FieldElement51([46631670391394, 26858488380279, 172001252624164, 1539503410401727, 440555926501948])
[INFO] [stdout] }
[INFO] [stdout] EdwardsPoint{
[INFO] [stdout] 	X: FieldElement51([470226769231526, 1281213382187191, 1154837324929388, 959477807378633, 1129511384426604]),
[INFO] [stdout] 	Y: FieldElement51([1802965527046721, 1701896607846494, 1587918889948955, 1064062591333625, 828358451273764]),
[INFO] [stdout] 	Z: FieldElement51([898445681492805, 1376643309555281, 40312032966645, 1791890817625834, 630719825290575]),
[INFO] [stdout] 	T: FieldElement51([2205168143293835, 2224941325304968, 2079798561061083, 712296403283520, 1811243887183299])
[INFO] [stdout] }
[INFO] [stdout]  right: RistrettoPoint: coset 
[INFO] [stdout] EdwardsPoint{
[INFO] [stdout] 	X: FieldElement51([2110259827547341, 1862002009774352, 1237179718926058, 1343985708400542, 1038051461775757]),
[INFO] [stdout] 	Y: FieldElement51([1914572632127504, 2242400843790735, 1090221328421516, 839572655642327, 148990370445314]),
[INFO] [stdout] 	Z: FieldElement51([1762516833384188, 1382528922729313, 1724417146302231, 455023048164187, 485099656810788]),
[INFO] [stdout] 	T: FieldElement51([1292023611548951, 1714675862148769, 1791015014416833, 1971631378793881, 920266262177697])
[INFO] [stdout] }
[INFO] [stdout] EdwardsPoint{
[INFO] [stdout] 	X: FieldElement51([321779483347161, 1588743021892992, 988728929149705, 1535471246951584, 873102444143630]),
[INFO] [stdout] 	Y: FieldElement51([1849262304847387, 609114512276925, 2049144011593509, 1494030360386303, 1455054774090339]),
[INFO] [stdout] 	Z: FieldElement51([858030260823198, 751865962066895, 1205285524334528, 733016945918461, 1627953566850113]),
[INFO] [stdout] 	T: FieldElement51([1939805008201723, 1858775382426023, 1764160460114213, 977733425643313, 418862170705569])
[INFO] [stdout] }
[INFO] [stdout] EdwardsPoint{
[INFO] [stdout] 	X: FieldElement51([1444164013620442, 1170845126792790, 514759144572718, 2189544668900698, 1963396349320200]),
[INFO] [stdout] 	Y: FieldElement51([2161481314958636, 1642618763150600, 1509381345294777, 949822365939166, 1160927576969842]),
[INFO] [stdout] 	Z: FieldElement51([858030260823198, 751865962066895, 1205285524334528, 733016945918461, 1627953566850113]),
[INFO] [stdout] 	T: FieldElement51([311994805483506, 393024431259224, 487639353571034, 1274066388041934, 1832937642979678])
[INFO] [stdout] }
[INFO] [stdout] EdwardsPoint{
[INFO] [stdout] 	X: FieldElement51([1930020330338068, 663056791792255, 1263070884535542, 716328566733663, 1378697369541617]),
[INFO] [stdout] 	Y: FieldElement51([402537508837842, 1642685301408322, 202655802091738, 757769453298944, 796745039594908]),
[INFO] [stdout] 	Z: FieldElement51([858030260823198, 751865962066895, 1205285524334528, 733016945918461, 1627953566850113]),
[INFO] [stdout] 	T: FieldElement51([1939805008201723, 1858775382426023, 1764160460114213, 977733425643313, 418862170705569])
[INFO] [stdout] }
[INFO] [stdout] stack backtrace:
[INFO] [stdout]    0:     0x5796c8c87ea2 - std::backtrace_rs::backtrace::libunwind::trace::hd39b1f53d3cf9745
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/../../backtrace/src/backtrace/libunwind.rs:117:9
[INFO] [stdout]    1:     0x5796c8c87ea2 - std::backtrace_rs::backtrace::trace_unsynchronized::he91d9a75d4e3972b
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/../../backtrace/src/backtrace/mod.rs:66:14
[INFO] [stdout]    2:     0x5796c8c87ea2 - std::sys::backtrace::_print_fmt::hca46938f8c6e22cf
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/sys/backtrace.rs:66:9
[INFO] [stdout]    3:     0x5796c8c87ea2 - <std::sys::backtrace::BacktraceLock::print::DisplayBacktrace as core::fmt::Display>::fmt::ha499add612cccf8e
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/sys/backtrace.rs:39:26
[INFO] [stdout]    4:     0x5796c8cad5c3 - core::fmt::rt::Argument::fmt::hd21145b75a833b7a
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/core/src/fmt/rt.rs:173:76
[INFO] [stdout]    5:     0x5796c8cad5c3 - core::fmt::write::hb10c956f5235c8a4
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/core/src/fmt/mod.rs:1465:25
[INFO] [stdout]    6:     0x5796c8c85083 - std::io::default_write_fmt::hdb7615052be2ba4d
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/io/mod.rs:639:11
[INFO] [stdout]    7:     0x5796c8c85083 - std::io::Write::write_fmt::he1bcd251ec6e4153
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/io/mod.rs:1954:13
[INFO] [stdout]    8:     0x5796c8c87cf2 - std::sys::backtrace::BacktraceLock::print::hb47c770ef659fd10
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/sys/backtrace.rs:42:9
[INFO] [stdout]    9:     0x5796c8c8940c - std::panicking::default_hook::{{closure}}::hdda8afb9d457a22c
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panicking.rs:300:27
[INFO] [stdout]   10:     0x5796c8c89262 - std::panicking::default_hook::h7c46b44874fe5c9a
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panicking.rs:324:9
[INFO] [stdout]   11:     0x5796c8c35694 - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h178a5fcedee41e2f
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   12:     0x5796c8c35694 - test::test_main_with_exit_callback::{{closure}}::h951a41e0149d6d5d
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/test/src/lib.rs:145:21
[INFO] [stdout]   13:     0x5796c8c89deb - <alloc::boxed::Box<F,A> as core::ops::function::Fn<Args>>::call::h13602080f5b63276
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/alloc/src/boxed.rs:1985:9
[INFO] [stdout]   14:     0x5796c8c89deb - std::panicking::rust_panic_with_hook::ha6cb99ed099eb1c5
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panicking.rs:841:13
[INFO] [stdout]   15:     0x5796c8c89bba - std::panicking::begin_panic_handler::{{closure}}::he11808bc797ee921
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panicking.rs:706:13
[INFO] [stdout]   16:     0x5796c8c88399 - std::sys::backtrace::__rust_end_short_backtrace::h9418807cb7346258
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/sys/backtrace.rs:168:18
[INFO] [stdout]   17:     0x5796c8c8984d - __rustc[18fb429eef004894]::rust_begin_unwind
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panicking.rs:697:5
[INFO] [stdout]   18:     0x5796c8cac110 - core::panicking::panic_fmt::hd890aeb12c3a3fc3
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/core/src/panicking.rs:75:14
[INFO] [stdout]   19:     0x5796c8cac3a7 - core::panicking::assert_failed_inner::h02e1528dd7bc6647
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/core/src/panicking.rs:448:17
[INFO] [stdout]   20:     0x5796c8bf9991 - core::panicking::assert_failed::h249c6fc44434f63f
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/core/src/panicking.rs:403:5
[INFO] [stdout]   21:     0x5796c8bf6e1f - BulletProofs_arg::inner_product_argument::tests::test_reconstruction_of_P::h27ab1f5d08c0ae8c
[INFO] [stdout]                                at /opt/rustwide/workdir/src/main.rs:596:9
[INFO] [stdout]   22:     0x5796c8bf7d99 - BulletProofs_arg::inner_product_argument::tests::test_reconstruction_of_P::{{closure}}::h0ec36847133fdddb
[INFO] [stdout]                                at /opt/rustwide/workdir/src/main.rs:557:34
[INFO] [stdout]   23:     0x5796c8bf7d99 - core::ops::function::FnOnce::call_once::h9b095c43ae5d04eb
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   24:     0x5796c8c3ae1b - core::ops::function::FnOnce::call_once::h2869fb5b0a2b0bdc
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   25:     0x5796c8c3ae1b - test::__rust_begin_short_backtrace::h7dd7142bd62fa711
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/test/src/lib.rs:648:18
[INFO] [stdout]   26:     0x5796c8c3a00e - test::run_test_in_process::{{closure}}::h43a753f038d36b3f
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/test/src/lib.rs:671:74
[INFO] [stdout]   27:     0x5796c8c3a00e - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h0ca95dd3e12d1e16
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   28:     0x5796c8c3a00e - std::panicking::catch_unwind::do_call::he308587d70ac34ba
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panicking.rs:589:40
[INFO] [stdout]   29:     0x5796c8c3a00e - std::panicking::catch_unwind::h30dcba31973e8fb0
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panicking.rs:552:19
[INFO] [stdout]   30:     0x5796c8c3a00e - std::panic::catch_unwind::hfb68364e5621fbee
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panic.rs:359:14
[INFO] [stdout]   31:     0x5796c8c3a00e - test::run_test_in_process::hcdcc2977903b998a
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/test/src/lib.rs:671:27
[INFO] [stdout]   32:     0x5796c8c3a00e - test::run_test::{{closure}}::h544a6550958c5d14
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/test/src/lib.rs:592:43
[INFO] [stdout]   33:     0x5796c8bfdb84 - test::run_test::{{closure}}::hb172e48ebe2b92c7
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/test/src/lib.rs:622:41
[INFO] [stdout]   34:     0x5796c8bfdb84 - std::sys::backtrace::__rust_begin_short_backtrace::h7e79d8706638bea0
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/sys/backtrace.rs:152:18
[INFO] [stdout]   35:     0x5796c8c0155a - std::thread::Builder::spawn_unchecked_::{{closure}}::{{closure}}::hc4a275f1e71b8ab0
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/thread/mod.rs:559:17
[INFO] [stdout]   36:     0x5796c8c0155a - <core::panic::unwind_safe::AssertUnwindSafe<F> as core::ops::function::FnOnce<()>>::call_once::h01ed0d242df78cfd
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/core/src/panic/unwind_safe.rs:272:9
[INFO] [stdout]   37:     0x5796c8c0155a - std::panicking::catch_unwind::do_call::h052f373fb905fee0
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panicking.rs:589:40
[INFO] [stdout]   38:     0x5796c8c0155a - std::panicking::catch_unwind::hb425d20c8ffb09c8
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panicking.rs:552:19
[INFO] [stdout]   39:     0x5796c8c0155a - std::panic::catch_unwind::ha0d5dfbf18fdeda5
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/panic.rs:359:14
[INFO] [stdout]   40:     0x5796c8c0155a - std::thread::Builder::spawn_unchecked_::{{closure}}::hbe79182bd37949c7
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/thread/mod.rs:557:30
[INFO] [stdout]   41:     0x5796c8c0155a - core::ops::function::FnOnce::call_once{{vtable.shim}}::hc096c4a06972fde5
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/core/src/ops/function.rs:250:5
[INFO] [stdout]   42:     0x5796c8c8cd47 - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h47377e27fb938a26
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/alloc/src/boxed.rs:1971:9
[INFO] [stdout]   43:     0x5796c8c8cd47 - <alloc::boxed::Box<F,A> as core::ops::function::FnOnce<Args>>::call_once::h72f1fe5d095abf57
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/alloc/src/boxed.rs:1971:9
[INFO] [stdout]   44:     0x5796c8c8cd47 - std::sys::pal::unix::thread::Thread::new::thread_start::h0a4d8e1b9c0d38cf
[INFO] [stdout]                                at /rustc/d98a5da813da67eb189387b8ccfb73cf481275d8/library/std/src/sys/pal/unix/thread.rs:97:17
[INFO] [stdout]   45:     0x780dcaa12aa4 - <unknown>
[INFO] [stdout]   46:     0x780dcaa9fa34 - clone
[INFO] [stdout]   47:                0x0 - <unknown>
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] failures:
[INFO] [stdout]     inner_product_argument::tests::test_prove_and_verify
[INFO] [stdout]     inner_product_argument::tests::test_reconstruction_of_P
[INFO] [stdout] 
[INFO] [stdout] test result: FAILED. 4 passed; 2 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.07s
[INFO] [stdout] 
[INFO] [stderr] error: test failed, to rerun pass `--bin BulletProofs_arg`
[INFO] running `Command { std: "docker" "inspect" "efcf934d8a78b187fc287e40a0ed59aba5dc7fed35042d7b7ad5f2f2e44a4016", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "efcf934d8a78b187fc287e40a0ed59aba5dc7fed35042d7b7ad5f2f2e44a4016", kill_on_drop: false }`
[INFO] [stdout] efcf934d8a78b187fc287e40a0ed59aba5dc7fed35042d7b7ad5f2f2e44a4016
