CMap2

Struct CMap2 

Source
pub struct CMap2<T: CoordsFloat> { /* private fields */ }
Expand description

§2D combinatorial map implementation

Information regarding maps can be found in the user guide. This documentation focuses on the implementation and its API.

Notes on implementation:

  • We encode β0 as the inverse function of β1. This is extremely useful (read required) to implement correct and efficient i-cell computation. Additionally, while β0 can be accessed using the beta method, we do not define the 0-sew / 0-unsew operations.
  • We chose a boundary-less representation of meshes (i.e. darts on the boundary are 2-free).
  • The null dart will always be encoded as 0.

§Generics

  • T: CoordsFloat – Generic FP type for coordinates representation

§Example

The following code corresponds to this flow of operations:

CMAP2_EXAMPLE

Note that:

  • we create the map using its builder structure: CMapBuilder
  • we insert a few assertions to demonstrate the progressive changes applied to the structure
  • even though the faces are represented in the figure, they are not stored in the structure
  • we use a lot of methods with the force_ prefix; these are convenience methods when synchronization isn’t needed
use honeycomb_core::{
    cmap::{CMap2, CMapBuilder, OrbitPolicy},
    geometry::Vertex2
};

// build a triangle (A)
let mut map: CMap2<f64> = CMapBuilder::<2>::from_n_darts(3).build().unwrap(); // three darts
map.force_link::<1>(1, 2); // beta1(1) = 2 & beta0(2) = 1
map.force_link::<1>(2, 3); // beta1(2) = 3 & beta0(3) = 2
map.force_link::<1>(3, 1); // beta1(3) = 1 & beta0(1) = 3
map.force_write_vertex(1, (0.0, 0.0));
map.force_write_vertex(2, (1.0, 0.0));
map.force_write_vertex(3, (0.0, 1.0));

// we can go through the face using an orbit
{
    let mut face = map.orbit(OrbitPolicy::Face, 1);
    assert_eq!(face.next(), Some(1));
    assert_eq!(face.next(), Some(2));
    assert_eq!(face.next(), Some(3));
    assert_eq!(face.next(), None);
}

// build a second triangle (B)
let first_added_dart_id = map.allocate_used_darts(3);
assert_eq!(first_added_dart_id, 4);
map.force_link::<1>(4, 5);
map.force_link::<1>(5, 6);
map.force_link::<1>(6, 4);
map.force_write_vertex(4, (0.0, 2.0));
map.force_write_vertex(5, (2.0, 0.0));
map.force_write_vertex(6, (1.0, 1.0));

// there should be two faces now
let faces: Vec<_> = map.iter_faces().collect();
assert_eq!(&faces, &[1, 4]);

// sew both triangles (C)
map.force_sew::<2>(2, 4);

// there are 5 edges now, making up a square & its diagonal
let edges: Vec<_> = map.iter_edges().collect();
assert_eq!(&edges, &[1, 2, 3, 5, 6]);

// adjust bottom-right & top-left vertex position (D)
assert_eq!(
    map.force_write_vertex(2, Vertex2::from((1.0, 0.0))),
    Some(Vertex2(1.5, 0.0)) // `write` act as a `replace`
);
assert_eq!(
    map.force_write_vertex(3, Vertex2::from((0.0, 1.0))),
    Some(Vertex2(0.0, 1.5)) // these values were the average of sewn vertices
);

// separate the diagonal from the rest (E)
map.force_unsew::<1>(1);
map.force_unsew::<1>(2);
map.force_unsew::<1>(6);
map.force_unsew::<1>(4);
// break up & remove the diagonal
map.force_unsew::<2>(2); // this makes dart 2 and 4 free
map.release_dart(2);
map.release_dart(4);
// sew the square back up
map.force_sew::<1>(1, 5);
map.force_sew::<1>(6, 3);

