[INFO] cloning repository https://github.com/MrMisc/Outbreak_CIC-Model
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/MrMisc/Outbreak_CIC-Model" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FMrMisc%2FOutbreak_CIC-Model", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FMrMisc%2FOutbreak_CIC-Model'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 9ab94193568a6b36e077bf164d4f49be252bb5d7
[INFO] checking MrMisc/Outbreak_CIC-Model against master#bca37a20bd376ce3fd138e7cdee7fe704e0f8814 for pr-139493-3
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FMrMisc%2FOutbreak_CIC-Model" "/workspace/builds/worker-1-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc1/source'...
[INFO] [stderr] done.
[INFO] [stderr] Updating files:   7% (259/3379)
Updating files:   8% (271/3379)
Updating files:   9% (305/3379)
Updating files:  10% (338/3379)
Updating files:  11% (372/3379)
Updating files:  12% (406/3379)
Updating files:  13% (440/3379)
Updating files:  14% (474/3379)
Updating files:  15% (507/3379)
Updating files:  16% (541/3379)
Updating files:  16% (548/3379)
Updating files:  17% (575/3379)
Updating files:  18% (609/3379)
Updating files:  19% (643/3379)
Updating files:  20% (676/3379)
Updating files:  21% (710/3379)
Updating files:  22% (744/3379)
Updating files:  23% (778/3379)
Updating files:  24% (811/3379)
Updating files:  25% (845/3379)
Updating files:  26% (879/3379)
Updating files:  27% (913/3379)
Updating files:  28% (947/3379)
Updating files:  29% (980/3379)
Updating files:  30% (1014/3379)
Updating files:  31% (1048/3379)
Updating files:  31% (1057/3379)
Updating files:  32% (1082/3379)
Updating files:  33% (1116/3379)
Updating files:  34% (1149/3379)
Updating files:  35% (1183/3379)
Updating files:  36% (1217/3379)
Updating files:  37% (1251/3379)
Updating files:  38% (1285/3379)
Updating files:  39% (1318/3379)
Updating files:  40% (1352/3379)
Updating files:  41% (1386/3379)
Updating files:  42% (1420/3379)
Updating files:  43% (1453/3379)
Updating files:  44% (1487/3379)
Updating files:  45% (1521/3379)
Updating files:  46% (1555/3379)
Updating files:  47% (1589/3379)
Updating files:  48% (1622/3379)
Updating files:  49% (1656/3379)
Updating files:  50% (1690/3379)
Updating files:  51% (1724/3379)
Updating files:  52% (1758/3379)
Updating files:  53% (1791/3379)
Updating files:  54% (1825/3379)
Updating files:  55% (1859/3379)
Updating files:  56% (1893/3379)
Updating files:  57% (1927/3379)
Updating files:  58% (1960/3379)
Updating files:  59% (1994/3379)
Updating files:  60% (2028/3379)
Updating files:  61% (2062/3379)
Updating files:  62% (2095/3379)
Updating files:  63% (2129/3379)
Updating files:  64% (2163/3379)
Updating files:  65% (2197/3379)
Updating files:  66% (2231/3379)
Updating files:  67% (2264/3379)
Updating files:  68% (2298/3379)
Updating files:  69% (2332/3379)
Updating files:  70% (2366/3379)
Updating files:  71% (2400/3379)
Updating files:  72% (2433/3379)
Updating files:  73% (2467/3379)
Updating files:  74% (2501/3379)
Updating files:  75% (2535/3379)
Updating files:  76% (2569/3379)
Updating files:  77% (2602/3379)
Updating files:  78% (2636/3379)
Updating files:  79% (2670/3379)
Updating files:  79% (2691/3379)
Updating files:  80% (2704/3379)
Updating files:  81% (2737/3379)
Updating files:  82% (2771/3379)
Updating files:  83% (2805/3379)
Updating files:  84% (2839/3379)
Updating files:  85% (2873/3379)
Updating files:  86% (2906/3379)
Updating files:  87% (2940/3379)
Updating files:  87% (2944/3379)
Updating files:  88% (2974/3379)
Updating files:  89% (3008/3379)
Updating files:  90% (3042/3379)
Updating files:  91% (3075/3379)
Updating files:  91% (3084/3379)
Updating files:  92% (3109/3379)
Updating files:  92% (3123/3379)
Updating files:  93% (3143/3379)
Updating files:  93% (3167/3379)
Updating files:  94% (3177/3379)
Updating files:  95% (3211/3379)
Updating files:  96% (3244/3379)
Updating files:  97% (3278/3379)
Updating files:  98% (3312/3379)
Updating files:  99% (3346/3379)
Updating files: 100% (3379/3379)
Updating files: 100% (3379/3379), done.
[INFO] started tweaking git repo https://github.com/MrMisc/Outbreak_CIC-Model
[INFO] finished tweaking git repo https://github.com/MrMisc/Outbreak_CIC-Model
[INFO] tweaked toml for git repo https://github.com/MrMisc/Outbreak_CIC-Model written to /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/MrMisc/Outbreak_CIC-Model on toolchain bca37a20bd376ce3fd138e7cdee7fe704e0f8814
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+bca37a20bd376ce3fd138e7cdee7fe704e0f8814" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/MrMisc/Outbreak_CIC-Model 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" "+bca37a20bd376ce3fd138e7cdee7fe704e0f8814" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded matrixmultiply v0.3.8
[INFO] [stderr]   Downloaded num-complex v0.4.4
[INFO] [stderr]   Downloaded serde_derive v1.0.189
[INFO] [stderr]   Downloaded serde v1.0.189
[INFO] [stderr]   Downloaded serde_json v1.0.107
[INFO] [stderr]   Downloaded statrs v0.16.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bca37a20bd376ce3fd138e7cdee7fe704e0f8814" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] c498868ef9429e89e42ecf4a7f83001a832c37b3e8f2ccaf8798eb59986d7aab
[INFO] running `Command { std: "docker" "start" "-a" "c498868ef9429e89e42ecf4a7f83001a832c37b3e8f2ccaf8798eb59986d7aab", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "c498868ef9429e89e42ecf4a7f83001a832c37b3e8f2ccaf8798eb59986d7aab", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c498868ef9429e89e42ecf4a7f83001a832c37b3e8f2ccaf8798eb59986d7aab", kill_on_drop: false }`
[INFO] [stdout] c498868ef9429e89e42ecf4a7f83001a832c37b3e8f2ccaf8798eb59986d7aab
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-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:aa71247004a7fa38d13ec170f48f06cdedf5bc50b2a8645e56ed7e992e6fa513" "/opt/rustwide/cargo-home/bin/cargo" "+bca37a20bd376ce3fd138e7cdee7fe704e0f8814" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] a4c978ebeb238d3e7f43a204147bc30c6a345491fd09df9158703924b1784f72
[INFO] running `Command { std: "docker" "start" "-a" "a4c978ebeb238d3e7f43a204147bc30c6a345491fd09df9158703924b1784f72", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.69
[INFO] [stderr]    Compiling num-traits v0.2.17
[INFO] [stderr]    Compiling libc v0.2.149
[INFO] [stderr]    Compiling num-integer v0.1.45
[INFO] [stderr]     Checking bytemuck v1.14.0
[INFO] [stderr]    Compiling num-rational v0.4.1
[INFO] [stderr]    Compiling matrixmultiply v0.3.8
[INFO] [stderr]    Compiling serde v1.0.189
[INFO] [stderr]    Compiling serde_json v1.0.107
[INFO] [stderr]     Checking memchr v2.6.4
[INFO] [stderr]     Checking safe_arch v0.7.1
[INFO] [stderr]     Checking wide v0.7.13
[INFO] [stderr]     Checking getrandom v0.2.10
[INFO] [stderr]    Compiling quote v1.0.33
[INFO] [stderr]     Checking csv-core v0.1.11
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]    Compiling syn v2.0.38
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking approx v0.5.1
[INFO] [stderr]     Checking num-complex v0.4.4
[INFO] [stderr]     Checking rand_distr v0.4.3
[INFO] [stderr]     Checking simba v0.6.0
[INFO] [stderr]    Compiling serde_derive v1.0.189
[INFO] [stderr]    Compiling nalgebra-macros v0.1.0
[INFO] [stderr]     Checking nalgebra v0.29.0
[INFO] [stderr]     Checking csv v1.3.0
[INFO] [stderr]     Checking statrs v0.16.0
[INFO] [stderr]     Checking Outbreak_CIC v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `Standard`
[INFO] [stdout]  --> src/main.rs:3:41
[INFO] [stdout]   |
[INFO] [stdout] 3 | use rand::distributions::{Distribution, Standard};
[INFO] [stdout]   |                                         ^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `StudentsT`, `Triangular`, and `Weibull`
[INFO] [stdout]  --> src/main.rs:6:52
[INFO] [stdout]   |
[INFO] [stdout] 6 | use statrs::distribution::{Gamma, Normal, Poisson, StudentsT, Triangular, Weibull};
[INFO] [stdout]   |                                                    ^^^^^^^^^  ^^^^^^^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `io` and `process`
[INFO] [stdout]   --> src/main.rs:22:15
[INFO] [stdout]    |
[INFO] [stdout] 22 | use std::{fs, io, process};
[INFO] [stdout]    |               ^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `Zone_3D` should have an upper camel case name
[INFO] [stdout]    --> src/main.rs:114:12
[INFO] [stdout]     |
[INFO] [stdout] 114 | pub struct Zone_3D {
[INFO] [stdout]     |            ^^^^^^^ help: convert the identifier to upper camel case: `Zone3d`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `Segment_3D` should have an upper camel case name
[INFO] [stdout]    --> src/main.rs:122:12
[INFO] [stdout]     |
[INFO] [stdout] 122 | pub struct Segment_3D {
[INFO] [stdout]     |            ^^^^^^^^^^ help: convert the identifier to upper camel case: `Segment3d`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around function argument
[INFO] [stdout]    --> src/main.rs:526:29
[INFO] [stdout]     |
[INFO] [stdout] 526 | ...                   ((internal_index - start_index) as f64 / (step_size as f64) * PI),
[INFO] [stdout]     |                       ^                                                               ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 526 -                             ((internal_index - start_index) as f64 / (step_size as f64) * PI),
[INFO] [stdout] 526 +                             (internal_index - start_index) as f64 / (step_size as f64) * PI,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around function argument
[INFO] [stdout]    --> src/main.rs:537:29
[INFO] [stdout]     |
[INFO] [stdout] 537 | ...                   ((end_index - internal_index) as f64 / (step_size as f64) * PI),
[INFO] [stdout]     |                       ^                                                             ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 537 -                             ((end_index - internal_index) as f64 / (step_size as f64) * PI),
[INFO] [stdout] 537 +                             (end_index - internal_index) as f64 / (step_size as f64) * PI,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `host` should have an upper camel case name
[INFO] [stdout]    --> src/main.rs:661:12
[INFO] [stdout]     |
[INFO] [stdout] 661 | pub struct host {
[INFO] [stdout]     |            ^^^^ help: convert the identifier to upper camel case: `Host`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around closure body
[INFO] [stdout]     --> src/main.rs:1744:29
[INFO] [stdout]      |
[INFO] [stdout] 1744 |                 .filter(|x| ((!x.colonized && x.motile == 0) || (!x.infected && x.motile != 0)))
[INFO] [stdout]      |                             ^                                                                 ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1744 -                 .filter(|x| ((!x.colonized && x.motile == 0) || (!x.infected && x.motile != 0)))
[INFO] [stdout] 1744 +                 .filter(|x| (!x.colonized && x.motile == 0) || (!x.infected && x.motile != 0))
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]     --> src/main.rs:1818:36
[INFO] [stdout]      |
[INFO] [stdout] 1818 |             .filter_map(|mut x| if (x.contaminated) { Some(x) } else { None })
[INFO] [stdout]      |                                    ^              ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1818 -             .filter_map(|mut x| if (x.contaminated) { Some(x) } else { None })
[INFO] [stdout] 1818 +             .filter_map(|mut x| if x.contaminated { Some(x) } else { None })
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]     --> src/main.rs:1841:58
[INFO] [stdout]      |
[INFO] [stdout] 1841 |                     let hosttohost_contact_rules: bool = (HOSTTOHOST_CONTACT_SPREAD
[INFO] [stdout]      |                                                          ^
[INFO] [stdout] 1842 |                         || !HOSTTOHOST_CONTACT_SPREAD && !(inf.motile == 0 && x.motile == 0));
[INFO] [stdout]      |                                                                                             ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1841 ~                     let hosttohost_contact_rules: bool = HOSTTOHOST_CONTACT_SPREAD
[INFO] [stdout] 1842 ~                         || !HOSTTOHOST_CONTACT_SPREAD && !(inf.motile == 0 && x.motile == 0);
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]     --> src/main.rs:1843:57
[INFO] [stdout]      |
[INFO] [stdout] 1843 |                     let hosttoegg_contact_rules: bool = (HOSTTOEGG_CONTACT_SPREAD
[INFO] [stdout]      |                                                         ^
[INFO] [stdout] 1844 |                         || (!HOSTTOEGG_CONTACT_SPREAD && !(inf.motile == 0 && x.motile == 1)));
[INFO] [stdout]      |                                                                                              ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1843 ~                     let hosttoegg_contact_rules: bool = HOSTTOEGG_CONTACT_SPREAD
[INFO] [stdout] 1844 ~                         || (!HOSTTOEGG_CONTACT_SPREAD && !(inf.motile == 0 && x.motile == 1));
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]     --> src/main.rs:1845:60
[INFO] [stdout]      |
[INFO] [stdout] 1845 |                     let hosttofaeces_contact_rules: bool = (HOSTTOFAECES_CONTACT_SPREAD
[INFO] [stdout]      |                                                            ^
[INFO] [stdout] 1846 |                         || !HOSTTOFAECES_CONTACT_SPREAD && !(inf.motile == 0 && x.motile == 2));
[INFO] [stdout]      |                                                                                               ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1845 ~                     let hosttofaeces_contact_rules: bool = HOSTTOFAECES_CONTACT_SPREAD
[INFO] [stdout] 1846 ~                         || !HOSTTOFAECES_CONTACT_SPREAD && !(inf.motile == 0 && x.motile == 2);
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]     --> src/main.rs:1847:57
[INFO] [stdout]      |
[INFO] [stdout] 1847 |                     let eggtohost_contact_rules: bool = (EGGTOHOST_CONTACT_SPREAD
[INFO] [stdout]      |                                                         ^
[INFO] [stdout] 1848 |                         || !EGGTOHOST_CONTACT_SPREAD && !(inf.motile == 1 && x.motile == 0));
[INFO] [stdout]      |                                                                                            ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1847 ~                     let eggtohost_contact_rules: bool = EGGTOHOST_CONTACT_SPREAD
[INFO] [stdout] 1848 ~                         || !EGGTOHOST_CONTACT_SPREAD && !(inf.motile == 1 && x.motile == 0);
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]     --> src/main.rs:1849:60
[INFO] [stdout]      |
[INFO] [stdout] 1849 |                     let faecestohost_contact_rules: bool = (FAECESTOHOST_CONTACT_SPREAD
[INFO] [stdout]      |                                                            ^
[INFO] [stdout] 1850 |                         || !FAECESTOHOST_CONTACT_SPREAD && !(inf.motile == 2 && x.motile == 0));
[INFO] [stdout]      |                                                                                               ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1849 ~                     let faecestohost_contact_rules: bool = FAECESTOHOST_CONTACT_SPREAD
[INFO] [stdout] 1850 ~                         || !FAECESTOHOST_CONTACT_SPREAD && !(inf.motile == 2 && x.motile == 0);
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]     --> src/main.rs:1851:59
[INFO] [stdout]      |
[INFO] [stdout] 1851 |                     let eggtofaeces_contact_rules: bool = (EGGTOFAECES_CONTACT_SPREAD
[INFO] [stdout]      |                                                           ^
[INFO] [stdout] 1852 |                         || !EGGTOFAECES_CONTACT_SPREAD && !(inf.motile == 1 && x.motile == 2));
[INFO] [stdout]      |                                                                                              ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1851 ~                     let eggtofaeces_contact_rules: bool = EGGTOFAECES_CONTACT_SPREAD
[INFO] [stdout] 1852 ~                         || !EGGTOFAECES_CONTACT_SPREAD && !(inf.motile == 1 && x.motile == 2);
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]     --> src/main.rs:1853:59
[INFO] [stdout]      |
[INFO] [stdout] 1853 |                     let faecestoegg_contact_rules: bool = (FAECESTOEGG_CONTACT_SPREAD
[INFO] [stdout]      |                                                           ^
[INFO] [stdout] 1854 |                         || !FAECESTOEGG_CONTACT_SPREAD && !(inf.motile == 2 && x.motile == 1));
[INFO] [stdout]      |                                                                                              ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1853 ~                     let faecestoegg_contact_rules: bool = FAECESTOEGG_CONTACT_SPREAD
[INFO] [stdout] 1854 ~                         || !FAECESTOEGG_CONTACT_SPREAD && !(inf.motile == 2 && x.motile == 1);
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Standard`
[INFO] [stdout]  --> src/main.rs:3:41
[INFO] [stdout]   |
[INFO] [stdout] 3 | use rand::distributions::{Distribution, Standard};
[INFO] [stdout]   |                                         ^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `StudentsT`, `Triangular`, and `Weibull`
[INFO] [stdout]  --> src/main.rs:6:52
[INFO] [stdout]   |
[INFO] [stdout] 6 | use statrs::distribution::{Gamma, Normal, Poisson, StudentsT, Triangular, Weibull};
[INFO] [stdout]   |                                                    ^^^^^^^^^  ^^^^^^^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `io` and `process`
[INFO] [stdout]   --> src/main.rs:22:15
[INFO] [stdout]    |
[INFO] [stdout] 22 | use std::{fs, io, process};
[INFO] [stdout]    |               ^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `Zone_3D` should have an upper camel case name
[INFO] [stdout]    --> src/main.rs:114:12
[INFO] [stdout]     |
[INFO] [stdout] 114 | pub struct Zone_3D {
[INFO] [stdout]     |            ^^^^^^^ help: convert the identifier to upper camel case: `Zone3d`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `Segment_3D` should have an upper camel case name
[INFO] [stdout]    --> src/main.rs:122:12
[INFO] [stdout]     |
[INFO] [stdout] 122 | pub struct Segment_3D {
[INFO] [stdout]     |            ^^^^^^^^^^ help: convert the identifier to upper camel case: `Segment3d`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around function argument
[INFO] [stdout]    --> src/main.rs:526:29
[INFO] [stdout]     |
[INFO] [stdout] 526 | ...                   ((internal_index - start_index) as f64 / (step_size as f64) * PI),
[INFO] [stdout]     |                       ^                                                               ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 526 -                             ((internal_index - start_index) as f64 / (step_size as f64) * PI),
[INFO] [stdout] 526 +                             (internal_index - start_index) as f64 / (step_size as f64) * PI,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around function argument
[INFO] [stdout]    --> src/main.rs:537:29
[INFO] [stdout]     |
[INFO] [stdout] 537 | ...                   ((end_index - internal_index) as f64 / (step_size as f64) * PI),
[INFO] [stdout]     |                       ^                                                             ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 537 -                             ((end_index - internal_index) as f64 / (step_size as f64) * PI),
[INFO] [stdout] 537 +                             (end_index - internal_index) as f64 / (step_size as f64) * PI,
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `host` should have an upper camel case name
[INFO] [stdout]    --> src/main.rs:661:12
[INFO] [stdout]     |
[INFO] [stdout] 661 | pub struct host {
[INFO] [stdout]     |            ^^^^ help: convert the identifier to upper camel case: `Host`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around closure body
[INFO] [stdout]     --> src/main.rs:1744:29
[INFO] [stdout]      |
[INFO] [stdout] 1744 |                 .filter(|x| ((!x.colonized && x.motile == 0) || (!x.infected && x.motile != 0)))
[INFO] [stdout]      |                             ^                                                                 ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1744 -                 .filter(|x| ((!x.colonized && x.motile == 0) || (!x.infected && x.motile != 0)))
[INFO] [stdout] 1744 +                 .filter(|x| (!x.colonized && x.motile == 0) || (!x.infected && x.motile != 0))
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]     --> src/main.rs:1818:36
[INFO] [stdout]      |
[INFO] [stdout] 1818 |             .filter_map(|mut x| if (x.contaminated) { Some(x) } else { None })
[INFO] [stdout]      |                                    ^              ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1818 -             .filter_map(|mut x| if (x.contaminated) { Some(x) } else { None })
[INFO] [stdout] 1818 +             .filter_map(|mut x| if x.contaminated { Some(x) } else { None })
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]     --> src/main.rs:1841:58
[INFO] [stdout]      |
[INFO] [stdout] 1841 |                     let hosttohost_contact_rules: bool = (HOSTTOHOST_CONTACT_SPREAD
[INFO] [stdout]      |                                                          ^
[INFO] [stdout] 1842 |                         || !HOSTTOHOST_CONTACT_SPREAD && !(inf.motile == 0 && x.motile == 0));
[INFO] [stdout]      |                                                                                             ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1841 ~                     let hosttohost_contact_rules: bool = HOSTTOHOST_CONTACT_SPREAD
[INFO] [stdout] 1842 ~                         || !HOSTTOHOST_CONTACT_SPREAD && !(inf.motile == 0 && x.motile == 0);
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]     --> src/main.rs:1843:57
[INFO] [stdout]      |
[INFO] [stdout] 1843 |                     let hosttoegg_contact_rules: bool = (HOSTTOEGG_CONTACT_SPREAD
[INFO] [stdout]      |                                                         ^
[INFO] [stdout] 1844 |                         || (!HOSTTOEGG_CONTACT_SPREAD && !(inf.motile == 0 && x.motile == 1)));
[INFO] [stdout]      |                                                                                              ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1843 ~                     let hosttoegg_contact_rules: bool = HOSTTOEGG_CONTACT_SPREAD
[INFO] [stdout] 1844 ~                         || (!HOSTTOEGG_CONTACT_SPREAD && !(inf.motile == 0 && x.motile == 1));
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]     --> src/main.rs:1845:60
[INFO] [stdout]      |
[INFO] [stdout] 1845 |                     let hosttofaeces_contact_rules: bool = (HOSTTOFAECES_CONTACT_SPREAD
[INFO] [stdout]      |                                                            ^
[INFO] [stdout] 1846 |                         || !HOSTTOFAECES_CONTACT_SPREAD && !(inf.motile == 0 && x.motile == 2));
[INFO] [stdout]      |                                                                                               ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1845 ~                     let hosttofaeces_contact_rules: bool = HOSTTOFAECES_CONTACT_SPREAD
[INFO] [stdout] 1846 ~                         || !HOSTTOFAECES_CONTACT_SPREAD && !(inf.motile == 0 && x.motile == 2);
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]     --> src/main.rs:1847:57
[INFO] [stdout]      |
[INFO] [stdout] 1847 |                     let eggtohost_contact_rules: bool = (EGGTOHOST_CONTACT_SPREAD
[INFO] [stdout]      |                                                         ^
[INFO] [stdout] 1848 |                         || !EGGTOHOST_CONTACT_SPREAD && !(inf.motile == 1 && x.motile == 0));
[INFO] [stdout]      |                                                                                            ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1847 ~                     let eggtohost_contact_rules: bool = EGGTOHOST_CONTACT_SPREAD
[INFO] [stdout] 1848 ~                         || !EGGTOHOST_CONTACT_SPREAD && !(inf.motile == 1 && x.motile == 0);
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]     --> src/main.rs:1849:60
[INFO] [stdout]      |
[INFO] [stdout] 1849 |                     let faecestohost_contact_rules: bool = (FAECESTOHOST_CONTACT_SPREAD
[INFO] [stdout]      |                                                            ^
[INFO] [stdout] 1850 |                         || !FAECESTOHOST_CONTACT_SPREAD && !(inf.motile == 2 && x.motile == 0));
[INFO] [stdout]      |                                                                                               ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1849 ~                     let faecestohost_contact_rules: bool = FAECESTOHOST_CONTACT_SPREAD
[INFO] [stdout] 1850 ~                         || !FAECESTOHOST_CONTACT_SPREAD && !(inf.motile == 2 && x.motile == 0);
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]     --> src/main.rs:1851:59
[INFO] [stdout]      |
[INFO] [stdout] 1851 |                     let eggtofaeces_contact_rules: bool = (EGGTOFAECES_CONTACT_SPREAD
[INFO] [stdout]      |                                                           ^
[INFO] [stdout] 1852 |                         || !EGGTOFAECES_CONTACT_SPREAD && !(inf.motile == 1 && x.motile == 2));
[INFO] [stdout]      |                                                                                              ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1851 ~                     let eggtofaeces_contact_rules: bool = EGGTOFAECES_CONTACT_SPREAD
[INFO] [stdout] 1852 ~                         || !EGGTOFAECES_CONTACT_SPREAD && !(inf.motile == 1 && x.motile == 2);
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]     --> src/main.rs:1853:59
[INFO] [stdout]      |
[INFO] [stdout] 1853 |                     let faecestoegg_contact_rules: bool = (FAECESTOEGG_CONTACT_SPREAD
[INFO] [stdout]      |                                                           ^
[INFO] [stdout] 1854 |                         || !FAECESTOEGG_CONTACT_SPREAD && !(inf.motile == 2 && x.motile == 1));
[INFO] [stdout]      |                                                                                              ^
[INFO] [stdout]      |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]      |
[INFO] [stdout] 1853 ~                     let faecestoegg_contact_rules: bool = FAECESTOEGG_CONTACT_SPREAD
[INFO] [stdout] 1854 ~                         || !FAECESTOEGG_CONTACT_SPREAD && !(inf.motile == 2 && x.motile == 1);
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::prelude::SliceRandom`
[INFO] [stdout]  --> src/main.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use rand::prelude::SliceRandom;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `thing` is never read
[INFO] [stdout]   --> src/main.rs:54:26
[INFO] [stdout]    |
[INFO] [stdout] 54 |     let mut thing: f64 = 0.0;
[INFO] [stdout]    |                          ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout]    = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `thing` is never read
[INFO] [stdout]   --> src/main.rs:72:26
[INFO] [stdout]    |
[INFO] [stdout] 72 |     let mut thing: f64 = 0.0;
[INFO] [stdout]    |                          ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:135:61
[INFO] [stdout]     |
[INFO] [stdout] 135 |     fn generate(&mut self, infected: bool, colonized: bool, mut n: u32, mut hosts: &mut Vec<host>) {
[INFO] [stdout]     |                                                             ----^
[INFO] [stdout]     |                                                             |
[INFO] [stdout]     |                                                             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:135:73
[INFO] [stdout]     |
[INFO] [stdout] 135 |     fn generate(&mut self, infected: bool, colonized: bool, mut n: u32, mut hosts: &mut Vec<host>) {
[INFO] [stdout]     |                                                                         ----^^^^^
[INFO] [stdout]     |                                                                         |
[INFO] [stdout]     |                                                                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:224:44
[INFO] [stdout]     |
[INFO] [stdout] 224 |         self.segments.iter_mut().for_each(|mut seg| {
[INFO] [stdout]     |                                            ----^^^
[INFO] [stdout]     |                                            |
[INFO] [stdout]     |                                            help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `counter`
[INFO] [stdout]    --> src/main.rs:342:9
[INFO] [stdout]     |
[INFO] [stdout] 342 |         counter: usize,
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_counter`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::prelude::SliceRandom`
[INFO] [stdout]  --> src/main.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use rand::prelude::SliceRandom;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `thing` is never read
[INFO] [stdout]   --> src/main.rs:54:26
[INFO] [stdout]    |
[INFO] [stdout] 54 |     let mut thing: f64 = 0.0;
[INFO] [stdout]    |                          ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout]    = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `thing` is never read
[INFO] [stdout]   --> src/main.rs:72:26
[INFO] [stdout]    |
[INFO] [stdout] 72 |     let mut thing: f64 = 0.0;
[INFO] [stdout]    |                          ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:488:59
[INFO] [stdout]     |
[INFO] [stdout] 488 |             vector.iter_mut().enumerate().for_each(|(idx, mut host)| {
[INFO] [stdout]     |                                                           ----^^^^
[INFO] [stdout]     |                                                           |
[INFO] [stdout]     |                                                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:135:61
[INFO] [stdout]     |
[INFO] [stdout] 135 |     fn generate(&mut self, infected: bool, colonized: bool, mut n: u32, mut hosts: &mut Vec<host>) {
[INFO] [stdout]     |                                                             ----^
[INFO] [stdout]     |                                                             |
[INFO] [stdout]     |                                                             help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:504:21
[INFO] [stdout]     |
[INFO] [stdout] 504 |                 let mut minima: usize = idx - idx % step_size;
[INFO] [stdout]     |                     ----^^^^^^
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:559:13
[INFO] [stdout]     |
[INFO] [stdout] 559 |         let mut chunk_iter = vector.chunks_exact_mut(step_size);
[INFO] [stdout]     |             ----^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:563:13
[INFO] [stdout]     |
[INFO] [stdout] 563 |         let mut indices_to_infect: Vec<usize> = Vec::new();
[INFO] [stdout]     |             ----^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:611:21
[INFO] [stdout]     |
[INFO] [stdout] 611 |                 let mut eviscerator: &mut Eviscerator = &mut evs[j % step_size];
[INFO] [stdout]     |                     ----^^^^^^^^^^^
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:135:73
[INFO] [stdout]     |
[INFO] [stdout] 135 |     fn generate(&mut self, infected: bool, colonized: bool, mut n: u32, mut hosts: &mut Vec<host>) {
[INFO] [stdout]     |                                                                         ----^^^^^
[INFO] [stdout]     |                                                                         |
[INFO] [stdout]     |                                                                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `set`
[INFO] [stdout]    --> src/main.rs:398:9
[INFO] [stdout]     |
[INFO] [stdout] 398 |         set: usize,
[INFO] [stdout]     |         ^^^ help: if this is intentional, prefix it with an underscore: `_set`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `vector_length`
[INFO] [stdout]    --> src/main.rs:414:13
[INFO] [stdout]     |
[INFO] [stdout] 414 |         let vector_length: usize = vector.len();
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_vector_length`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `no_infected`
[INFO] [stdout]    --> src/main.rs:415:13
[INFO] [stdout]     |
[INFO] [stdout] 415 |         let no_infected: usize = vector
[INFO] [stdout]     |             ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_no_infected`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `no_not_infected`
[INFO] [stdout]    --> src/main.rs:420:13
[INFO] [stdout]     |
[INFO] [stdout] 420 |         let no_not_infected: usize = vector
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_no_not_infected`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `minima`
[INFO] [stdout]    --> src/main.rs:504:21
[INFO] [stdout]     |
[INFO] [stdout] 504 |                 let mut minima: usize = idx - idx % step_size;
[INFO] [stdout]     |                     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_minima`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `indices_to_infect`
[INFO] [stdout]    --> src/main.rs:563:13
[INFO] [stdout]     |
[INFO] [stdout] 563 |         let mut indices_to_infect: Vec<usize> = Vec::new();
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_indices_to_infect`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `index_spacing` is never read
[INFO] [stdout]    --> src/main.rs:453:40
[INFO] [stdout]     |
[INFO] [stdout] 453 |         let mut index_spacing: usize = 0;
[INFO] [stdout]     |                                        ^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `angle_spacing` is never read
[INFO] [stdout]    --> src/main.rs:467:44
[INFO] [stdout]     |
[INFO] [stdout] 467 |             let mut angle_spacing: usize = 0;
[INFO] [stdout]     |                                            ^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `maxima` is never read
[INFO] [stdout]    --> src/main.rs:508:21
[INFO] [stdout]     |
[INFO] [stdout] 508 |                     maxima = vector.len();
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `fail` is never read
[INFO] [stdout]    --> src/main.rs:574:34
[INFO] [stdout]     |
[INFO] [stdout] 574 |             let mut fail: bool = true;
[INFO] [stdout]     |                                  ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:826:37
[INFO] [stdout]     |
[INFO] [stdout] 826 |         vector.iter_mut().for_each(|mut x| {
[INFO] [stdout]     |                                     ----^
[INFO] [stdout]     |                                     |
[INFO] [stdout]     |                                     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:224:44
[INFO] [stdout]     |
[INFO] [stdout] 224 |         self.segments.iter_mut().for_each(|mut seg| {
[INFO] [stdout]     |                                            ----^^^
[INFO] [stdout]     |                                            |
[INFO] [stdout]     |                                            help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:825:16
[INFO] [stdout]     |
[INFO] [stdout] 825 |     fn recover(mut vector: &mut Vec<host>) {
[INFO] [stdout]     |                ----^^^^^^
[INFO] [stdout]     |                |
[INFO] [stdout]     |                help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:854:41
[INFO] [stdout]     |
[INFO] [stdout] 854 |             vector.iter_mut().for_each(|mut h| {
[INFO] [stdout]     |                                         ----^
[INFO] [stdout]     |                                         |
[INFO] [stdout]     |                                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:875:41
[INFO] [stdout]     |
[INFO] [stdout] 875 |             vector.iter_mut().for_each(|mut h| {
[INFO] [stdout]     |                                         ----^
[INFO] [stdout]     |                                         |
[INFO] [stdout]     |                                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:845:9
[INFO] [stdout]     |
[INFO] [stdout] 845 |         mut vector: &mut Vec<host>,
[INFO] [stdout]     |         ----^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `counter`
[INFO] [stdout]    --> src/main.rs:342:9
[INFO] [stdout]     |
[INFO] [stdout] 342 |         counter: usize,
[INFO] [stdout]     |         ^^^^^^^ help: if this is intentional, prefix it with an underscore: `_counter`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1033:45
[INFO] [stdout]      |
[INFO] [stdout] 1033 |                 vector.iter_mut().for_each(|mut x| {
[INFO] [stdout]      |                                             ----^
[INFO] [stdout]      |                                             |
[INFO] [stdout]      |                                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1020:18
[INFO] [stdout]      |
[INFO] [stdout] 1020 |     fn transport(mut vector: &mut Vec<host>, space: &mut Vec<Zone_3D>, influx: bool) {
[INFO] [stdout]      |                  ----^^^^^^
[INFO] [stdout]      |                  |
[INFO] [stdout]      |                  help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1022:13
[INFO] [stdout]      |
[INFO] [stdout] 1022 |         let mut output: Vec<host> = Vec::new();
[INFO] [stdout]      |             ----^^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `std_y`
[INFO] [stdout]     --> src/main.rs:1087:33
[INFO] [stdout]      |
[INFO] [stdout] 1087 | ...                   let std_y: f64 = ((x.range_y as f64) / SPORADICITY) as f64;
[INFO] [stdout]      |                           ^^^^^ help: if this is intentional, prefix it with an underscore: `_std_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `output`
[INFO] [stdout]     --> src/main.rs:1022:13
[INFO] [stdout]      |
[INFO] [stdout] 1022 |         let mut output: Vec<host> = Vec::new();
[INFO] [stdout]      |             ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_output`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `origin_z`
[INFO] [stdout]     --> src/main.rs:1266:13
[INFO] [stdout]      |
[INFO] [stdout] 1266 |         let origin_z = self.origin_z.clone();
[INFO] [stdout]      |             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_origin_z`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:488:59
[INFO] [stdout]     |
[INFO] [stdout] 488 |             vector.iter_mut().enumerate().for_each(|(idx, mut host)| {
[INFO] [stdout]     |                                                           ----^^^^
[INFO] [stdout]     |                                                           |
[INFO] [stdout]     |                                                           help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1357:13
[INFO] [stdout]      |
[INFO] [stdout] 1357 |         let mut vecc_into: Vec<host> = vector
[INFO] [stdout]      |             ----^^^^^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:504:21
[INFO] [stdout]     |
[INFO] [stdout] 504 |                 let mut minima: usize = idx - idx % step_size;
[INFO] [stdout]     |                     ----^^^^^^
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:559:13
[INFO] [stdout]     |
[INFO] [stdout] 559 |         let mut chunk_iter = vector.chunks_exact_mut(step_size);
[INFO] [stdout]     |             ----^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:563:13
[INFO] [stdout]     |
[INFO] [stdout] 563 |         let mut indices_to_infect: Vec<usize> = Vec::new();
[INFO] [stdout]     |             ----^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |             |
[INFO] [stdout]     |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:611:21
[INFO] [stdout]     |
[INFO] [stdout] 611 |                 let mut eviscerator: &mut Eviscerator = &mut evs[j % step_size];
[INFO] [stdout]     |                     ----^^^^^^^^^^^
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `set`
[INFO] [stdout]    --> src/main.rs:398:9
[INFO] [stdout]     |
[INFO] [stdout] 398 |         set: usize,
[INFO] [stdout]     |         ^^^ help: if this is intentional, prefix it with an underscore: `_set`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `vector_length`
[INFO] [stdout]    --> src/main.rs:414:13
[INFO] [stdout]     |
[INFO] [stdout] 414 |         let vector_length: usize = vector.len();
[INFO] [stdout]     |             ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_vector_length`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `no_infected`
[INFO] [stdout]    --> src/main.rs:415:13
[INFO] [stdout]     |
[INFO] [stdout] 415 |         let no_infected: usize = vector
[INFO] [stdout]     |             ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_no_infected`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `no_not_infected`
[INFO] [stdout]    --> src/main.rs:420:13
[INFO] [stdout]     |
[INFO] [stdout] 420 |         let no_not_infected: usize = vector
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_no_not_infected`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `minima`
[INFO] [stdout]    --> src/main.rs:504:21
[INFO] [stdout]     |
[INFO] [stdout] 504 |                 let mut minima: usize = idx - idx % step_size;
[INFO] [stdout]     |                     ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_minima`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `indices_to_infect`
[INFO] [stdout]    --> src/main.rs:563:13
[INFO] [stdout]     |
[INFO] [stdout] 563 |         let mut indices_to_infect: Vec<usize> = Vec::new();
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_indices_to_infect`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `index_spacing` is never read
[INFO] [stdout]    --> src/main.rs:453:40
[INFO] [stdout]     |
[INFO] [stdout] 453 |         let mut index_spacing: usize = 0;
[INFO] [stdout]     |                                        ^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `angle_spacing` is never read
[INFO] [stdout]    --> src/main.rs:467:44
[INFO] [stdout]     |
[INFO] [stdout] 467 |             let mut angle_spacing: usize = 0;
[INFO] [stdout]     |                                            ^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `maxima` is never read
[INFO] [stdout]    --> src/main.rs:508:21
[INFO] [stdout]     |
[INFO] [stdout] 508 |                     maxima = vector.len();
[INFO] [stdout]     |                     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `fail` is never read
[INFO] [stdout]    --> src/main.rs:574:34
[INFO] [stdout]     |
[INFO] [stdout] 574 |             let mut fail: bool = true;
[INFO] [stdout]     |                                  ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `new_z` is assigned to, but never used
[INFO] [stdout]     --> src/main.rs:1456:17
[INFO] [stdout]      |
[INFO] [stdout] 1456 |             let mut new_z: f64 = self.z.clone() as f64;
[INFO] [stdout]      |                 ^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: consider using `_new_z` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `new_x` is never read
[INFO] [stdout]     --> src/main.rs:1454:34
[INFO] [stdout]      |
[INFO] [stdout] 1454 |             let mut new_x: f64 = self.x.clone() as f64;
[INFO] [stdout]      |                                  ^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:826:37
[INFO] [stdout]     |
[INFO] [stdout] 826 |         vector.iter_mut().for_each(|mut x| {
[INFO] [stdout]     |                                     ----^
[INFO] [stdout]     |                                     |
[INFO] [stdout]     |                                     help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `new_z` is never read
[INFO] [stdout]     --> src/main.rs:1604:21
[INFO] [stdout]      |
[INFO] [stdout] 1604 |                     new_z = self.origin_z as f64;
[INFO] [stdout]      |                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:825:16
[INFO] [stdout]     |
[INFO] [stdout] 825 |     fn recover(mut vector: &mut Vec<host>) {
[INFO] [stdout]     |                ----^^^^^^
[INFO] [stdout]     |                |
[INFO] [stdout]     |                help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `new_z` is never read
[INFO] [stdout]     --> src/main.rs:1594:21
[INFO] [stdout]      |
[INFO] [stdout] 1594 | /                     new_z = limits::min(
[INFO] [stdout] 1595 | |                         self.z + PERCH_HEIGHT,
[INFO] [stdout] 1596 | |                         self.origin_z as f64 + self.range_z as f64,
[INFO] [stdout] 1597 | |                     );
[INFO] [stdout]      | |_____________________^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `new_z` is never read
[INFO] [stdout]     --> src/main.rs:1585:21
[INFO] [stdout]      |
[INFO] [stdout] 1585 | /                     new_z = limits::min(
[INFO] [stdout] 1586 | |                         limits::max(
[INFO] [stdout] 1587 | |                             0.0,
[INFO] [stdout] 1588 | |                             self.z + mult[2] * normal(MEAN_MOVE_Z, STD_MOVE_Z, MAX_MOVE_Z),
[INFO] [stdout] 1589 | |                         ),
[INFO] [stdout] 1590 | |                         GRIDSIZE[self.zone as usize][2],
[INFO] [stdout] 1591 | |                     );
[INFO] [stdout]      | |_____________________^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `new_z` is never read
[INFO] [stdout]     --> src/main.rs:1531:21
[INFO] [stdout]      |
[INFO] [stdout] 1531 |                     new_z = self.origin_z as f64;
[INFO] [stdout]      |                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `new_z` is never read
[INFO] [stdout]     --> src/main.rs:1521:21
[INFO] [stdout]      |
[INFO] [stdout] 1521 | /                     new_z = limits::min(
[INFO] [stdout] 1522 | |                         self.z + PERCH_HEIGHT,
[INFO] [stdout] 1523 | |                         self.origin_z as f64 + self.range_z as f64,
[INFO] [stdout] 1524 | |                     );
[INFO] [stdout]      | |_____________________^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `new_z` is never read
[INFO] [stdout]     --> src/main.rs:1512:21
[INFO] [stdout]      |
[INFO] [stdout] 1512 | /                     new_z = limits::min(
[INFO] [stdout] 1513 | |                         limits::max(
[INFO] [stdout] 1514 | |                             self.origin_z as f64,
[INFO] [stdout] 1515 | |                             self.z + mult[2] * normal(MEAN_MOVE_Z, STD_MOVE_Z, MAX_MOVE_Z),
[INFO] [stdout] 1516 | |                         ),
[INFO] [stdout] 1517 | |                         self.origin_z as f64 + self.range_z as f64,
[INFO] [stdout] 1518 | |                     );
[INFO] [stdout]      | |_____________________^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1729:26
[INFO] [stdout]      |
[INFO] [stdout] 1729 |             .filter_map(|mut x| {
[INFO] [stdout]      |                          ----^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:854:41
[INFO] [stdout]     |
[INFO] [stdout] 854 |             vector.iter_mut().for_each(|mut h| {
[INFO] [stdout]     |                                         ----^
[INFO] [stdout]     |                                         |
[INFO] [stdout]     |                                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:875:41
[INFO] [stdout]     |
[INFO] [stdout] 875 |             vector.iter_mut().for_each(|mut h| {
[INFO] [stdout]     |                                         ----^
[INFO] [stdout]     |                                         |
[INFO] [stdout]     |                                         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/main.rs:845:9
[INFO] [stdout]     |
[INFO] [stdout] 845 |         mut vector: &mut Vec<host>,
[INFO] [stdout]     |         ----^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1818:26
[INFO] [stdout]      |
[INFO] [stdout] 1818 |             .filter_map(|mut x| if (x.contaminated) { Some(x) } else { None })
[INFO] [stdout]      |                          ----^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1928:26
[INFO] [stdout]      |
[INFO] [stdout] 1928 |             .filter_map(|mut x| {
[INFO] [stdout]      |                          ----^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1950:26
[INFO] [stdout]      |
[INFO] [stdout] 1950 |             .filter_map(|mut x| {
[INFO] [stdout]      |                          ----^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1977:26
[INFO] [stdout]      |
[INFO] [stdout] 1977 |             .filter_map(|mut x| {
[INFO] [stdout]      |                          ----^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1033:45
[INFO] [stdout]      |
[INFO] [stdout] 1033 |                 vector.iter_mut().for_each(|mut x| {
[INFO] [stdout]      |                                             ----^
[INFO] [stdout]      |                                             |
[INFO] [stdout]      |                                             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1020:18
[INFO] [stdout]      |
[INFO] [stdout] 1020 |     fn transport(mut vector: &mut Vec<host>, space: &mut Vec<Zone_3D>, influx: bool) {
[INFO] [stdout]      |                  ----^^^^^^
[INFO] [stdout]      |                  |
[INFO] [stdout]      |                  help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1022:13
[INFO] [stdout]      |
[INFO] [stdout] 1022 |         let mut output: Vec<host> = Vec::new();
[INFO] [stdout]      |             ----^^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `std_y`
[INFO] [stdout]     --> src/main.rs:1087:33
[INFO] [stdout]      |
[INFO] [stdout] 1087 | ...                   let std_y: f64 = ((x.range_y as f64) / SPORADICITY) as f64;
[INFO] [stdout]      |                           ^^^^^ help: if this is intentional, prefix it with an underscore: `_std_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `output`
[INFO] [stdout]     --> src/main.rs:1022:13
[INFO] [stdout]      |
[INFO] [stdout] 1022 |         let mut output: Vec<host> = Vec::new();
[INFO] [stdout]      |             ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_output`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `origin_z`
[INFO] [stdout]     --> src/main.rs:1266:13
[INFO] [stdout]      |
[INFO] [stdout] 1266 |         let origin_z = self.origin_z.clone();
[INFO] [stdout]      |             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_origin_z`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:2057:13
[INFO] [stdout]      |
[INFO] [stdout] 2057 |         let mut inventory: Vec<host> = inventory
[INFO] [stdout]      |             ----^^^^^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:2132:44
[INFO] [stdout]      |
[INFO] [stdout] 2132 |         zone.segments.iter_mut().for_each(|mut x| {
[INFO] [stdout]      |                                            ----^
[INFO] [stdout]      |                                            |
[INFO] [stdout]      |                                            help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1357:13
[INFO] [stdout]      |
[INFO] [stdout] 1357 |         let mut vecc_into: Vec<host> = vector
[INFO] [stdout]      |             ----^^^^^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `new_z` is assigned to, but never used
[INFO] [stdout]     --> src/main.rs:1456:17
[INFO] [stdout]      |
[INFO] [stdout] 1456 |             let mut new_z: f64 = self.z.clone() as f64;
[INFO] [stdout]      |                 ^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: consider using `_new_z` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `new_x` is never read
[INFO] [stdout]     --> src/main.rs:1454:34
[INFO] [stdout]      |
[INFO] [stdout] 1454 |             let mut new_x: f64 = self.x.clone() as f64;
[INFO] [stdout]      |                                  ^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `new_z` is never read
[INFO] [stdout]     --> src/main.rs:1604:21
[INFO] [stdout]      |
[INFO] [stdout] 1604 |                     new_z = self.origin_z as f64;
[INFO] [stdout]      |                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `new_z` is never read
[INFO] [stdout]     --> src/main.rs:1594:21
[INFO] [stdout]      |
[INFO] [stdout] 1594 | /                     new_z = limits::min(
[INFO] [stdout] 1595 | |                         self.z + PERCH_HEIGHT,
[INFO] [stdout] 1596 | |                         self.origin_z as f64 + self.range_z as f64,
[INFO] [stdout] 1597 | |                     );
[INFO] [stdout]      | |_____________________^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `new_z` is never read
[INFO] [stdout]     --> src/main.rs:1585:21
[INFO] [stdout]      |
[INFO] [stdout] 1585 | /                     new_z = limits::min(
[INFO] [stdout] 1586 | |                         limits::max(
[INFO] [stdout] 1587 | |                             0.0,
[INFO] [stdout] 1588 | |                             self.z + mult[2] * normal(MEAN_MOVE_Z, STD_MOVE_Z, MAX_MOVE_Z),
[INFO] [stdout] 1589 | |                         ),
[INFO] [stdout] 1590 | |                         GRIDSIZE[self.zone as usize][2],
[INFO] [stdout] 1591 | |                     );
[INFO] [stdout]      | |_____________________^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `new_z` is never read
[INFO] [stdout]     --> src/main.rs:1531:21
[INFO] [stdout]      |
[INFO] [stdout] 1531 |                     new_z = self.origin_z as f64;
[INFO] [stdout]      |                     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `new_z` is never read
[INFO] [stdout]     --> src/main.rs:1521:21
[INFO] [stdout]      |
[INFO] [stdout] 1521 | /                     new_z = limits::min(
[INFO] [stdout] 1522 | |                         self.z + PERCH_HEIGHT,
[INFO] [stdout] 1523 | |                         self.origin_z as f64 + self.range_z as f64,
[INFO] [stdout] 1524 | |                     );
[INFO] [stdout]      | |_____________________^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `new_z` is never read
[INFO] [stdout]     --> src/main.rs:1512:21
[INFO] [stdout]      |
[INFO] [stdout] 1512 | /                     new_z = limits::min(
[INFO] [stdout] 1513 | |                         limits::max(
[INFO] [stdout] 1514 | |                             self.origin_z as f64,
[INFO] [stdout] 1515 | |                             self.z + mult[2] * normal(MEAN_MOVE_Z, STD_MOVE_Z, MAX_MOVE_Z),
[INFO] [stdout] 1516 | |                         ),
[INFO] [stdout] 1517 | |                         self.origin_z as f64 + self.range_z as f64,
[INFO] [stdout] 1518 | |                     );
[INFO] [stdout]      | |_____________________^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1729:26
[INFO] [stdout]      |
[INFO] [stdout] 1729 |             .filter_map(|mut x| {
[INFO] [stdout]      |                          ----^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1818:26
[INFO] [stdout]      |
[INFO] [stdout] 1818 |             .filter_map(|mut x| if (x.contaminated) { Some(x) } else { None })
[INFO] [stdout]      |                          ----^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1928:26
[INFO] [stdout]      |
[INFO] [stdout] 1928 |             .filter_map(|mut x| {
[INFO] [stdout]      |                          ----^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:2295:47
[INFO] [stdout]      |
[INFO] [stdout] 2295 |             eviscerators.iter_mut().for_each(|mut ev| {
[INFO] [stdout]      |                                               ----^^
[INFO] [stdout]      |                                               |
[INFO] [stdout]      |                                               help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1950:26
[INFO] [stdout]      |
[INFO] [stdout] 1950 |             .filter_map(|mut x| {
[INFO] [stdout]      |                          ----^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:1977:26
[INFO] [stdout]      |
[INFO] [stdout] 1977 |             .filter_map(|mut x| {
[INFO] [stdout]      |                          ----^
[INFO] [stdout]      |                          |
[INFO] [stdout]      |                          help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:2057:13
[INFO] [stdout]      |
[INFO] [stdout] 2057 |         let mut inventory: Vec<host> = inventory
[INFO] [stdout]      |             ----^^^^^^^^^
[INFO] [stdout]      |             |
[INFO] [stdout]      |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:2132:44
[INFO] [stdout]      |
[INFO] [stdout] 2132 |         zone.segments.iter_mut().for_each(|mut x| {
[INFO] [stdout]      |                                            ----^
[INFO] [stdout]      |                                            |
[INFO] [stdout]      |                                            help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:2270:9
[INFO] [stdout]      |
[INFO] [stdout] 2270 |     let mut file = OpenOptions::new()
[INFO] [stdout]      |         ----^^^^
[INFO] [stdout]      |         |
[INFO] [stdout]      |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:2426:54
[INFO] [stdout]      |
[INFO] [stdout] 2426 |             let [mut perc_cont, mut perc, mut perc2, mut total_hosts, mut total_hosts2, mut perc3, mut perc4, mut total_hosts4] =
[INFO] [stdout]      |                                                      ----^^^^^^^^^^^
[INFO] [stdout]      |                                                      |
[INFO] [stdout]      |                                                      help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:2426:71
[INFO] [stdout]      |
[INFO] [stdout] 2426 |             let [mut perc_cont, mut perc, mut perc2, mut total_hosts, mut total_hosts2, mut perc3, mut perc4, mut total_hosts4] =
[INFO] [stdout]      |                                                                       ----^^^^^^^^^^^^
[INFO] [stdout]      |                                                                       |
[INFO] [stdout]      |                                                                       help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:2426:111
[INFO] [stdout]      |
[INFO] [stdout] 2426 |             let [mut perc_cont, mut perc, mut perc2, mut total_hosts, mut total_hosts2, mut perc3, mut perc4, mut total_hosts4] =
[INFO] [stdout]      |                                                                                                               ----^^^^^^^^^^^^
[INFO] [stdout]      |                                                                                                               |
[INFO] [stdout]      |                                                                                                               help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `collection_zone_no`
[INFO] [stdout]     --> src/main.rs:2423:13
[INFO] [stdout]      |
[INFO] [stdout] 2423 |         let collection_zone_no: u8 = no_of_zones as u8 + 1;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_collection_zone_no`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `collect` is never read
[INFO] [stdout]     --> src/main.rs:2279:38
[INFO] [stdout]      |
[INFO] [stdout] 2279 |         let mut collect: Vec<host> = Vec::new();
[INFO] [stdout]      |                                      ^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `eviscerate` is never read
[INFO] [stdout]    --> src/main.rs:118:5
[INFO] [stdout]     |
[INFO] [stdout] 114 | pub struct Zone_3D {
[INFO] [stdout]     |            ------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 118 |     eviscerate: bool,
[INFO] [stdout]     |     ^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `Zone_3D` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `eviscerated` is never read
[INFO] [stdout]    --> src/main.rs:131:5
[INFO] [stdout]     |
[INFO] [stdout] 122 | pub struct Segment_3D {
[INFO] [stdout]     |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 131 |     eviscerated: bool,
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `Segment_3D` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `generate` is never used
[INFO] [stdout]    --> src/main.rs:135:8
[INFO] [stdout]     |
[INFO] [stdout] 134 | impl Segment_3D {
[INFO] [stdout]     | --------------- method in this implementation
[INFO] [stdout] 135 |     fn generate(&mut self, infected: bool, colonized: bool, mut n: u32, mut hosts: &mut Vec<host>) {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `generate_full` and `modify` are never used
[INFO] [stdout]    --> src/main.rs:262:8
[INFO] [stdout]     |
[INFO] [stdout] 180 | impl Zone_3D {
[INFO] [stdout]     | ------------ associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 262 |     fn generate_full(zone: usize, grid: [u64; 3], step: [usize; 3]) -> Zone_3D {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 304 |     fn modify(&mut self, start: [u64; 3], end: [u64; 3], range: [usize; 3]) {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TIME_TO_COLONIZE` is never used
[INFO] [stdout]    --> src/main.rs:705:7
[INFO] [stdout]     |
[INFO] [stdout] 705 | const TIME_TO_COLONIZE: [f64; 2] = [5.0 * 24.0, 11.6 * 24.0]; //95% CI for generation time
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `COLONIZE_TIME_MAX_OVERRIDE` is never used
[INFO] [stdout]    --> src/main.rs:706:7
[INFO] [stdout]     |
[INFO] [stdout] 706 | const COLONIZE_TIME_MAX_OVERRIDE: f64 = 26.0 * 24.0;
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `infect`, `contaminate_multiple`, `collect`, `collect_and_replace`, and `report` are never used
[INFO] [stdout]     --> src/main.rs:941:8
[INFO] [stdout]      |
[INFO] [stdout]  824 | impl host {
[INFO] [stdout]      | --------- associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  941 |     fn infect(mut vector: Vec<host>, loc_x: u64, loc_y: u64, loc_z: u64, zone: usize) -> Vec<host> {
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  992 |     fn contaminate_multiple(
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1923 |     fn collect(inventory: Vec<host>) -> [Vec<host>; 2] {
[INFO] [stdout]      |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1972 |     fn collect_and_replace(inventory: Vec<host>, zone: &mut Zone_3D) -> [Vec<host>; 2] {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 2019 |     fn report(inventory: &Vec<host>) -> [f64; 4] {
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ages` should have an upper case name
[INFO] [stdout]    --> src/main.rs:803:7
[INFO] [stdout]     |
[INFO] [stdout] 803 | const ages: [f64; 2] = [0.01, 1.0]; //Time hosts are expected spend in each region minimally
[INFO] [stdout]     |       ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_upper_case_globals)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 803 - const ages: [f64; 2] = [0.01, 1.0]; //Time hosts are expected spend in each region minimally
[INFO] [stdout] 803 + const AGES: [f64; 2] = [0.01, 1.0]; //Time hosts are expected spend in each region minimally
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `FinalZone` should have a snake case name
[INFO] [stdout]     --> src/main.rs:2333:17
[INFO] [stdout]      |
[INFO] [stdout] 2333 |         let mut FinalZone: &mut Zone_3D = &mut zones[GRIDSIZE.len() - 1];
[INFO] [stdout]      |                 ^^^^^^^^^ help: convert the identifier to snake case: `final_zone`
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]     --> src/main.rs:2438:13
[INFO] [stdout]      |
[INFO] [stdout] 2438 | /             wtr.write_record(&[
[INFO] [stdout] 2439 | |                 perc_cont.to_string(),
[INFO] [stdout] 2440 | |                 total_hosts.to_string(),
[INFO] [stdout] 2441 | |                 no_cont.to_string(),
[INFO] [stdout] ...    |
[INFO] [stdout] 2453 | |                 format!("Zone {}", iter),
[INFO] [stdout] 2454 | |             ]);
[INFO] [stdout]      | |______________^
[INFO] [stdout]      |
[INFO] [stdout]      = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]      = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]      |
[INFO] [stdout] 2438 |             let _ = wtr.write_record(&[
[INFO] [stdout]      |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:2295:47
[INFO] [stdout]      |
[INFO] [stdout] 2295 |             eviscerators.iter_mut().for_each(|mut ev| {
[INFO] [stdout]      |                                               ----^^
[INFO] [stdout]      |                                               |
[INFO] [stdout]      |                                               help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:2270:9
[INFO] [stdout]      |
[INFO] [stdout] 2270 |     let mut file = OpenOptions::new()
[INFO] [stdout]      |         ----^^^^
[INFO] [stdout]      |         |
[INFO] [stdout]      |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:2426:54
[INFO] [stdout]      |
[INFO] [stdout] 2426 |             let [mut perc_cont, mut perc, mut perc2, mut total_hosts, mut total_hosts2, mut perc3, mut perc4, mut total_hosts4] =
[INFO] [stdout]      |                                                      ----^^^^^^^^^^^
[INFO] [stdout]      |                                                      |
[INFO] [stdout]      |                                                      help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:2426:71
[INFO] [stdout]      |
[INFO] [stdout] 2426 |             let [mut perc_cont, mut perc, mut perc2, mut total_hosts, mut total_hosts2, mut perc3, mut perc4, mut total_hosts4] =
[INFO] [stdout]      |                                                                       ----^^^^^^^^^^^^
[INFO] [stdout]      |                                                                       |
[INFO] [stdout]      |                                                                       help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/main.rs:2426:111
[INFO] [stdout]      |
[INFO] [stdout] 2426 |             let [mut perc_cont, mut perc, mut perc2, mut total_hosts, mut total_hosts2, mut perc3, mut perc4, mut total_hosts4] =
[INFO] [stdout]      |                                                                                                               ----^^^^^^^^^^^^
[INFO] [stdout]      |                                                                                                               |
[INFO] [stdout]      |                                                                                                               help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `collection_zone_no`
[INFO] [stdout]     --> src/main.rs:2423:13
[INFO] [stdout]      |
[INFO] [stdout] 2423 |         let collection_zone_no: u8 = no_of_zones as u8 + 1;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_collection_zone_no`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `collect` is never read
[INFO] [stdout]     --> src/main.rs:2279:38
[INFO] [stdout]      |
[INFO] [stdout] 2279 |         let mut collect: Vec<host> = Vec::new();
[INFO] [stdout]      |                                      ^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `eviscerate` is never read
[INFO] [stdout]    --> src/main.rs:118:5
[INFO] [stdout]     |
[INFO] [stdout] 114 | pub struct Zone_3D {
[INFO] [stdout]     |            ------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 118 |     eviscerate: bool,
[INFO] [stdout]     |     ^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `Zone_3D` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `eviscerated` is never read
[INFO] [stdout]    --> src/main.rs:131:5
[INFO] [stdout]     |
[INFO] [stdout] 122 | pub struct Segment_3D {
[INFO] [stdout]     |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 131 |     eviscerated: bool,
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `Segment_3D` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `generate` is never used
[INFO] [stdout]    --> src/main.rs:135:8
[INFO] [stdout]     |
[INFO] [stdout] 134 | impl Segment_3D {
[INFO] [stdout]     | --------------- method in this implementation
[INFO] [stdout] 135 |     fn generate(&mut self, infected: bool, colonized: bool, mut n: u32, mut hosts: &mut Vec<host>) {
[INFO] [stdout]     |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `generate_full` and `modify` are never used
[INFO] [stdout]    --> src/main.rs:262:8
[INFO] [stdout]     |
[INFO] [stdout] 180 | impl Zone_3D {
[INFO] [stdout]     | ------------ associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 262 |     fn generate_full(zone: usize, grid: [u64; 3], step: [usize; 3]) -> Zone_3D {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 304 |     fn modify(&mut self, start: [u64; 3], end: [u64; 3], range: [usize; 3]) {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TIME_TO_COLONIZE` is never used
[INFO] [stdout]    --> src/main.rs:705:7
[INFO] [stdout]     |
[INFO] [stdout] 705 | const TIME_TO_COLONIZE: [f64; 2] = [5.0 * 24.0, 11.6 * 24.0]; //95% CI for generation time
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `COLONIZE_TIME_MAX_OVERRIDE` is never used
[INFO] [stdout]    --> src/main.rs:706:7
[INFO] [stdout]     |
[INFO] [stdout] 706 | const COLONIZE_TIME_MAX_OVERRIDE: f64 = 26.0 * 24.0;
[INFO] [stdout]     |       ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `infect`, `contaminate_multiple`, `collect`, `collect_and_replace`, and `report` are never used
[INFO] [stdout]     --> src/main.rs:941:8
[INFO] [stdout]      |
[INFO] [stdout]  824 | impl host {
[INFO] [stdout]      | --------- associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  941 |     fn infect(mut vector: Vec<host>, loc_x: u64, loc_y: u64, loc_z: u64, zone: usize) -> Vec<host> {
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  992 |     fn contaminate_multiple(
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1923 |     fn collect(inventory: Vec<host>) -> [Vec<host>; 2] {
[INFO] [stdout]      |        ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1972 |     fn collect_and_replace(inventory: Vec<host>, zone: &mut Zone_3D) -> [Vec<host>; 2] {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 2019 |     fn report(inventory: &Vec<host>) -> [f64; 4] {
[INFO] [stdout]      |        ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ages` should have an upper case name
[INFO] [stdout]    --> src/main.rs:803:7
[INFO] [stdout]     |
[INFO] [stdout] 803 | const ages: [f64; 2] = [0.01, 1.0]; //Time hosts are expected spend in each region minimally
[INFO] [stdout]     |       ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(non_upper_case_globals)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] help: convert the identifier to upper case
[INFO] [stdout]     |
[INFO] [stdout] 803 - const ages: [f64; 2] = [0.01, 1.0]; //Time hosts are expected spend in each region minimally
[INFO] [stdout] 803 + const AGES: [f64; 2] = [0.01, 1.0]; //Time hosts are expected spend in each region minimally
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `FinalZone` should have a snake case name
[INFO] [stdout]     --> src/main.rs:2333:17
[INFO] [stdout]      |
[INFO] [stdout] 2333 |         let mut FinalZone: &mut Zone_3D = &mut zones[GRIDSIZE.len() - 1];
[INFO] [stdout]      |                 ^^^^^^^^^ help: convert the identifier to snake case: `final_zone`
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused `Result` that must be used
[INFO] [stdout]     --> src/main.rs:2438:13
[INFO] [stdout]      |
[INFO] [stdout] 2438 | /             wtr.write_record(&[
[INFO] [stdout] 2439 | |                 perc_cont.to_string(),
[INFO] [stdout] 2440 | |                 total_hosts.to_string(),
[INFO] [stdout] 2441 | |                 no_cont.to_string(),
[INFO] [stdout] ...    |
[INFO] [stdout] 2453 | |                 format!("Zone {}", iter),
[INFO] [stdout] 2454 | |             ]);
[INFO] [stdout]      | |______________^
[INFO] [stdout]      |
[INFO] [stdout]      = note: this `Result` may be an `Err` variant, which should be handled
[INFO] [stdout]      = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]      |
[INFO] [stdout] 2438 |             let _ = wtr.write_record(&[
[INFO] [stdout]      |             +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 33.94s
[INFO] running `Command { std: "docker" "inspect" "a4c978ebeb238d3e7f43a204147bc30c6a345491fd09df9158703924b1784f72", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a4c978ebeb238d3e7f43a204147bc30c6a345491fd09df9158703924b1784f72", kill_on_drop: false }`
[INFO] [stdout] a4c978ebeb238d3e7f43a204147bc30c6a345491fd09df9158703924b1784f72
