src/mapping/quadratic.rs

Thu, 01 May 2025 02:28:28 -0500

author
Tuomo Valkonen <tuomov@iki.fi>
date
Thu, 01 May 2025 02:28:28 -0500
branch
dev
changeset 121
fc7d923ff6e7
parent 110
a1278320be26
permissions
-rw-r--r--

another overflow

99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
1 /*!
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
2 Quadratic functions of the form $\frac{1}{2}\|Ax-b\|_2^2$ for an operator $A$
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
3 to a [`Euclidean`] space.
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
4 */
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
5
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
6 #![allow(non_snake_case)]
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
7
102
aead46a19767 LipschitzDifferentiableImpl
Tuomo Valkonen <tuomov@iki.fi>
parents: 99
diff changeset
8 use super::{DifferentiableImpl, LipschitzDifferentiableImpl, Mapping};
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
9 use crate::convex::ConvexMapping;
110
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 109
diff changeset
10 use crate::error::DynResult;
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
11 use crate::euclidean::Euclidean;
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
12 use crate::instance::{Instance, Space};
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
13 use crate::linops::{BoundedLinear, Linear, Preadjointable};
109
943c6b3b9414 More Normed usage
Tuomo Valkonen <tuomov@iki.fi>
parents: 102
diff changeset
14 use crate::norms::{Norm, NormExponent, Normed, L2};
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
15 use crate::types::Float;
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
16 use std::marker::PhantomData;
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
17
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
18 /// Functions of the form $\frac{1}{2}\|Ax-b\|_2^2$ for an operator $A$
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
19 /// to a [`Euclidean`] space.
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
20 #[derive(Clone, Copy)]
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
21 pub struct Quadratic<'a, F: Float, Domain: Space, A: Mapping<Domain>> {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
22 opA: &'a A,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
23 b: &'a <A as Mapping<Domain>>::Codomain,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
24 _phantoms: PhantomData<F>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
25 }
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
26
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
27 #[allow(non_snake_case)]
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
28 impl<'a, F: Float, Domain: Space, A: Mapping<Domain>> Quadratic<'a, F, Domain, A> {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
29 pub fn new(opA: &'a A, b: &'a A::Codomain) -> Self {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
30 Quadratic {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
31 opA,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
32 b,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
33 _phantoms: PhantomData,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
34 }
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
35 }
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
36
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
37 pub fn operator(&self) -> &'a A {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
38 self.opA
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
39 }
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
40
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
41 pub fn data(&self) -> &'a <A as Mapping<Domain>>::Codomain {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
42 self.b
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
43 }
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
44 }
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
45
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
46 //+ AdjointProductBoundedBy<RNDM<F, N>, P, FloatType = F>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
47
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
48 impl<'a, F: Float, X: Space, A: Mapping<X>> Mapping<X> for Quadratic<'a, F, X, A>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
49 where
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
50 A::Codomain: Euclidean<F>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
51 {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
52 type Codomain = F;
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
53
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
54 fn apply<I: Instance<X>>(&self, x: I) -> F {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
55 // TODO: possibly (if at all more effcient) use GEMV once generalised
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
56 // to not require preallocation. However, Rust should be pretty efficient
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
57 // at not doing preallocations or anything here, as the result of self.opA.apply()
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
58 // can be consumed, so maybe GEMV is no use.
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
59 (self.opA.apply(x) - self.b).norm2_squared() / F::TWO
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
60 }
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
61 }
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
62
109
943c6b3b9414 More Normed usage
Tuomo Valkonen <tuomov@iki.fi>
parents: 102
diff changeset
63 impl<'a, F: Float, X: Normed<F>, A: Linear<X>> ConvexMapping<X, F> for Quadratic<'a, F, X, A> where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
64 A::Codomain: Euclidean<F>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
65 {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
66 }
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
67
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
68 impl<'a, F, X, A> DifferentiableImpl<X> for Quadratic<'a, F, X, A>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
69 where
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
70 F: Float,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
71 X: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
72 <A as Mapping<X>>::Codomain: Euclidean<F>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
73 A: Linear<X> + Preadjointable<X>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
74 <<A as Mapping<X>>::Codomain as Euclidean<F>>::Output: Instance<<A as Mapping<X>>::Codomain>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
75 {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
76 type Derivative = A::PreadjointCodomain;
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
77
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
78 fn differential_impl<I: Instance<X>>(&self, x: I) -> Self::Derivative {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
79 // TODO: possibly (if at all more effcient) use GEMV once generalised
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
80 // to not require preallocation. However, Rust should be pretty efficient
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
81 // at not doing preallocations or anything here, as the result of self.opA.apply()
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
82 // can be consumed, so maybe GEMV is no use.
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
83 self.opA.preadjoint().apply(self.opA.apply(x) - self.b)
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
84 }
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
85 }
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
86
102
aead46a19767 LipschitzDifferentiableImpl
Tuomo Valkonen <tuomov@iki.fi>
parents: 99
diff changeset
87 impl<'a, F, X, ExpX, A> LipschitzDifferentiableImpl<X, ExpX> for Quadratic<'a, F, X, A>
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
88 where
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
89 F: Float,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
90 X: Space + Clone + Norm<F, ExpX>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
91 ExpX: NormExponent,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
92 A: Clone + BoundedLinear<X, ExpX, L2, F>,
102
aead46a19767 LipschitzDifferentiableImpl
Tuomo Valkonen <tuomov@iki.fi>
parents: 99
diff changeset
93 Self: DifferentiableImpl<X>,
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
94 {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
95 type FloatType = F;
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
96
110
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 109
diff changeset
97 fn diff_lipschitz_factor(&self, seminorm: ExpX) -> DynResult<F> {
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 109
diff changeset
98 Ok(self.opA.opnorm_bound(seminorm, L2)?.powi(2))
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
99 }
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
100 }

mercurial