Compare commits
	
		
			No commits in common. "72d81439c12f3fad32d714aaaed1ca4b039afa17" and "c3995f572506094758b4c5719db5af5a994e00df" have entirely different histories.
		
	
	
		
			72d81439c1
			...
			c3995f5725
		
	
		|  | @ -109,24 +109,22 @@ impl TransferRegion { | |||
|     } | ||||
| 
 | ||||
|     pub fn get_destination_wells(&self) -> Vec<(u8, u8)> { | ||||
|         match &self.source_region { | ||||
|             Region::Custom(c) => c.dest.clone(), | ||||
|             _ => { | ||||
|         let map = self.calculate_map(); | ||||
|         let source_wells = self.get_source_wells(); | ||||
| 
 | ||||
|         let mut wells = Vec::<(u8, u8)>::new(); | ||||
| 
 | ||||
|         // log::debug!("GDW:");
 | ||||
|         for well in source_wells { | ||||
|             if let Some(mut dest_wells) = map(well) { | ||||
|                 // log::debug!("Map {:?} to {:?}", well, dest_wells);
 | ||||
|                 wells.append(&mut dest_wells); | ||||
|             } | ||||
|         } | ||||
|         // log::debug!("GDW END.");
 | ||||
| 
 | ||||
|         wells | ||||
|     } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     #[allow(clippy::type_complexity)] // Resolving gives inherent associated type error
 | ||||
|     pub fn calculate_map(&self) -> Box<dyn Fn((u8, u8)) -> Option<Vec<(u8, u8)>> + '_> { | ||||
|  | @ -206,16 +204,14 @@ impl TransferRegion { | |||
|                             // How many times can we replicate?
 | ||||
|                             (1..) | ||||
|                                 .position(|n| { | ||||
|                                     n * number_used_src_wells.0 * il_dest.0.unsigned_abs() | ||||
|                                         - il_dest.0.unsigned_abs() | ||||
|                                     n * number_used_src_wells.0 * il_dest.0.unsigned_abs() - il_dest.0.unsigned_abs() | ||||
|                                         + 1 | ||||
|                                         > d_dims.0 | ||||
|                                 }) | ||||
|                                 .unwrap() as u8, | ||||
|                             (1..) | ||||
|                                 .position(|n| { | ||||
|                                     n * number_used_src_wells.1 * il_dest.1.unsigned_abs() | ||||
|                                         - il_dest.1.unsigned_abs() | ||||
|                                     n * number_used_src_wells.1 * il_dest.1.unsigned_abs() - il_dest.1.unsigned_abs() | ||||
|                                         + 1 | ||||
|                                         > d_dims.1 | ||||
|                                 }) | ||||
|  | @ -246,12 +242,14 @@ impl TransferRegion { | |||
|                                 .filter(|(x, y)| { | ||||
|                                     // How many times have we replicated? < How many are we allowed
 | ||||
|                                     // to replicate?
 | ||||
|                                     x.checked_sub(d_ul.0).unwrap().div_euclid( | ||||
|                                         number_used_src_wells.0 * il_dest.0.unsigned_abs(), | ||||
|                                     ) < count.0 | ||||
|                                         && y.checked_sub(d_ul.1).unwrap().div_euclid( | ||||
|                                             number_used_src_wells.1 * il_dest.1.unsigned_abs(), | ||||
|                                         ) < count.1 | ||||
|                                     x.checked_sub(d_ul.0) | ||||
|                                         .unwrap() | ||||
|                                         .div_euclid(number_used_src_wells.0 * il_dest.0.unsigned_abs()) | ||||
|                                         < count.0 | ||||
|                                         && y.checked_sub(d_ul.1) | ||||
|                                             .unwrap() | ||||
|                                             .div_euclid(number_used_src_wells.1 * il_dest.1.unsigned_abs()) | ||||
|                                             < count.1 | ||||
|                                 }) | ||||
|                                 .collect(), | ||||
|                         ) | ||||
|  |  | |||
|  | @ -1,6 +1,7 @@ | |||
| pub fn letters_to_num(letters: &str) -> Option<u8> { | ||||
|     let mut num: u8 = 0; | ||||
|     for (i, letter) in letters.to_ascii_uppercase().chars().rev().enumerate() { | ||||
|         log::debug!("{}, {}", i, letter); | ||||
|         let n = letter as u8; | ||||
|         if !(65..=90).contains(&n) { | ||||
|             return None; | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue