day19: rayon - ez mode parallelization, speed * 6
All checks were successful
test / AoC 2024 (push) Successful in 3m16s

This commit is contained in:
Keenan Tims 2024-12-18 23:07:13 -08:00
parent 6b6dededc2
commit c2e3422544
Signed by: ktims
GPG Key ID: 11230674D69038D4

View File

@ -1,5 +1,6 @@
use aoc_runner_derive::aoc; use aoc_runner_derive::aoc;
use itertools::Itertools; use itertools::Itertools;
use rayon::iter::{IntoParallelIterator, ParallelIterator};
use rustc_hash::FxHashMap; use rustc_hash::FxHashMap;
use std::fmt::{Display, Write}; use std::fmt::{Display, Write};
@ -39,7 +40,7 @@ impl Display for Stripe {
} }
} }
#[derive(Debug)] #[derive(Debug, Clone)]
struct Design { struct Design {
stripes: Vec<Stripe>, stripes: Vec<Stripe>,
} }
@ -118,14 +119,16 @@ impl Onsen {
} }
fn count_possible(&self) -> i64 { fn count_possible(&self) -> i64 {
self.designs self.designs
.iter() .clone()
.into_par_iter()
.map(|d| self.possible(&d.stripes)) .map(|d| self.possible(&d.stripes))
.filter(|p| *p) .filter(|p| *p)
.count() as i64 .count() as i64
} }
fn count_ways(&self) -> i64 { fn count_ways(&self) -> i64 {
self.designs self.designs
.iter() .clone()
.into_par_iter()
.map(|d| self.ways(&d.stripes, FxHashMap::default()).1) .map(|d| self.ways(&d.stripes, FxHashMap::default()).1)
.sum::<i64>() .sum::<i64>()
} }