cairo_vm::with_std::ops

Trait Add

1.0.0 · Source
pub trait Add<Rhs = Self> {
    type Output;

    // Required method
    fn add(self, rhs: Rhs) -> Self::Output;
}
Expand description

The addition operator +.

Note that Rhs is Self by default, but this is not mandatory. For example, std::time::SystemTime implements Add<Duration>, which permits operations of the form SystemTime = SystemTime + Duration.

§Examples

§Addable points

use std::ops::Add;

#[derive(Debug, Copy, Clone, PartialEq)]
struct Point {
    x: i32,
    y: i32,
}

impl Add for Point {
    type Output = Self;

    fn add(self, other: Self) -> Self {
        Self {
            x: self.x + other.x,
            y: self.y + other.y,
        }
    }
}

assert_eq!(Point { x: 1, y: 0 } + Point { x: 2, y: 3 },
           Point { x: 3, y: 3 });

§Implementing Add with generics

Here is an example of the same Point struct implementing the Add trait using generics.

use std::ops::Add;

#[derive(Debug, Copy, Clone, PartialEq)]
struct Point<T> {
    x: T,
    y: T,
}

// Notice that the implementation uses the associated type `Output`.
impl<T: Add<Output = T>> Add for Point<T> {
    type Output = Self;

    fn add(self, other: Self) -> Self::Output {
        Self {
            x: self.x + other.x,
            y: self.y + other.y,
        }
    }
}

assert_eq!(Point { x: 1, y: 0 } + Point { x: 2, y: 3 },
           Point { x: 3, y: 3 });

Required Associated Types§

1.0.0 · Source

type Output

The resulting type after applying the + operator.

Required Methods§

1.0.0 · Source

fn add(self, rhs: Rhs) -> Self::Output

Performs the + operation.

§Example
assert_eq!(12 + 1, 13);

Implementors§

1.0.0 · Source§

impl Add for f16

1.0.0 · Source§

impl Add for f32

1.0.0 · Source§

impl Add for f64

1.0.0 · Source§

impl Add for f128

1.0.0 · Source§

impl Add for i8

1.0.0 · Source§

impl Add for i16

1.0.0 · Source§

impl Add for i32

1.0.0 · Source§

impl Add for i64

1.0.0 · Source§

impl Add for i128

1.0.0 · Source§

impl Add for isize

1.0.0 · Source§

impl Add for u8

1.0.0 · Source§

impl Add for u16

1.0.0 · Source§

impl Add for u32

1.0.0 · Source§

impl Add for u64

1.0.0 · Source§

impl Add for u128

1.0.0 · Source§

impl Add for usize

Source§

impl Add for Felt

Field addition. Never overflows/underflows.

Source§

impl Add for Assume

1.74.0 · Source§

impl Add for Saturating<i8>

1.74.0 · Source§

impl Add for Saturating<i16>

1.74.0 · Source§

impl Add for Saturating<i32>

1.74.0 · Source§

impl Add for Saturating<i64>

1.74.0 · Source§

impl Add for Saturating<i128>

1.74.0 · Source§

impl Add for Saturating<isize>

1.74.0 · Source§

impl Add for Saturating<u8>

1.74.0 · Source§

impl Add for Saturating<u16>

1.74.0 · Source§

impl Add for Saturating<u32>

1.74.0 · Source§

impl Add for Saturating<u64>

1.74.0 · Source§

impl Add for Saturating<u128>

1.74.0 · Source§

impl Add for Saturating<usize>

1.0.0 · Source§

impl Add for cairo_vm::with_std::num::Wrapping<i8>

1.0.0 · Source§

impl Add for cairo_vm::with_std::num::Wrapping<i16>

1.0.0 · Source§

impl Add for cairo_vm::with_std::num::Wrapping<i32>

1.0.0 · Source§

impl Add for cairo_vm::with_std::num::Wrapping<i64>

1.0.0 · Source§

impl Add for cairo_vm::with_std::num::Wrapping<i128>

1.0.0 · Source§

impl Add for cairo_vm::with_std::num::Wrapping<isize>

1.0.0 · Source§

impl Add for cairo_vm::with_std::num::Wrapping<u8>

1.0.0 · Source§

impl Add for cairo_vm::with_std::num::Wrapping<u16>

1.0.0 · Source§

impl Add for cairo_vm::with_std::num::Wrapping<u32>

1.0.0 · Source§

impl Add for cairo_vm::with_std::num::Wrapping<u64>

1.0.0 · Source§

impl Add for cairo_vm::with_std::num::Wrapping<u128>

1.0.0 · Source§

impl Add for cairo_vm::with_std::num::Wrapping<usize>

1.3.0 · Source§

impl Add for Duration

Source§

impl Add for Checked<Limb>

Source§

impl Add for crypto_bigint::wrapping::Wrapping<Limb>

Source§

impl Add for BigInt

Source§

impl Add for BigUint

Source§

impl Add for udouble

Source§

impl Add for Decimal

Source§

impl Add for starknet_ff::FieldElement

Source§

impl Add for ProjectivePoint

Source§

impl Add for ATerm

Source§

impl Add<&MaybeRelocatable> for Relocatable

Adds a MaybeRelocatable to self Cant add two relocatable values

1.0.0 · Source§

impl Add<&f16> for &f16

1.0.0 · Source§

impl Add<&f16> for f16

1.0.0 · Source§

impl Add<&f32> for &f32

1.0.0 · Source§

impl Add<&f32> for f32

1.0.0 · Source§

impl Add<&f64> for &f64

1.0.0 · Source§

impl Add<&f64> for f64