// there's only the square face left
let faces: Vec<_> = map.iter_faces().collect();
assert_eq!(&faces, &[1]);
// we can check the vertices
let vertices = map.iter_vertices();
let mut value_iterator = vertices.map(|vertex_id| map.force_read_vertex(vertex_id).unwrap());
assert_eq!(value_iterator.next(), Some(Vertex2::from((0.0, 0.0)))); // vertex ID 1
assert_eq!(value_iterator.next(), Some(Vertex2::from((0.0, 1.0)))); // vertex ID 3
assert_eq!(value_iterator.next(), Some(Vertex2::from((1.0, 0.0)))); // vertex ID 5
assert_eq!(value_iterator.next(), Some(Vertex2::from((1.0, 1.0)))); // vertex ID 6

Implementations§

Source§

impl<T: CoordsFloat> CMap2<T>

Beta-related methods

Source

pub fn beta<const I: u8>(&self, dart_id: DartIdType) -> DartIdType

Return βI(dart_id).

§Panics

The method will panic if I is not 0, 1 or 2.

Source

pub fn beta_rt(&self, i: u8, dart_id: DartIdType) -> DartIdType

Return βi(dart_id).

§Panics

The method will panic if i is not 0, 1 or 2.

Source

pub fn beta_tx<const I: u8>( &self, t: &mut Transaction, dart_id: DartIdType, ) -> StmClosureResult<DartIdType>

Return βI(dart_id).

§Errors

This method is meant to be called in a context where the returned Result is used to validate the transaction passed as argument. Errors should not be processed manually, only processed via the ? operator.

§Panics

The method will panic if I is not 0, 1 or 2.

Source

pub fn beta_rt_tx( &self, t: &mut Transaction, i: u8, dart_id: DartIdType, ) -> StmClosureResult<DartIdType>

Return βi(dart_id).

§Errors

This method is meant to be called in a context where the returned Result is used to validate the transaction passed as argument. Errors should not be processed manually, only processed via the ? operator.

§Panics

The method will panic if i is not 0, 1 or 2.

Source

pub fn is_i_free<const I: u8>(&self, dart_id: DartIdType) -> bool

Check if a given dart is I-free.

§Return

Return a boolean indicating if the dart is I-free, i.e.:

  • true if βI(dart_id) = NULL_DART_ID,
  • false else.
§Panics

The function will panic if I is not 0, 1 or 2.

Source

pub fn is_free(&self, dart_id: DartIdType) -> bool

Check if a given dart is i-free, for all i.

§Return

Return a boolean indicating if the dart is 0-free, 1-free and 2-free.

Source

pub fn is_free_tx( &self, t: &mut Transaction, dart_id: DartIdType, ) -> StmClosureResult<bool>

Check if a given dart is i-free, for all i.

§Return / Errors

Return a boolean indicating if the dart is 0-free, 1-free and 2-free.

This method is meant to be called in a context where the returned Result is used to validate the transaction passed as argument. Errors should not be processed manually, only processed via the ? operator.

Source§

impl<T: CoordsFloat> CMap2<T>

I-cell-related methods

Source

pub fn vertex_id(&self, dart_id: DartIdType) -> VertexIdType

Compute the ID of the vertex a given dart is part of.

This corresponds to the minimum dart ID among darts composing the 0-cell orbit.

Source

pub fn vertex_id_tx( &self, t: &mut Transaction, dart_id: DartIdType, ) -> StmClosureResult<VertexIdType>

Compute the ID of the vertex a given dart is part of.

This corresponds to the minimum dart ID among darts composing the 0-cell orbit.

§Errors

This method is meant to be called in a context where the returned Result is used to validate the transaction passed as argument. Errors should not be processed manually, only processed via the ? operator.

Source

pub fn edge_id(&self, dart_id: DartIdType) -> EdgeIdType

Compute the ID of the edge a given dart is part of.

This corresponds to the minimum dart ID among darts composing the 1-cell orbit.

Source

pub fn edge_id_tx( &self, t: &mut Transaction, dart_id: DartIdType, ) -> StmClosureResult<EdgeIdType>

Compute the ID of the edge a given dart is part of.

This corresponds to the minimum dart ID among darts composing the 1-cell orbit.

