[INFO] cloning repository https://github.com/sidharthsunilkumar/ocpt
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/sidharthsunilkumar/ocpt" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsidharthsunilkumar%2Focpt", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsidharthsunilkumar%2Focpt'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 671b20062db0ebe4393e40caf01b7ed1186e034e
[INFO] checking sidharthsunilkumar/ocpt against try#5ef65a4ed75279dc1b7a26cedc27293a9f4ca8db for pr-143717
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsidharthsunilkumar%2Focpt" "/workspace/builds/worker-1-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/sidharthsunilkumar/ocpt
[INFO] finished tweaking git repo https://github.com/sidharthsunilkumar/ocpt
[INFO] tweaked toml for git repo https://github.com/sidharthsunilkumar/ocpt written to /workspace/builds/worker-1-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/sidharthsunilkumar/ocpt on toolchain 5ef65a4ed75279dc1b7a26cedc27293a9f4ca8db
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+5ef65a4ed75279dc1b7a26cedc27293a9f4ca8db" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/sidharthsunilkumar/ocpt 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" "+5ef65a4ed75279dc1b7a26cedc27293a9f4ca8db" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded rayon-cond v0.3.0
[INFO] [stderr]   Downloaded priority-queue v1.4.0
[INFO] [stderr]   Downloaded hyper-util v0.1.12
[INFO] [stderr]   Downloaded rustworkx-core v0.14.2
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/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:90999bfc7ae267e83380e433d8e61a7c072ca6729e92edbae886d3423b3a6f4c" "/opt/rustwide/cargo-home/bin/cargo" "+5ef65a4ed75279dc1b7a26cedc27293a9f4ca8db" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 0e7ae64006cc32ad03530c761d1889884f13d257d277f9be720da1d6f1371b6e
[INFO] running `Command { std: "docker" "start" "-a" "0e7ae64006cc32ad03530c761d1889884f13d257d277f9be720da1d6f1371b6e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "0e7ae64006cc32ad03530c761d1889884f13d257d277f9be720da1d6f1371b6e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0e7ae64006cc32ad03530c761d1889884f13d257d277f9be720da1d6f1371b6e", kill_on_drop: false }`
[INFO] [stdout] 0e7ae64006cc32ad03530c761d1889884f13d257d277f9be720da1d6f1371b6e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/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" "-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:90999bfc7ae267e83380e433d8e61a7c072ca6729e92edbae886d3423b3a6f4c" "/opt/rustwide/cargo-home/bin/cargo" "+5ef65a4ed75279dc1b7a26cedc27293a9f4ca8db" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] ed75594e9be79353c58040f99d4eae89049a311607715c6e0878206b1fbd8b7f
[INFO] running `Command { std: "docker" "start" "-a" "ed75594e9be79353c58040f99d4eae89049a311607715c6e0878206b1fbd8b7f", kill_on_drop: false }`
[INFO] [stderr]     Checking pin-project-lite v0.2.16
[INFO] [stderr]     Checking futures-core v0.3.31
[INFO] [stderr]     Checking either v1.15.0
[INFO] [stderr]     Checking http v1.3.1
[INFO] [stderr]    Compiling syn v2.0.101
[INFO] [stderr]     Checking smallvec v1.15.0
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]     Checking futures-task v0.3.31
[INFO] [stderr]     Checking pin-utils v0.1.0
[INFO] [stderr]     Checking mio v1.0.4
[INFO] [stderr]     Checking socket2 v0.5.9
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking parking_lot_core v0.9.10
[INFO] [stderr]     Checking rayon v1.10.0
[INFO] [stderr]     Checking signal-hook-registry v1.4.5
[INFO] [stderr]     Checking log v0.4.27
[INFO] [stderr]    Compiling httparse v1.10.1
[INFO] [stderr]     Checking tower-service v0.3.3
[INFO] [stderr]    Compiling getrandom v0.3.3
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]     Checking parking_lot v0.12.3
[INFO] [stderr]     Checking tracing-core v0.1.33
[INFO] [stderr]    Compiling indexmap v1.9.3
[INFO] [stderr]    Compiling rustversion v1.0.21
[INFO] [stderr]     Checking tower-layer v0.3.3
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]     Checking futures-channel v0.3.31
[INFO] [stderr]    Compiling priority-queue v1.4.0
[INFO] [stderr]     Checking sync_wrapper v1.0.2
[INFO] [stderr]    Compiling serde_json v1.0.140
[INFO] [stderr]    Compiling num-conv v0.1.0
[INFO] [stderr]     Checking hashbrown v0.12.3
[INFO] [stderr]     Checking httpdate v1.0.3
[INFO] [stderr]     Checking powerfmt v0.2.0
[INFO] [stderr]    Compiling time-core v0.1.4
[INFO] [stderr]     Checking http-body v1.0.1
[INFO] [stderr]     Checking http-body-util v0.1.3
[INFO] [stderr]     Checking hashbrown v0.15.3
[INFO] [stderr]     Checking form_urlencoded v1.2.1
[INFO] [stderr]    Compiling time-macros v0.2.22
[INFO] [stderr]     Checking deranged v0.4.0
[INFO] [stderr]     Checking itertools v0.11.0
[INFO] [stderr]     Checking mime v0.3.17
[INFO] [stderr]     Checking num_threads v0.1.7
[INFO] [stderr]     Checking indexmap v2.9.0
[INFO] [stderr]     Checking fixedbitset v0.4.2
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]     Checking rand_pcg v0.3.1
[INFO] [stderr]     Checking matchit v0.7.3
[INFO] [stderr]     Checking bitflags v2.9.1
[INFO] [stderr]     Checking termcolor v1.4.1
[INFO] [stderr]     Checking chrono v0.4.41
[INFO] [stderr]     Checking tower-http v0.5.2
[INFO] [stderr]     Checking itertools v0.14.0
[INFO] [stderr]     Checking petgraph v0.6.5
[INFO] [stderr]     Checking time v0.3.41
[INFO] [stderr]     Checking rayon-cond v0.3.0
[INFO] [stderr]     Checking simplelog v0.12.2
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling async-trait v0.1.88
[INFO] [stderr]     Checking rustworkx-core v0.14.2
[INFO] [stderr]     Checking tokio v1.45.1
[INFO] [stderr]     Checking axum-core v0.4.5
[INFO] [stderr]     Checking serde_path_to_error v0.1.17
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking hyper v1.6.0
[INFO] [stderr]     Checking tower v0.5.2
[INFO] [stderr]     Checking hyper-util v0.1.12
[INFO] [stderr]     Checking axum v0.7.9
[INFO] [stderr]     Checking dfg_visualizer v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `serde::Deserialize`
[INFO] [stdout]  --> src/main.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use serde::Deserialize;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::env`
[INFO] [stdout]  --> src/main.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::env;
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::Write`
[INFO] [stdout]  --> src/main.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::io::Write;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Event` and `Object`
[INFO] [stdout]  --> src/main.rs:8:30
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::types::{OcelJson, Event, Object, ProcessForest, TreeNode};
[INFO] [stdout]   |                              ^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde::Deserialize`
[INFO] [stdout]  --> src/build_relations_fns.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use serde::Deserialize;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HashSet`
[INFO] [stdout]  --> src/build_relations_fns.rs:2:33
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::collections::{HashMap, HashSet};
[INFO] [stdout]   |                                 ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HashSet`
[INFO] [stdout]  --> src/types.rs:2:33
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::collections::{HashMap, HashSet};
[INFO] [stdout]   |                                 ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `chrono::NaiveDateTime`
[INFO] [stdout]  --> src/divergence_free_dfg.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use chrono::NaiveDateTime;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `DateTime` and `Utc`
[INFO] [stdout]  --> src/divergence_free_dfg.rs:3:14
[INFO] [stdout]   |
[INFO] [stdout] 3 | use chrono::{DateTime, Utc};
[INFO] [stdout]   |              ^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::BufReader`
[INFO] [stdout]  --> src/divergence_free_dfg.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::io::BufReader;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json::Value`
[INFO] [stdout]  --> src/divergence_free_dfg.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use serde_json::Value;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `VecDeque`
[INFO] [stdout]  --> src/start_cuts_opti_v1.rs:1:42
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::{HashMap, HashSet, VecDeque};
[INFO] [stdout]   |                                          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::cost_to_cut::to_be_non_reachable`
[INFO] [stdout]  --> src/start_cuts_opti_v1.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::cost_to_cut::to_be_non_reachable;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::best_redo_cuts::best_redo_cut`
[INFO] [stdout]  --> src/start_cuts_opti_v2.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::best_redo_cuts::best_redo_cut;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::cost_to_cut::to_be_non_reachable`
[INFO] [stdout]  --> src/start_cuts_opti_v2.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::cost_to_cut::to_be_non_reachable;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::good_cuts::best_possible_sequence_cut`
[INFO] [stdout]  --> src/start_cuts_opti_v2.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::good_cuts::best_possible_sequence_cut;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::best_exclusive_cut::best_exclusive_cut`
[INFO] [stdout]  --> src/start_cuts_opti_v2.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::best_exclusive_cut::best_exclusive_cut;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ProcessForest` and `TreeNode`
[INFO] [stdout]   --> src/start_cuts_opti_v2.rs:10:20
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::types::{ProcessForest, TreeNode};
[INFO] [stdout]    |                    ^^^^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::best_sequence_cut_v2`
[INFO] [stdout]   --> src/start_cuts_opti_v2.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | use crate::best_sequence_cut_v2;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/start_cuts_opti_v2.rs:39:7
[INFO] [stdout]    |
[INFO] [stdout] 39 |     if(!excl_set1.is_empty() && !excl_set2.is_empty() && is_exclusive_choice_cut_possible(&filtered_dfg, &excl_set1, &excl_set2)) {
[INFO] [stdout]    |       ^                                                                                                                         ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 39 -     if(!excl_set1.is_empty() && !excl_set2.is_empty() && is_exclusive_choice_cut_possible(&filtered_dfg, &excl_set1, &excl_set2)) {
[INFO] [stdout] 39 +     if !excl_set1.is_empty() && !excl_set2.is_empty() && is_exclusive_choice_cut_possible(&filtered_dfg, &excl_set1, &excl_set2) {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/start_cuts_opti_v2.rs:47:7
[INFO] [stdout]    |
[INFO] [stdout] 47 |     if(!set1.is_empty() && !set2.is_empty() && is_sequence_cut_possible(&filtered_dfg, &set1, &set2)) {
[INFO] [stdout]    |       ^                                                                                             ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 47 -     if(!set1.is_empty() && !set2.is_empty() && is_sequence_cut_possible(&filtered_dfg, &set1, &set2)) {
[INFO] [stdout] 47 +     if !set1.is_empty() && !set2.is_empty() && is_sequence_cut_possible(&filtered_dfg, &set1, &set2) {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/start_cuts_opti_v2.rs:57:7
[INFO] [stdout]    |
[INFO] [stdout] 57 |     if(is_parallel && !para_set1.is_empty() && !para_set2.is_empty() && parallel_cut_condition_check(&para_set1, &para_set2, &start_activities, &end_activities)) {
[INFO] [stdout]    |       ^                                                                                                                                                         ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 57 -     if(is_parallel && !para_set1.is_empty() && !para_set2.is_empty() && parallel_cut_condition_check(&para_set1, &para_set2, &start_activities, &end_activities)) {
[INFO] [stdout] 57 +     if is_parallel && !para_set1.is_empty() && !para_set2.is_empty() && parallel_cut_condition_check(&para_set1, &para_set2, &start_activities, &end_activities) {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/start_cuts_opti_v2.rs:65:8
[INFO] [stdout]    |
[INFO] [stdout] 65 | ...if (is_redo && !redo_set2.is_empty() && !redo_set1.is_empty() && redo_cut_condition_check(&filtered_dfg, &redo_set1, &redo_set2, &start_activities, &end_activities)) {
[INFO] [stdout]    |       ^                                                                                                                                                                ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 65 -     if (is_redo && !redo_set2.is_empty() && !redo_set1.is_empty() && redo_cut_condition_check(&filtered_dfg, &redo_set1, &redo_set2, &start_activities, &end_activities)) {
[INFO] [stdout] 65 +     if is_redo && !redo_set2.is_empty() && !redo_set1.is_empty() && redo_cut_condition_check(&filtered_dfg, &redo_set1, &redo_set2, &start_activities, &end_activities) {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/start_cuts_opti_v2.rs:86:7
[INFO] [stdout]    |
[INFO] [stdout] 86 |     if(!is_sequence) {
[INFO] [stdout]    |       ^            ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 86 -     if(!is_sequence) {
[INFO] [stdout] 86 +     if !is_sequence {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:261:16
[INFO] [stdout]     |
[INFO] [stdout] 261 |             if (r1 || r2) {
[INFO] [stdout]     |                ^        ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 261 -             if (r1 || r2) {
[INFO] [stdout] 261 +             if r1 || r2 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:587:19
[INFO] [stdout]     |
[INFO] [stdout] 587 |         } else if (!is_s1_redo && is_s2_redo) {
[INFO] [stdout]     |                   ^                         ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 587 -         } else if (!is_s1_redo && is_s2_redo) {
[INFO] [stdout] 587 +         } else if !is_s1_redo && is_s2_redo {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `json`
[INFO] [stdout]  --> src/format_conversion.rs:2:18
[INFO] [stdout]   |
[INFO] [stdout] 2 | use serde_json::{json, Value};
[INFO] [stdout]   |                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `VecDeque`
[INFO] [stdout]  --> src/cost_to_cut.rs:1:42
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::{HashMap, HashSet, VecDeque};
[INFO] [stdout]   |                                          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cmp::min`
[INFO] [stdout]  --> src/cost_to_cut.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::cmp::min;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `VecDeque`
[INFO] [stdout]  --> src/cost_to_add.rs:1:42
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::{HashMap, HashSet, VecDeque};
[INFO] [stdout]   |                                          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::info`
[INFO] [stdout]  --> src/cost_to_add.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use log::info;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `BTreeMap`
[INFO] [stdout]  --> src/good_cuts.rs:2:52
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::collections::{HashMap, HashSet, VecDeque, BTreeMap};
[INFO] [stdout]   |                                                    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `petgraph::graphmap::DiGraphMap`
[INFO] [stdout]  --> src/good_cuts.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use petgraph::graphmap::DiGraphMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Graph` and `NodeIndex`
[INFO] [stdout]  --> src/good_cuts.rs:6:23
[INFO] [stdout]   |
[INFO] [stdout] 6 | use petgraph::graph::{Graph, NodeIndex};
[INFO] [stdout]   |                       ^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `petgraph::algo::ford_fulkerson`
[INFO] [stdout]  --> src/good_cuts.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use petgraph::algo::ford_fulkerson;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `petgraph::visit::EdgeRef`
[INFO] [stdout]  --> src/good_cuts.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use petgraph::visit::EdgeRef;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `petgraph::Direction`
[INFO] [stdout]  --> src/good_cuts.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use petgraph::Direction;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::info`
[INFO] [stdout]  --> src/best_sequence_cut.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use log::info;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::info`
[INFO] [stdout]  --> src/best_exclusive_cut.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use log::info;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/best_parallel_cut.rs:217:23
[INFO] [stdout]     |
[INFO] [stdout] 217 |             } else if (new_set1.len().abs_diff(new_set2.len()) < solution.set1.len().abs_diff(solution.set2.len())) {
[INFO] [stdout]     |                       ^                                                                                           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 217 -             } else if (new_set1.len().abs_diff(new_set2.len()) < solution.set1.len().abs_diff(solution.set2.len())) {
[INFO] [stdout] 217 +             } else if new_set1.len().abs_diff(new_set2.len()) < solution.set1.len().abs_diff(solution.set2.len()) {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ptr::null`
[INFO] [stdout]  --> src/best_redo_cuts.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::ptr::null;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::cost_to_cut::to_be_non_reachable`
[INFO] [stdout]  --> src/best_redo_cuts.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::cost_to_cut::to_be_non_reachable;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::info`
[INFO] [stdout]  --> src/best_redo_cuts.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use log::info;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/best_redo_cuts.rs:77:19
[INFO] [stdout]    |
[INFO] [stdout] 77 |         } else if (!btw_start_and_end && btw_end_and_start) {
[INFO] [stdout]    |                   ^                                       ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 77 -         } else if (!btw_start_and_end && btw_end_and_start) {
[INFO] [stdout] 77 +         } else if !btw_start_and_end && btw_end_and_start {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/best_redo_cuts.rs:79:18
[INFO] [stdout]    |
[INFO] [stdout] 79 |         } else if(btw_start_and_end && btw_end_and_start) {
[INFO] [stdout]    |                  ^                                      ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 79 -         } else if(btw_start_and_end && btw_end_and_start) {
[INFO] [stdout] 79 +         } else if btw_start_and_end && btw_end_and_start {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `response::Html`
[INFO] [stdout]   --> src/main.rs:37:34
[INFO] [stdout]    |
[INFO] [stdout] 37 | use axum::{Router, routing::get, response::Html};
[INFO] [stdout]    |                                  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde::Deserialize`
[INFO] [stdout]  --> src/main.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use serde::Deserialize;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::env`
[INFO] [stdout]  --> src/main.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::env;
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::Write`
[INFO] [stdout]  --> src/main.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::io::Write;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Event` and `Object`
[INFO] [stdout]  --> src/main.rs:8:30
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::types::{OcelJson, Event, Object, ProcessForest, TreeNode};
[INFO] [stdout]   |                              ^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde::Deserialize`
[INFO] [stdout]  --> src/build_relations_fns.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use serde::Deserialize;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HashSet`
[INFO] [stdout]  --> src/build_relations_fns.rs:2:33
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::collections::{HashMap, HashSet};
[INFO] [stdout]   |                                 ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `HashSet`
[INFO] [stdout]  --> src/types.rs:2:33
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::collections::{HashMap, HashSet};
[INFO] [stdout]   |                                 ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `chrono::NaiveDateTime`
[INFO] [stdout]  --> src/divergence_free_dfg.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use chrono::NaiveDateTime;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `DateTime` and `Utc`
[INFO] [stdout]  --> src/divergence_free_dfg.rs:3:14
[INFO] [stdout]   |
[INFO] [stdout] 3 | use chrono::{DateTime, Utc};
[INFO] [stdout]   |              ^^^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::BufReader`
[INFO] [stdout]  --> src/divergence_free_dfg.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::io::BufReader;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json::Value`
[INFO] [stdout]  --> src/divergence_free_dfg.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use serde_json::Value;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `VecDeque`
[INFO] [stdout]  --> src/start_cuts_opti_v1.rs:1:42
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::{HashMap, HashSet, VecDeque};
[INFO] [stdout]   |                                          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::cost_to_cut::to_be_non_reachable`
[INFO] [stdout]  --> src/start_cuts_opti_v1.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::cost_to_cut::to_be_non_reachable;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::best_redo_cuts::best_redo_cut`
[INFO] [stdout]  --> src/start_cuts_opti_v2.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::best_redo_cuts::best_redo_cut;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::cost_to_cut::to_be_non_reachable`
[INFO] [stdout]  --> src/start_cuts_opti_v2.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::cost_to_cut::to_be_non_reachable;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::good_cuts::best_possible_sequence_cut`
[INFO] [stdout]  --> src/start_cuts_opti_v2.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::good_cuts::best_possible_sequence_cut;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::best_exclusive_cut::best_exclusive_cut`
[INFO] [stdout]  --> src/start_cuts_opti_v2.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::best_exclusive_cut::best_exclusive_cut;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ProcessForest` and `TreeNode`
[INFO] [stdout]   --> src/start_cuts_opti_v2.rs:10:20
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::types::{ProcessForest, TreeNode};
[INFO] [stdout]    |                    ^^^^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::best_sequence_cut_v2`
[INFO] [stdout]   --> src/start_cuts_opti_v2.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | use crate::best_sequence_cut_v2;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/start_cuts_opti_v2.rs:39:7
[INFO] [stdout]    |
[INFO] [stdout] 39 |     if(!excl_set1.is_empty() && !excl_set2.is_empty() && is_exclusive_choice_cut_possible(&filtered_dfg, &excl_set1, &excl_set2)) {
[INFO] [stdout]    |       ^                                                                                                                         ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 39 -     if(!excl_set1.is_empty() && !excl_set2.is_empty() && is_exclusive_choice_cut_possible(&filtered_dfg, &excl_set1, &excl_set2)) {
[INFO] [stdout] 39 +     if !excl_set1.is_empty() && !excl_set2.is_empty() && is_exclusive_choice_cut_possible(&filtered_dfg, &excl_set1, &excl_set2) {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/start_cuts_opti_v2.rs:47:7
[INFO] [stdout]    |
[INFO] [stdout] 47 |     if(!set1.is_empty() && !set2.is_empty() && is_sequence_cut_possible(&filtered_dfg, &set1, &set2)) {
[INFO] [stdout]    |       ^                                                                                             ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 47 -     if(!set1.is_empty() && !set2.is_empty() && is_sequence_cut_possible(&filtered_dfg, &set1, &set2)) {
[INFO] [stdout] 47 +     if !set1.is_empty() && !set2.is_empty() && is_sequence_cut_possible(&filtered_dfg, &set1, &set2) {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/start_cuts_opti_v2.rs:57:7
[INFO] [stdout]    |
[INFO] [stdout] 57 |     if(is_parallel && !para_set1.is_empty() && !para_set2.is_empty() && parallel_cut_condition_check(&para_set1, &para_set2, &start_activities, &end_activities)) {
[INFO] [stdout]    |       ^                                                                                                                                                         ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 57 -     if(is_parallel && !para_set1.is_empty() && !para_set2.is_empty() && parallel_cut_condition_check(&para_set1, &para_set2, &start_activities, &end_activities)) {
[INFO] [stdout] 57 +     if is_parallel && !para_set1.is_empty() && !para_set2.is_empty() && parallel_cut_condition_check(&para_set1, &para_set2, &start_activities, &end_activities) {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/start_cuts_opti_v2.rs:65:8
[INFO] [stdout]    |
[INFO] [stdout] 65 | ...if (is_redo && !redo_set2.is_empty() && !redo_set1.is_empty() && redo_cut_condition_check(&filtered_dfg, &redo_set1, &redo_set2, &start_activities, &end_activities)) {
[INFO] [stdout]    |       ^                                                                                                                                                                ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 65 -     if (is_redo && !redo_set2.is_empty() && !redo_set1.is_empty() && redo_cut_condition_check(&filtered_dfg, &redo_set1, &redo_set2, &start_activities, &end_activities)) {
[INFO] [stdout] 65 +     if is_redo && !redo_set2.is_empty() && !redo_set1.is_empty() && redo_cut_condition_check(&filtered_dfg, &redo_set1, &redo_set2, &start_activities, &end_activities) {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/start_cuts_opti_v2.rs:86:7
[INFO] [stdout]    |
[INFO] [stdout] 86 |     if(!is_sequence) {
[INFO] [stdout]    |       ^            ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 86 -     if(!is_sequence) {
[INFO] [stdout] 86 +     if !is_sequence {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:261:16
[INFO] [stdout]     |
[INFO] [stdout] 261 |             if (r1 || r2) {
[INFO] [stdout]     |                ^        ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 261 -             if (r1 || r2) {
[INFO] [stdout] 261 +             if r1 || r2 {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:587:19
[INFO] [stdout]     |
[INFO] [stdout] 587 |         } else if (!is_s1_redo && is_s2_redo) {
[INFO] [stdout]     |                   ^                         ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 587 -         } else if (!is_s1_redo && is_s2_redo) {
[INFO] [stdout] 587 +         } else if !is_s1_redo && is_s2_redo {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `json`
[INFO] [stdout]  --> src/format_conversion.rs:2:18
[INFO] [stdout]   |
[INFO] [stdout] 2 | use serde_json::{json, Value};
[INFO] [stdout]   |                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `VecDeque`
[INFO] [stdout]  --> src/cost_to_cut.rs:1:42
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::{HashMap, HashSet, VecDeque};
[INFO] [stdout]   |                                          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cmp::min`
[INFO] [stdout]  --> src/cost_to_cut.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::cmp::min;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `VecDeque`
[INFO] [stdout]  --> src/cost_to_add.rs:1:42
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::collections::{HashMap, HashSet, VecDeque};
[INFO] [stdout]   |                                          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::info`
[INFO] [stdout]  --> src/cost_to_add.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use log::info;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `BTreeMap`
[INFO] [stdout]  --> src/good_cuts.rs:2:52
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::collections::{HashMap, HashSet, VecDeque, BTreeMap};
[INFO] [stdout]   |                                                    ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `petgraph::graphmap::DiGraphMap`
[INFO] [stdout]  --> src/good_cuts.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use petgraph::graphmap::DiGraphMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Graph` and `NodeIndex`
[INFO] [stdout]  --> src/good_cuts.rs:6:23
[INFO] [stdout]   |
[INFO] [stdout] 6 | use petgraph::graph::{Graph, NodeIndex};
[INFO] [stdout]   |                       ^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `petgraph::algo::ford_fulkerson`
[INFO] [stdout]  --> src/good_cuts.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use petgraph::algo::ford_fulkerson;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `petgraph::visit::EdgeRef`
[INFO] [stdout]  --> src/good_cuts.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use petgraph::visit::EdgeRef;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `petgraph::Direction`
[INFO] [stdout]  --> src/good_cuts.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use petgraph::Direction;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::info`
[INFO] [stdout]  --> src/best_sequence_cut.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use log::info;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::info`
[INFO] [stdout]  --> src/best_exclusive_cut.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use log::info;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/best_parallel_cut.rs:217:23
[INFO] [stdout]     |
[INFO] [stdout] 217 |             } else if (new_set1.len().abs_diff(new_set2.len()) < solution.set1.len().abs_diff(solution.set2.len())) {
[INFO] [stdout]     |                       ^                                                                                           ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 217 -             } else if (new_set1.len().abs_diff(new_set2.len()) < solution.set1.len().abs_diff(solution.set2.len())) {
[INFO] [stdout] 217 +             } else if new_set1.len().abs_diff(new_set2.len()) < solution.set1.len().abs_diff(solution.set2.len()) {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::ptr::null`
[INFO] [stdout]  --> src/best_redo_cuts.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::ptr::null;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::cost_to_cut::to_be_non_reachable`
[INFO] [stdout]  --> src/best_redo_cuts.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::cost_to_cut::to_be_non_reachable;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::info`
[INFO] [stdout]  --> src/best_redo_cuts.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use log::info;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/best_redo_cuts.rs:77:19
[INFO] [stdout]    |
[INFO] [stdout] 77 |         } else if (!btw_start_and_end && btw_end_and_start) {
[INFO] [stdout]    |                   ^                                       ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 77 -         } else if (!btw_start_and_end && btw_end_and_start) {
[INFO] [stdout] 77 +         } else if !btw_start_and_end && btw_end_and_start {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]   --> src/best_redo_cuts.rs:79:18
[INFO] [stdout]    |
[INFO] [stdout] 79 |         } else if(btw_start_and_end && btw_end_and_start) {
[INFO] [stdout]    |                  ^                                      ^
[INFO] [stdout]    |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 79 -         } else if(btw_start_and_end && btw_end_and_start) {
[INFO] [stdout] 79 +         } else if btw_start_and_end && btw_end_and_start {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `response::Html`
[INFO] [stdout]   --> src/main.rs:37:34
[INFO] [stdout]    |
[INFO] [stdout] 37 | use axum::{Router, routing::get, response::Html};
[INFO] [stdout]    |                                  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `itertools::Itertools`
[INFO] [stdout]   --> src/start_cuts_opti_v2.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use itertools::Itertools;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ocel`
[INFO] [stdout]   --> src/interaction_patterns.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     ocel: &OcelJson,
[INFO] [stdout]    |     ^^^^ help: if this is intentional, prefix it with an underscore: `_ocel`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `next_otype`
[INFO] [stdout]   --> src/divergence_free_dfg.rs:82:17
[INFO] [stdout]    |
[INFO] [stdout] 82 |             let next_otype = &next_relation.4;
[INFO] [stdout]    |                 ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_next_otype`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `filtered_dfg`
[INFO] [stdout]  --> src/start_cuts.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 |     filtered_dfg: &HashMap<(String, String), usize>,
[INFO] [stdout]   |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_filtered_dfg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `itertools::Itertools`
[INFO] [stdout]   --> src/start_cuts_opti_v2.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use itertools::Itertools;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `idx`
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:285:10
[INFO] [stdout]     |
[INFO] [stdout] 285 |     for (idx, candidate_scc) in sccs.iter().enumerate() {
[INFO] [stdout]     |          ^^^ help: if this is intentional, prefix it with an underscore: `_idx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `filtered_dfg`
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:666:17
[INFO] [stdout]     |
[INFO] [stdout] 666 |             let filtered_dfg = filter_keep_dfg(&dfg, &combined_activites);
[INFO] [stdout]     |                 ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_filtered_dfg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `filtered_start_activites`
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:668:18
[INFO] [stdout]     |
[INFO] [stdout] 668 | ...   let (filtered_start_activites,filtered_end_activites)=get_start_and_end_activities_v2(&dfg, &combined_activites, start_activities, ...
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_filtered_start_activites`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `filtered_end_activites`
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:668:43
[INFO] [stdout]     |
[INFO] [stdout] 668 | ...rt_activites,filtered_end_activites)=get_start_and_end_activities_v2(&dfg, &combined_activites, start_activities, end_activities);
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_filtered_end_activites`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `filtered_dfg`
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:637:5
[INFO] [stdout]     |
[INFO] [stdout] 637 |     filtered_dfg: &HashMap<(String, String), usize>,
[INFO] [stdout]     |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_filtered_dfg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ocel`
[INFO] [stdout]   --> src/interaction_patterns.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 |     ocel: &OcelJson,
[INFO] [stdout]    |     ^^^^ help: if this is intentional, prefix it with an underscore: `_ocel`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `next_otype`
[INFO] [stdout]   --> src/divergence_free_dfg.rs:82:17
[INFO] [stdout]    |
[INFO] [stdout] 82 |             let next_otype = &next_relation.4;
[INFO] [stdout]    |                 ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_next_otype`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `filtered_dfg`
[INFO] [stdout]  --> src/start_cuts.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 |     filtered_dfg: &HashMap<(String, String), usize>,
[INFO] [stdout]   |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_filtered_dfg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:422:9
[INFO] [stdout]     |
[INFO] [stdout] 422 |     let mut common_activities = intersection.clone();
[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: `idx`
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:285:10
[INFO] [stdout]     |
[INFO] [stdout] 285 |     for (idx, candidate_scc) in sccs.iter().enumerate() {
[INFO] [stdout]     |          ^^^ help: if this is intentional, prefix it with an underscore: `_idx`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `filtered_dfg`
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:666:17
[INFO] [stdout]     |
[INFO] [stdout] 666 |             let filtered_dfg = filter_keep_dfg(&dfg, &combined_activites);
[INFO] [stdout]     |                 ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_filtered_dfg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `flow` is assigned to, but never used
[INFO] [stdout]   --> src/cost_to_cut.rs:95:13
[INFO] [stdout]    |
[INFO] [stdout] 95 |     let mut flow = 0;
[INFO] [stdout]    |             ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: consider using `_flow` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `filtered_start_activites`
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:668:18
[INFO] [stdout]     |
[INFO] [stdout] 668 | ...   let (filtered_start_activites,filtered_end_activites)=get_start_and_end_activities_v2(&dfg, &combined_activites, start_activities, ...
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_filtered_start_activites`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `filtered_end_activites`
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:668:43
[INFO] [stdout]     |
[INFO] [stdout] 668 | ...rt_activites,filtered_end_activites)=get_start_and_end_activities_v2(&dfg, &combined_activites, start_activities, end_activities);
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_filtered_end_activites`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `filtered_dfg`
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:637:5
[INFO] [stdout]     |
[INFO] [stdout] 637 |     filtered_dfg: &HashMap<(String, String), usize>,
[INFO] [stdout]     |     ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_filtered_dfg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dfg`
[INFO] [stdout]    --> src/cost_to_cut.rs:218:5
[INFO] [stdout]     |
[INFO] [stdout] 218 |     dfg: &HashMap<(String, String), usize>,
[INFO] [stdout]     |     ^^^ help: if this is intentional, prefix it with an underscore: `_dfg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:422:9
[INFO] [stdout]     |
[INFO] [stdout] 422 |     let mut common_activities = intersection.clone();
[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: `max_flow_value`
[INFO] [stdout]    --> src/best_exclusive_cut.rs:191:17
[INFO] [stdout]     |
[INFO] [stdout] 191 |             let max_flow_value = graph.max_flow(&source, &sink);
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_max_flow_value`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `flow` is assigned to, but never used
[INFO] [stdout]   --> src/cost_to_cut.rs:95:13
[INFO] [stdout]    |
[INFO] [stdout] 95 |     let mut flow = 0;
[INFO] [stdout]    |             ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: consider using `_flow` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `from`
[INFO] [stdout]    --> src/best_exclusive_cut.rs:297:11
[INFO] [stdout]     |
[INFO] [stdout] 297 |     for ((from, to), cap) in &graph.capacity {
[INFO] [stdout]     |           ^^^^ help: if this is intentional, prefix it with an underscore: `_from`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `to`
[INFO] [stdout]    --> src/best_exclusive_cut.rs:297:17
[INFO] [stdout]     |
[INFO] [stdout] 297 |     for ((from, to), cap) in &graph.capacity {
[INFO] [stdout]     |                 ^^ help: if this is intentional, prefix it with an underscore: `_to`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cap`
[INFO] [stdout]    --> src/best_exclusive_cut.rs:297:22
[INFO] [stdout]     |
[INFO] [stdout] 297 |     for ((from, to), cap) in &graph.capacity {
[INFO] [stdout]     |                      ^^^ help: if this is intentional, prefix it with an underscore: `_cap`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `from`
[INFO] [stdout]    --> src/best_exclusive_cut.rs:301:11
[INFO] [stdout]     |
[INFO] [stdout] 301 |     for ((from, to), flow) in &graph.flow {
[INFO] [stdout]     |           ^^^^ help: if this is intentional, prefix it with an underscore: `_from`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `to`
[INFO] [stdout]    --> src/best_exclusive_cut.rs:301:17
[INFO] [stdout]     |
[INFO] [stdout] 301 |     for ((from, to), flow) in &graph.flow {
[INFO] [stdout]     |                 ^^ help: if this is intentional, prefix it with an underscore: `_to`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `flow`
[INFO] [stdout]    --> src/best_exclusive_cut.rs:301:22
[INFO] [stdout]     |
[INFO] [stdout] 301 |     for ((from, to), flow) in &graph.flow {
[INFO] [stdout]     |                      ^^^^ help: if this is intentional, prefix it with an underscore: `_flow`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `dfg`
[INFO] [stdout]    --> src/cost_to_cut.rs:218:5
[INFO] [stdout]     |
[INFO] [stdout] 218 |     dfg: &HashMap<(String, String), usize>,
[INFO] [stdout]     |     ^^^ help: if this is intentional, prefix it with an underscore: `_dfg`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `max_flow_value`
[INFO] [stdout]    --> src/best_exclusive_cut.rs:191:17
[INFO] [stdout]     |
[INFO] [stdout] 191 |             let max_flow_value = graph.max_flow(&source, &sink);
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_max_flow_value`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `from`
[INFO] [stdout]    --> src/best_exclusive_cut.rs:297:11
[INFO] [stdout]     |
[INFO] [stdout] 297 |     for ((from, to), cap) in &graph.capacity {
[INFO] [stdout]     |           ^^^^ help: if this is intentional, prefix it with an underscore: `_from`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `to`
[INFO] [stdout]    --> src/best_exclusive_cut.rs:297:17
[INFO] [stdout]     |
[INFO] [stdout] 297 |     for ((from, to), cap) in &graph.capacity {
[INFO] [stdout]     |                 ^^ help: if this is intentional, prefix it with an underscore: `_to`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cap`
[INFO] [stdout]    --> src/best_exclusive_cut.rs:297:22
[INFO] [stdout]     |
[INFO] [stdout] 297 |     for ((from, to), cap) in &graph.capacity {
[INFO] [stdout]     |                      ^^^ help: if this is intentional, prefix it with an underscore: `_cap`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `from`
[INFO] [stdout]    --> src/best_exclusive_cut.rs:301:11
[INFO] [stdout]     |
[INFO] [stdout] 301 |     for ((from, to), flow) in &graph.flow {
[INFO] [stdout]     |           ^^^^ help: if this is intentional, prefix it with an underscore: `_from`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `to`
[INFO] [stdout]    --> src/best_exclusive_cut.rs:301:17
[INFO] [stdout]     |
[INFO] [stdout] 301 |     for ((from, to), flow) in &graph.flow {
[INFO] [stdout]     |                 ^^ help: if this is intentional, prefix it with an underscore: `_to`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `flow`
[INFO] [stdout]    --> src/best_exclusive_cut.rs:301:22
[INFO] [stdout]     |
[INFO] [stdout] 301 |     for ((from, to), flow) in &graph.flow {
[INFO] [stdout]     |                      ^^^^ help: if this is intentional, prefix it with an underscore: `_flow`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `con`
[INFO] [stdout]   --> src/main.rs:96:15
[INFO] [stdout]    |
[INFO] [stdout] 96 |     let (div, con, rel, defi, all_activities, all_object_types) =
[INFO] [stdout]    |               ^^^ help: if this is intentional, prefix it with an underscore: `_con`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rel`
[INFO] [stdout]   --> src/main.rs:96:20
[INFO] [stdout]    |
[INFO] [stdout] 96 |     let (div, con, rel, defi, all_activities, all_object_types) =
[INFO] [stdout]    |                    ^^^ help: if this is intentional, prefix it with an underscore: `_rel`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `defi`
[INFO] [stdout]   --> src/main.rs:96:25
[INFO] [stdout]    |
[INFO] [stdout] 96 |     let (div, con, rel, defi, all_activities, all_object_types) =
[INFO] [stdout]    |                         ^^^^ help: if this is intentional, prefix it with an underscore: `_defi`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `all_object_types`
[INFO] [stdout]   --> src/main.rs:96:47
[INFO] [stdout]    |
[INFO] [stdout] 96 |     let (div, con, rel, defi, all_activities, all_object_types) =
[INFO] [stdout]    |                                               ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_all_object_types`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `start_acts`
[INFO] [stdout]    --> src/main.rs:108:15
[INFO] [stdout]     |
[INFO] [stdout] 108 |     let (dfg, start_acts, end_acts) =
[INFO] [stdout]     |               ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_start_acts`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `end_acts`
[INFO] [stdout]    --> src/main.rs:108:27
[INFO] [stdout]     |
[INFO] [stdout] 108 |     let (dfg, start_acts, end_acts) =
[INFO] [stdout]     |                           ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_end_acts`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `con`
[INFO] [stdout]   --> src/main.rs:96:15
[INFO] [stdout]    |
[INFO] [stdout] 96 |     let (div, con, rel, defi, all_activities, all_object_types) =
[INFO] [stdout]    |               ^^^ help: if this is intentional, prefix it with an underscore: `_con`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `rel`
[INFO] [stdout]   --> src/main.rs:96:20
[INFO] [stdout]    |
[INFO] [stdout] 96 |     let (div, con, rel, defi, all_activities, all_object_types) =
[INFO] [stdout]    |                    ^^^ help: if this is intentional, prefix it with an underscore: `_rel`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `defi`
[INFO] [stdout]   --> src/main.rs:96:25
[INFO] [stdout]    |
[INFO] [stdout] 96 |     let (div, con, rel, defi, all_activities, all_object_types) =
[INFO] [stdout]    |                         ^^^^ help: if this is intentional, prefix it with an underscore: `_defi`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `all_object_types`
[INFO] [stdout]   --> src/main.rs:96:47
[INFO] [stdout]    |
[INFO] [stdout] 96 |     let (div, con, rel, defi, all_activities, all_object_types) =
[INFO] [stdout]    |                                               ^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_all_object_types`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `start_acts`
[INFO] [stdout]    --> src/main.rs:108:15
[INFO] [stdout]     |
[INFO] [stdout] 108 |     let (dfg, start_acts, end_acts) =
[INFO] [stdout]     |               ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_start_acts`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `end_acts`
[INFO] [stdout]    --> src/main.rs:108:27
[INFO] [stdout]     |
[INFO] [stdout] 108 |     let (dfg, start_acts, end_acts) =
[INFO] [stdout]     |                           ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_end_acts`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `hello` is never used
[INFO] [stdout]   --> src/main.rs:44:10
[INFO] [stdout]    |
[INFO] [stdout] 44 | async fn hello() -> Json<Value> {
[INFO] [stdout]    |          ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `main1` is never used
[INFO] [stdout]   --> src/main.rs:56:10
[INFO] [stdout]    |
[INFO] [stdout] 56 | async fn main1() {
[INFO] [stdout]    |          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `log_sorted_map` is never used
[INFO] [stdout]    --> src/main.rs:162:4
[INFO] [stdout]     |
[INFO] [stdout] 162 | fn log_sorted_map<T: std::fmt::Debug + Ord, U: std::fmt::Debug>(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `print_process_tree` is never used
[INFO] [stdout]    --> src/main.rs:189:4
[INFO] [stdout]     |
[INFO] [stdout] 189 | fn print_process_tree(tree: &TreeNode, depth: usize) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `print_process_forest` is never used
[INFO] [stdout]    --> src/main.rs:197:4
[INFO] [stdout]     |
[INFO] [stdout] 197 | fn print_process_forest(forest: &ProcessForest) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_start_and_end_activities_from_dfg` is never used
[INFO] [stdout]    --> src/main.rs:226:4
[INFO] [stdout]     |
[INFO] [stdout] 226 | fn get_start_and_end_activities_from_dfg(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `mainkoi` is never used
[INFO] [stdout]    --> src/main.rs:251:4
[INFO] [stdout]     |
[INFO] [stdout] 251 | fn mainkoi() {
[INFO] [stdout]     |    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `global_log` is never read
[INFO] [stdout]  --> src/types.rs:8:9
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct OcelJson {
[INFO] [stdout]   |            -------- field in this struct
[INFO] [stdout] 7 |     #[serde(rename = "ocel:global-log")]
[INFO] [stdout] 8 |     pub global_log: serde_json::Value,
[INFO] [stdout]   |         ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `OcelJson` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TreeNode` is never constructed
[INFO] [stdout]   --> src/types.rs:33:12
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub struct TreeNode {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `ProcessForest` is never used
[INFO] [stdout]   --> src/types.rs:38:10
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub type ProcessForest = Vec<TreeNode>;
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Node` is never constructed
[INFO] [stdout]   --> src/types.rs:43:12
[INFO] [stdout]    |
[INFO] [stdout] 43 | pub struct Node {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Edge` is never constructed
[INFO] [stdout]   --> src/types.rs:49:12
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub struct Edge {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Graph` is never constructed
[INFO] [stdout]   --> src/types.rs:57:12
[INFO] [stdout]    |
[INFO] [stdout] 57 | pub struct Graph {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_cuts` is never used
[INFO] [stdout]  --> src/start_cuts.rs:6:8
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub fn find_cuts(
[INFO] [stdout]   |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_reachable` is never used
[INFO] [stdout]    --> src/start_cuts.rs:109:4
[INFO] [stdout]     |
[INFO] [stdout] 109 | fn is_reachable(
[INFO] [stdout]     |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `filter_keep_dfg` is never used
[INFO] [stdout]    --> src/start_cuts.rs:135:4
[INFO] [stdout]     |
[INFO] [stdout] 135 | fn filter_keep_dfg(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_sequence_cut_possible` is never used
[INFO] [stdout]    --> src/start_cuts.rs:148:8
[INFO] [stdout]     |
[INFO] [stdout] 148 | pub fn is_sequence_cut_possible(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_exclusive_choice_cut_possible` is never used
[INFO] [stdout]    --> src/start_cuts.rs:175:8
[INFO] [stdout]     |
[INFO] [stdout] 175 | pub fn is_exclusive_choice_cut_possible(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_parallel_cut_possible` is never used
[INFO] [stdout]    --> src/start_cuts.rs:190:4
[INFO] [stdout]     |
[INFO] [stdout] 190 | fn is_parallel_cut_possible(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_redo_cut_possible` is never used
[INFO] [stdout]    --> src/start_cuts.rs:233:4
[INFO] [stdout]     |
[INFO] [stdout] 233 | fn is_redo_cut_possible(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_start_and_end_activities` is never used
[INFO] [stdout]    --> src/start_cuts.rs:329:4
[INFO] [stdout]     |
[INFO] [stdout] 329 | fn get_start_and_end_activities(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_start_and_end_activities_v2` is never used
[INFO] [stdout]    --> src/start_cuts.rs:359:4
[INFO] [stdout]     |
[INFO] [stdout] 359 | fn get_start_and_end_activities_v2(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `strongly_connected_components` is never used
[INFO] [stdout]  --> src/start_cuts_opti_v1.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn strongly_connected_components(
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_scc_dag` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:102:8
[INFO] [stdout]     |
[INFO] [stdout] 102 | pub fn build_scc_dag(
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `partition_scc_sets` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:126:8
[INFO] [stdout]     |
[INFO] [stdout] 126 | pub fn partition_scc_sets(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `print_strongly_connected_components` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:165:8
[INFO] [stdout]     |
[INFO] [stdout] 165 | pub fn print_strongly_connected_components(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_sequence_cut` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:265:8
[INFO] [stdout]     |
[INFO] [stdout] 265 | pub fn find_sequence_cut(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_subgraph` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:344:4
[INFO] [stdout]     |
[INFO] [stdout] 344 | fn build_subgraph(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `dfs` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:360:4
[INFO] [stdout]     |
[INFO] [stdout] 360 | fn dfs(node: &String, graph: &HashMap<String, Vec<String>>, visited: &mut HashSet<String>) {
[INFO] [stdout]     |    ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `compute_sccs` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:374:4
[INFO] [stdout]     |
[INFO] [stdout] 374 | fn compute_sccs(
[INFO] [stdout]     |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `dfs_postorder` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:403:4
[INFO] [stdout]     |
[INFO] [stdout] 403 | fn dfs_postorder(
[INFO] [stdout]     |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `dfs_collect` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:421:4
[INFO] [stdout]     |
[INFO] [stdout] 421 | fn dfs_collect(
[INFO] [stdout]     |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_cuts_start` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:440:8
[INFO] [stdout]     |
[INFO] [stdout] 440 | pub fn find_cuts_start(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_best_cut` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:598:4
[INFO] [stdout]     |
[INFO] [stdout] 598 | fn find_best_cut(
[INFO] [stdout]     |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_cuts` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:635:8
[INFO] [stdout]     |
[INFO] [stdout] 635 | pub fn find_cuts(
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_reachable` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:738:4
[INFO] [stdout]     |
[INFO] [stdout] 738 | fn is_reachable(
[INFO] [stdout]     |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `filter_keep_dfg` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:764:4
[INFO] [stdout]     |
[INFO] [stdout] 764 | fn filter_keep_dfg(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_sequence_cut_possible` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:777:4
[INFO] [stdout]     |
[INFO] [stdout] 777 | fn is_sequence_cut_possible(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_exclusive_choice_cut_possible` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:804:4
[INFO] [stdout]     |
[INFO] [stdout] 804 | fn is_exclusive_choice_cut_possible(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_parallel_cut_possible` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:819:4
[INFO] [stdout]     |
[INFO] [stdout] 819 | fn is_parallel_cut_possible(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_redo_cut_possible` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:862:4
[INFO] [stdout]     |
[INFO] [stdout] 862 | fn is_redo_cut_possible(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_start_and_end_activities` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:958:4
[INFO] [stdout]     |
[INFO] [stdout] 958 | fn get_start_and_end_activities(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_start_and_end_activities_v2` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:988:4
[INFO] [stdout]     |
[INFO] [stdout] 988 | fn get_start_and_end_activities_v2(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_cuts_start` is never used
[INFO] [stdout]   --> src/start_cuts_opti_v2.rs:19:8
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub fn find_cuts_start(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_exclusive_choice_cut` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:187:4
[INFO] [stdout]     |
[INFO] [stdout] 187 | fn find_exclusive_choice_cut(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `exclusive_cut_condition_check` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:251:4
[INFO] [stdout]     |
[INFO] [stdout] 251 | fn exclusive_cut_condition_check(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_sequence_cut` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:270:4
[INFO] [stdout]     |
[INFO] [stdout] 270 | fn find_sequence_cut(dfg: &HashMap<(String, String), usize>, all_activities: &HashSet<String>)
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `strongly_connected_components` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:295:4
[INFO] [stdout]     |
[INFO] [stdout] 295 | fn strongly_connected_components(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_scc_dag` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:382:8
[INFO] [stdout]     |
[INFO] [stdout] 382 | pub fn build_scc_dag(
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `partition_scc_sets` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:406:8
[INFO] [stdout]     |
[INFO] [stdout] 406 | pub fn partition_scc_sets(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_reachable_in_dag` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:467:8
[INFO] [stdout]     |
[INFO] [stdout] 467 | pub fn is_reachable_in_dag(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `sequence_cut_condition_check` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:490:4
[INFO] [stdout]     |
[INFO] [stdout] 490 | fn sequence_cut_condition_check(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_parallel_cut` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:510:4
[INFO] [stdout]     |
[INFO] [stdout] 510 | fn find_parallel_cut(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parallel_cut_condition_check` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:549:4
[INFO] [stdout]     |
[INFO] [stdout] 549 | fn parallel_cut_condition_check(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_redo_cut` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:564:4
[INFO] [stdout]     |
[INFO] [stdout] 564 | fn find_redo_cut(
[INFO] [stdout]     |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `redo_cut_condition_check` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:597:4
[INFO] [stdout]     |
[INFO] [stdout] 597 | fn redo_cut_condition_check(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `filter_keep_dfg` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:676:4
[INFO] [stdout]     |
[INFO] [stdout] 676 | fn filter_keep_dfg(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check_bi_direction_sets` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:688:4
[INFO] [stdout]     |
[INFO] [stdout] 688 | fn check_bi_direction_sets(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_start_and_end_activities` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:703:4
[INFO] [stdout]     |
[INFO] [stdout] 703 | fn get_start_and_end_activities(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_reachable_before_end_activity` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:740:8
[INFO] [stdout]     |
[INFO] [stdout] 740 | pub fn is_reachable_before_end_activity(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `dfg_to_json` is never used
[INFO] [stdout]  --> src/format_conversion.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub fn dfg_to_json(dfg: &HashMap<(String, String), usize>) -> Value {
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `to_be_non_reachable` is never used
[INFO] [stdout]  --> src/cost_to_cut.rs:4:8
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub fn to_be_non_reachable(
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_all_paths` is never used
[INFO] [stdout]   --> src/cost_to_cut.rs:26:4
[INFO] [stdout]    |
[INFO] [stdout] 26 | fn find_all_paths(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_paths_dfs` is never used
[INFO] [stdout]   --> src/cost_to_cut.rs:39:4
[INFO] [stdout]    |
[INFO] [stdout] 39 | fn find_paths_dfs(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_min_edge_cut` is never used
[INFO] [stdout]   --> src/cost_to_cut.rs:69:4
[INFO] [stdout]    |
[INFO] [stdout] 69 | fn find_min_edge_cut(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_min_edge_cut_old` is never used
[INFO] [stdout]    --> src/cost_to_cut.rs:164:4
[INFO] [stdout]     |
[INFO] [stdout] 164 | fn find_min_edge_cut_old(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_disconnected` is never used
[INFO] [stdout]    --> src/cost_to_cut.rs:217:4
[INFO] [stdout]     |
[INFO] [stdout] 217 | fn is_disconnected(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_reachable` is never used
[INFO] [stdout]    --> src/cost_to_cut.rs:243:8
[INFO] [stdout]     |
[INFO] [stdout] 243 | pub fn is_reachable(
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `add_edge_to_dfg` is never used
[INFO] [stdout]  --> src/cost_to_add.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub fn add_edge_to_dfg(
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CutResult` is never constructed
[INFO] [stdout]    --> src/good_cuts.rs:107:12
[INFO] [stdout]     |
[INFO] [stdout] 107 | pub struct CutResult {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ActivityPartitioner` is never constructed
[INFO] [stdout]    --> src/good_cuts.rs:114:12
[INFO] [stdout]     |
[INFO] [stdout] 114 | pub struct ActivityPartitioner {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/good_cuts.rs:123:12
[INFO] [stdout]     |
[INFO] [stdout] 122 | impl ActivityPartitioner {
[INFO] [stdout]     | ------------------------ associated items in this implementation
[INFO] [stdout] 123 |     pub fn new(dfg: &HashMap<(String, String), usize>, all_activities: &HashSet<String>) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub fn solve(&self) -> Option<CutResult> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 178 |     fn try_source_sink(&self, source: usize, sink: usize) -> Option<CutResult> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 228 |     fn edmonds_karp(&self, source: usize, sink: usize, mut capacity: Vec<Vec<usize>>) 
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 288 |     fn find_reachable(&self, source: usize, residual: &[Vec<usize>]) -> HashSet<usize> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 307 |     fn validate_partition(&self, set1: &[String], set2: &[String]) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 333 |     fn get_reachable_nodes(&self, start: usize) -> HashSet<usize> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `perform_cut` is never used
[INFO] [stdout]    --> src/good_cuts.rs:354:8
[INFO] [stdout]     |
[INFO] [stdout] 354 | pub fn perform_cut(
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `best_possible_sequence_cut` is never used
[INFO] [stdout]    --> src/good_cuts.rs:391:8
[INFO] [stdout]     |
[INFO] [stdout] 391 | pub fn best_possible_sequence_cut(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `best_sequence_cut` is never used
[INFO] [stdout]  --> src/best_sequence_cut.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub fn best_sequence_cut(
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Graph` is never constructed
[INFO] [stdout]  --> src/best_exclusive_cut.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 5 | struct Graph {
[INFO] [stdout]   |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/best_exclusive_cut.rs:12:8
[INFO] [stdout]     |
[INFO] [stdout] 11  | impl Graph {
[INFO] [stdout]     | ---------- associated items in this implementation
[INFO] [stdout] 12  |     fn new() -> Self {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 20  |     fn add_edge(&mut self, from: String, to: String, cap: usize) {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 33  |     fn get_capacity(&self, from: &str, to: &str) -> usize {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37  |     fn get_flow(&self, from: &str, to: &str) -> usize {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41  |     fn get_residual_capacity(&self, from: &str, to: &str) -> usize {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45  |     fn push_flow(&mut self, from: &str, to: &str, amount: usize) {
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 55  |     fn bfs_find_path(&self, source: &str, sink: &str) -> Option<Vec<String>> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 92  |     fn max_flow(&mut self, source: &str, sink: &str) -> usize {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 116 |     fn find_reachable_from_source(&self, source: &str) -> HashSet<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `best_exclusive_cut` is never used
[INFO] [stdout]    --> src/best_exclusive_cut.rs:136:8
[INFO] [stdout]     |
[INFO] [stdout] 136 | pub fn best_exclusive_cut(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `test_example` is never used
[INFO] [stdout]    --> src/best_exclusive_cut.rs:256:8
[INFO] [stdout]     |
[INFO] [stdout] 256 | pub fn test_example() {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `print_graph` is never used
[INFO] [stdout]    --> src/best_exclusive_cut.rs:293:4
[INFO] [stdout]     |
[INFO] [stdout] 293 | fn print_graph(
[INFO] [stdout]     |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PartitionResult` is never constructed
[INFO] [stdout]  --> src/best_parallel_cut.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct PartitionResult {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Solution` is never constructed
[INFO] [stdout]   --> src/best_parallel_cut.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | struct Solution {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `best_parallel_cut` is never used
[INFO] [stdout]   --> src/best_parallel_cut.rs:22:8
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub fn best_parallel_cut(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `hello` is never used
[INFO] [stdout]   --> src/main.rs:44:10
[INFO] [stdout]    |
[INFO] [stdout] 44 | async fn hello() -> Json<Value> {
[INFO] [stdout]    |          ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `main1` is never used
[INFO] [stdout]   --> src/main.rs:56:10
[INFO] [stdout]    |
[INFO] [stdout] 56 | async fn main1() {
[INFO] [stdout]    |          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `generate_initial_partition` is never used
[INFO] [stdout]   --> src/best_parallel_cut.rs:73:4
[INFO] [stdout]    |
[INFO] [stdout] 73 | fn generate_initial_partition(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `local_search_improvement` is never used
[INFO] [stdout]    --> src/best_parallel_cut.rs:103:4
[INFO] [stdout]     |
[INFO] [stdout] 103 | fn local_search_improvement(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `log_sorted_map` is never used
[INFO] [stdout]    --> src/main.rs:162:4
[INFO] [stdout]     |
[INFO] [stdout] 162 | fn log_sorted_map<T: std::fmt::Debug + Ord, U: std::fmt::Debug>(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `final_optimization` is never used
[INFO] [stdout]    --> src/best_parallel_cut.rs:184:4
[INFO] [stdout]     |
[INFO] [stdout] 184 | fn final_optimization(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `calculate_cost` is never used
[INFO] [stdout]    --> src/best_parallel_cut.rs:231:4
[INFO] [stdout]     |
[INFO] [stdout] 231 | fn calculate_cost(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_edges_to_add` is never used
[INFO] [stdout]    --> src/best_parallel_cut.rs:254:4
[INFO] [stdout]     |
[INFO] [stdout] 254 | fn get_edges_to_add(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `print_process_tree` is never used
[INFO] [stdout]    --> src/main.rs:189:4
[INFO] [stdout]     |
[INFO] [stdout] 189 | fn print_process_tree(tree: &TreeNode, depth: usize) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_partition_result` is never used
[INFO] [stdout]    --> src/best_parallel_cut.rs:277:4
[INFO] [stdout]     |
[INFO] [stdout] 277 | fn create_partition_result(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PartitionResult` is never constructed
[INFO] [stdout]  --> src/best_parallel_cut_exhaustive.rs:4:16
[INFO] [stdout]   |
[INFO] [stdout] 4 |     pub struct PartitionResult {
[INFO] [stdout]   |                ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `best_parallel_cut_exhaustive` is never used
[INFO] [stdout]   --> src/best_parallel_cut_exhaustive.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 15 |     pub fn best_parallel_cut_exhaustive(
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `calculate_partition_cost` is never used
[INFO] [stdout]    --> src/best_parallel_cut_exhaustive.rs:104:8
[INFO] [stdout]     |
[INFO] [stdout] 104 |     fn calculate_partition_cost(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `best_parallel_cut_exhaustive_optimized` is never used
[INFO] [stdout]    --> src/best_parallel_cut_exhaustive.rs:134:12
[INFO] [stdout]     |
[INFO] [stdout] 134 |     pub fn best_parallel_cut_exhaustive_optimized(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `calculate_cost_optimized` is never used
[INFO] [stdout]    --> src/best_parallel_cut_exhaustive.rs:228:8
[INFO] [stdout]     |
[INFO] [stdout] 228 |     fn calculate_cost_optimized(mask: u64, n: usize, edge_matrix: &[Vec<bool>]) -> usize {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `best_parallel_cut_exhaustive_memory_efficient` is never used
[INFO] [stdout]    --> src/best_parallel_cut_exhaustive.rs:251:12
[INFO] [stdout]     |
[INFO] [stdout] 251 |     pub fn best_parallel_cut_exhaustive_memory_efficient(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `search_combinations` is never used
[INFO] [stdout]    --> src/best_parallel_cut_exhaustive.rs:307:8
[INFO] [stdout]     |
[INFO] [stdout] 307 |     fn search_combinations(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `best_redo_cut` is never used
[INFO] [stdout]  --> src/best_redo_cuts.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn best_redo_cut(
[INFO] [stdout]   |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `remove_edges_dfg` is never used
[INFO] [stdout]    --> src/best_redo_cuts.rs:161:4
[INFO] [stdout]     |
[INFO] [stdout] 161 | fn remove_edges_dfg(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `remove_activity_from_dfg` is never used
[INFO] [stdout]    --> src/best_redo_cuts.rs:190:4
[INFO] [stdout]     |
[INFO] [stdout] 190 | fn remove_activity_from_dfg(dfg: &mut HashMap<(String, String), usize>, activity: &String) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Graph` is never constructed
[INFO] [stdout]  --> src/best_sequence_cut_v2.rs:4:8
[INFO] [stdout]   |
[INFO] [stdout] 4 | struct Graph {
[INFO] [stdout]   |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `print_process_forest` is never used
[INFO] [stdout]    --> src/main.rs:197:4
[INFO] [stdout]     |
[INFO] [stdout] 197 | fn print_process_forest(forest: &ProcessForest) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/best_sequence_cut_v2.rs:11:8
[INFO] [stdout]     |
[INFO] [stdout] 10  | impl Graph {
[INFO] [stdout]     | ---------- associated items in this implementation
[INFO] [stdout] 11  |     fn new() -> Self {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 19  |     fn add_edge(&mut self, from: String, to: String, cap: usize) {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27  |     fn get_capacity(&self, from: &str, to: &str) -> usize {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 31  |     fn get_flow(&self, from: &str, to: &str) -> usize {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 35  |     fn get_residual_capacity(&self, from: &str, to: &str) -> usize {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 39  |     fn push_flow(&mut self, from: &str, to: &str, amount: usize) {
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 52  |     fn bfs_find_path(&self, source: &str, sink: &str) -> Option<Vec<String>> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 89  |     fn max_flow(&mut self, source: &str, sink: &str) -> usize {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 113 |     fn find_reachable_from_source(&self, source: &str) -> HashSet<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `best_exclusive_cut` is never used
[INFO] [stdout]    --> src/best_sequence_cut_v2.rs:133:8
[INFO] [stdout]     |
[INFO] [stdout] 133 | pub fn best_exclusive_cut(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PartitionResult` is never constructed
[INFO] [stdout]  --> src/best_parallel_cut_v2.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct PartitionResult {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `bfs` is never used
[INFO] [stdout]   --> src/best_parallel_cut_v2.rs:25:4
[INFO] [stdout]    |
[INFO] [stdout] 25 | fn bfs(
[INFO] [stdout]    |    ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_s_t_min_cut` is never used
[INFO] [stdout]   --> src/best_parallel_cut_v2.rs:66:4
[INFO] [stdout]    |
[INFO] [stdout] 66 | fn find_s_t_min_cut(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `best_parallel_cut_v2` is never used
[INFO] [stdout]    --> src/best_parallel_cut_v2.rs:126:8
[INFO] [stdout]     |
[INFO] [stdout] 126 | pub fn best_parallel_cut_v2(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_start_and_end_activities_from_dfg` is never used
[INFO] [stdout]    --> src/main.rs:226:4
[INFO] [stdout]     |
[INFO] [stdout] 226 | fn get_start_and_end_activities_from_dfg(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `mainkoi` is never used
[INFO] [stdout]    --> src/main.rs:251:4
[INFO] [stdout]     |
[INFO] [stdout] 251 | fn mainkoi() {
[INFO] [stdout]     |    ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `global_log` is never read
[INFO] [stdout]  --> src/types.rs:8:9
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct OcelJson {
[INFO] [stdout]   |            -------- field in this struct
[INFO] [stdout] 7 |     #[serde(rename = "ocel:global-log")]
[INFO] [stdout] 8 |     pub global_log: serde_json::Value,
[INFO] [stdout]   |         ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `OcelJson` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TreeNode` is never constructed
[INFO] [stdout]   --> src/types.rs:33:12
[INFO] [stdout]    |
[INFO] [stdout] 33 | pub struct TreeNode {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type alias `ProcessForest` is never used
[INFO] [stdout]   --> src/types.rs:38:10
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub type ProcessForest = Vec<TreeNode>;
[INFO] [stdout]    |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Node` is never constructed
[INFO] [stdout]   --> src/types.rs:43:12
[INFO] [stdout]    |
[INFO] [stdout] 43 | pub struct Node {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Edge` is never constructed
[INFO] [stdout]   --> src/types.rs:49:12
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub struct Edge {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Graph` is never constructed
[INFO] [stdout]   --> src/types.rs:57:12
[INFO] [stdout]    |
[INFO] [stdout] 57 | pub struct Graph {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_cuts` is never used
[INFO] [stdout]  --> src/start_cuts.rs:6:8
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub fn find_cuts(
[INFO] [stdout]   |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_reachable` is never used
[INFO] [stdout]    --> src/start_cuts.rs:109:4
[INFO] [stdout]     |
[INFO] [stdout] 109 | fn is_reachable(
[INFO] [stdout]     |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `filter_keep_dfg` is never used
[INFO] [stdout]    --> src/start_cuts.rs:135:4
[INFO] [stdout]     |
[INFO] [stdout] 135 | fn filter_keep_dfg(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_sequence_cut_possible` is never used
[INFO] [stdout]    --> src/start_cuts.rs:148:8
[INFO] [stdout]     |
[INFO] [stdout] 148 | pub fn is_sequence_cut_possible(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_exclusive_choice_cut_possible` is never used
[INFO] [stdout]    --> src/start_cuts.rs:175:8
[INFO] [stdout]     |
[INFO] [stdout] 175 | pub fn is_exclusive_choice_cut_possible(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_parallel_cut_possible` is never used
[INFO] [stdout]    --> src/start_cuts.rs:190:4
[INFO] [stdout]     |
[INFO] [stdout] 190 | fn is_parallel_cut_possible(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_redo_cut_possible` is never used
[INFO] [stdout]    --> src/start_cuts.rs:233:4
[INFO] [stdout]     |
[INFO] [stdout] 233 | fn is_redo_cut_possible(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_start_and_end_activities` is never used
[INFO] [stdout]    --> src/start_cuts.rs:329:4
[INFO] [stdout]     |
[INFO] [stdout] 329 | fn get_start_and_end_activities(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_start_and_end_activities_v2` is never used
[INFO] [stdout]    --> src/start_cuts.rs:359:4
[INFO] [stdout]     |
[INFO] [stdout] 359 | fn get_start_and_end_activities_v2(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `strongly_connected_components` is never used
[INFO] [stdout]  --> src/start_cuts_opti_v1.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn strongly_connected_components(
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_scc_dag` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:102:8
[INFO] [stdout]     |
[INFO] [stdout] 102 | pub fn build_scc_dag(
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `partition_scc_sets` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:126:8
[INFO] [stdout]     |
[INFO] [stdout] 126 | pub fn partition_scc_sets(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `print_strongly_connected_components` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:165:8
[INFO] [stdout]     |
[INFO] [stdout] 165 | pub fn print_strongly_connected_components(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_sequence_cut` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:265:8
[INFO] [stdout]     |
[INFO] [stdout] 265 | pub fn find_sequence_cut(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_subgraph` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:344:4
[INFO] [stdout]     |
[INFO] [stdout] 344 | fn build_subgraph(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `dfs` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:360:4
[INFO] [stdout]     |
[INFO] [stdout] 360 | fn dfs(node: &String, graph: &HashMap<String, Vec<String>>, visited: &mut HashSet<String>) {
[INFO] [stdout]     |    ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `compute_sccs` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:374:4
[INFO] [stdout]     |
[INFO] [stdout] 374 | fn compute_sccs(
[INFO] [stdout]     |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `dfs_postorder` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:403:4
[INFO] [stdout]     |
[INFO] [stdout] 403 | fn dfs_postorder(
[INFO] [stdout]     |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `dfs_collect` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:421:4
[INFO] [stdout]     |
[INFO] [stdout] 421 | fn dfs_collect(
[INFO] [stdout]     |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_cuts_start` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:440:8
[INFO] [stdout]     |
[INFO] [stdout] 440 | pub fn find_cuts_start(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_best_cut` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:598:4
[INFO] [stdout]     |
[INFO] [stdout] 598 | fn find_best_cut(
[INFO] [stdout]     |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_cuts` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:635:8
[INFO] [stdout]     |
[INFO] [stdout] 635 | pub fn find_cuts(
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_reachable` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:738:4
[INFO] [stdout]     |
[INFO] [stdout] 738 | fn is_reachable(
[INFO] [stdout]     |    ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `filter_keep_dfg` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:764:4
[INFO] [stdout]     |
[INFO] [stdout] 764 | fn filter_keep_dfg(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_sequence_cut_possible` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:777:4
[INFO] [stdout]     |
[INFO] [stdout] 777 | fn is_sequence_cut_possible(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_exclusive_choice_cut_possible` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:804:4
[INFO] [stdout]     |
[INFO] [stdout] 804 | fn is_exclusive_choice_cut_possible(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_parallel_cut_possible` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:819:4
[INFO] [stdout]     |
[INFO] [stdout] 819 | fn is_parallel_cut_possible(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_redo_cut_possible` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:862:4
[INFO] [stdout]     |
[INFO] [stdout] 862 | fn is_redo_cut_possible(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_start_and_end_activities` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:958:4
[INFO] [stdout]     |
[INFO] [stdout] 958 | fn get_start_and_end_activities(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_start_and_end_activities_v2` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v1.rs:988:4
[INFO] [stdout]     |
[INFO] [stdout] 988 | fn get_start_and_end_activities_v2(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_cuts_start` is never used
[INFO] [stdout]   --> src/start_cuts_opti_v2.rs:19:8
[INFO] [stdout]    |
[INFO] [stdout] 19 | pub fn find_cuts_start(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_exclusive_choice_cut` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:187:4
[INFO] [stdout]     |
[INFO] [stdout] 187 | fn find_exclusive_choice_cut(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `exclusive_cut_condition_check` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:251:4
[INFO] [stdout]     |
[INFO] [stdout] 251 | fn exclusive_cut_condition_check(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_sequence_cut` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:270:4
[INFO] [stdout]     |
[INFO] [stdout] 270 | fn find_sequence_cut(dfg: &HashMap<(String, String), usize>, all_activities: &HashSet<String>)
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `strongly_connected_components` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:295:4
[INFO] [stdout]     |
[INFO] [stdout] 295 | fn strongly_connected_components(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `build_scc_dag` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:382:8
[INFO] [stdout]     |
[INFO] [stdout] 382 | pub fn build_scc_dag(
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `partition_scc_sets` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:406:8
[INFO] [stdout]     |
[INFO] [stdout] 406 | pub fn partition_scc_sets(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_reachable_in_dag` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:467:8
[INFO] [stdout]     |
[INFO] [stdout] 467 | pub fn is_reachable_in_dag(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `sequence_cut_condition_check` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:490:4
[INFO] [stdout]     |
[INFO] [stdout] 490 | fn sequence_cut_condition_check(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_parallel_cut` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:510:4
[INFO] [stdout]     |
[INFO] [stdout] 510 | fn find_parallel_cut(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `totalCost` should have a snake case name
[INFO] [stdout]   --> src/cost_to_add.rs:12:13
[INFO] [stdout]    |
[INFO] [stdout] 12 |     let mut totalCost = 0;
[INFO] [stdout]    |             ^^^^^^^^^ help: convert the identifier to snake case: `total_cost`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parallel_cut_condition_check` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:549:4
[INFO] [stdout]     |
[INFO] [stdout] 549 | fn parallel_cut_condition_check(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_redo_cut` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:564:4
[INFO] [stdout]     |
[INFO] [stdout] 564 | fn find_redo_cut(
[INFO] [stdout]     |    ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `redo_cut_condition_check` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:597:4
[INFO] [stdout]     |
[INFO] [stdout] 597 | fn redo_cut_condition_check(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `filter_keep_dfg` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:676:4
[INFO] [stdout]     |
[INFO] [stdout] 676 | fn filter_keep_dfg(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check_bi_direction_sets` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:688:4
[INFO] [stdout]     |
[INFO] [stdout] 688 | fn check_bi_direction_sets(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_start_and_end_activities` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:703:4
[INFO] [stdout]     |
[INFO] [stdout] 703 | fn get_start_and_end_activities(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_reachable_before_end_activity` is never used
[INFO] [stdout]    --> src/start_cuts_opti_v2.rs:740:8
[INFO] [stdout]     |
[INFO] [stdout] 740 | pub fn is_reachable_before_end_activity(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `dfg_to_json` is never used
[INFO] [stdout]  --> src/format_conversion.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub fn dfg_to_json(dfg: &HashMap<(String, String), usize>) -> Value {
[INFO] [stdout]   |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `to_be_non_reachable` is never used
[INFO] [stdout]  --> src/cost_to_cut.rs:4:8
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub fn to_be_non_reachable(
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_all_paths` is never used
[INFO] [stdout]   --> src/cost_to_cut.rs:26:4
[INFO] [stdout]    |
[INFO] [stdout] 26 | fn find_all_paths(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_paths_dfs` is never used
[INFO] [stdout]   --> src/cost_to_cut.rs:39:4
[INFO] [stdout]    |
[INFO] [stdout] 39 | fn find_paths_dfs(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_min_edge_cut` is never used
[INFO] [stdout]   --> src/cost_to_cut.rs:69:4
[INFO] [stdout]    |
[INFO] [stdout] 69 | fn find_min_edge_cut(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_min_edge_cut_old` is never used
[INFO] [stdout]    --> src/cost_to_cut.rs:164:4
[INFO] [stdout]     |
[INFO] [stdout] 164 | fn find_min_edge_cut_old(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_disconnected` is never used
[INFO] [stdout]    --> src/cost_to_cut.rs:217:4
[INFO] [stdout]     |
[INFO] [stdout] 217 | fn is_disconnected(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `is_reachable` is never used
[INFO] [stdout]    --> src/cost_to_cut.rs:243:8
[INFO] [stdout]     |
[INFO] [stdout] 243 | pub fn is_reachable(
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `add_edge_to_dfg` is never used
[INFO] [stdout]  --> src/cost_to_add.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub fn add_edge_to_dfg(
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CutResult` is never constructed
[INFO] [stdout]    --> src/good_cuts.rs:107:12
[INFO] [stdout]     |
[INFO] [stdout] 107 | pub struct CutResult {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ActivityPartitioner` is never constructed
[INFO] [stdout]    --> src/good_cuts.rs:114:12
[INFO] [stdout]     |
[INFO] [stdout] 114 | pub struct ActivityPartitioner {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/good_cuts.rs:123:12
[INFO] [stdout]     |
[INFO] [stdout] 122 | impl ActivityPartitioner {
[INFO] [stdout]     | ------------------------ associated items in this implementation
[INFO] [stdout] 123 |     pub fn new(dfg: &HashMap<(String, String), usize>, all_activities: &HashSet<String>) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 153 |     pub fn solve(&self) -> Option<CutResult> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 178 |     fn try_source_sink(&self, source: usize, sink: usize) -> Option<CutResult> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 228 |     fn edmonds_karp(&self, source: usize, sink: usize, mut capacity: Vec<Vec<usize>>) 
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 288 |     fn find_reachable(&self, source: usize, residual: &[Vec<usize>]) -> HashSet<usize> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 307 |     fn validate_partition(&self, set1: &[String], set2: &[String]) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 333 |     fn get_reachable_nodes(&self, start: usize) -> HashSet<usize> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `perform_cut` is never used
[INFO] [stdout]    --> src/good_cuts.rs:354:8
[INFO] [stdout]     |
[INFO] [stdout] 354 | pub fn perform_cut(
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `best_possible_sequence_cut` is never used
[INFO] [stdout]    --> src/good_cuts.rs:391:8
[INFO] [stdout]     |
[INFO] [stdout] 391 | pub fn best_possible_sequence_cut(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `best_sequence_cut` is never used
[INFO] [stdout]  --> src/best_sequence_cut.rs:7:8
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub fn best_sequence_cut(
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Graph` is never constructed
[INFO] [stdout]  --> src/best_exclusive_cut.rs:5:8
[INFO] [stdout]   |
[INFO] [stdout] 5 | struct Graph {
[INFO] [stdout]   |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/best_exclusive_cut.rs:12:8
[INFO] [stdout]     |
[INFO] [stdout] 11  | impl Graph {
[INFO] [stdout]     | ---------- associated items in this implementation
[INFO] [stdout] 12  |     fn new() -> Self {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 20  |     fn add_edge(&mut self, from: String, to: String, cap: usize) {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 33  |     fn get_capacity(&self, from: &str, to: &str) -> usize {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37  |     fn get_flow(&self, from: &str, to: &str) -> usize {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41  |     fn get_residual_capacity(&self, from: &str, to: &str) -> usize {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45  |     fn push_flow(&mut self, from: &str, to: &str, amount: usize) {
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 55  |     fn bfs_find_path(&self, source: &str, sink: &str) -> Option<Vec<String>> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 92  |     fn max_flow(&mut self, source: &str, sink: &str) -> usize {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 116 |     fn find_reachable_from_source(&self, source: &str) -> HashSet<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `best_exclusive_cut` is never used
[INFO] [stdout]    --> src/best_exclusive_cut.rs:136:8
[INFO] [stdout]     |
[INFO] [stdout] 136 | pub fn best_exclusive_cut(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `test_example` is never used
[INFO] [stdout]    --> src/best_exclusive_cut.rs:256:8
[INFO] [stdout]     |
[INFO] [stdout] 256 | pub fn test_example() {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `print_graph` is never used
[INFO] [stdout]    --> src/best_exclusive_cut.rs:293:4
[INFO] [stdout]     |
[INFO] [stdout] 293 | fn print_graph(
[INFO] [stdout]     |    ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PartitionResult` is never constructed
[INFO] [stdout]  --> src/best_parallel_cut.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct PartitionResult {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Solution` is never constructed
[INFO] [stdout]   --> src/best_parallel_cut.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 15 | struct Solution {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `best_parallel_cut` is never used
[INFO] [stdout]   --> src/best_parallel_cut.rs:22:8
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub fn best_parallel_cut(
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `generate_initial_partition` is never used
[INFO] [stdout]   --> src/best_parallel_cut.rs:73:4
[INFO] [stdout]    |
[INFO] [stdout] 73 | fn generate_initial_partition(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `local_search_improvement` is never used
[INFO] [stdout]    --> src/best_parallel_cut.rs:103:4
[INFO] [stdout]     |
[INFO] [stdout] 103 | fn local_search_improvement(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `final_optimization` is never used
[INFO] [stdout]    --> src/best_parallel_cut.rs:184:4
[INFO] [stdout]     |
[INFO] [stdout] 184 | fn final_optimization(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `calculate_cost` is never used
[INFO] [stdout]    --> src/best_parallel_cut.rs:231:4
[INFO] [stdout]     |
[INFO] [stdout] 231 | fn calculate_cost(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_edges_to_add` is never used
[INFO] [stdout]    --> src/best_parallel_cut.rs:254:4
[INFO] [stdout]     |
[INFO] [stdout] 254 | fn get_edges_to_add(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `create_partition_result` is never used
[INFO] [stdout]    --> src/best_parallel_cut.rs:277:4
[INFO] [stdout]     |
[INFO] [stdout] 277 | fn create_partition_result(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PartitionResult` is never constructed
[INFO] [stdout]  --> src/best_parallel_cut_exhaustive.rs:4:16
[INFO] [stdout]   |
[INFO] [stdout] 4 |     pub struct PartitionResult {
[INFO] [stdout]   |                ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `best_parallel_cut_exhaustive` is never used
[INFO] [stdout]   --> src/best_parallel_cut_exhaustive.rs:15:12
[INFO] [stdout]    |
[INFO] [stdout] 15 |     pub fn best_parallel_cut_exhaustive(
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `calculate_partition_cost` is never used
[INFO] [stdout]    --> src/best_parallel_cut_exhaustive.rs:104:8
[INFO] [stdout]     |
[INFO] [stdout] 104 |     fn calculate_partition_cost(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `best_parallel_cut_exhaustive_optimized` is never used
[INFO] [stdout]    --> src/best_parallel_cut_exhaustive.rs:134:12
[INFO] [stdout]     |
[INFO] [stdout] 134 |     pub fn best_parallel_cut_exhaustive_optimized(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `calculate_cost_optimized` is never used
[INFO] [stdout]    --> src/best_parallel_cut_exhaustive.rs:228:8
[INFO] [stdout]     |
[INFO] [stdout] 228 |     fn calculate_cost_optimized(mask: u64, n: usize, edge_matrix: &[Vec<bool>]) -> usize {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `best_parallel_cut_exhaustive_memory_efficient` is never used
[INFO] [stdout]    --> src/best_parallel_cut_exhaustive.rs:251:12
[INFO] [stdout]     |
[INFO] [stdout] 251 |     pub fn best_parallel_cut_exhaustive_memory_efficient(
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `search_combinations` is never used
[INFO] [stdout]    --> src/best_parallel_cut_exhaustive.rs:307:8
[INFO] [stdout]     |
[INFO] [stdout] 307 |     fn search_combinations(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `best_redo_cut` is never used
[INFO] [stdout]  --> src/best_redo_cuts.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn best_redo_cut(
[INFO] [stdout]   |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `remove_edges_dfg` is never used
[INFO] [stdout]    --> src/best_redo_cuts.rs:161:4
[INFO] [stdout]     |
[INFO] [stdout] 161 | fn remove_edges_dfg(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `remove_activity_from_dfg` is never used
[INFO] [stdout]    --> src/best_redo_cuts.rs:190:4
[INFO] [stdout]     |
[INFO] [stdout] 190 | fn remove_activity_from_dfg(dfg: &mut HashMap<(String, String), usize>, activity: &String) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Graph` is never constructed
[INFO] [stdout]  --> src/best_sequence_cut_v2.rs:4:8
[INFO] [stdout]   |
[INFO] [stdout] 4 | struct Graph {
[INFO] [stdout]   |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/best_sequence_cut_v2.rs:11:8
[INFO] [stdout]     |
[INFO] [stdout] 10  | impl Graph {
[INFO] [stdout]     | ---------- associated items in this implementation
[INFO] [stdout] 11  |     fn new() -> Self {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 19  |     fn add_edge(&mut self, from: String, to: String, cap: usize) {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 27  |     fn get_capacity(&self, from: &str, to: &str) -> usize {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 31  |     fn get_flow(&self, from: &str, to: &str) -> usize {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 35  |     fn get_residual_capacity(&self, from: &str, to: &str) -> usize {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 39  |     fn push_flow(&mut self, from: &str, to: &str, amount: usize) {
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 52  |     fn bfs_find_path(&self, source: &str, sink: &str) -> Option<Vec<String>> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 89  |     fn max_flow(&mut self, source: &str, sink: &str) -> usize {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 113 |     fn find_reachable_from_source(&self, source: &str) -> HashSet<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `best_exclusive_cut` is never used
[INFO] [stdout]    --> src/best_sequence_cut_v2.rs:133:8
[INFO] [stdout]     |
[INFO] [stdout] 133 | pub fn best_exclusive_cut(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PartitionResult` is never constructed
[INFO] [stdout]  --> src/best_parallel_cut_v2.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct PartitionResult {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `bfs` is never used
[INFO] [stdout]   --> src/best_parallel_cut_v2.rs:25:4
[INFO] [stdout]    |
[INFO] [stdout] 25 | fn bfs(
[INFO] [stdout]    |    ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `find_s_t_min_cut` is never used
[INFO] [stdout]   --> src/best_parallel_cut_v2.rs:66:4
[INFO] [stdout]    |
[INFO] [stdout] 66 | fn find_s_t_min_cut(
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `best_parallel_cut_v2` is never used
[INFO] [stdout]    --> src/best_parallel_cut_v2.rs:126:8
[INFO] [stdout]     |
[INFO] [stdout] 126 | pub fn best_parallel_cut_v2(
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `totalCost` should have a snake case name
[INFO] [stdout]   --> src/cost_to_add.rs:12:13
[INFO] [stdout]    |
[INFO] [stdout] 12 |     let mut totalCost = 0;
[INFO] [stdout]    |             ^^^^^^^^^ help: convert the identifier to snake case: `total_cost`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 35.31s
[INFO] running `Command { std: "docker" "inspect" "ed75594e9be79353c58040f99d4eae89049a311607715c6e0878206b1fbd8b7f", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "ed75594e9be79353c58040f99d4eae89049a311607715c6e0878206b1fbd8b7f", kill_on_drop: false }`
[INFO] [stdout] ed75594e9be79353c58040f99d4eae89049a311607715c6e0878206b1fbd8b7f