1.0.0 · Source§

impl Add<&f128> for &f128

1.0.0 · Source§

impl Add<&f128> for f128

1.0.0 · Source§

impl Add<&i8> for &i8

Source§

impl Add<&i8> for &BigInt

1.0.0 · Source§

impl Add<&i8> for i8

Source§

impl Add<&i8> for BigInt

1.0.0 · Source§

impl Add<&i16> for &i16

Source§

impl Add<&i16> for &BigInt

1.0.0 · Source§

impl Add<&i16> for i16

Source§

impl Add<&i16> for BigInt

1.0.0 · Source§

impl Add<&i32> for &i32

Source§

impl Add<&i32> for &BigInt

1.0.0 · Source§

impl Add<&i32> for i32

Source§

impl Add<&i32> for BigInt

1.0.0 · Source§

impl Add<&i64> for &i64

Source§

impl Add<&i64> for &BigInt

1.0.0 · Source§

impl Add<&i64> for i64

Source§

impl Add<&i64> for BigInt

1.0.0 · Source§

impl Add<&i128> for &i128

Source§

impl Add<&i128> for &BigInt

1.0.0 · Source§

impl Add<&i128> for i128

Source§

impl Add<&i128> for BigInt

1.0.0 · Source§

impl Add<&isize> for &isize

Source§

impl Add<&isize> for &BigInt

1.0.0 · Source§

impl Add<&isize> for isize

Source§

impl Add<&isize> for BigInt

1.0.0 · Source§

impl Add<&str> for String

Implements the + operator for concatenating two strings.

This consumes the String on the left-hand side and re-uses its buffer (growing it if necessary). This is done to avoid allocating a new String and copying the entire contents on every operation, which would lead to O(n^2) running time when building an n-byte string by repeated concatenation.

The string on the right-hand side is only borrowed; its contents are copied into the returned String.

§Examples

Concatenating two Strings takes the first by value and borrows the second:

let a = String::from("hello");
let b = String::from(" world");
let c = a + &b;
// `a` is moved and can no longer be used here.

If you want to keep using the first String, you can clone it and append to the clone instead:

let a = String::from("hello");
let b = String::from(" world");
let c = a.clone() + &b;
// `a` is still valid here.

Concatenating &str slices can be done by converting the first to a String:

let a = "hello";
let b = " world";
let c = a.to_string() + b;
1.0.0 · Source§

impl Add<&u8> for &u8

Source§

impl Add<&u8> for &BigInt

Source§

impl Add<&u8> for &BigUint

1.0.0 · Source§

impl Add<&u8> for u8

Source§

impl Add<&u8> for BigInt

Source§

impl Add<&u8> for BigUint

1.0.0 · Source§

impl Add<&u16> for &u16

Source§

impl Add<&u16> for &BigInt

Source§

impl Add<&u16> for &BigUint

1.0.0 · Source§

impl Add<&u16> for u16

Source§

impl Add<&u16> for BigInt

Source§

impl Add<&u16> for BigUint

1.0.0 · Source§

impl Add<&u32> for &u32

Source§

impl Add<&u32> for &BigInt

Source§

impl Add<&u32> for &BigUint

1.0.0 · Source§

impl Add<&u32> for u32

Source§

impl Add<&u32> for BigInt

Source§

impl Add<&u32> for BigUint

1.0.0 · Source§

impl Add<&u64> for &u64

Source§

impl Add<&u64> for &BigInt

Source§

impl Add<&u64> for &BigUint

1.0.0 · Source§

impl Add<&u64> for u64

Source§

impl Add<&u64> for BigInt

Source§

impl Add<&u64> for BigUint

1.0.0 · Source§

impl Add<&u128> for &u128

Source§

impl Add<&u128> for &BigInt

Source§

impl Add<&u128> for &BigUint

1.0.0 · Source§

impl Add<&u128> for u128

Source§

impl Add<&u128> for BigInt

Source§

impl Add<&u128> for BigUint

1.0.0 · Source§

impl Add<&usize> for &usize

Source§

impl Add<&usize> for &BigInt

Source§

impl Add<&usize> for &BigUint

1.0.0 · Source§

impl Add<&usize> for usize

Source§

impl Add<&usize> for BigInt

Source§

impl Add<&usize> for BigUint

Source§

impl Add<&Felt> for &Felt

Field addition. Never overflows/underflows.

Source§

impl Add<&Felt> for u64

Source§

impl Add<&Felt> for Felt

Field addition. Never overflows/underflows.

Source§

impl Add<&Felt> for Relocatable

Source§

impl Add<&ExecutionResources> for &ExecutionResources

1.74.0 · Source§

impl Add<&Saturating<i8>> for &Saturating<i8>

1.74.0 · Source§

impl Add<&Saturating<i8>> for Saturating<i8>

1.74.0 · Source§

impl Add<&Saturating<i16>> for &Saturating<i16>

1.74.0 · Source§

impl Add<&Saturating<i16>> for Saturating<i16>

1.74.0 · Source§

impl Add<&Saturating<i32>> for &Saturating<i32>

1.74.0 · Source§

impl Add<&Saturating<i32>> for Saturating<i32>

1.74.0 · Source§

impl Add<&Saturating<i64>> for &Saturating<i64>

1.74.0 · Source§

impl Add<&Saturating<i64>> for Saturating<i64>

1.74.0 · Source§

impl Add<&Saturating<i128>> for &Saturating<i128>

1.74.0 · Source§

impl Add<&Saturating<i128>> for Saturating<i128>

1.74.0 · Source§

impl Add<&Saturating<isize>> for &Saturating<isize>