§Errors

This method is meant to be called in a context where the returned Result is used to validate the transaction passed as argument. Errors should not be processed manually, only processed via the ? operator.

Source

pub fn face_id(&self, dart_id: DartIdType) -> FaceIdType

Compute the ID of the face a given dart is part of.

This corresponds to the minimum dart ID among darts composing the 2-cell orbit.

Source

pub fn face_id_tx( &self, t: &mut Transaction, dart_id: DartIdType, ) -> StmClosureResult<FaceIdType>

Compute the ID of the face a given dart is part of.

This corresponds to the minimum dart ID among darts composing the 2-cell orbit.

§Errors

This method is meant to be called in a context where the returned Result is used to validate the transaction passed as argument. Errors should not be processed manually, only processed via the ? operator.

Source

pub fn iter_vertices(&self) -> impl Iterator<Item = VertexIdType> + '_

Return an iterator over IDs of all the map’s vertices.

Source

pub fn iter_edges(&self) -> impl Iterator<Item = EdgeIdType> + '_

Return an iterator over IDs of all the map’s edges.

Source

pub fn iter_faces(&self) -> impl Iterator<Item = FaceIdType> + '_

Return an iterator over IDs of all the map’s faces.

Source

pub fn par_iter_vertices( &self, ) -> impl ParallelIterator<Item = VertexIdType> + '_

Return an iterator over IDs of all the map’s vertices.

Source

pub fn par_iter_edges(&self) -> impl ParallelIterator<Item = EdgeIdType> + '_

Return an iterator over IDs of all the map’s edges.

Source

pub fn par_iter_faces(&self) -> impl ParallelIterator<Item = FaceIdType> + '_

Return an iterator over IDs of all the map’s faces.

Source§

impl<T: CoordsFloat> CMap2<T>

Built-in vertex-related methods

Source

pub fn n_vertices(&self) -> usize

Return the current number of vertices.

Source

pub fn read_vertex( &self, t: &mut Transaction, vertex_id: VertexIdType, ) -> StmClosureResult<Option<Vertex2<T>>>

Return the vertex associated to a given identifier.

§Return / Errors

This method is meant to be called in a context where the returned Result is used to validate the transaction passed as argument. Errors should not be processed manually, only processed via the ? operator.

This method return a Option taking the following values:

  • Some(v: Vertex2) if there is a vertex associated to this ID,
  • None otherwise.
§Panics

The method may panic if:

  • the index lands out of bounds,
  • the index cannot be converted to usize.
Source

pub fn write_vertex( &self, t: &mut Transaction, vertex_id: VertexIdType, vertex: impl Into<Vertex2<T>>, ) -> StmClosureResult<Option<Vertex2<T>>>

Replace the vertex associated to a given identifier and return its old value.

§Arguments
  • vertex_id: VertexIdentifier – Identifier of the vertex to replace.
  • vertex: impl Into<Vertex2> – New Vertex2 value.
§Return / Errors

This method is meant to be called in a context where the returned Result is used to validate the transaction passed as argument. Errors should not be processed manually, only processed via the ? operator.

The result contains an Option taking the following values:

  • Some(v: Vertex2) if there was an old value,
  • None otherwise.
§Panics

The method may panic if:

  • the index lands out of bounds,
  • the index cannot be converted to usize.
Source

pub fn remove_vertex( &self, t: &mut Transaction, vertex_id: VertexIdType, ) -> StmClosureResult<Option<Vertex2<T>>>

Remove the vertex associated to a given identifier and return it.

§Return / Errors

This method is meant to be called in a context where the returned Result is used to validate the transaction passed as argument. Errors should not be processed manually,

The result contains an Option taking the following values:

  • Some(v: Vertex2) if there was a value,
  • None otherwise.
§Panics

The method may panic if:

  • the index lands out of bounds,
  • the index cannot be converted to usize.
Source

pub fn force_read_vertex(&self, vertex_id: VertexIdType) -> Option<Vertex2<T>>

