# HG changeset patch # User Tuomo Valkonen # Date 1746947025 18000 # Node ID f75bf34adda0b8df216f055288638f5e00ebae98 # Parent 212f75931da0c55f81bbc66fe4de2bdfcf93757e Switch from Cow to MyCow for DifferentiableImpl to avoid Clone trait bound diff -r 212f75931da0 -r f75bf34adda0 src/mapping.rs --- a/src/mapping.rs Thu May 08 22:53:31 2025 -0500 +++ b/src/mapping.rs Sun May 11 02:03:45 2025 -0500 @@ -3,12 +3,12 @@ */ use crate::error::DynResult; +use crate::instance::MyCow; pub use crate::instance::{BasicDecomposition, Decomposition, Instance, Space}; use crate::loc::Loc; use crate::norms::{Norm, NormExponent}; use crate::operator_arithmetic::{Constant, Weighted}; use crate::types::{ClosedMul, Float, Num}; -use std::borrow::Cow; use std::marker::PhantomData; use std::ops::Mul; @@ -124,7 +124,7 @@ impl DifferentiableMapping for T where Domain: Space, - T: Clone + Mapping + DifferentiableImpl, + T: Mapping + DifferentiableImpl, { type DerivativeDomain = T::Derivative; type Differential<'b> @@ -139,26 +139,26 @@ fn diff(self) -> Differential<'static, Domain, Self> { Differential { - g: Cow::Owned(self), + g: MyCow::Owned(self), _space: PhantomData, } } fn diff_ref(&self) -> Differential<'_, Domain, Self> { Differential { - g: Cow::Borrowed(self), + g: MyCow::Borrowed(self), _space: PhantomData, } } } /// Container for the differential [`Mapping`] of a [`DifferentiableMapping`]. -pub struct Differential<'a, X, G: Clone> { - g: Cow<'a, G>, +pub struct Differential<'a, X, G> { + g: MyCow<'a, G>, _space: PhantomData, } -impl<'a, X, G: Clone> Differential<'a, X, G> { +impl<'a, X, G> Differential<'a, X, G> { pub fn base_fn(&self) -> &G { &self.g } @@ -167,7 +167,7 @@ impl<'a, X, G> Mapping for Differential<'a, X, G> where X: Space, - G: Clone + DifferentiableMapping, + G: DifferentiableMapping, { type Codomain = G::DerivativeDomain; @@ -211,8 +211,8 @@ impl>> FlattenCodomain for G {} /// Container for dimensional slicing [`Loc`]`` codomain of a [`Mapping`] to `F`. -pub struct SlicedCodomain<'a, X, F, G: Clone, const N: usize> { - g: Cow<'a, G>, +pub struct SlicedCodomain<'a, X, F, G, const N: usize> { + g: MyCow<'a, G>, slice: usize, _phantoms: PhantomData<(X, F)>, } @@ -221,7 +221,7 @@ where X: Space, F: Copy + Space, - G: Mapping> + Clone, + G: Mapping>, { type Codomain = F; @@ -236,13 +236,13 @@ /// An auto-trait for constructing a [`FlattenCodomain`] structure for /// flattening the codomain of a [`Mapping`] from [`Loc`]`` to `F`. pub trait SliceCodomain: - Mapping> + Clone + Sized + Mapping> + Sized { /// Flatten the codomain from [`Loc`]`` to `F`. fn slice_codomain(self, slice: usize) -> SlicedCodomain<'static, X, F, Self, N> { assert!(slice < N); SlicedCodomain { - g: Cow::Owned(self), + g: MyCow::Owned(self), slice, _phantoms: PhantomData, } @@ -252,14 +252,14 @@ fn slice_codomain_ref(&self, slice: usize) -> SlicedCodomain<'_, X, F, Self, N> { assert!(slice < N); SlicedCodomain { - g: Cow::Borrowed(self), + g: MyCow::Borrowed(self), slice, _phantoms: PhantomData, } } } -impl> + Clone, const N: usize> +impl>, const N: usize> SliceCodomain for G { } @@ -337,7 +337,7 @@ impl<'b, M, X, A> Lipschitz for Differential<'b, X, A> where X: Space, - A: LipschitzDifferentiableImpl + Clone, + A: LipschitzDifferentiableImpl, { type FloatType = A::FloatType; diff -r 212f75931da0 -r f75bf34adda0 src/mapping/dataterm.rs --- a/src/mapping/dataterm.rs Thu May 08 22:53:31 2025 -0500 +++ b/src/mapping/dataterm.rs Sun May 11 02:03:45 2025 -0500 @@ -128,9 +128,9 @@ impl<'a, F, X, Y, A, G> LipschitzDifferentiableImpl for DataTerm where F: Float, - X: Normed + Clone, + X: Normed, Y: Normed, - A: Clone + BoundedLinear, + A: BoundedLinear, G: Mapping + LipschitzDifferentiableImpl, Self: DifferentiableImpl, { diff -r 212f75931da0 -r f75bf34adda0 src/operator_arithmetic.rs --- a/src/operator_arithmetic.rs Thu May 08 22:53:31 2025 -0500 +++ b/src/operator_arithmetic.rs Sun May 11 02:03:45 2025 -0500 @@ -2,72 +2,74 @@ Arithmetic of [`Mapping`]s. */ -use serde::Serialize; +use crate::instance::{Instance, Space}; +use crate::mapping::{DifferentiableImpl, DifferentiableMapping, Mapping}; use crate::types::*; -use crate::instance::{Space, Instance}; -use crate::mapping::{Mapping, DifferentiableImpl, DifferentiableMapping}; +use serde::Serialize; /// A trait for encoding constant [`Float`] values -pub trait Constant : Copy + Sync + Send + 'static + std::fmt::Debug + Into { +pub trait Constant: Copy + Sync + Send + 'static + std::fmt::Debug + Into { /// The type of the value - type Type : Float; + type Type: Float; /// Returns the value of the constant fn value(&self) -> Self::Type; } -impl Constant for F { +impl Constant for F { type Type = F; #[inline] - fn value(&self) -> F { *self } + fn value(&self) -> F { + *self + } } /// Weighting of a [`Mapping`] by scalar multiplication. -#[derive(Copy,Clone,Debug,Serialize)] -pub struct Weighted { +#[derive(Copy, Clone, Debug, Serialize)] +pub struct Weighted { /// The weight - pub weight : C, + pub weight: C, /// The base [`Mapping`] being weighted. - pub base_fn : T, + pub base_fn: T, } impl Weighted where - C : Constant, + C: Constant, { /// Construct from an iterator. - pub fn new(weight : C, base_fn : T) -> Self { - Weighted{ weight, base_fn } + pub fn new(weight: C, base_fn: T) -> Self { + Weighted { weight, base_fn } } } impl<'a, T, V, D, F, C> Mapping for Weighted where - F : Float, - D : Space, - T : Mapping, - V : Space + ClosedMul, - C : Constant + F: Float, + D: Space, + T: Mapping, + V: Space + ClosedMul, + C: Constant, { type Codomain = V; #[inline] - fn apply>(&self, x : I) -> Self::Codomain { + fn apply>(&self, x: I) -> Self::Codomain { self.base_fn.apply(x) * self.weight.value() } } impl<'a, T, V, D, F, C> DifferentiableImpl for Weighted where - F : Float, - D : Space, - T : DifferentiableMapping, - V : Space + std::ops::Mul, - C : Constant + F: Float, + D: Space, + T: DifferentiableMapping, + V: Space + std::ops::Mul, + C: Constant, { type Derivative = V; #[inline] - fn differential_impl>(&self, x : I) -> Self::Derivative { + fn differential_impl>(&self, x: I) -> Self::Derivative { self.base_fn.differential(x) * self.weight.value() } } @@ -76,9 +78,9 @@ #[derive(Serialize, Debug, Clone)] pub struct MappingSum(Vec); -impl< M> MappingSum { +impl MappingSum { /// Construct from an iterator. - pub fn new>(iter : I) -> Self { + pub fn new>(iter: I) -> Self { MappingSum(iter.into_iter().collect()) } @@ -90,27 +92,27 @@ impl Mapping for MappingSum where - Domain : Space + Clone, - M : Mapping, - M::Codomain : std::iter::Sum + Clone + Domain: Space + Clone, + M: Mapping, + M::Codomain: std::iter::Sum + Clone, { type Codomain = M::Codomain; - fn apply>(&self, x : I) -> Self::Codomain { + fn apply>(&self, x: I) -> Self::Codomain { let xr = x.ref_instance(); self.0.iter().map(|c| c.apply(xr)).sum() } } -impl DifferentiableImpl for MappingSum< M> +impl DifferentiableImpl for MappingSum where - Domain : Space + Clone, - M : DifferentiableMapping, - M :: DerivativeDomain : std::iter::Sum + Domain: Space, + M: DifferentiableMapping, + M::DerivativeDomain: std::iter::Sum, { type Derivative = M::DerivativeDomain; - fn differential_impl>(&self, x : I) -> Self::Derivative { + fn differential_impl>(&self, x: I) -> Self::Derivative { let xr = x.ref_instance(); self.0.iter().map(|c| c.differential(xr)).sum() }