1.74.0 · Source§

impl Add<&Saturating<isize>> for Saturating<isize>

1.74.0 · Source§

impl Add<&Saturating<u8>> for &Saturating<u8>

1.74.0 · Source§

impl Add<&Saturating<u8>> for Saturating<u8>

1.74.0 · Source§

impl Add<&Saturating<u16>> for &Saturating<u16>

1.74.0 · Source§

impl Add<&Saturating<u16>> for Saturating<u16>

1.74.0 · Source§

impl Add<&Saturating<u32>> for &Saturating<u32>

1.74.0 · Source§

impl Add<&Saturating<u32>> for Saturating<u32>

1.74.0 · Source§

impl Add<&Saturating<u64>> for &Saturating<u64>

1.74.0 · Source§

impl Add<&Saturating<u64>> for Saturating<u64>

1.74.0 · Source§

impl Add<&Saturating<u128>> for &Saturating<u128>

1.74.0 · Source§

impl Add<&Saturating<u128>> for Saturating<u128>

1.74.0 · Source§

impl Add<&Saturating<usize>> for &Saturating<usize>

1.74.0 · Source§

impl Add<&Saturating<usize>> for Saturating<usize>

1.14.0 · Source§

impl Add<&Wrapping<i8>> for &cairo_vm::with_std::num::Wrapping<i8>

1.14.0 · Source§

impl Add<&Wrapping<i8>> for cairo_vm::with_std::num::Wrapping<i8>

1.14.0 · Source§

impl Add<&Wrapping<i16>> for &cairo_vm::with_std::num::Wrapping<i16>

1.14.0 · Source§

impl Add<&Wrapping<i16>> for cairo_vm::with_std::num::Wrapping<i16>

1.14.0 · Source§

impl Add<&Wrapping<i32>> for &cairo_vm::with_std::num::Wrapping<i32>

1.14.0 · Source§

impl Add<&Wrapping<i32>> for cairo_vm::with_std::num::Wrapping<i32>

1.14.0 · Source§

impl Add<&Wrapping<i64>> for &cairo_vm::with_std::num::Wrapping<i64>

1.14.0 · Source§

impl Add<&Wrapping<i64>> for cairo_vm::with_std::num::Wrapping<i64>

1.14.0 · Source§

impl Add<&Wrapping<i128>> for &cairo_vm::with_std::num::Wrapping<i128>

1.14.0 · Source§

impl Add<&Wrapping<i128>> for cairo_vm::with_std::num::Wrapping<i128>

1.14.0 · Source§

impl Add<&Wrapping<isize>> for &cairo_vm::with_std::num::Wrapping<isize>

1.14.0 · Source§

impl Add<&Wrapping<isize>> for cairo_vm::with_std::num::Wrapping<isize>

1.14.0 · Source§

impl Add<&Wrapping<u8>> for &cairo_vm::with_std::num::Wrapping<u8>

1.14.0 · Source§

impl Add<&Wrapping<u8>> for cairo_vm::with_std::num::Wrapping<u8>

1.14.0 · Source§

impl Add<&Wrapping<u16>> for &cairo_vm::with_std::num::Wrapping<u16>

1.14.0 · Source§

impl Add<&Wrapping<u16>> for cairo_vm::with_std::num::Wrapping<u16>

1.14.0 · Source§

impl Add<&Wrapping<u32>> for &cairo_vm::with_std::num::Wrapping<u32>

1.14.0 · Source§

impl Add<&Wrapping<u32>> for cairo_vm::with_std::num::Wrapping<u32>

1.14.0 · Source§

impl Add<&Wrapping<u64>> for &cairo_vm::with_std::num::Wrapping<u64>

1.14.0 · Source§

impl Add<&Wrapping<u64>> for cairo_vm::with_std::num::Wrapping<u64>

1.14.0 · Source§

impl Add<&Wrapping<u128>> for &cairo_vm::with_std::num::Wrapping<u128>

1.14.0 · Source§

impl Add<&Wrapping<u128>> for cairo_vm::with_std::num::Wrapping<u128>

1.14.0 · Source§

impl Add<&Wrapping<usize>> for &cairo_vm::with_std::num::Wrapping<usize>

1.14.0 · Source§

impl Add<&Wrapping<usize>> for cairo_vm::with_std::num::Wrapping<usize>

Source§

impl Add<&Checked<Limb>> for &Checked<Limb>

Source§

impl Add<&Checked<Limb>> for Checked<Limb>

Source§

impl Add<&Wrapping<Limb>> for &crypto_bigint::wrapping::Wrapping<Limb>

Source§

impl Add<&Wrapping<Limb>> for crypto_bigint::wrapping::Wrapping<Limb>

Source§

impl Add<&BigInt> for &i8

Source§

impl Add<&BigInt> for &i16

Source§

impl Add<&BigInt> for &i32

Source§

impl Add<&BigInt> for &i64

Source§

impl Add<&BigInt> for &i128

Source§

impl Add<&BigInt> for &isize

Source§

impl Add<&BigInt> for &u8

Source§

impl Add<&BigInt> for &u16

Source§

impl Add<&BigInt> for &u32

Source§

impl Add<&BigInt> for &u64

Source§

impl Add<&BigInt> for &u128

Source§

impl Add<&BigInt> for &usize

Source§

impl Add<&BigInt> for &BigInt

Source§

impl Add<&BigInt> for i8

Source§

impl Add<&BigInt> for i16

Source§

impl Add<&BigInt> for i32

Source§

impl Add<&BigInt> for i64

Source§

impl Add<&BigInt> for i128

Source§

impl Add<&BigInt> for isize