Read the vertex associated to a given identifier.

This variant is equivalent to read_vertex, but internally uses a transaction that will be retried until validated.

Source

pub fn force_write_vertex( &self, vertex_id: VertexIdType, vertex: impl Into<Vertex2<T>>, ) -> Option<Vertex2<T>>

Replace the vertex associated to a given identifier and return its old value.

This variant is equivalent to write_vertex, but internally uses a transaction that will be retried until validated.

Source

pub fn force_remove_vertex(&self, vertex_id: VertexIdType) -> Option<Vertex2<T>>

Remove the vertex associated to a given identifier and return it.

This variant is equivalent to remove_vertex, but internally uses a transaction that will be retried until validated.

Source§

impl<T: CoordsFloat> CMap2<T>

Generic attribute-related methods

Source

pub fn read_attribute<A: AttributeBind + AttributeUpdate>( &self, t: &mut Transaction, id: A::IdentifierType, ) -> StmClosureResult<Option<A>>

Return the attribute A value associated to a given identifier.

The kind of cell A binds to is automatically deduced using its AttributeBind implementation.

§Return / Errors

This method is meant to be called in a context where the returned Result is used to validate the transaction passed as argument. Errors should not be processed manually, only processed via the ? operator.

This method return a Option taking the following values:

  • Some(a: A) if there is a value associated to this ID,
  • None otherwise, or if there is no storage for this kind of attribute in the map.
§Panics

The method may panic if:

  • the index lands out of bounds,
  • the index cannot be converted to usize.
Source

pub fn write_attribute<A: AttributeBind + AttributeUpdate>( &self, t: &mut Transaction, id: A::IdentifierType, val: A, ) -> StmClosureResult<Option<A>>

Replace the attribute A value associated to a given identifier and return its old value.

§Arguments
  • index: A::IdentifierType – Identifier of the cell’s value to replace.
  • val: A – Attribute value.
§Return / Errors

This method is meant to be called in a context where the returned Result is used to validate the transaction passed as argument. Errors should not be processed manually, only processed via the ? operator.

The result contains an Option taking the following values:

  • Some(a: A) if there was an old value,
  • None otherwise, or if there is no storage for this kind of attribute in the map.
§Panics

The method may panic if:

  • the index lands out of bounds,
  • the index cannot be converted to usize.
Source

pub fn remove_attribute<A: AttributeBind + AttributeUpdate>( &self, t: &mut Transaction, id: A::IdentifierType, ) -> StmClosureResult<Option<A>>

Remove the attribute A value associated to a given identifier and return it.

§Return / Errors

This method is meant to be called in a context where the returned Result is used to validate the transaction passed as argument. Errors should not be processed manually, only processed via the ? operator.

The result contains an Option taking the following values:

  • Some(a: A) if there was a value,
  • None otherwise, or if there is no storage for this kind of attribute in the map.
§Panics

The method may panic if:

  • the index lands out of bounds,
  • the index cannot be converted to usize.
Source

pub fn force_read_attribute<A: AttributeBind + AttributeUpdate>( &self, id: A::IdentifierType, ) -> Option<A>

Return the attribute A value associated to a given identifier.

This variant is equivalent to read_attribute, but internally uses a transaction that will be retried until validated.

Source

pub fn force_write_attribute<A: AttributeBind + AttributeUpdate>( &self, id: A::IdentifierType, val: A, ) -> Option<A>

Replace the attribute A value associated to a given identifier and return its old value.

This variant is equivalent to write_attribute, but internally uses a transaction that will be retried until validated.

Source

pub fn force_remove_attribute<A: AttributeBind + AttributeUpdate>( &self, id: A::IdentifierType, ) -> Option<A>

Remove the attribute A value associated to a given identifier and return it.

This variant is equivalent to remove_attribute, but internally uses a transaction that will be retried until validated.

Source

pub fn remove_attribute_storage<A: AttributeBind + AttributeUpdate>(&mut self)

Remove the attribute A’s storage from the map.

