From 31eb5008322d9971b79aebc94faaaac7b9be0f26 Mon Sep 17 00:00:00 2001 From: Keenan Tims Date: Wed, 11 Dec 2024 19:40:45 -0800 Subject: [PATCH] day7: slight performance improvement from skipping ThreadLoacls --- src/day7.rs | 7 ++----- 1 file changed, 2 insertions(+), 5 deletions(-) diff --git a/src/day7.rs b/src/day7.rs index 715f38b..3c67097 100644 --- a/src/day7.rs +++ b/src/day7.rs @@ -2,7 +2,6 @@ use aoc_runner_derive::{aoc, aoc_generator}; use itertools::Itertools; use rayon::iter::{IntoParallelRefIterator, ParallelIterator}; use std::io::{BufRead, Lines}; -use thread_local::ThreadLocal; #[aoc_generator(day7)] pub fn get_input(input: &[u8]) -> Calibrations { @@ -43,7 +42,7 @@ impl Operator { match self { Operator::Add => a + b, Operator::Multiply => a * b, - Operator::Concatenate => u64::pow(10, u64::ilog10(b) + 1) * a + b, + Operator::Concatenate => u64::pow(10, b.ilog10() + 1) * a + b, } } } @@ -84,14 +83,12 @@ impl Calibrations { .par_iter() .map(|cal| { let n_opers = cal.numbers.len() - 1; - let tl = ThreadLocal::new(); if operator_sets[n_opers] .par_iter() .find_any(|oper_set| Self::check_oper_set(cal, oper_set)) .is_some() { - let cal_local = tl.get_or(|| cal.clone()); - return cal_local.result; + return cal.result; } 0 })