Source§

impl Add<&BigInt> for u8

Source§

impl Add<&BigInt> for u16

Source§

impl Add<&BigInt> for u32

Source§

impl Add<&BigInt> for u64

Source§

impl Add<&BigInt> for u128

Source§

impl Add<&BigInt> for usize

Source§

impl Add<&BigInt> for BigInt

Source§

impl Add<&BigUint> for &u8

Source§

impl Add<&BigUint> for &u16

Source§

impl Add<&BigUint> for &u32

Source§

impl Add<&BigUint> for &u64

Source§

impl Add<&BigUint> for &u128

Source§

impl Add<&BigUint> for &usize

Source§

impl Add<&BigUint> for &BigUint

Source§

impl Add<&BigUint> for u8

Source§

impl Add<&BigUint> for u16

Source§

impl Add<&BigUint> for u32

Source§

impl Add<&BigUint> for u64

Source§

impl Add<&BigUint> for u128

Source§

impl Add<&BigUint> for usize

Source§

impl Add<&BigUint> for BigUint

Source§

impl Add<&AffinePoint> for &AffinePoint

Source§

impl Add<&AffinePoint> for &ProjectivePoint

Source§

impl Add<&ProjectivePoint> for &ProjectivePoint

Source§

impl Add<i8> for &BigInt

Source§

impl Add<i8> for BigInt

Source§

impl Add<i16> for &BigInt

Source§

impl Add<i16> for BigInt

Source§

impl Add<i32> for &BigInt

Source§

impl Add<i32> for Relocatable

Source§

impl Add<i32> for BigInt

Source§

impl Add<i64> for &BigInt

Source§

impl Add<i64> for BigInt

Source§

impl Add<i128> for &BigInt

Source§

impl Add<i128> for BigInt

Source§

impl Add<isize> for &BigInt

Source§

impl Add<isize> for BigInt

Source§

impl Add<u8> for &BigInt

Source§

impl Add<u8> for &BigUint

Source§

impl Add<u8> for BigInt

Source§

impl Add<u8> for BigUint

Source§

impl Add<u16> for &BigInt

Source§

impl Add<u16> for &BigUint

Source§

impl Add<u16> for BigInt

Source§

impl Add<u16> for BigUint

Source§

impl Add<u32> for &BigInt

Source§

impl Add<u32> for &BigUint

Source§

impl Add<u32> for Relocatable

Source§

impl Add<u32> for BigInt

Source§

impl Add<u32> for BigUint

Source§

impl Add<u64> for &Felt

Field addition. Never overflows/underflows.

Source§

impl Add<u64> for &BigInt

Source§

impl Add<u64> for &BigUint

Source§

impl Add<u64> for Felt

Field addition. Never overflows/underflows.

Source§

impl Add<u64> for BigInt

Source§

impl Add<u64> for BigUint

Source§

impl Add<u128> for &BigInt

Source§

impl Add<u128> for &BigUint

Source§

impl Add<u128> for BigInt

Source§

impl Add<u128> for BigUint

Source§

impl Add<u128> for udouble

Source§

impl Add<usize> for &BigInt

Source§

impl Add<usize> for &BigUint

Source§

impl Add<usize> for Relocatable

Source§

impl Add<usize> for BigInt

Source§

impl Add<usize> for BigUint

Source§

impl Add<Felt> for &Felt

Field addition. Never overflows/underflows.

1.8.0 · Source§

impl Add<Duration> for Instant

1.8.0 · Source§

impl Add<Duration> for SystemTime

Source§

impl Add<Checked<Limb>> for &Checked<Limb>

Source§

impl Add<Wrapping<Limb>> for &crypto_bigint::wrapping::Wrapping<Limb>

Source§

impl Add<BigInt> for &i8

Source§

impl Add<BigInt> for &i16

Source§

impl Add<BigInt> for &i32

Source§

impl Add<BigInt> for &i64

Source§

impl Add<BigInt> for &i128

Source§

impl Add<BigInt> for &isize

Source§

impl Add<BigInt> for &u8

Source§

impl Add<BigInt> for &u16

Source§

impl Add<BigInt> for &u32

Source§

impl Add<BigInt> for &u64

Source§

impl Add<BigInt> for &u128

Source§

impl Add<BigInt> for &usize

Source§

impl Add<BigInt> for &BigInt

Source§

impl Add<BigInt> for i8

Source§

impl Add<BigInt> for i16

Source§

impl Add<BigInt> for i32

Source§

impl Add<BigInt> for i64

Source§

impl Add<BigInt> for i128

Source§

impl Add<BigInt> for isize

Source§

impl Add<BigInt> for u8

Source§

impl Add<BigInt> for u16

Source§

impl Add<BigInt> for u32

Source§

impl Add<BigInt> for u64

Source§

impl Add<BigInt> for u128

Source§

impl Add<BigInt> for usize

Source§

impl Add<BigUint> for &u8

Source§

impl Add<BigUint> for &u16

Source§

impl Add<BigUint> for &u32

Source§

impl Add<BigUint> for &u64

Source§

impl Add<BigUint> for &u128

Source§

impl Add<BigUint> for &usize

Source§

impl Add<BigUint> for &BigUint

Source§

impl Add<BigUint> for u8

Source§

impl Add<BigUint> for u16

Source§

impl Add<BigUint> for u32

Source§

impl Add<BigUint> for u64

Source§

impl Add<BigUint> for u128

Source§

impl Add<BigUint> for usize

Source§

impl Add<AffinePoint> for ProjectivePoint

Source§

impl Add<B0> for UTerm

UTerm + B0 = UTerm