This method is useful when implementing routines that uses attributes to run; Those can then be removed before the final result is returned.

Source

pub fn contains_attribute<A: AttributeBind + AttributeUpdate>(&self) -> bool

Return a boolean indicating if the map contains the specified attribute.

Source§

impl<T: CoordsFloat> CMap2<T>

I-link operator.

§Description

This operation corresponds to coherently linking two darts via their β images. Unlike sewing, this does not alter associated attributes. For a thorough explanation of this operation, its hypothesis & consequences, refer to the user guide.

§Arguments
  • const I: u8 – Link dimension.
  • t: &mut Transaction – Transaction associated to the operation.
  • ld: DartIdType – First dart ID.
  • rd: DartIdType – Second dart ID.
§Errors

This method should be called in a transactional context. The Result is then used to validate the transaction; Errors should not be processed manually, only processed via the ? operator. The policy in case of failure can be defined when creating the transaction, using Transaction::with_control.

§Panics

The method may panic if:

  • I >= 3 or I == 0,
  • the two darts are not I-linkable.

I-unlink operator.

§Description

This operation corresponds to unlinking two darts by resetting their β images. Unlike unsewing, this does not alter associated attributes. For a thorough explanation of this operation, its hypothesis & consequences, refer to the user guide.

§Arguments
  • const I: u8 – Unlink dimension.
  • t: &mut Transaction – Transaction associated to the operation.
  • ld: DartIdType – First dart ID.

The second dart ID is fetched using I and ld.

§Errors

This method should be called in a transactional context. The Result is then used to validate the transaction; Errors should not be processed manually, only processed via the ? operator. The policy in case of failure can be defined when creating the transaction, using Transaction::with_control.

§Panics

The method may panic if:

  • I >= 3 or I == 0,
  • ld is already I-free.

I-link operator.

This variant is equivalent to link, but internally uses a transaction that will be retried until validated.

This variant is equivalent to unlink, but internally uses a transaction that will be retried until validated.

Source§

impl<T: CoordsFloat> CMap2<T>

Orbits

Source

pub fn orbit( &self, opolicy: OrbitPolicy, dart_id: DartIdType, ) -> impl Iterator<Item = DartIdType>

Generic orbit implementation.

§Arguments
  • opolicy: OrbitPolicy – Policy used by the orbit for the BFS.
  • dart_id: DartIdentifier – Dart of which the structure will compute the orbit.
§The search algorithm

The search algorithm used to establish the list of dart included in the orbit is a Breadth-First Search algorithm. This means that:

  • we look at the images of the current dart through all beta functions, adding those to a queue, before moving on to the next dart.
  • we apply the beta functions in their specified order; This guarantees a consistent and predictable result.
§Performance

Currently, orbits use two dynamically allocated structures for computation: a VecDeque, and a HashSet. There is a possibility to use static thread-local instances to avoid ephemeral allocations, but it would require a guard mechanism.

Source

pub fn orbit_tx( &self, t: &mut Transaction, opolicy: OrbitPolicy, dart_id: DartIdType, ) -> impl Iterator<Item = StmClosureResult<DartIdType>>

Generic orbit transactional implementation.

Source

pub fn i_cell<const I: u8>( &self, dart_id: DartIdType, ) -> impl Iterator<Item = DartIdType>

Return the orbit defined by a dart and its I-cell.

§Usage

The returned item can be iterated upon to retrieve all dart member of the cell. Note that the dart passed as an argument is included as the first element of the returned orbit.

§Panics

The method will panic if I is not 0, 1 or 2.

Source§

impl<T: CoordsFloat + 'static> CMap2<T>

Serialization methods

Source

pub fn serialize(&self, writer: impl Write)

Serialize the map under a custom format.

The format specification is described in the user guide.

§Panics

This method may panic if writing to the file fails.

Source

pub fn to_vtk_binary(&self, writer: impl Write)

Generate a legacy VTK file from the map.

§Panics

This function may panic if the internal writing routine fails, i.e.:

  • vertex coordinates cannot be cast to f32 or f64,
  • a vertex cannot be found.
