[INFO] cloning repository https://github.com/enricozanardo/wall-e
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/enricozanardo/wall-e" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fenricozanardo%2Fwall-e", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fenricozanardo%2Fwall-e'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 630da121b1d60a7c51b25053ee0d7523a80a9b0b
[INFO] building enricozanardo/wall-e against master#c7f6aa2869acdbf014d094c6e427e554e160b6db for pr-146237-2
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fenricozanardo%2Fwall-e" "/workspace/builds/worker-5-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/enricozanardo/wall-e
[INFO] removed 0 missing examples
[INFO] finished tweaking git repo https://github.com/enricozanardo/wall-e
[INFO] tweaked toml for git repo https://github.com/enricozanardo/wall-e written to /workspace/builds/worker-5-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/enricozanardo/wall-e on toolchain c7f6aa2869acdbf014d094c6e427e554e160b6db
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+c7f6aa2869acdbf014d094c6e427e554e160b6db" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/enricozanardo/wall-e 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" "+c7f6aa2869acdbf014d094c6e427e554e160b6db" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded rand_distr v0.4.3
[INFO] [stderr]   Downloaded getrandom v0.2.16
[INFO] [stderr]   Downloaded ppv-lite86 v0.2.21
[INFO] [stderr]   Downloaded ndarray-rand v0.14.0
[INFO] [stderr]   Downloaded num-complex v0.4.6
[INFO] [stderr]   Downloaded number_prefix v0.4.0
[INFO] [stderr]   Downloaded ndarray-parallel v0.9.1
[INFO] [stderr]   Downloaded matrixmultiply v0.1.15
[INFO] [stderr]   Downloaded env_filter v0.1.3
[INFO] [stderr]   Downloaded bincode v1.3.3
[INFO] [stderr]   Downloaded web-time v1.1.0
[INFO] [stderr]   Downloaded csv-core v0.1.12
[INFO] [stderr]   Downloaded memmap2 v0.9.5
[INFO] [stderr]   Downloaded console v0.15.11
[INFO] [stderr]   Downloaded encode_unicode v1.0.0
[INFO] [stderr]   Downloaded clap v4.5.37
[INFO] [stderr]   Downloaded bytemuck v1.22.0
[INFO] [stderr]   Downloaded portable-atomic-util v0.2.4
[INFO] [stderr]   Downloaded env_logger v0.11.8
[INFO] [stderr]   Downloaded zerocopy-derive v0.8.24
[INFO] [stderr]   Downloaded jiff-static v0.2.13
[INFO] [stderr]   Downloaded matrixmultiply v0.3.9
[INFO] [stderr]   Downloaded itertools v0.7.11
[INFO] [stderr]   Downloaded indicatif v0.17.11
[INFO] [stderr]   Downloaded cc v1.2.19
[INFO] [stderr]   Downloaded libm v0.2.13
[INFO] [stderr]   Downloaded ndarray v0.12.1
[INFO] [stderr]   Downloaded clap_builder v4.5.37
[INFO] [stderr]   Downloaded zerocopy v0.8.24
[INFO] [stderr]   Downloaded portable-atomic v1.11.0
[INFO] [stderr]   Downloaded ndarray v0.15.6
[INFO] [stderr]   Downloaded rawpointer v0.1.0
[INFO] [stderr]   Downloaded jiff v0.2.13
[INFO] [stderr]   Downloaded csv v1.3.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+c7f6aa2869acdbf014d094c6e427e554e160b6db" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] e18f9b7ae63ddbb3be410ad39022b91cdc92f1134bb2440d84982ee68dee59aa
[INFO] running `Command { std: "docker" "start" "-a" "e18f9b7ae63ddbb3be410ad39022b91cdc92f1134bb2440d84982ee68dee59aa", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "e18f9b7ae63ddbb3be410ad39022b91cdc92f1134bb2440d84982ee68dee59aa", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "e18f9b7ae63ddbb3be410ad39022b91cdc92f1134bb2440d84982ee68dee59aa", kill_on_drop: false }`
[INFO] [stdout] e18f9b7ae63ddbb3be410ad39022b91cdc92f1134bb2440d84982ee68dee59aa
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+c7f6aa2869acdbf014d094c6e427e554e160b6db" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 5d86b93ff766945f2a980686ec3efdca7c260efde10acb21567d87074a8632a5
[INFO] running `Command { std: "docker" "start" "-a" "5d86b93ff766945f2a980686ec3efdca7c260efde10acb21567d87074a8632a5", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.95
[INFO] [stderr]    Compiling unicode-ident v1.0.18
[INFO] [stderr]    Compiling autocfg v1.4.0
[INFO] [stderr]    Compiling libc v0.2.172
[INFO] [stderr]    Compiling libm v0.2.13
[INFO] [stderr]    Compiling stable_deref_trait v1.2.0
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling memchr v2.7.4
[INFO] [stderr]    Compiling litemap v0.7.5
[INFO] [stderr]    Compiling cfg-if v1.0.0
[INFO] [stderr]    Compiling writeable v0.5.5
[INFO] [stderr]    Compiling icu_locid_transform_data v1.5.1
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]    Compiling icu_properties_data v1.5.1
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling zerocopy v0.8.24
[INFO] [stderr]    Compiling icu_normalizer_data v1.5.1
[INFO] [stderr]    Compiling rayon-core v1.12.1
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling crossbeam-epoch v0.9.18
[INFO] [stderr]    Compiling utf8parse v0.2.2
[INFO] [stderr]    Compiling anstyle-parse v0.2.6
[INFO] [stderr]    Compiling quote v1.0.40
[INFO] [stderr]    Compiling crossbeam-deque v0.8.6
[INFO] [stderr]    Compiling syn v2.0.100
[INFO] [stderr]    Compiling aho-corasick v1.1.3
[INFO] [stderr]    Compiling num-complex v0.2.4
[INFO] [stderr]    Compiling getrandom v0.2.16
[INFO] [stderr]    Compiling matrixmultiply v0.3.9
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling utf8_iter v1.0.4
[INFO] [stderr]    Compiling utf16_iter v1.0.5
[INFO] [stderr]    Compiling regex-syntax v0.8.5
[INFO] [stderr]    Compiling smallvec v1.15.0
[INFO] [stderr]    Compiling anstyle-query v1.1.2
[INFO] [stderr]    Compiling is_terminal_polyfill v1.70.1
[INFO] [stderr]    Compiling colorchoice v1.0.3
[INFO] [stderr]    Compiling write16 v1.0.0
[INFO] [stderr]    Compiling anstyle v1.0.10
[INFO] [stderr]    Compiling matrixmultiply v0.1.15
[INFO] [stderr]    Compiling rayon v1.10.0
[INFO] [stderr]    Compiling anstream v0.6.18
[INFO] [stderr]    Compiling rawpointer v0.1.0
[INFO] [stderr]    Compiling getrandom v0.3.2
[INFO] [stderr]    Compiling rustix v1.0.5
[INFO] [stderr]    Compiling rawpointer v0.2.1
[INFO] [stderr]    Compiling portable-atomic v1.11.0
[INFO] [stderr]    Compiling once_cell v1.21.3
[INFO] [stderr]    Compiling ndarray v0.12.1
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling num-integer v0.1.46
[INFO] [stderr]    Compiling num-complex v0.4.6
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling itertools v0.7.11
[INFO] [stderr]    Compiling ryu v1.0.20
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling unicode-width v0.2.0
[INFO] [stderr]    Compiling linux-raw-sys v0.9.4
[INFO] [stderr]    Compiling bitflags v2.9.0
[INFO] [stderr]    Compiling regex-automata v0.4.9
[INFO] [stderr]    Compiling heck v0.5.0
[INFO] [stderr]    Compiling serde_json v1.0.140
[INFO] [stderr]    Compiling itoa v1.0.15
[INFO] [stderr]    Compiling strsim v0.11.1
[INFO] [stderr]    Compiling percent-encoding v2.3.1
[INFO] [stderr]    Compiling clap_lex v0.7.4
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling log v0.4.27
[INFO] [stderr]    Compiling clap_builder v4.5.37
[INFO] [stderr]    Compiling rand_distr v0.4.3
[INFO] [stderr]    Compiling form_urlencoded v1.2.1
[INFO] [stderr]    Compiling console v0.15.11
[INFO] [stderr]    Compiling csv-core v0.1.12
[INFO] [stderr]    Compiling jiff v0.2.13
[INFO] [stderr]    Compiling synstructure v0.13.1
[INFO] [stderr]    Compiling fastrand v2.3.0
[INFO] [stderr]    Compiling number_prefix v0.4.0
[INFO] [stderr]    Compiling iana-time-zone v0.1.63
[INFO] [stderr]    Compiling indicatif v0.17.11
[INFO] [stderr]    Compiling memmap2 v0.9.5
[INFO] [stderr]    Compiling ndarray-parallel v0.9.1
[INFO] [stderr]    Compiling regex v1.11.1
[INFO] [stderr]    Compiling tempfile v3.19.1
[INFO] [stderr]    Compiling env_filter v0.1.3
[INFO] [stderr]    Compiling num_cpus v1.16.0
[INFO] [stderr]    Compiling bytemuck v1.22.0
[INFO] [stderr]    Compiling byteorder v1.5.0
[INFO] [stderr]    Compiling lazy_static v1.5.0
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.7.5
[INFO] [stderr]    Compiling zerovec-derive v0.10.3
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling icu_provider_macros v1.5.0
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling clap_derive v4.5.32
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling yoke v0.7.5
[INFO] [stderr]    Compiling zerovec v0.10.4
[INFO] [stderr]    Compiling tinystr v0.7.6
[INFO] [stderr]    Compiling icu_collections v1.5.0
[INFO] [stderr]    Compiling clap v4.5.37
[INFO] [stderr]    Compiling icu_locid v1.5.0
[INFO] [stderr]    Compiling env_logger v0.11.8
[INFO] [stderr]    Compiling icu_provider v1.5.0
[INFO] [stderr]    Compiling icu_locid_transform v1.5.0
[INFO] [stderr]    Compiling icu_properties v1.5.1
[INFO] [stderr]    Compiling icu_normalizer v1.5.0
[INFO] [stderr]    Compiling ndarray v0.15.6
[INFO] [stderr]    Compiling csv v1.3.1
[INFO] [stderr]    Compiling bincode v1.3.3
[INFO] [stderr]    Compiling chrono v0.4.40
[INFO] [stderr]    Compiling idna_adapter v1.2.0
[INFO] [stderr]    Compiling idna v1.0.3
[INFO] [stderr]    Compiling url v2.5.4
[INFO] [stderr]    Compiling ndarray-rand v0.14.0
[INFO] [stderr]    Compiling wall-e1 v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `Duration`
[INFO] [stdout]  --> src/nabla/memory_opt.rs:4:26
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::time::{Instant, Duration};
[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: `Axis` and `Ix3`
[INFO] [stdout]  --> src/training/mod.rs:4:46
[INFO] [stdout]   |
[INFO] [stdout] 4 | use ndarray::{Array, Array1, Array2, Array3, Axis, Ix1, Ix2, Ix3, Ix0, IxDyn, s};
[INFO] [stdout]   |                                              ^^^^            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ndarray::Array0`
[INFO] [stdout]   --> src/training/mod.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use ndarray::Array0;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ndarray::array`
[INFO] [stdout]   --> src/training/mod.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use ndarray::array;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Instant`
[INFO] [stdout]   --> src/training/mod.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use std::time::Instant;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Arc`, `Barrier`, and `Mutex`
[INFO] [stdout]   --> src/training/mod.rs:17:17
[INFO] [stdout]    |
[INFO] [stdout] 17 | use std::sync::{Mutex, Arc, Barrier};
[INFO] [stdout]    |                 ^^^^^  ^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `AtomicUsize` and `Ordering`
[INFO] [stdout]   --> src/training/mod.rs:18:25
[INFO] [stdout]    |
[INFO] [stdout] 18 | use std::sync::atomic::{AtomicUsize, Ordering};
[INFO] [stdout]    |                         ^^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::nabla::memory_opt`
[INFO] [stdout]   --> src/training/enhanced_trainer.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use crate::nabla::memory_opt;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Barrier`
[INFO] [stdout]   --> src/training/enhanced_trainer.rs:19:29
[INFO] [stdout]    |
[INFO] [stdout] 19 | use std::sync::{Arc, Mutex, Barrier};
[INFO] [stdout]    |                             ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `MutexGuard` and `Mutex`
[INFO] [stdout]  --> src/training/batch_dispatcher.rs:4:17
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::sync::{Mutex, MutexGuard};
[INFO] [stdout]   |                 ^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread::ThreadId`
[INFO] [stdout]  --> src/training/batch_dispatcher.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::thread::ThreadId;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `v`
[INFO] [stdout]   --> src/nabla/memory_opt.rs:88:15
[INFO] [stdout]    |
[INFO] [stdout] 88 |     if let Ok(v) = std::env::var("MALLOC_ARENA_MAX") {
[INFO] [stdout]    |               ^ help: if this is intentional, prefix it with an underscore: `_v`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `count`
[INFO] [stdout]    --> src/tokenizer/word_bpe.rs:420:20
[INFO] [stdout]     |
[INFO] [stdout] 420 |         for (word, count) in word_counts.iter().filter(|&(_, count)| *count >= min_frequency) {
[INFO] [stdout]     |                    ^^^^^ help: if this is intentional, prefix it with an underscore: `_count`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tokens_to_add`
[INFO] [stdout]     --> src/training/mod.rs:1315:13
[INFO] [stdout]      |
[INFO] [stdout] 1315 |         let tokens_to_add = new_vocab_size - current_size;
[INFO] [stdout]      |             ^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]      |
[INFO] [stdout] 1315 |         let _tokens_to_add = new_vocab_size - current_size;
[INFO] [stdout]      |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `CHUNK_SIZE`
[INFO] [stdout]      |
[INFO] [stdout] 1315 -         let tokens_to_add = new_vocab_size - current_size;
[INFO] [stdout] 1315 +         let training::enhanced_trainer::EnhancedTrainer::learn_tokenizer_from_text::CHUNK_SIZE = new_vocab_size - current_size;
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `reported_progress` is assigned to, but never used
[INFO] [stdout]    --> src/training/generation.rs:174:17
[INFO] [stdout]     |
[INFO] [stdout] 174 |         let mut reported_progress = false;
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: consider using `_reported_progress` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `reported_progress` is never read
[INFO] [stdout]    --> src/training/generation.rs:181:17
[INFO] [stdout]     |
[INFO] [stdout] 181 |                 reported_progress = true;
[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: unused variable: `batch`
[INFO] [stdout]    --> src/training/enhanced_trainer.rs:538:34
[INFO] [stdout]     |
[INFO] [stdout] 538 |                     if let (Some(batch), Some(target)) = (inputs.get(batch_idx), targets.get(batch_idx)) {
[INFO] [stdout]     |                                  ^^^^^ help: if this is intentional, prefix it with an underscore: `_batch`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `target`
[INFO] [stdout]    --> src/training/enhanced_trainer.rs:538:47
[INFO] [stdout]     |
[INFO] [stdout] 538 |                     if let (Some(batch), Some(target)) = (inputs.get(batch_idx), targets.get(batch_idx)) {
[INFO] [stdout]     |                                               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_target`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/training/enhanced_trainer.rs:542:29
[INFO] [stdout]     |
[INFO] [stdout] 542 |                         let mut loss_guard = loss_mutex.lock().unwrap();
[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: unused variable: `thread_id`
[INFO] [stdout]     --> src/training/enhanced_trainer.rs:3454:13
[INFO] [stdout]      |
[INFO] [stdout] 3454 |         for thread_id in 0..num_threads {
[INFO] [stdout]      |             ^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]      |
[INFO] [stdout] 3454 |         for _thread_id in 0..num_threads {
[INFO] [stdout]      |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `CHUNK_SIZE`
[INFO] [stdout]      |
[INFO] [stdout] 3454 -         for thread_id in 0..num_threads {
[INFO] [stdout] 3454 +         for training::enhanced_trainer::EnhancedTrainer::learn_tokenizer_from_text::CHUNK_SIZE in 0..num_threads {
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `progress_reported` is never read
[INFO] [stdout]     --> src/training/enhanced_trainer.rs:3714:13
[INFO] [stdout]      |
[INFO] [stdout] 3714 |             progress_reported = true;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `determine_allocator_type` is never used
[INFO] [stdout]   --> src/nabla/memory_opt.rs:79:4
[INFO] [stdout]    |
[INFO] [stdout] 79 | fn determine_allocator_type() -> Option<String> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_total_elapsed` is never used
[INFO] [stdout]    --> src/training/enhanced_trainer.rs:165:8
[INFO] [stdout]     |
[INFO] [stdout] 134 | impl ThreadStateTracker {
[INFO] [stdout]     | ----------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 165 |     fn get_total_elapsed(&self) -> std::time::Duration {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `run_with_timeout` is never used
[INFO] [stdout]     --> src/training/enhanced_trainer.rs:2001:8
[INFO] [stdout]      |
[INFO] [stdout]  201 | impl EnhancedTrainer {
[INFO] [stdout]      | -------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 2001 |     fn run_with_timeout<F, T>(&self, f: F, timeout: std::time::Duration) -> Option<T> 
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `V0_HEADER_SIZE` is never used
[INFO] [stdout]    --> src/training/enhanced_trainer.rs:101:15
[INFO] [stdout]     |
[INFO] [stdout] 101 |     pub const V0_HEADER_SIZE: usize = 32;
[INFO] [stdout]     |               ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `time` is never read
[INFO] [stdout]   --> src/training/batch_dispatcher.rs:44:5
[INFO] [stdout]    |
[INFO] [stdout] 40 | struct LockEvent {
[INFO] [stdout]    |        --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 44 |     time: Instant,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TextGenerator`
[INFO] [stdout]  --> src/bin/test_multithreading.rs:5:42
[INFO] [stdout]   |
[INFO] [stdout] 5 | use wall_e1::training::{EnhancedTrainer, TextGenerator};
[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 import: `std::env`
[INFO] [stdout]  --> src/bin/diagnose_training.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::env;
[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 import: `wall_e1::tokenizer::Tokenizer`
[INFO] [stdout]  --> src/bin/diagnose_training.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use wall_e1::tokenizer::Tokenizer;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fs::File`
[INFO] [stdout]  --> src/bin/diagnose_training.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::fs::File;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::Read`
[INFO] [stdout]  --> src/bin/diagnose_training.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::io::Read;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `wall_e1::nabla::tensor::Tensor`
[INFO] [stdout]  --> src/bin/memory_test.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use wall_e1::nabla::tensor::Tensor;
[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: `ProgressBar` and `ProgressStyle`
[INFO] [stdout]   --> src/bin/train_enhanced_model.rs:16:17
[INFO] [stdout]    |
[INFO] [stdout] 16 | use indicatif::{ProgressBar, ProgressStyle};
[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: `Arc`, `AtomicUsize`, `Mutex`, and `Ordering`
[INFO] [stdout]   --> src/bin/train_enhanced_model.rs:17:17
[INFO] [stdout]    |
[INFO] [stdout] 17 | use std::sync::{Arc, Mutex, atomic::{AtomicUsize, Ordering}};
[INFO] [stdout]    |                 ^^^  ^^^^^           ^^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `thread_id`
[INFO] [stdout]   --> src/bin/train_enhanced_model.rs:47:13
[INFO] [stdout]    |
[INFO] [stdout] 47 |         let thread_id = format!("{:?}", std::thread::current().id());
[INFO] [stdout]    |             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_thread_id`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `thread_count`
[INFO] [stdout]    --> src/bin/train_enhanced_model.rs:371:13
[INFO] [stdout]     |
[INFO] [stdout] 371 |         let thread_count = if op == &"data_loading" { min_data_threads } else { pool.get_num_threads() };
[INFO] [stdout]     |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_thread_count`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `setup_start`
[INFO] [stdout]    --> src/bin/train_enhanced_model.rs:428:9
[INFO] [stdout]     |
[INFO] [stdout] 428 |     let setup_start = Instant::now();
[INFO] [stdout]     |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_setup_start`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `curriculum_examples` is assigned to, but never used
[INFO] [stdout]    --> src/bin/train_enhanced_model.rs:462:13
[INFO] [stdout]     |
[INFO] [stdout] 462 |     let mut curriculum_examples: usize = 2000;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: consider using `_curriculum_examples` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `auto_resize_vocab` is assigned to, but never used
[INFO] [stdout]    --> src/bin/train_enhanced_model.rs:466:13
[INFO] [stdout]     |
[INFO] [stdout] 466 |     let mut auto_resize_vocab = false;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: consider using `_auto_resize_vocab` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `watchdog_timeout` is assigned to, but never used
[INFO] [stdout]    --> src/bin/train_enhanced_model.rs:467:13
[INFO] [stdout]     |
[INFO] [stdout] 467 |     let mut watchdog_timeout: Option<u64> = None;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: consider using `_watchdog_timeout` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `target_id_max` is assigned to, but never used
[INFO] [stdout]    --> src/bin/train_enhanced_model.rs:470:13
[INFO] [stdout]     |
[INFO] [stdout] 470 |     let mut target_id_max: Option<usize> = None;
[INFO] [stdout]     |             ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: consider using `_target_id_max` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `curriculum_examples` is never read
[INFO] [stdout]    --> src/bin/train_enhanced_model.rs:675:25
[INFO] [stdout]     |
[INFO] [stdout] 675 |                         curriculum_examples = num;
[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 `auto_resize_vocab` is never read
[INFO] [stdout]    --> src/bin/train_enhanced_model.rs:681:17
[INFO] [stdout]     |
[INFO] [stdout] 681 |                 auto_resize_vocab = true;
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `watchdog_timeout` is never read
[INFO] [stdout]    --> src/bin/train_enhanced_model.rs:687:25
[INFO] [stdout]     |
[INFO] [stdout] 687 |                         watchdog_timeout = Some(timeout);
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `target_id_max` is never read
[INFO] [stdout]    --> src/bin/train_enhanced_model.rs:711:25
[INFO] [stdout]     |
[INFO] [stdout] 711 |                         target_id_max = Some(max_id);
[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/bin/train_enhanced_model.rs:1230:9
[INFO] [stdout]      |
[INFO] [stdout] 1230 |     let mut path_with_dir = if !final_save_path_str.starts_with("models/") {
[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: unused variable: `epoch`
[INFO] [stdout]     --> src/bin/train_enhanced_model.rs:1340:68
[INFO] [stdout]      |
[INFO] [stdout] 1340 | fn train_epoch(trainer: &mut EnhancedTrainer, tokens: &Vec<usize>, epoch: usize, 
[INFO] [stdout]      |                                                                    ^^^^^ help: if this is intentional, prefix it with an underscore: `_epoch`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `batch_inputs`
[INFO] [stdout]     --> src/bin/train_enhanced_model.rs:1508:10
[INFO] [stdout]      |
[INFO] [stdout] 1508 |     let (batch_inputs, min_seq_len, truncated_inputs, batch_targets_arr, timing) = pool_result.install(|| {
[INFO] [stdout]      |          ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_batch_inputs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `min_seq_len`
[INFO] [stdout]     --> src/bin/train_enhanced_model.rs:1508:24
[INFO] [stdout]      |
[INFO] [stdout] 1508 |     let (batch_inputs, min_seq_len, truncated_inputs, batch_targets_arr, timing) = pool_result.install(|| {
[INFO] [stdout]      |                        ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_min_seq_len`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `k`
[INFO] [stdout]     --> src/bin/train_enhanced_model.rs:1779:13
[INFO] [stdout]      |
[INFO] [stdout] 1779 |     let (m, k) = a.dim();
[INFO] [stdout]      |             ^ help: if this is intentional, prefix it with an underscore: `_k`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `prepare_batch_parallel` is never used
[INFO] [stdout]     --> src/bin/train_enhanced_model.rs:1472:4
[INFO] [stdout]      |
[INFO] [stdout] 1472 | fn prepare_batch_parallel(
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `detect_simd_features` is never used
[INFO] [stdout]     --> src/bin/train_enhanced_model.rs:1691:4
[INFO] [stdout]      |
[INFO] [stdout] 1691 | fn detect_simd_features() -> Vec<String> {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `enable_simd_optimizations` is never used
[INFO] [stdout]     --> src/bin/train_enhanced_model.rs:1728:4
[INFO] [stdout]      |
[INFO] [stdout] 1728 | fn enable_simd_optimizations(features: &[String]) -> bool {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `matrix_multiply_simd` is never used
[INFO] [stdout]     --> src/bin/train_enhanced_model.rs:1774:4
[INFO] [stdout]      |
[INFO] [stdout] 1774 | fn matrix_multiply_simd(a: &ndarray::Array2<f32>, b: &ndarray::Array2<f32>) -> ndarray::Array2<f32> {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `matrix_multiply_avx2` is never used
[INFO] [stdout]     --> src/bin/train_enhanced_model.rs:1844:4
[INFO] [stdout]      |
[INFO] [stdout] 1844 | fn matrix_multiply_avx2(a: &ndarray::Array2<f32>, b: &ndarray::Array2<f32>, result: &mut ndarray::Array2<f32>) {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `matrix_multiply_scalar` is never used
[INFO] [stdout]     --> src/bin/train_enhanced_model.rs:1850:4
[INFO] [stdout]      |
[INFO] [stdout] 1850 | fn matrix_multiply_scalar(a: &ndarray::Array2<f32>, b: &ndarray::Array2<f32>, result: &mut ndarray::Array2<f32>) {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 53s
[INFO] running `Command { std: "docker" "inspect" "5d86b93ff766945f2a980686ec3efdca7c260efde10acb21567d87074a8632a5", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5d86b93ff766945f2a980686ec3efdca7c260efde10acb21567d87074a8632a5", kill_on_drop: false }`
[INFO] [stdout] 5d86b93ff766945f2a980686ec3efdca7c260efde10acb21567d87074a8632a5
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+c7f6aa2869acdbf014d094c6e427e554e160b6db" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] b74515bfb009a4d3415c0e56e4ca1888c3d2458b45325bcaeada1d375e018afe
[INFO] running `Command { std: "docker" "start" "-a" "b74515bfb009a4d3415c0e56e4ca1888c3d2458b45325bcaeada1d375e018afe", kill_on_drop: false }`
[INFO] [stdout] warning: unused import: `Duration`
[INFO] [stdout]  --> src/nabla/memory_opt.rs:4:26
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::time::{Instant, Duration};
[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: `Axis` and `Ix3`
[INFO] [stdout]  --> src/training/mod.rs:4:46
[INFO] [stdout]   |
[INFO] [stdout] 4 | use ndarray::{Array, Array1, Array2, Array3, Axis, Ix1, Ix2, Ix3, Ix0, IxDyn, s};
[INFO] [stdout]   |                                              ^^^^            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ndarray::Array0`
[INFO] [stdout]   --> src/training/mod.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use ndarray::Array0;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ndarray::array`
[INFO] [stdout]   --> src/training/mod.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use ndarray::array;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Instant`
[INFO] [stdout]   --> src/training/mod.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use std::time::Instant;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Arc`, `Barrier`, and `Mutex`
[INFO] [stdout]   --> src/training/mod.rs:17:17
[INFO] [stdout]    |
[INFO] [stdout] 17 | use std::sync::{Mutex, Arc, Barrier};
[INFO] [stdout]    |                 ^^^^^  ^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `AtomicUsize` and `Ordering`
[INFO] [stdout]   --> src/training/mod.rs:18:25
[INFO] [stdout]    |
[INFO] [stdout] 18 | use std::sync::atomic::{AtomicUsize, Ordering};
[INFO] [stdout]    |                         ^^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::nabla::memory_opt`
[INFO] [stdout]   --> src/training/enhanced_trainer.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use crate::nabla::memory_opt;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Barrier`
[INFO] [stdout]   --> src/training/enhanced_trainer.rs:19:29
[INFO] [stdout]    |
[INFO] [stdout] 19 | use std::sync::{Arc, Mutex, Barrier};
[INFO] [stdout]    |                             ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `MutexGuard` and `Mutex`
[INFO] [stdout]  --> src/training/batch_dispatcher.rs:4:17
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::sync::{Mutex, MutexGuard};
[INFO] [stdout]   |                 ^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread::ThreadId`
[INFO] [stdout]  --> src/training/batch_dispatcher.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::thread::ThreadId;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `v`
[INFO] [stdout]   --> src/nabla/memory_opt.rs:88:15
[INFO] [stdout]    |
[INFO] [stdout] 88 |     if let Ok(v) = std::env::var("MALLOC_ARENA_MAX") {
[INFO] [stdout]    |               ^ help: if this is intentional, prefix it with an underscore: `_v`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `count`
[INFO] [stdout]    --> src/tokenizer/word_bpe.rs:420:20
[INFO] [stdout]     |
[INFO] [stdout] 420 |         for (word, count) in word_counts.iter().filter(|&(_, count)| *count >= min_frequency) {
[INFO] [stdout]     |                    ^^^^^ help: if this is intentional, prefix it with an underscore: `_count`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tokens_to_add`
[INFO] [stdout]     --> src/training/mod.rs:1315:13
[INFO] [stdout]      |
[INFO] [stdout] 1315 |         let tokens_to_add = new_vocab_size - current_size;
[INFO] [stdout]      |             ^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]      |
[INFO] [stdout] 1315 |         let _tokens_to_add = new_vocab_size - current_size;
[INFO] [stdout]      |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `CHUNK_SIZE`
[INFO] [stdout]      |
[INFO] [stdout] 1315 -         let tokens_to_add = new_vocab_size - current_size;
[INFO] [stdout] 1315 +         let training::enhanced_trainer::EnhancedTrainer::learn_tokenizer_from_text::CHUNK_SIZE = new_vocab_size - current_size;
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `reported_progress` is assigned to, but never used
[INFO] [stdout]    --> src/training/generation.rs:174:17
[INFO] [stdout]     |
[INFO] [stdout] 174 |         let mut reported_progress = false;
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: consider using `_reported_progress` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `reported_progress` is never read
[INFO] [stdout]    --> src/training/generation.rs:181:17
[INFO] [stdout]     |
[INFO] [stdout] 181 |                 reported_progress = true;
[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: unused variable: `batch`
[INFO] [stdout]    --> src/training/enhanced_trainer.rs:538:34
[INFO] [stdout]     |
[INFO] [stdout] 538 |                     if let (Some(batch), Some(target)) = (inputs.get(batch_idx), targets.get(batch_idx)) {
[INFO] [stdout]     |                                  ^^^^^ help: if this is intentional, prefix it with an underscore: `_batch`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `target`
[INFO] [stdout]    --> src/training/enhanced_trainer.rs:538:47
[INFO] [stdout]     |
[INFO] [stdout] 538 |                     if let (Some(batch), Some(target)) = (inputs.get(batch_idx), targets.get(batch_idx)) {
[INFO] [stdout]     |                                               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_target`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/training/enhanced_trainer.rs:542:29
[INFO] [stdout]     |
[INFO] [stdout] 542 |                         let mut loss_guard = loss_mutex.lock().unwrap();
[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: unused variable: `thread_id`
[INFO] [stdout]     --> src/training/enhanced_trainer.rs:3454:13
[INFO] [stdout]      |
[INFO] [stdout] 3454 |         for thread_id in 0..num_threads {
[INFO] [stdout]      |             ^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]      |
[INFO] [stdout] 3454 |         for _thread_id in 0..num_threads {
[INFO] [stdout]      |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `CHUNK_SIZE`
[INFO] [stdout]      |
[INFO] [stdout] 3454 -         for thread_id in 0..num_threads {
[INFO] [stdout] 3454 +         for training::enhanced_trainer::EnhancedTrainer::learn_tokenizer_from_text::CHUNK_SIZE in 0..num_threads {
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `progress_reported` is never read
[INFO] [stdout]     --> src/training/enhanced_trainer.rs:3714:13
[INFO] [stdout]      |
[INFO] [stdout] 3714 |             progress_reported = true;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `determine_allocator_type` is never used
[INFO] [stdout]   --> src/nabla/memory_opt.rs:79:4
[INFO] [stdout]    |
[INFO] [stdout] 79 | fn determine_allocator_type() -> Option<String> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_total_elapsed` is never used
[INFO] [stdout]    --> src/training/enhanced_trainer.rs:165:8
[INFO] [stdout]     |
[INFO] [stdout] 134 | impl ThreadStateTracker {
[INFO] [stdout]     | ----------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 165 |     fn get_total_elapsed(&self) -> std::time::Duration {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `run_with_timeout` is never used
[INFO] [stdout]     --> src/training/enhanced_trainer.rs:2001:8
[INFO] [stdout]      |
[INFO] [stdout]  201 | impl EnhancedTrainer {
[INFO] [stdout]      | -------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 2001 |     fn run_with_timeout<F, T>(&self, f: F, timeout: std::time::Duration) -> Option<T> 
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling wall-e1 v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: constant `V0_HEADER_SIZE` is never used
[INFO] [stdout]    --> src/training/enhanced_trainer.rs:101:15
[INFO] [stdout]     |
[INFO] [stdout] 101 |     pub const V0_HEADER_SIZE: usize = 32;
[INFO] [stdout]     |               ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `time` is never read
[INFO] [stdout]   --> src/training/batch_dispatcher.rs:44:5
[INFO] [stdout]    |
[INFO] [stdout] 40 | struct LockEvent {
[INFO] [stdout]    |        --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 44 |     time: Instant,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Array2`
[INFO] [stdout]  --> examples/model_test.rs:6:15
[INFO] [stdout]   |
[INFO] [stdout] 6 | use ndarray::{Array2, s};
[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 import: `WordPieceBPETokenizer`
[INFO] [stdout]  --> examples/test_model.rs:6:26
[INFO] [stdout]   |
[INFO] [stdout] 6 | use wall_e1::tokenizer::{WordPieceBPETokenizer, Tokenizer};
[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 import: `ndarray::Array2`
[INFO] [stdout]  --> examples/test_model.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use ndarray::Array2;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `ProgressBar` and `ProgressStyle`
[INFO] [stdout]   --> examples/test_model.rs:10:17
[INFO] [stdout]    |
[INFO] [stdout] 10 | use indicatif::{ProgressBar, ProgressStyle};
[INFO] [stdout]    |                 ^^^^^^^^^^^  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::prelude::*`
[INFO] [stdout]   --> examples/test_model.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use rand::prelude::*;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `wall_e1::tokenizer::basic_tokenizer::BasicTokenizer`
[INFO] [stdout]  --> examples/train_qa_model.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use wall_e1::tokenizer::basic_tokenizer::BasicTokenizer;
[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 import: `wall_e1::nabla::tensor::Tensor`
[INFO] [stdout]  --> src/bin/memory_test.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use wall_e1::nabla::tensor::Tensor;
[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 import: `std::env`
[INFO] [stdout]  --> src/bin/diagnose_training.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::env;
[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 import: `wall_e1::tokenizer::Tokenizer`
[INFO] [stdout]  --> src/bin/diagnose_training.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use wall_e1::tokenizer::Tokenizer;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fs::File`
[INFO] [stdout]  --> src/bin/diagnose_training.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::fs::File;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::Read`
[INFO] [stdout]  --> src/bin/diagnose_training.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::io::Read;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `add_load_method_to_trainer` is never used
[INFO] [stdout]   --> examples/test_model.rs:14:4
[INFO] [stdout]    |
[INFO] [stdout] 14 | fn add_load_method_to_trainer() -> Result<(), Box<dyn Error>> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TextGenerator`
[INFO] [stdout]  --> src/bin/test_multithreading.rs:5:42
[INFO] [stdout]   |
[INFO] [stdout] 5 | use wall_e1::training::{EnhancedTrainer, TextGenerator};
[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: `ProgressBar` and `ProgressStyle`
[INFO] [stdout]   --> src/bin/train_enhanced_model.rs:16:17
[INFO] [stdout]    |
[INFO] [stdout] 16 | use indicatif::{ProgressBar, ProgressStyle};
[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: `Arc`, `AtomicUsize`, `Mutex`, and `Ordering`
[INFO] [stdout]   --> src/bin/train_enhanced_model.rs:17:17
[INFO] [stdout]    |
[INFO] [stdout] 17 | use std::sync::{Arc, Mutex, atomic::{AtomicUsize, Ordering}};
[INFO] [stdout]    |                 ^^^  ^^^^^           ^^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Duration`
[INFO] [stdout]  --> src/nabla/memory_opt.rs:4:26
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::time::{Instant, Duration};
[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: `Axis` and `Ix3`
[INFO] [stdout]  --> src/training/mod.rs:4:46
[INFO] [stdout]   |
[INFO] [stdout] 4 | use ndarray::{Array, Array1, Array2, Array3, Axis, Ix1, Ix2, Ix3, Ix0, IxDyn, s};
[INFO] [stdout]   |                                              ^^^^            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ndarray::Array0`
[INFO] [stdout]   --> src/training/mod.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use ndarray::Array0;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ndarray::array`
[INFO] [stdout]   --> src/training/mod.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use ndarray::array;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::time::Instant`
[INFO] [stdout]   --> src/training/mod.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use std::time::Instant;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Arc`, `Barrier`, and `Mutex`
[INFO] [stdout]   --> src/training/mod.rs:17:17
[INFO] [stdout]    |
[INFO] [stdout] 17 | use std::sync::{Mutex, Arc, Barrier};
[INFO] [stdout]    |                 ^^^^^  ^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `AtomicUsize` and `Ordering`
[INFO] [stdout]   --> src/training/mod.rs:18:25
[INFO] [stdout]    |
[INFO] [stdout] 18 | use std::sync::atomic::{AtomicUsize, Ordering};
[INFO] [stdout]    |                         ^^^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::nabla::memory_opt`
[INFO] [stdout]   --> src/training/enhanced_trainer.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use crate::nabla::memory_opt;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Barrier`
[INFO] [stdout]   --> src/training/enhanced_trainer.rs:19:29
[INFO] [stdout]    |
[INFO] [stdout] 19 | use std::sync::{Arc, Mutex, Barrier};
[INFO] [stdout]    |                             ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `MutexGuard` and `Mutex`
[INFO] [stdout]  --> src/training/batch_dispatcher.rs:4:17
[INFO] [stdout]   |
[INFO] [stdout] 4 | use std::sync::{Mutex, MutexGuard};
[INFO] [stdout]   |                 ^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::thread::ThreadId`
[INFO] [stdout]  --> src/training/batch_dispatcher.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::thread::ThreadId;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `thread_id`
[INFO] [stdout]   --> src/bin/train_enhanced_model.rs:47:13
[INFO] [stdout]    |
[INFO] [stdout] 47 |         let thread_id = format!("{:?}", std::thread::current().id());
[INFO] [stdout]    |             ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_thread_id`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `thread_count`
[INFO] [stdout]    --> src/bin/train_enhanced_model.rs:371:13
[INFO] [stdout]     |
[INFO] [stdout] 371 |         let thread_count = if op == &"data_loading" { min_data_threads } else { pool.get_num_threads() };
[INFO] [stdout]     |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_thread_count`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `setup_start`
[INFO] [stdout]    --> src/bin/train_enhanced_model.rs:428:9
[INFO] [stdout]     |
[INFO] [stdout] 428 |     let setup_start = Instant::now();
[INFO] [stdout]     |         ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_setup_start`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `curriculum_examples` is assigned to, but never used
[INFO] [stdout]    --> src/bin/train_enhanced_model.rs:462:13
[INFO] [stdout]     |
[INFO] [stdout] 462 |     let mut curriculum_examples: usize = 2000;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: consider using `_curriculum_examples` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `auto_resize_vocab` is assigned to, but never used
[INFO] [stdout]    --> src/bin/train_enhanced_model.rs:466:13
[INFO] [stdout]     |
[INFO] [stdout] 466 |     let mut auto_resize_vocab = false;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: consider using `_auto_resize_vocab` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `watchdog_timeout` is assigned to, but never used
[INFO] [stdout]    --> src/bin/train_enhanced_model.rs:467:13
[INFO] [stdout]     |
[INFO] [stdout] 467 |     let mut watchdog_timeout: Option<u64> = None;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: consider using `_watchdog_timeout` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `target_id_max` is assigned to, but never used
[INFO] [stdout]    --> src/bin/train_enhanced_model.rs:470:13
[INFO] [stdout]     |
[INFO] [stdout] 470 |     let mut target_id_max: Option<usize> = None;
[INFO] [stdout]     |             ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: consider using `_target_id_max` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `curriculum_examples` is never read
[INFO] [stdout]    --> src/bin/train_enhanced_model.rs:675:25
[INFO] [stdout]     |
[INFO] [stdout] 675 |                         curriculum_examples = num;
[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 `auto_resize_vocab` is never read
[INFO] [stdout]    --> src/bin/train_enhanced_model.rs:681:17
[INFO] [stdout]     |
[INFO] [stdout] 681 |                 auto_resize_vocab = true;
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `watchdog_timeout` is never read
[INFO] [stdout]    --> src/bin/train_enhanced_model.rs:687:25
[INFO] [stdout]     |
[INFO] [stdout] 687 |                         watchdog_timeout = Some(timeout);
[INFO] [stdout]     |                         ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `target_id_max` is never read
[INFO] [stdout]    --> src/bin/train_enhanced_model.rs:711:25
[INFO] [stdout]     |
[INFO] [stdout] 711 |                         target_id_max = Some(max_id);
[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/bin/train_enhanced_model.rs:1230:9
[INFO] [stdout]      |
[INFO] [stdout] 1230 |     let mut path_with_dir = if !final_save_path_str.starts_with("models/") {
[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: unused variable: `epoch`
[INFO] [stdout]     --> src/bin/train_enhanced_model.rs:1340:68
[INFO] [stdout]      |
[INFO] [stdout] 1340 | fn train_epoch(trainer: &mut EnhancedTrainer, tokens: &Vec<usize>, epoch: usize, 
[INFO] [stdout]      |                                                                    ^^^^^ help: if this is intentional, prefix it with an underscore: `_epoch`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `batch_inputs`
[INFO] [stdout]     --> src/bin/train_enhanced_model.rs:1508:10
[INFO] [stdout]      |
[INFO] [stdout] 1508 |     let (batch_inputs, min_seq_len, truncated_inputs, batch_targets_arr, timing) = pool_result.install(|| {
[INFO] [stdout]      |          ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_batch_inputs`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `min_seq_len`
[INFO] [stdout]     --> src/bin/train_enhanced_model.rs:1508:24
[INFO] [stdout]      |
[INFO] [stdout] 1508 |     let (batch_inputs, min_seq_len, truncated_inputs, batch_targets_arr, timing) = pool_result.install(|| {
[INFO] [stdout]      |                        ^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_min_seq_len`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `k`
[INFO] [stdout]     --> src/bin/train_enhanced_model.rs:1779:13
[INFO] [stdout]      |
[INFO] [stdout] 1779 |     let (m, k) = a.dim();
[INFO] [stdout]      |             ^ help: if this is intentional, prefix it with an underscore: `_k`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `prepare_batch_parallel` is never used
[INFO] [stdout]     --> src/bin/train_enhanced_model.rs:1472:4
[INFO] [stdout]      |
[INFO] [stdout] 1472 | fn prepare_batch_parallel(
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `detect_simd_features` is never used
[INFO] [stdout]     --> src/bin/train_enhanced_model.rs:1691:4
[INFO] [stdout]      |
[INFO] [stdout] 1691 | fn detect_simd_features() -> Vec<String> {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `enable_simd_optimizations` is never used
[INFO] [stdout]     --> src/bin/train_enhanced_model.rs:1728:4
[INFO] [stdout]      |
[INFO] [stdout] 1728 | fn enable_simd_optimizations(features: &[String]) -> bool {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `matrix_multiply_simd` is never used
[INFO] [stdout]     --> src/bin/train_enhanced_model.rs:1774:4
[INFO] [stdout]      |
[INFO] [stdout] 1774 | fn matrix_multiply_simd(a: &ndarray::Array2<f32>, b: &ndarray::Array2<f32>) -> ndarray::Array2<f32> {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `matrix_multiply_avx2` is never used
[INFO] [stdout]     --> src/bin/train_enhanced_model.rs:1844:4
[INFO] [stdout]      |
[INFO] [stdout] 1844 | fn matrix_multiply_avx2(a: &ndarray::Array2<f32>, b: &ndarray::Array2<f32>, result: &mut ndarray::Array2<f32>) {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `matrix_multiply_scalar` is never used
[INFO] [stdout]     --> src/bin/train_enhanced_model.rs:1850:4
[INFO] [stdout]      |
[INFO] [stdout] 1850 | fn matrix_multiply_scalar(a: &ndarray::Array2<f32>, b: &ndarray::Array2<f32>, result: &mut ndarray::Array2<f32>) {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `v`
[INFO] [stdout]   --> src/nabla/memory_opt.rs:88:15
[INFO] [stdout]    |
[INFO] [stdout] 88 |     if let Ok(v) = std::env::var("MALLOC_ARENA_MAX") {
[INFO] [stdout]    |               ^ help: if this is intentional, prefix it with an underscore: `_v`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `count`
[INFO] [stdout]    --> src/tokenizer/word_bpe.rs:420:20
[INFO] [stdout]     |
[INFO] [stdout] 420 |         for (word, count) in word_counts.iter().filter(|&(_, count)| *count >= min_frequency) {
[INFO] [stdout]     |                    ^^^^^ help: if this is intentional, prefix it with an underscore: `_count`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tokens`
[INFO] [stdout]    --> src/tokenizer/word_bpe.rs:745:13
[INFO] [stdout]     |
[INFO] [stdout] 745 |         let tokens = tokenizer.tokenize(text);
[INFO] [stdout]     |             ^^^^^^ help: if this is intentional, prefix it with an underscore: `_tokens`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `tokens_to_add`
[INFO] [stdout]     --> src/training/mod.rs:1315:13
[INFO] [stdout]      |
[INFO] [stdout] 1315 |         let tokens_to_add = new_vocab_size - current_size;
[INFO] [stdout]      |             ^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]      |
[INFO] [stdout] 1315 |         let _tokens_to_add = new_vocab_size - current_size;
[INFO] [stdout]      |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `CHUNK_SIZE`
[INFO] [stdout]      |
[INFO] [stdout] 1315 -         let tokens_to_add = new_vocab_size - current_size;
[INFO] [stdout] 1315 +         let training::enhanced_trainer::EnhancedTrainer::learn_tokenizer_from_text::CHUNK_SIZE = new_vocab_size - current_size;
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `reported_progress` is assigned to, but never used
[INFO] [stdout]    --> src/training/generation.rs:174:17
[INFO] [stdout]     |
[INFO] [stdout] 174 |         let mut reported_progress = false;
[INFO] [stdout]     |                 ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: consider using `_reported_progress` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `reported_progress` is never read
[INFO] [stdout]    --> src/training/generation.rs:181:17
[INFO] [stdout]     |
[INFO] [stdout] 181 |                 reported_progress = true;
[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: unused variable: `batch`
[INFO] [stdout]    --> src/training/enhanced_trainer.rs:538:34
[INFO] [stdout]     |
[INFO] [stdout] 538 |                     if let (Some(batch), Some(target)) = (inputs.get(batch_idx), targets.get(batch_idx)) {
[INFO] [stdout]     |                                  ^^^^^ help: if this is intentional, prefix it with an underscore: `_batch`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `target`
[INFO] [stdout]    --> src/training/enhanced_trainer.rs:538:47
[INFO] [stdout]     |
[INFO] [stdout] 538 |                     if let (Some(batch), Some(target)) = (inputs.get(batch_idx), targets.get(batch_idx)) {
[INFO] [stdout]     |                                               ^^^^^^ help: if this is intentional, prefix it with an underscore: `_target`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/training/enhanced_trainer.rs:542:29
[INFO] [stdout]     |
[INFO] [stdout] 542 |                         let mut loss_guard = loss_mutex.lock().unwrap();
[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: unused variable: `thread_id`
[INFO] [stdout]     --> src/training/enhanced_trainer.rs:3454:13
[INFO] [stdout]      |
[INFO] [stdout] 3454 |         for thread_id in 0..num_threads {
[INFO] [stdout]      |             ^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]      |
[INFO] [stdout] 3454 |         for _thread_id in 0..num_threads {
[INFO] [stdout]      |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `CHUNK_SIZE`
[INFO] [stdout]      |
[INFO] [stdout] 3454 -         for thread_id in 0..num_threads {
[INFO] [stdout] 3454 +         for training::enhanced_trainer::EnhancedTrainer::learn_tokenizer_from_text::CHUNK_SIZE in 0..num_threads {
[INFO] [stdout]      |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `progress_reported` is never read
[INFO] [stdout]     --> src/training/enhanced_trainer.rs:3714:13
[INFO] [stdout]      |
[INFO] [stdout] 3714 |             progress_reported = true;
[INFO] [stdout]      |             ^^^^^^^^^^^^^^^^^
[INFO] [stdout]      |
[INFO] [stdout]      = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `determine_allocator_type` is never used
[INFO] [stdout]   --> src/nabla/memory_opt.rs:79:4
[INFO] [stdout]    |
[INFO] [stdout] 79 | fn determine_allocator_type() -> Option<String> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_total_elapsed` is never used
[INFO] [stdout]    --> src/training/enhanced_trainer.rs:165:8
[INFO] [stdout]     |
[INFO] [stdout] 134 | impl ThreadStateTracker {
[INFO] [stdout]     | ----------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 165 |     fn get_total_elapsed(&self) -> std::time::Duration {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `run_with_timeout` is never used
[INFO] [stdout]     --> src/training/enhanced_trainer.rs:2001:8
[INFO] [stdout]      |
[INFO] [stdout]  201 | impl EnhancedTrainer {
[INFO] [stdout]      | -------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 2001 |     fn run_with_timeout<F, T>(&self, f: F, timeout: std::time::Duration) -> Option<T> 
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `V0_HEADER_SIZE` is never used
[INFO] [stdout]    --> src/training/enhanced_trainer.rs:101:15
[INFO] [stdout]     |
[INFO] [stdout] 101 |     pub const V0_HEADER_SIZE: usize = 32;
[INFO] [stdout]     |               ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `time` is never read
[INFO] [stdout]   --> src/training/batch_dispatcher.rs:44:5
[INFO] [stdout]    |
[INFO] [stdout] 40 | struct LockEvent {
[INFO] [stdout]    |        --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 44 |     time: Instant,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 11.58s
[INFO] running `Command { std: "docker" "inspect" "b74515bfb009a4d3415c0e56e4ca1888c3d2458b45325bcaeada1d375e018afe", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b74515bfb009a4d3415c0e56e4ca1888c3d2458b45325bcaeada1d375e018afe", kill_on_drop: false }`
[INFO] [stdout] b74515bfb009a4d3415c0e56e4ca1888c3d2458b45325bcaeada1d375e018afe