Source§

impl Add<B1> for UTerm

UTerm + B1 = UInt<UTerm, B1>

1.14.0 · Source§

impl<'a> Add for Cow<'a, str>

Source§

type Output = Cow<'a, str>

1.14.0 · Source§

impl<'a> Add<&'a str> for Cow<'a, str>

Source§

type Output = Cow<'a, str>

Source§

impl<'a> Add<&'a Decimal> for Decimal

1.0.0 · Source§

impl<'a> Add<f16> for &'a f16

1.0.0 · Source§

impl<'a> Add<f32> for &'a f32

1.0.0 · Source§

impl<'a> Add<f64> for &'a f64

1.0.0 · Source§

impl<'a> Add<f128> for &'a f128

1.0.0 · Source§

impl<'a> Add<i8> for &'a i8

1.0.0 · Source§

impl<'a> Add<i16> for &'a i16

1.0.0 · Source§

impl<'a> Add<i32> for &'a i32

1.0.0 · Source§

impl<'a> Add<i64> for &'a i64

1.0.0 · Source§

impl<'a> Add<i128> for &'a i128

1.0.0 · Source§

impl<'a> Add<isize> for &'a isize

1.0.0 · Source§

impl<'a> Add<u8> for &'a u8

1.0.0 · Source§

impl<'a> Add<u16> for &'a u16

1.0.0 · Source§

impl<'a> Add<u32> for &'a u32

1.0.0 · Source§

impl<'a> Add<u64> for &'a u64

1.0.0 · Source§

impl<'a> Add<u128> for &'a u128

1.0.0 · Source§

impl<'a> Add<usize> for &'a usize

1.74.0 · Source§

impl<'a> Add<Saturating<i8>> for &'a Saturating<i8>

1.74.0 · Source§

impl<'a> Add<Saturating<i16>> for &'a Saturating<i16>

1.74.0 · Source§

impl<'a> Add<Saturating<i32>> for &'a Saturating<i32>

1.74.0 · Source§

impl<'a> Add<Saturating<i64>> for &'a Saturating<i64>

1.74.0 · Source§

impl<'a> Add<Saturating<i128>> for &'a Saturating<i128>

1.74.0 · Source§

impl<'a> Add<Saturating<isize>> for &'a Saturating<isize>

1.74.0 · Source§

impl<'a> Add<Saturating<u8>> for &'a Saturating<u8>

1.74.0 · Source§

impl<'a> Add<Saturating<u16>> for &'a Saturating<u16>

1.74.0 · Source§

impl<'a> Add<Saturating<u32>> for &'a Saturating<u32>

1.74.0 · Source§

impl<'a> Add<Saturating<u64>> for &'a Saturating<u64>

1.74.0 · Source§

impl<'a> Add<Saturating<u128>> for &'a Saturating<u128>

1.74.0 · Source§

impl<'a> Add<Saturating<usize>> for &'a Saturating<usize>

1.14.0 · Source§

impl<'a> Add<Wrapping<i8>> for &'a cairo_vm::with_std::num::Wrapping<i8>

1.14.0 · Source§

impl<'a> Add<Wrapping<i16>> for &'a cairo_vm::with_std::num::Wrapping<i16>

1.14.0 · Source§

impl<'a> Add<Wrapping<i32>> for &'a cairo_vm::with_std::num::Wrapping<i32>

1.14.0 · Source§

impl<'a> Add<Wrapping<i64>> for &'a cairo_vm::with_std::num::Wrapping<i64>

1.14.0 · Source§

impl<'a> Add<Wrapping<i128>> for &'a cairo_vm::with_std::num::Wrapping<i128>

1.14.0 · Source§

impl<'a> Add<Wrapping<isize>> for &'a cairo_vm::with_std::num::Wrapping<isize>

1.14.0 · Source§

impl<'a> Add<Wrapping<u8>> for &'a cairo_vm::with_std::num::Wrapping<u8>

1.14.0 · Source§

impl<'a> Add<Wrapping<u16>> for &'a cairo_vm::with_std::num::Wrapping<u16>

1.14.0 · Source§

impl<'a> Add<Wrapping<u32>> for &'a cairo_vm::with_std::num::Wrapping<u32>

1.14.0 · Source§

impl<'a> Add<Wrapping<u64>> for &'a cairo_vm::with_std::num::Wrapping<u64>

1.14.0 · Source§

impl<'a> Add<Wrapping<u128>> for &'a cairo_vm::with_std::num::Wrapping<u128>

1.14.0 · Source§

impl<'a> Add<Wrapping<usize>> for &'a cairo_vm::with_std::num::Wrapping<usize>

Source§

impl<'a> Add<Decimal> for &'a Decimal

Source§

impl<'a, 'b> Add<&'b Decimal> for &'a Decimal

Source§

impl<'a, 'b, P> Add<&'a CubicExtField<P>> for &'b CubicExtField<P>
where P: CubicExtConfig,

Source§

impl<'a, 'b, P> Add<&'a QuadExtField<P>> for &'b QuadExtField<P>
where P: QuadExtConfig,

Source§

impl<'a, 'b, P> Add<&'a mut CubicExtField<P>> for &'b CubicExtField<P>
where P: CubicExtConfig,

Source§

impl<'a, 'b, P> Add<&'a mut QuadExtField<P>> for &'b QuadExtField<P>
where P: QuadExtConfig,

Source§

impl<'a, 'b, P, const N: usize> Add<&'b Fp<P, N>> for &'a Fp<P, N>
where P: FpConfig<N>,

Source§

type Output = Fp<P, N>

Source§