Source

pub fn to_vtk_ascii(&self, writer: impl Write)

Generate a legacy VTK file from the map.

§Panics

This function may panic if the internal writing routine fails, i.e.:

  • vertex coordinates cannot be cast to f32 or f64,
  • a vertex cannot be found.
Source§

impl<T: CoordsFloat> CMap2<T>

§Sew implementations

Source

pub fn sew<const I: u8>( &self, t: &mut Transaction, ld: DartIdType, rd: DartIdType, ) -> TransactionClosureResult<(), SewError>

I-sew operator.

§Description

This operation corresponds to:

  • coherently linking two darts via their β images,
  • merging the attributes associated to their respective original I-cells.

For a thorough explanation of this operation, its hypothesis & consequences, refer to the user guide.

§Arguments
  • const I: u8 – Sew dimension.
  • t: &mut Transaction – Transaction associated to the operation.
  • ld: DartIdType – First dart ID.
  • rd: DartIdType – Second dart ID.
§Errors

This variant will abort the sew operation and raise an error if:

  • the transaction cannot be completed,
  • one (or more) attribute merge fails,
  • for I == 2: orientation is inconsistent.

The returned error can be used in conjunction with transaction control to avoid any modifications in case of failure at attribute level. The user can then choose to retry or abort as he wishes using Transaction::with_control.

§Panics

The method may panic if:

  • I >= 3 or I == 0,
  • the two darts are not I-sewable.
Source

pub fn unsew<const I: u8>( &self, t: &mut Transaction, ld: DartIdType, ) -> TransactionClosureResult<(), SewError>

I-unsew operator.

§Description

This operation corresponds to:

  • unlinking two darts by resetting their β images,
  • splitting the attributes associated to the original I-cell.

For a thorough explanation of this operation, its hypothesis & consequences, refer to the user guide.

§Arguments
  • const I: u8 – Unsew dimension.
  • t: &mut Transaction – Transaction associated to the operation.
  • ld: DartIdType – First dart ID.

The second dart ID is fetched using I and ld.

§Errors

This variant will abort the unsew operation and raise an error if:

  • the transaction cannot be completed,
  • one (or more) attribute split fails,

The returned error can be used in conjunction with transaction control to avoid any modifications in case of failure at attribute level. The user can then choose to retry or abort as he wishes using Transaction::with_control.

§Panics

The method may panic if:

  • I >= 3 or I == 0,
  • ld is already I-free.
Source

pub fn force_sew<const I: u8>( &self, ld: DartIdType, rd: DartIdType, ) -> Result<(), SewError>

I-sew operator.

This variant is equivalent to sew, but internally uses a transaction that will be retried until validated.

Source

pub fn force_unsew<const I: u8>(&self, ld: DartIdType) -> Result<(), SewError>

I-unsew operator.

This variant is equivalent to unsew, but internally uses a transaction that will be retried until validated.

Source§

impl<T: CoordsFloat> CMap2<T>

Dart-related methods

Source

pub fn n_darts(&self) -> usize

Return the current number of darts.

Source

pub fn n_unused_darts(&self) -> usize

Return the current number of unused darts.

Source

pub fn is_unused(&self, d: DartIdType) -> bool

Return whether a given dart is unused or not.

Source

pub fn is_unused_tx( &self, t: &mut Transaction, d: DartIdType, ) -> StmClosureResult<bool>

Return whether a given dart is unused or not.

§Errors

This method is meant to be called in a context where the returned Result is used to validate the transaction passed as argument. Errors should not be processed manually, only processed via the ? operator.

Source

pub fn allocate_used_darts(&mut self, n_darts: usize) -> DartIdType

Add n_darts new free darts to the map.

Added darts are marked as used.

§Return

Return the ID of the first new dart. Other IDs are in the range ID..ID+n_darts.

Source

pub fn allocate_unused_darts(&mut self, n_darts: usize) -> DartIdType

Add n_darts new free darts to the map.

