Rename cell_id to cellid
This commit is contained in:
parent
d1e6f536fb
commit
524d1f85d2
@ -34,10 +34,10 @@ mod tests {
|
|||||||
assert_eq!(extract_binary(0b111100_0_1, 1..=1), 0b0);
|
assert_eq!(extract_binary(0b111100_0_1, 1..=1), 0b0);
|
||||||
|
|
||||||
// A full test from the docs
|
// A full test from the docs
|
||||||
let cell_id = 0b0100101110101000_1011100010010011_1001001100100100_1100000000000000_u64;
|
let cellid = 0b0100101110101000_1011100010010011_1001001100100100_1100000000000000_u64;
|
||||||
assert_eq!(extract_binary(cell_id, 15..=24), 0b10_01001001);
|
assert_eq!(extract_binary(cellid, 15..=24), 0b10_01001001);
|
||||||
assert_eq!(extract_binary(cell_id, 25..=37), 0b01001_11001001);
|
assert_eq!(extract_binary(cellid, 25..=37), 0b01001_11001001);
|
||||||
assert_eq!(extract_binary(cell_id, 38..=50), 0b00010_11100010);
|
assert_eq!(extract_binary(cellid, 38..=50), 0b00010_11100010);
|
||||||
assert_eq!(extract_binary(cell_id, 51..=63), 0b01001_01110101);
|
assert_eq!(extract_binary(cellid, 51..=63), 0b01001_01110101);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
24
src/v0.rs
24
src/v0.rs
@ -13,30 +13,30 @@ pub struct UnpackedCellID {
|
|||||||
|
|
||||||
impl From<CellID> for UnpackedCellID {
|
impl From<CellID> for UnpackedCellID {
|
||||||
/// Convert a `CellID` to an `UnpackedCellID`
|
/// Convert a `CellID` to an `UnpackedCellID`
|
||||||
fn from(cell_id: CellID) -> Self {
|
fn from(cellid: CellID) -> Self {
|
||||||
Self::from(cell_id.0)
|
Self::from(cellid.0)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl From<u64> for UnpackedCellID {
|
impl From<u64> for UnpackedCellID {
|
||||||
fn from(cell_id: u64) -> Self {
|
fn from(cellid: u64) -> Self {
|
||||||
Self {
|
Self {
|
||||||
number_bits: conversions::extract_binary(cell_id, 15..=24) as u16,
|
number_bits: conversions::extract_binary(cellid, 15..=24) as u16,
|
||||||
word0_bits: conversions::extract_binary(cell_id, 25..=37) as u16,
|
word0_bits: conversions::extract_binary(cellid, 25..=37) as u16,
|
||||||
word1_bits: conversions::extract_binary(cell_id, 38..=50) as u16,
|
word1_bits: conversions::extract_binary(cellid, 38..=50) as u16,
|
||||||
word2_bits: conversions::extract_binary(cell_id, 51..=63) as u16,
|
word2_bits: conversions::extract_binary(cellid, 51..=63) as u16,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl From<UnpackedCellID> for Address<'_> {
|
impl From<UnpackedCellID> for Address<'_> {
|
||||||
fn from(unpacked_cell_id: UnpackedCellID) -> Self {
|
fn from(unpacked_cellid: UnpackedCellID) -> Self {
|
||||||
let word0 = words::NUMBER_TO_WORDS[unpacked_cell_id.word0_bits as usize][0];
|
let word0 = words::NUMBER_TO_WORDS[unpacked_cellid.word0_bits as usize][0];
|
||||||
let word1 = words::NUMBER_TO_WORDS[unpacked_cell_id.word1_bits as usize][0];
|
let word1 = words::NUMBER_TO_WORDS[unpacked_cellid.word1_bits as usize][0];
|
||||||
let word2 = words::NUMBER_TO_WORDS[unpacked_cell_id.word2_bits as usize][0];
|
let word2 = words::NUMBER_TO_WORDS[unpacked_cellid.word2_bits as usize][0];
|
||||||
|
|
||||||
Self {
|
Self {
|
||||||
number: u32::from(unpacked_cell_id.number_bits),
|
number: u32::from(unpacked_cellid.number_bits),
|
||||||
words: [word0, word1, word2],
|
words: [word0, word1, word2],
|
||||||
version: Version::V0,
|
version: Version::V0,
|
||||||
}
|
}
|
||||||
|
@ -29,25 +29,25 @@ fn test_cellid_translation() {
|
|||||||
|
|
||||||
eprintln!(
|
eprintln!(
|
||||||
"Entry: ({},{}) => {:0>64b}",
|
"Entry: ({},{}) => {:0>64b}",
|
||||||
entry.lat, entry.lon, entry.cell_id
|
entry.lat, entry.lon, entry.cellid
|
||||||
);
|
);
|
||||||
eprintln!("\taddr: {addr}");
|
eprintln!("\taddr: {addr}");
|
||||||
|
|
||||||
// Make sure the rust s2 implementation is accurate
|
// Make sure the rust s2 implementation is accurate
|
||||||
assert_eq!(entry.cell_id, CellID(entry.cell_id).0);
|
assert_eq!(entry.cellid, CellID(entry.cellid).0);
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
(entry.cell_id & CELLID_LEVEL_23_BITMASK) | CELLID_LEVEL_23_END_BIT,
|
(entry.cellid & CELLID_LEVEL_23_BITMASK) | CELLID_LEVEL_23_END_BIT,
|
||||||
CellID(entry.cell_id).parent(CELLID_LEVEL).0
|
CellID(entry.cellid).parent(CELLID_LEVEL).0
|
||||||
);
|
);
|
||||||
|
|
||||||
// Make sure the address is at the right level
|
// Make sure the address is at the right level
|
||||||
assert_eq!(addr_cellid.level(), CELLID_LEVEL);
|
assert_eq!(addr_cellid.level(), CELLID_LEVEL);
|
||||||
|
|
||||||
// Next, check if creating an address from a cellid matches itself
|
// Next, check if creating an address from a cellid matches itself
|
||||||
assert_eq!(addr, Address::from_cellid_u64(entry.cell_id));
|
assert_eq!(addr, Address::from_cellid_u64(entry.cellid));
|
||||||
|
|
||||||
// Now check if the actual cell id matches
|
// Now check if the actual cell id matches
|
||||||
assert_eq_u64!(addr_cellid.0, CellID(entry.cell_id).parent(CELLID_LEVEL).0);
|
assert_eq_u64!(addr_cellid.0, CellID(entry.cellid).parent(CELLID_LEVEL).0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user