impl<'a, 'b, T, R> Add<&'b Mint<T, R>> for &'a Mint<T, R>
where T: Integer<Output = T> + Clone + for<'r> Add<&'r T>, R: Reducer<T> + Clone,

Source§

type Output = Mint<T, R>

Source§

impl<'a, P> Add<&'a CubicExtField<P>> for CubicExtField<P>
where P: CubicExtConfig,

Source§

impl<'a, P> Add<&'a QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

Source§

impl<'a, P> Add<&'a mut CubicExtField<P>> for CubicExtField<P>
where P: CubicExtConfig,

Source§

impl<'a, P> Add<&'a mut QuadExtField<P>> for QuadExtField<P>
where P: QuadExtConfig,

Source§

impl<'a, P, const N: usize> Add<&'a Fp<P, N>> for Fp<P, N>
where P: FpConfig<N>,

Source§

type Output = Fp<P, N>

Source§

impl<'a, P, const N: usize> Add<&'a mut Fp<P, N>> for Fp<P, N>
where P: FpConfig<N>,

Source§

type Output = Fp<P, N>

Source§

impl<'b, P> Add<CubicExtField<P>> for &'b CubicExtField<P>
where P: CubicExtConfig,

Source§

impl<'b, P> Add<QuadExtField<P>> for &'b QuadExtField<P>
where P: QuadExtConfig,

Source§

impl<'lhs, 'rhs, T, const N: usize> Add<&'rhs Simd<T, N>> for &'lhs Simd<T, N>
where T: SimdElement, Simd<T, N>: Add<Output = Simd<T, N>>, LaneCount<N>: SupportedLaneCount,

Source§

type Output = Simd<T, N>

Source§

impl<Al, Vl, Ar, Vr> Add<TArr<Vr, Ar>> for TArr<Vl, Al>
where Al: Add<Ar>, Vl: Add<Vr>,

Source§

type Output = TArr<<Vl as Add<Vr>>::Output, <Al as Add<Ar>>::Output>

Source§

impl<F> Add for DenseMultilinearPolynomial<F>
where F: IsField, <F as IsField>::BaseType: Send + Sync,

Adds another multilinear polynomial to self. Assumes the two polynomials have the same number of variables.

Source§

impl<F, L> Add<&FieldElement<F>> for &Polynomial<FieldElement<L>>
where L: IsField, F: IsSubFieldOf<L>,

Source§

impl<F, L> Add<&FieldElement<F>> for Polynomial<FieldElement<L>>
where L: IsField, F: IsSubFieldOf<L>,

Source§

impl<F, L> Add<&FieldElement<L>> for &lambdaworks_math::field::element::FieldElement<F>
where F: IsSubFieldOf<L>, L: IsField,

Addition operator overloading for field elements

Source§

impl<F, L> Add<&FieldElement<L>> for lambdaworks_math::field::element::FieldElement<F>
where F: IsSubFieldOf<L>, L: IsField,

Source§

impl<F, L> Add<&Polynomial<FieldElement<L>>> for &lambdaworks_math::field::element::FieldElement<F>
where L: IsField, F: IsSubFieldOf<L>,

Source§

impl<F, L> Add<&Polynomial<FieldElement<L>>> for &Polynomial<FieldElement<F>>
where L: IsField, F: IsSubFieldOf<L>,

Source§

impl<F, L> Add<&Polynomial<FieldElement<L>>> for lambdaworks_math::field::element::FieldElement<F>
where L: IsField, F: IsSubFieldOf<L>,

Source§

impl<F, L> Add<&Polynomial<FieldElement<L>>> for Polynomial<FieldElement<F>>
where L: IsField, F: IsSubFieldOf<L>,

Source§

impl<F, L> Add<FieldElement<F>> for &Polynomial<FieldElement<L>>
where L: IsField, F: IsSubFieldOf<L>,

Source§

impl<F, L> Add<FieldElement<F>> for Polynomial<FieldElement<L>>
where L: IsField, F: IsSubFieldOf<L>,

Source§

impl<F, L> Add<FieldElement<L>> for &lambdaworks_math::field::element::FieldElement<F>
where F: IsSubFieldOf<L>, L: IsField,

Source§

impl<F, L> Add<FieldElement<L>> for lambdaworks_math::field::element::FieldElement<F>
where F: IsSubFieldOf<L>, L: IsField,

Source§

impl<F, L> Add<Polynomial<FieldElement<L>>> for &lambdaworks_math::field::element::FieldElement<F>
where L: IsField, F: IsSubFieldOf<L>,

Source§

impl<F, L> Add<Polynomial<FieldElement<L>>> for &Polynomial<FieldElement<F>>
where L: IsField, F: IsSubFieldOf<L>,

Source§

impl<F, L> Add<Polynomial<FieldElement<L>>> for lambdaworks_math::field::element::FieldElement<F>
where L: IsField, F: IsSubFieldOf<L>,

Source§

impl<F, L> Add<Polynomial<FieldElement<L>>> for Polynomial<FieldElement<F>>
where L: IsField, F: IsSubFieldOf<L>,

Source§

impl<I> Add<I> for Z0
where I: Integer,

Z0 + I = I

Source§

impl<MOD, const LIMBS: usize> Add for Residue<MOD, LIMBS>
where MOD: ResidueParams<LIMBS>,

Source§

type Output = Residue<MOD, LIMBS>

Source§

impl<MOD, const LIMBS: usize> Add<&Residue<MOD, LIMBS>> for &Residue<MOD, LIMBS>
where MOD: ResidueParams<LIMBS>,

Source§

type Output = Residue<MOD, LIMBS>

Source§