Added dart are marked as unused.

§Return

Return the ID of the first new dart. Other IDs are in the range ID..ID+n_darts.

Source

pub fn reserve_darts( &self, n_darts: usize, ) -> Result<Vec<DartIdType>, DartReservationError>

Mark n_darts free darts as used and return them for usage.

§Return / Errors

This function returns a vector containing IDs of the darts marked as used. It will fail if there are not enough unused darts to return; darts will then be left as unused.

Source

pub fn reserve_darts_tx( &self, t: &mut Transaction, n_darts: usize, ) -> TransactionClosureResult<Vec<DartIdType>, DartReservationError>

Mark n_darts free darts as used and return them for usage.

§Return / Errors

This function returns a vector containing IDs of the darts marked as used. It will fail if there are not enough unused darts to return; darts will then be left as unused.

This method is meant to be called in a context where the returned Result is used to validate the transaction passed as argument. Errors should not be processed manually, only processed via the ? operator.

Source

pub fn claim_dart_tx( &self, t: &mut Transaction, dart_id: DartIdType, ) -> StmClosureResult<()>

Set a given dart as used.

§Errors

This method is meant to be called in a context where the returned Result is used to validate the transaction passed as argument. Errors should not be processed manually, only processed via the ? operator.

Source

pub fn release_dart( &self, dart_id: DartIdType, ) -> Result<bool, DartReleaseError>

Mark a free dart from the map as unused.

§Return / Errors

This method return a boolean indicating whether the art was already unused or not. It will fail if the dart is not free, i.e. if one of its beta images isn’t null.

Source

pub fn release_dart_tx( &self, t: &mut Transaction, dart_id: DartIdType, ) -> TransactionClosureResult<bool, DartReleaseError>

Mark a free dart from the map as unused.

§Return / Errors

This method return a boolean indicating whether the art was already unused or not. It will fail if the dart is not free, i.e. if one of its beta images isn’t null.

This method is meant to be called in a context where the returned Result is used to validate the transaction passed as argument. Errors should not be processed manually, only processed via the ? operator.

Source§

impl<T: CoordsFloat> CMap2<T>

Utilities

Source

pub fn set_beta<const I: u8>(&self, dart_id: DartIdType, new_val: DartIdType)

Set the value of βI(dart_id) to new_val.

Source

pub fn set_betas(&self, dart_id: DartIdType, [b0, b1, b2]: [DartIdType; 3])

Set the values of the beta functions of a dart.

§Arguments
  • dart_id: DartIdentifier – ID of the dart of interest.
  • betas: [DartIdentifier; 3] – Value of the images as [ β0(dart_id), β1(dart_id), β2(dart_id) ]

Trait Implementations§

Auto Trait Implementations§

§

impl<T> Freeze for CMap2<T>

§

impl<T> !RefUnwindSafe for CMap2<T>

§

impl<T> Unpin for CMap2<T>
where T: Unpin,

§

impl<T> !UnwindSafe for CMap2<T>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> Downcast for T
where T: Any,

§

fn into_any(self: Box<T>) -> Box<dyn Any>

Converts Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.
§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Converts Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
§

fn as_any(&self) -> &(dyn Any + 'static)

Converts &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Converts &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
§

impl<T> DowncastSend for T
where T: Any + Send,

§

fn into_any_send(self: Box<T>) -> Box<dyn Any + Send>

Converts Box<Trait> (where Trait: DowncastSend) to Box<dyn Any + Send>, which can then be downcast into Box<ConcreteType> where ConcreteType implements Trait.
§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

§

fn into_any_sync(self: Box<T>) -> Box<dyn Any + Send + Sync>

Converts Box<Trait> (where Trait: DowncastSync) to Box<dyn Any + Send + Sync>, which can then be downcast into Box<ConcreteType> where ConcreteType implements Trait.
§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Converts Arc<Trait> (where Trait: DowncastSync) to Arc<Any>, which can then be downcast into Arc<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
§

impl<T> Pointable for T

§

const ALIGN: usize

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.