diff options
author | eug-vs <eugene@eug-vs.xyz> | 2023-01-21 00:47:57 +0300 |
---|---|---|
committer | eug-vs <eugene@eug-vs.xyz> | 2023-01-21 00:49:16 +0300 |
commit | 46cbe2683efbbdef1e445722617ecf9905d92652 (patch) | |
tree | 6407acf3a34db34bd48185d83dd189c4eb183988 /src | |
parent | 0a890b42e8b701feed27faee4b0caf601f5bb258 (diff) | |
download | chessnost-46cbe2683efbbdef1e445722617ecf9905d92652.tar.gz |
refactor: do not pass u64 by reference
This is pointless since size of a pointer is also 64 bit on x64
systems, so we are not saving any memory at this point
Diffstat (limited to 'src')
-rw-r--r-- | src/bitboard.rs | 33 |
1 files changed, 16 insertions, 17 deletions
diff --git a/src/bitboard.rs b/src/bitboard.rs index 6aba264..0b62f87 100644 --- a/src/bitboard.rs +++ b/src/bitboard.rs @@ -2,7 +2,7 @@ pub type Bitboard = u64; /// Print bitboard on screen in the same way squares appear in memory /// (i.e the board is actually flipped along X) -pub fn print(bb: &Bitboard) { +pub fn print(bb: Bitboard) { for index in 0..64 { print!("{}", if bb >> index & 1 == 1 { "1" } else { "." }); if (index + 1) % 8 == 0 { @@ -13,15 +13,15 @@ pub fn print(bb: &Bitboard) { } /// Return bitboard cardinality, aka number of elements in the set -pub fn pop_count(bb: &Bitboard) -> u8 { - if bb == &0u64 { +pub fn pop_count(bb: Bitboard) -> u8 { + if bb == 0 { return 0; } - return pop_count(&(bb >> 1)) + (bb & 1) as u8; + return pop_count(bb >> 1) + (bb & 1) as u8; } /// Return Bitboard with only Least Single Bit -pub fn ls1b(bb: &Bitboard) -> u64 { +pub fn ls1b(bb: Bitboard) -> u64 { bb & !(bb - 1) } @@ -29,40 +29,39 @@ pub fn ls1b(bb: &Bitboard) -> u64 { /// /// WARNING: Only works for SINGLE Bitboards /// Useful for calculating bit-index of LS1B -pub fn bitscan(bb: &Bitboard) -> u8 { +pub fn bitscan(bb: Bitboard) -> u8 { debug_assert!(pop_count(bb) == 1, "Bitscan only works for SINGLE Bitboards!"); - pop_count(&(bb - 1)) + pop_count(bb - 1) } - #[cfg(test)] mod tests { use super::*; #[test] fn test_pop_count() { - assert_eq!(pop_count(&127), 7); + assert_eq!(pop_count(127), 7); } #[test] fn test_ls1b() { - assert_eq!(ls1b(&38), 2); - assert_eq!(ls1b(&16), 16); - assert_eq!(ls1b(&20), 4); + assert_eq!(ls1b(38), 2); + assert_eq!(ls1b(16), 16); + assert_eq!(ls1b(20), 4); } #[test] fn test_bitscan() { - assert_eq!(bitscan(&4), 2); - assert_eq!(bitscan(&16), 4); - assert_eq!(bitscan(&64), 6); - assert_eq!(bitscan(&128), 7); + assert_eq!(bitscan(4), 2); + assert_eq!(bitscan(16), 4); + assert_eq!(bitscan(64), 6); + assert_eq!(bitscan(128), 7); } #[test] #[should_panic(expected = "Bitscan only works for SINGLE Bitboards!")] fn test_bitscan_with_non_single_bb() { - bitscan(&5); + bitscan(5); } } |