impl<MOD, const LIMBS: usize> Add<&Residue<MOD, LIMBS>> for Residue<MOD, LIMBS>
where MOD: ResidueParams<LIMBS>,

Source§

type Output = Residue<MOD, LIMBS>

Source§

impl<MOD, const LIMBS: usize> Add<Residue<MOD, LIMBS>> for &Residue<MOD, LIMBS>
where MOD: ResidueParams<LIMBS>,

Source§

type Output = Residue<MOD, LIMBS>

Source§

impl<O> Add for F32<O>
where O: ByteOrder,

Source§

impl<O> Add for F64<O>
where O: ByteOrder,

Source§

impl<O> Add for I16<O>
where O: ByteOrder,

Source§

impl<O> Add for I32<O>
where O: ByteOrder,

Source§

impl<O> Add for I64<O>
where O: ByteOrder,

Source§

impl<O> Add for I128<O>
where O: ByteOrder,

Source§

impl<O> Add for U16<O>
where O: ByteOrder,

Source§

impl<O> Add for U32<O>
where O: ByteOrder,

Source§

impl<O> Add for U64<O>
where O: ByteOrder,

Source§

impl<O> Add for U128<O>
where O: ByteOrder,

Source§

impl<P> Add for CubicExtField<P>
where P: CubicExtConfig,

Source§

impl<P> Add for QuadExtField<P>
where P: QuadExtConfig,

Source§

impl<P, const N: usize> Add for Fp<P, N>
where P: FpConfig<N>,

Source§

type Output = Fp<P, N>

Source§

impl<T, R> Add for ReducedInt<T, R>
where T: PartialEq, R: Reducer<T>,

Source§

impl<T, R> Add for Mint<T, R>
where T: Integer + Clone, R: Reducer<T> + Clone,

Source§

type Output = Mint<T, R>

Source§

impl<T, R> Add<&ReducedInt<T, R>> for &ReducedInt<T, R>
where T: PartialEq + Clone, R: Reducer<T> + Clone,

Source§

impl<T, R> Add<&ReducedInt<T, R>> for ReducedInt<T, R>
where T: PartialEq + Clone, R: Reducer<T>,

Source§

impl<T, R> Add<&Mint<T, R>> for Mint<T, R>
where T: Integer<Output = T> + Clone + for<'r> Add<&'r T>, R: Reducer<T> + Clone,

Source§

type Output = Mint<T, R>

Source§

impl<T, R> Add<ReducedInt<T, R>> for &ReducedInt<T, R>
where T: PartialEq + Clone, R: Reducer<T>,

Source§

impl<T, R> Add<Mint<T, R>> for &Mint<T, R>
where T: Integer + Clone, R: Reducer<T> + Clone,

Source§

type Output = Mint<T, R>

Source§

impl<T, R> Add<T> for ReducedInt<T, R>
where T: PartialEq, R: Reducer<T>,

Source§

impl<T, const N: usize> Add<&Simd<T, N>> for Simd<T, N>
where T: SimdElement, Simd<T, N>: Add<Output = Simd<T, N>>, LaneCount<N>: SupportedLaneCount,

Source§

type Output = Simd<T, N>

Source§

impl<T, const N: usize> Add<Simd<T, N>> for &Simd<T, N>
where T: SimdElement, Simd<T, N>: Add<Output = Simd<T, N>>, LaneCount<N>: SupportedLaneCount,

Source§

type Output = Simd<T, N>

Source§

impl<U> Add<B1> for UInt<U, B0>
where U: Unsigned,

UInt<U, B0> + B1 = UInt<U + B1>

Source§

impl<U> Add<B1> for UInt<U, B1>
where U: Unsigned + Add<B1>, <U as Add<B1>>::Output: Unsigned,

UInt<U, B1> + B1 = UInt<U + B1, B0>

Source§

type Output = UInt<<U as Add<B1>>::Output, B0>

Source§

impl<U> Add<Z0> for NInt<U>
where U: Unsigned + NonZero,

NInt + Z0 = NInt

Source§

impl<U> Add<Z0> for PInt<U>
where U: Unsigned + NonZero,

PInt + Z0 = PInt

Source§

impl<U> Add<U> for UTerm
where U: Unsigned,

UTerm + U = U

Source§

impl<U, B> Add<B0> for UInt<U, B>
where U: Unsigned, B: Bit,

U + B0 = U

Source§

type Output = UInt<U, B>

Source§

impl<U, B> Add<UTerm> for UInt<U, B>
where U: Unsigned, B: Bit,

UInt<U, B> + UTerm = UInt<U, B>

Source§

type Output = UInt<U, B>

Source§

impl<Ul, Ur> Add<NInt<Ur>> for NInt<Ul>
where Ul: Unsigned + NonZero + Add<Ur>, Ur: Unsigned + NonZero, <Ul as Add<Ur>>::Output: Unsigned + NonZero,

N(Ul) + N(Ur) = N(Ul + Ur)

Source§

type Output = NInt<<Ul as Add<Ur>>::Output>

Source§

impl<Ul, Ur> Add<NInt<Ur>> for PInt<Ul>
where Ul: Unsigned + NonZero + Cmp<Ur> + PrivateIntegerAdd<<Ul as Cmp<Ur>>::Output, Ur>, Ur: Unsigned + NonZero,

P(Ul) + N(Ur): We resolve this with our PrivateAdd

Source§

type Output = <Ul as PrivateIntegerAdd<<Ul as Cmp<Ur>>::Output, Ur>>::Output

Source§

