Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

refactor!: rework cmap2 index & attribute system #36

Merged
merged 31 commits into from
Apr 16, 2024
Merged
Changes from 1 commit
Commits
Show all changes
31 commits
Select commit Hold shift + click to select a range
512fc22
refactor: remove useless field for the new impl
imrn99 Apr 12, 2024
a8442c7
refactor: update CMap2 constructor
imrn99 Apr 12, 2024
e0bd812
refactor: update orbits content
imrn99 Apr 12, 2024
95ee726
refacto: copy paste the content of the rework-icells branch
imrn99 Apr 12, 2024
716ec92
chore: update imports in twomap module
imrn99 Apr 12, 2024
5cc40dd
feat: add collection types for i-cells
imrn99 Apr 12, 2024
5302e73
fix: update some of the vertex related methods of CMap2
imrn99 Apr 12, 2024
574f56f
refactor: adjust size methods
imrn99 Apr 12, 2024
4e3621c
refactor: update generation mod & constructor sig
imrn99 Apr 12, 2024
3136288
refactor: change replace method behavior
imrn99 Apr 12, 2024
d01bc3e
refactor: rename CMap2::set_vertex to replace_vertex
imrn99 Apr 12, 2024
5e555b4
refactor: remove old CMap2 example
imrn99 Apr 12, 2024
1c007f6
refactor: update render handle code
imrn99 Apr 12, 2024
bcc05e1
fix: remove unecessary iterator copy in handle code
imrn99 Apr 15, 2024
4758fce
fix: update benchmark code
imrn99 Apr 15, 2024
0746728
fix: update splitsquaremap shift benchmark
imrn99 Apr 15, 2024
59ecf1e
fix: finish benchmark code updates
imrn99 Apr 15, 2024
af51813
refactor: update one/two_sew methods to use the new system
imrn99 Apr 15, 2024
5202e4e
refactor: rewrite unsew methods
imrn99 Apr 15, 2024
7279af4
refactor: update sew methods signature
imrn99 Apr 15, 2024
fdd6f06
fix: update (un)sew usagesto match signature
imrn99 Apr 15, 2024
4ed255f
fix: rewrite on unsew to use Attr::split
imrn99 Apr 15, 2024
78fa546
fix: change map size back to original value in benches
imrn99 Apr 15, 2024
e89f4fa
feat: add back the orientation check to two_sew
imrn99 Apr 15, 2024
3eb40c2
feat: complete size methods of attribute storage structs
imrn99 Apr 15, 2024
831080e
refactor: move the length+1 op to CMap2::new() from the storages
imrn99 Apr 16, 2024
f75efab
refactor: remove useless CMapError variant & add doc
imrn99 Apr 16, 2024
90e7cfd
doc: add doc & comment about the new ID computation
imrn99 Apr 16, 2024
9460d80
doc: adjust CMap2::i_cell doc to better reflect return type
imrn99 Apr 16, 2024
decb9ac
refactor: rename phantom data attribute in cell collections structs
imrn99 Apr 16, 2024
cd1a7d2
doc: add explanation on safe vertex removal in core/editing bench
imrn99 Apr 16, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
doc: add doc & comment about the new ID computation
imrn99 committed Apr 16, 2024
commit 90e7cfd03f25cc6b2da0c3d64c2ebe3964d6587a
42 changes: 42 additions & 0 deletions honeycomb-core/src/twomap.rs
Original file line number Diff line number Diff line change
@@ -387,7 +387,21 @@ impl<T: CoordsFloat> CMap2<T> {
///
/// Return the identifier of the associated vertex.
///
/// Cells identifiers are defined as the smallest identifier among the darts that make up the
/// cell. This definition has three interesting properties:
///
/// - A given cell ID can be computed from any dart of the cell, i.e. all darts have an
/// associated cell ID.
/// - Cell IDs are not affected by the order of traversal of the map.
/// - Because the ID is computed in real time, there is no need to store cell IDs and ensure
/// that the storage is consistent / up to date.
///
/// These properties come at the literal cost of the computation routine, which is:
/// 1. a BFS to compute a given orbit
/// 2. a minimum computation on the IDs composing the orbit
///
pub fn vertex_id(&self, dart_id: DartIdentifier) -> VertexIdentifier {
// unwraping the result is safe because the orbit is always non empty
Orbit2::new(self, OrbitPolicy::Vertex, dart_id)
.min()
.unwrap() as VertexIdentifier
@@ -403,7 +417,21 @@ impl<T: CoordsFloat> CMap2<T> {
///
/// Return the identifier of the associated edge.
///
/// Cells identifiers are defined as the smallest identifier among the darts that make up the
/// cell. This definition has three interesting properties:
///
/// - A given cell ID can be computed from any dart of the cell, i.e. all darts have an
/// associated cell ID.
/// - Cell IDs are not affected by the order of traversal of the map.
/// - Because the ID is computed in real time, there is no need to store cell IDs and ensure
/// that the storage is consistent / up to date.
///
/// These properties come at the literal cost of the computation routine, which is:
/// 1. a BFS to compute a given orbit
/// 2. a minimum computation on the IDs composing the orbit
///
pub fn edge_id(&self, dart_id: DartIdentifier) -> EdgeIdentifier {
// unwraping the result is safe because the orbit is always non empty
Orbit2::new(self, OrbitPolicy::Edge, dart_id).min().unwrap() as EdgeIdentifier
}

@@ -417,7 +445,21 @@ impl<T: CoordsFloat> CMap2<T> {
///
/// Return the identifier of the associated face.
///
/// Cells identifiers are defined as the smallest identifier among the darts that make up the
/// cell. This definition has three interesting properties:
///
/// - A given cell ID can be computed from any dart of the cell, i.e. all darts have an
/// associated cell ID.
/// - Cell IDs are not affected by the order of traversal of the map.
/// - Because the ID is computed in real time, there is no need to store cell IDs and ensure
/// that the storage is consistent / up to date.
///
/// These properties come at the literal cost of the computation routine, which is:
/// 1. a BFS to compute a given orbit
/// 2. a minimum computation on the IDs composing the orbit
///
pub fn face_id(&self, dart_id: DartIdentifier) -> FaceIdentifier {
// unwraping the result is safe because the orbit is always non empty
Orbit2::new(self, OrbitPolicy::Face, dart_id).min().unwrap() as FaceIdentifier
imrn99 marked this conversation as resolved.
Show resolved Hide resolved
}