impl<Ul, Ur> Add<PInt<Ur>> for NInt<Ul>
where Ul: Unsigned + NonZero, Ur: Unsigned + NonZero + Cmp<Ul> + PrivateIntegerAdd<<Ur as Cmp<Ul>>::Output, Ul>,

N(Ul) + P(Ur): We resolve this with our PrivateAdd

Source§

type Output = <Ur as PrivateIntegerAdd<<Ur as Cmp<Ul>>::Output, Ul>>::Output

Source§

impl<Ul, Ur> Add<PInt<Ur>> for PInt<Ul>
where Ul: Unsigned + NonZero + Add<Ur>, Ur: Unsigned + NonZero, <Ul as Add<Ur>>::Output: Unsigned + NonZero,

P(Ul) + P(Ur) = P(Ul + Ur)

Source§

type Output = PInt<<Ul as Add<Ur>>::Output>

Source§

impl<Ul, Ur> Add<UInt<Ur, B0>> for UInt<Ul, B0>
where Ul: Unsigned + Add<Ur>, Ur: Unsigned,

UInt<Ul, B0> + UInt<Ur, B0> = UInt<Ul + Ur, B0>

Source§

type Output = UInt<<Ul as Add<Ur>>::Output, B0>

Source§

impl<Ul, Ur> Add<UInt<Ur, B0>> for UInt<Ul, B1>
where Ul: Unsigned + Add<Ur>, Ur: Unsigned,

UInt<Ul, B1> + UInt<Ur, B0> = UInt<Ul + Ur, B1>

Source§

type Output = UInt<<Ul as Add<Ur>>::Output, B1>

Source§

impl<Ul, Ur> Add<UInt<Ur, B1>> for UInt<Ul, B0>
where Ul: Unsigned + Add<Ur>, Ur: Unsigned,

UInt<Ul, B0> + UInt<Ur, B1> = UInt<Ul + Ur, B1>

Source§

type Output = UInt<<Ul as Add<Ur>>::Output, B1>

Source§

impl<Ul, Ur> Add<UInt<Ur, B1>> for UInt<Ul, B1>
where Ul: Unsigned + Add<Ur>, Ur: Unsigned, <Ul as Add<Ur>>::Output: Add<B1>,

UInt<Ul, B1> + UInt<Ur, B1> = UInt<(Ul + Ur) + B1, B0>

Source§

type Output = UInt<<<Ul as Add<Ur>>::Output as Add<B1>>::Output, B0>

Source§

impl<const LIMBS: usize> Add for Checked<Uint<LIMBS>>

Source§

type Output = Checked<Uint<LIMBS>>

Source§

impl<const LIMBS: usize> Add for DynResidue<LIMBS>

Source§

impl<const LIMBS: usize> Add for crypto_bigint::wrapping::Wrapping<Uint<LIMBS>>

Source§

impl<const LIMBS: usize> Add<&Checked<Uint<LIMBS>>> for &Checked<Uint<LIMBS>>

Source§

type Output = Checked<Uint<LIMBS>>

Source§

impl<const LIMBS: usize> Add<&Checked<Uint<LIMBS>>> for Checked<Uint<LIMBS>>

Source§

type Output = Checked<Uint<LIMBS>>

Source§

impl<const LIMBS: usize> Add<&DynResidue<LIMBS>> for &DynResidue<LIMBS>

Source§

impl<const LIMBS: usize> Add<&DynResidue<LIMBS>> for DynResidue<LIMBS>

Source§

impl<const LIMBS: usize> Add<&Wrapping<Uint<LIMBS>>> for &crypto_bigint::wrapping::Wrapping<Uint<LIMBS>>

Source§

impl<const LIMBS: usize> Add<&Wrapping<Uint<LIMBS>>> for crypto_bigint::wrapping::Wrapping<Uint<LIMBS>>

Source§

impl<const LIMBS: usize> Add<Checked<Uint<LIMBS>>> for &Checked<Uint<LIMBS>>

Source§

type Output = Checked<Uint<LIMBS>>

Source§

impl<const LIMBS: usize> Add<DynResidue<LIMBS>> for &DynResidue<LIMBS>

Source§

impl<const LIMBS: usize> Add<Wrapping<Uint<LIMBS>>> for &crypto_bigint::wrapping::Wrapping<Uint<LIMBS>>

Source§

impl<const N: usize> Add for Simd<f32, N>

Source§

impl<const N: usize> Add for Simd<f64, N>

Source§

impl<const N: usize> Add for Simd<i8, N>

Source§

impl<const N: usize> Add for Simd<i16, N>

Source§

impl<const N: usize> Add for Simd<i32, N>

Source§

impl<const N: usize> Add for Simd<i64, N>

Source§

impl<const N: usize> Add for Simd<isize, N>

Source§

impl<const N: usize> Add for Simd<u8, N>

Source§

impl<const N: usize> Add for Simd<u16, N>

Source§

impl<const N: usize> Add for Simd<u32, N>

Source§

impl<const N: usize> Add for Simd<u64, N>

Source§

impl<const N: usize> Add for Simd<usize, N>

Source§

impl<const NUM_LIMBS: usize> Add for UnsignedInteger<NUM_LIMBS>

Source§

impl<const NUM_LIMBS: usize> Add<&UnsignedInteger<NUM_LIMBS>> for &UnsignedInteger<NUM_LIMBS>

Source§

impl<const NUM_LIMBS: usize> Add<&UnsignedInteger<NUM_LIMBS>> for UnsignedInteger<NUM_LIMBS>

Source§

impl<const NUM_LIMBS: usize> Add<UnsignedInteger<NUM_LIMBS>> for &UnsignedInteger<NUM_LIMBS>