src/linops.rs

Tue, 13 May 2025 00:24:51 -0500

author
Tuomo Valkonen <tuomov@iki.fi>
date
Tue, 13 May 2025 00:24:51 -0500
branch
dev
changeset 139
f78885441218
parent 133
2b13f8a0c8ba
child 140
26df914dda67
permissions
-rw-r--r--

new ZeroOp

0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
1 /*!
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
2 Abstract linear operators.
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
3 */
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
4
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
5 use crate::direct_product::Pair;
110
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 104
diff changeset
6 use crate::error::DynResult;
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
7 use crate::instance::Instance;
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
8 pub use crate::mapping::{Composition, DifferentiableImpl, Mapping, Space};
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
9 use crate::norms::{HasDual, Linfinity, Norm, NormExponent, PairNorm, L1, L2};
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
10 use crate::types::*;
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
11 use numeric_literals::replace_float_literals;
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
12 use serde::Serialize;
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
13 use std::marker::PhantomData;
130
0a689881b0f1 Add more AXPY super traits
Tuomo Valkonen <tuomov@iki.fi>
parents: 129
diff changeset
14 use std::ops::{Add, AddAssign, Div, DivAssign, Mul, MulAssign, Neg, Sub, SubAssign};
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
15
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
16 /// Trait for linear operators on `X`.
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
17 pub trait Linear<X: Space>: Mapping<X> {}
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
18
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
19 // impl<X: Space, A: Linear<X>> DifferentiableImpl<X> for A {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
20 // type Derivative = <Self as Mapping<X>>::Codomain;
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
21
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
22 // /// Compute the differential of `self` at `x`, consuming the input.
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
23 // 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: 74
diff changeset
24 // self.apply(x)
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
25 // }
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
26 // }
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
27
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
28 /// Efficient in-place summation.
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
29 #[replace_float_literals(Self::Field::cast_from(literal))]
130
0a689881b0f1 Add more AXPY super traits
Tuomo Valkonen <tuomov@iki.fi>
parents: 129
diff changeset
30 pub trait AXPY<X = Self>:
0a689881b0f1 Add more AXPY super traits
Tuomo Valkonen <tuomov@iki.fi>
parents: 129
diff changeset
31 Space
0a689881b0f1 Add more AXPY super traits
Tuomo Valkonen <tuomov@iki.fi>
parents: 129
diff changeset
32 + MulAssign<Self::Field>
0a689881b0f1 Add more AXPY super traits
Tuomo Valkonen <tuomov@iki.fi>
parents: 129
diff changeset
33 + DivAssign<Self::Field>
0a689881b0f1 Add more AXPY super traits
Tuomo Valkonen <tuomov@iki.fi>
parents: 129
diff changeset
34 + AddAssign<Self>
0a689881b0f1 Add more AXPY super traits
Tuomo Valkonen <tuomov@iki.fi>
parents: 129
diff changeset
35 + AddAssign<Self::Owned>
0a689881b0f1 Add more AXPY super traits
Tuomo Valkonen <tuomov@iki.fi>
parents: 129
diff changeset
36 + SubAssign<Self>
0a689881b0f1 Add more AXPY super traits
Tuomo Valkonen <tuomov@iki.fi>
parents: 129
diff changeset
37 + SubAssign<Self::Owned>
0a689881b0f1 Add more AXPY super traits
Tuomo Valkonen <tuomov@iki.fi>
parents: 129
diff changeset
38 + Mul<Self::Field, Output = Self::Owned>
0a689881b0f1 Add more AXPY super traits
Tuomo Valkonen <tuomov@iki.fi>
parents: 129
diff changeset
39 + Div<Self::Field, Output = Self::Owned>
0a689881b0f1 Add more AXPY super traits
Tuomo Valkonen <tuomov@iki.fi>
parents: 129
diff changeset
40 + Add<Self, Output = Self::Owned>
0a689881b0f1 Add more AXPY super traits
Tuomo Valkonen <tuomov@iki.fi>
parents: 129
diff changeset
41 + Add<Self::Owned, Output = Self::Owned>
0a689881b0f1 Add more AXPY super traits
Tuomo Valkonen <tuomov@iki.fi>
parents: 129
diff changeset
42 + Sub<Self, Output = Self::Owned>
0a689881b0f1 Add more AXPY super traits
Tuomo Valkonen <tuomov@iki.fi>
parents: 129
diff changeset
43 + Sub<Self::Owned, Output = Self::Owned>
0a689881b0f1 Add more AXPY super traits
Tuomo Valkonen <tuomov@iki.fi>
parents: 129
diff changeset
44 + Neg
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
45 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
46 X: Space,
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
47 {
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
48 type Field: Num;
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
49 type Owned: AXPY<X, Field = Self::Field>;
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
50 // type OriginGen<'a>: OriginGenerator<Self::Owned, F>
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
51 // where
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
52 // Self: 'a;
62
d8305c9b6fdf Move origin stuff to AXPY form Euclidean
Tuomo Valkonen <tuomov@iki.fi>
parents: 61
diff changeset
53
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
54 /// Computes `y = βy + αx`, where `y` is `Self`.
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
55 fn axpy<I: Instance<X>>(&mut self, α: Self::Field, x: I, β: Self::Field);
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
56
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
57 /// Copies `x` to `self`.
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
58 fn copy_from<I: Instance<X>>(&mut self, x: I) {
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
59 self.axpy(1.0, x, 0.0)
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
60 }
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
61
5
59dc4c5883f4 Improve documentation
Tuomo Valkonen <tuomov@iki.fi>
parents: 0
diff changeset
62 /// Computes `y = αx`, where `y` is `Self`.
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
63 fn scale_from<I: Instance<X>>(&mut self, α: Self::Field, x: I) {
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
64 self.axpy(α, x, 0.0)
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
65 }
62
d8305c9b6fdf Move origin stuff to AXPY form Euclidean
Tuomo Valkonen <tuomov@iki.fi>
parents: 61
diff changeset
66
d8305c9b6fdf Move origin stuff to AXPY form Euclidean
Tuomo Valkonen <tuomov@iki.fi>
parents: 61
diff changeset
67 /// Return a similar zero as `self`.
d8305c9b6fdf Move origin stuff to AXPY form Euclidean
Tuomo Valkonen <tuomov@iki.fi>
parents: 61
diff changeset
68 fn similar_origin(&self) -> Self::Owned;
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
69 // {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
70 // self.make_origin_generator().make_origin()
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
71 // }
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
72
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
73 /// Return a similar zero as `x`.
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
74 fn similar_origin_inst<I: Instance<Self>>(x: I) -> Self::Owned {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
75 x.eval(|xr| xr.similar_origin())
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
76 }
62
d8305c9b6fdf Move origin stuff to AXPY form Euclidean
Tuomo Valkonen <tuomov@iki.fi>
parents: 61
diff changeset
77
d8305c9b6fdf Move origin stuff to AXPY form Euclidean
Tuomo Valkonen <tuomov@iki.fi>
parents: 61
diff changeset
78 /// Set self to zero.
d8305c9b6fdf Move origin stuff to AXPY form Euclidean
Tuomo Valkonen <tuomov@iki.fi>
parents: 61
diff changeset
79 fn set_zero(&mut self);
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
80
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
81 //fn make_origin_generator(&self) -> Self::OriginGen<'_>;
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
82 }
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
83
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
84 /// Efficient in-place application for [`Linear`] operators.
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
85 #[replace_float_literals(F::cast_from(literal))]
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
86 pub trait GEMV<F: Num, X: Space, Y = <Self as Mapping<X>>::Codomain>: Linear<X> {
5
59dc4c5883f4 Improve documentation
Tuomo Valkonen <tuomov@iki.fi>
parents: 0
diff changeset
87 /// Computes `y = αAx + βy`, where `A` is `Self`.
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
88 fn gemv<I: Instance<X>>(&self, y: &mut Y, α: F, x: I, β: F);
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
89
67
d7c0f431cbd6 Discrete gradients
Tuomo Valkonen <tuomov@iki.fi>
parents: 66
diff changeset
90 #[inline]
5
59dc4c5883f4 Improve documentation
Tuomo Valkonen <tuomov@iki.fi>
parents: 0
diff changeset
91 /// Computes `y = Ax`, where `A` is `Self`
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
92 fn apply_mut<I: Instance<X>>(&self, y: &mut Y, x: I) {
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
93 self.gemv(y, 1.0, x, 0.0)
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
94 }
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
95
67
d7c0f431cbd6 Discrete gradients
Tuomo Valkonen <tuomov@iki.fi>
parents: 66
diff changeset
96 #[inline]
5
59dc4c5883f4 Improve documentation
Tuomo Valkonen <tuomov@iki.fi>
parents: 0
diff changeset
97 /// Computes `y += Ax`, where `A` is `Self`
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
98 fn apply_add<I: Instance<X>>(&self, y: &mut Y, x: I) {
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
99 self.gemv(y, 1.0, x, 1.0)
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
100 }
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
101 }
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
102
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
103 /// Bounded linear operators
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
104 pub trait BoundedLinear<X, XExp, CodExp, F = f64>: Linear<X>
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
105 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
106 F: Num,
124
6aa955ad8122 Transpose loc parameters to allow f64 defaults
Tuomo Valkonen <tuomov@iki.fi>
parents: 110
diff changeset
107 X: Space + Norm<XExp, F>,
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
108 XExp: NormExponent,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
109 CodExp: NormExponent,
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
110 {
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
111 /// A bound on the operator norm $\|A\|$ for the linear operator $A$=`self`.
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
112 /// This is not expected to be the norm, just any bound on it that can be
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
113 /// reasonably implemented. The [`NormExponent`] `xexp` indicates the norm
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
114 /// in `X`, and `codexp` in the codomain.
110
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 104
diff changeset
115 ///
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 104
diff changeset
116 /// This may fail with an error if the bound is for some reason incalculable.
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 104
diff changeset
117 fn opnorm_bound(&self, xexp: XExp, codexp: CodExp) -> DynResult<F>;
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
118 }
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
119
5
59dc4c5883f4 Improve documentation
Tuomo Valkonen <tuomov@iki.fi>
parents: 0
diff changeset
120 // Linear operator application into mutable target. The [`AsRef`] bound
59dc4c5883f4 Improve documentation
Tuomo Valkonen <tuomov@iki.fi>
parents: 0
diff changeset
121 // is used to guarantee compatibility with `Yʹ` and `Self::Codomain`;
59dc4c5883f4 Improve documentation
Tuomo Valkonen <tuomov@iki.fi>
parents: 0
diff changeset
122 // the former is assumed to be e.g. a view into the latter.
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
123
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
124 /*impl<X,Y,T> Fn(&X) -> Y for T where T : Linear<X,Codomain=Y> {
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
125 fn call(&self, x : &X) -> Y {
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
126 self.apply(x)
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
127 }
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
128 }*/
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
129
5
59dc4c5883f4 Improve documentation
Tuomo Valkonen <tuomov@iki.fi>
parents: 0
diff changeset
130 /// Trait for forming the adjoint operator of `Self`.
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
131 pub trait Adjointable<X, Yʹ>: Linear<X>
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
132 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
133 X: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
134 Yʹ: Space,
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
135 {
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
136 type AdjointCodomain: Space;
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
137 type Adjoint<'a>: Linear<Yʹ, Codomain = Self::AdjointCodomain>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
138 where
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
139 Self: 'a;
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
140
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
141 /// Form the adjoint operator of `self`.
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
142 fn adjoint(&self) -> Self::Adjoint<'_>;
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
143 }
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
144
5
59dc4c5883f4 Improve documentation
Tuomo Valkonen <tuomov@iki.fi>
parents: 0
diff changeset
145 /// Trait for forming a preadjoint of an operator.
59dc4c5883f4 Improve documentation
Tuomo Valkonen <tuomov@iki.fi>
parents: 0
diff changeset
146 ///
8
4e09b7829b51 Multithreaded bisection tree operations
Tuomo Valkonen <tuomov@iki.fi>
parents: 5
diff changeset
147 /// For an operator $A$ this is an operator $A\_\*$
4e09b7829b51 Multithreaded bisection tree operations
Tuomo Valkonen <tuomov@iki.fi>
parents: 5
diff changeset
148 /// such that its adjoint $(A\_\*)^\*=A$. The space `X` is the domain of the `Self`
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
149 /// operator. The space `Ypre` is the predual of its codomain, and should be the
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
150 /// domain of the adjointed operator. `Self::Preadjoint` should be
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
151 /// [`Adjointable`]`<'a,Ypre,X>`.
65
9327d544ca0b Reduce preadjointing constraints
Tuomo Valkonen <tuomov@iki.fi>
parents: 62
diff changeset
152 /// We do not make additional restrictions on `Self::Preadjoint` (in particular, it
9327d544ca0b Reduce preadjointing constraints
Tuomo Valkonen <tuomov@iki.fi>
parents: 62
diff changeset
153 /// does not have to be adjointable) to allow `X` to be a subspace yet the preadjoint
9327d544ca0b Reduce preadjointing constraints
Tuomo Valkonen <tuomov@iki.fi>
parents: 62
diff changeset
154 /// have the full space as the codomain, etc.
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
155 pub trait Preadjointable<X: Space, Ypre: Space = <Self as Mapping<X>>::Codomain>:
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
156 Linear<X>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
157 {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
158 type PreadjointCodomain: Space;
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
159 type Preadjoint<'a>: Linear<Ypre, Codomain = Self::PreadjointCodomain>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
160 where
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
161 Self: 'a;
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
162
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
163 /// Form the adjoint operator of `self`.
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
164 fn preadjoint(&self) -> Self::Preadjoint<'_>;
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
165 }
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
166
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
167 /// Adjointable operators $A: X → Y$ between reflexive spaces $X$ and $Y$.
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
168 pub trait SimplyAdjointable<X: Space>: Adjointable<X, <Self as Mapping<X>>::Codomain> {}
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
169 impl<'a, X: Space, T> SimplyAdjointable<X> for T where
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
170 T: Adjointable<X, <Self as Mapping<X>>::Codomain>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
171 {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
172 }
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
173
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
174 /// The identity operator
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
175 #[derive(Clone, Copy, Debug, Serialize, Eq, PartialEq)]
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
176 pub struct IdOp<X>(PhantomData<X>);
13
465fa2121ccb Better Linear and Mapping structure that can provide consuming and reference `apply`.
Tuomo Valkonen <tuomov@iki.fi>
parents: 8
diff changeset
177
465fa2121ccb Better Linear and Mapping structure that can provide consuming and reference `apply`.
Tuomo Valkonen <tuomov@iki.fi>
parents: 8
diff changeset
178 impl<X> IdOp<X> {
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
179 pub fn new() -> IdOp<X> {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
180 IdOp(PhantomData)
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
181 }
13
465fa2121ccb Better Linear and Mapping structure that can provide consuming and reference `apply`.
Tuomo Valkonen <tuomov@iki.fi>
parents: 8
diff changeset
182 }
465fa2121ccb Better Linear and Mapping structure that can provide consuming and reference `apply`.
Tuomo Valkonen <tuomov@iki.fi>
parents: 8
diff changeset
183
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
184 impl<X: Clone + Space> Mapping<X> for IdOp<X> {
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
185 type Codomain = X;
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
186
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
187 fn apply<I: Instance<X>>(&self, x: I) -> X {
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
188 x.own()
13
465fa2121ccb Better Linear and Mapping structure that can provide consuming and reference `apply`.
Tuomo Valkonen <tuomov@iki.fi>
parents: 8
diff changeset
189 }
465fa2121ccb Better Linear and Mapping structure that can provide consuming and reference `apply`.
Tuomo Valkonen <tuomov@iki.fi>
parents: 8
diff changeset
190 }
465fa2121ccb Better Linear and Mapping structure that can provide consuming and reference `apply`.
Tuomo Valkonen <tuomov@iki.fi>
parents: 8
diff changeset
191
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
192 impl<X: Clone + Space> Linear<X> for IdOp<X> {}
13
465fa2121ccb Better Linear and Mapping structure that can provide consuming and reference `apply`.
Tuomo Valkonen <tuomov@iki.fi>
parents: 8
diff changeset
193
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
194 #[replace_float_literals(F::cast_from(literal))]
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
195 impl<F: Num, X, Y> GEMV<F, X, Y> for IdOp<X>
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
196 where
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
197 Y: AXPY<X, Field = F>,
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
198 X: Clone + Space,
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
199 {
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
200 // Computes `y = αAx + βy`, where `A` is `Self`.
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
201 fn gemv<I: Instance<X>>(&self, y: &mut Y, α: F, x: I, β: F) {
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
202 y.axpy(α, x, β)
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
203 }
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
204
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
205 fn apply_mut<I: Instance<X>>(&self, y: &mut Y, x: I) {
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
206 y.copy_from(x);
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
207 }
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
208 }
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
209
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
210 impl<F, X, E> BoundedLinear<X, E, E, F> for IdOp<X>
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
211 where
124
6aa955ad8122 Transpose loc parameters to allow f64 defaults
Tuomo Valkonen <tuomov@iki.fi>
parents: 110
diff changeset
212 X: Space + Clone + Norm<E, F>,
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
213 F: Num,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
214 E: NormExponent,
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
215 {
110
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 104
diff changeset
216 fn opnorm_bound(&self, _xexp: E, _codexp: E) -> DynResult<F> {
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 104
diff changeset
217 Ok(F::ONE)
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
218 }
0
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
219 }
9f27689eb130 Initialise new clean repository
Tuomo Valkonen <tuomov@iki.fi>
parents:
diff changeset
220
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
221 impl<X: Clone + Space> Adjointable<X, X> for IdOp<X> {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
222 type AdjointCodomain = X;
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
223 type Adjoint<'a>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
224 = IdOp<X>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
225 where
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
226 X: 'a;
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
227
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
228 fn adjoint(&self) -> Self::Adjoint<'_> {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
229 IdOp::new()
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
230 }
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
231 }
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
232
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
233 impl<X: Clone + Space> Preadjointable<X, X> for IdOp<X> {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
234 type PreadjointCodomain = X;
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
235 type Preadjoint<'a>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
236 = IdOp<X>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
237 where
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
238 X: 'a;
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
239
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
240 fn preadjoint(&self) -> Self::Preadjoint<'_> {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
241 IdOp::new()
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
242 }
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
243 }
61
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
244
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
245 /// The zero operator from a space to itself
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
246 #[derive(Clone, Copy, Debug, Serialize, Eq, PartialEq)]
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
247 pub struct SimpleZeroOp;
66
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
248
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
249 impl<X> Mapping<X> for SimpleZeroOp
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
250 where
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
251 X: AXPY + Instance<X>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
252 {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
253 type Codomain = X::Owned;
66
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
254
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
255 fn apply<I: Instance<X>>(&self, x: I) -> X::Owned {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
256 X::similar_origin_inst(x)
66
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
257 }
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
258 }
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
259
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
260 impl<X> Linear<X> for SimpleZeroOp where X: AXPY + Instance<X> {}
66
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
261
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
262 #[replace_float_literals(F::cast_from(literal))]
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
263 impl<X, Y, F> GEMV<F, X, Y> for SimpleZeroOp
66
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
264 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
265 F: Num,
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
266 Y: AXPY<Field = F>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
267 X: AXPY<Field = F> + Instance<X>,
66
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
268 {
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
269 // Computes `y = αAx + βy`, where `A` is `Self`.
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
270 fn gemv<I: Instance<X>>(&self, y: &mut Y, _α: F, _x: I, β: F) {
66
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
271 *y *= β;
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
272 }
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
273
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
274 fn apply_mut<I: Instance<X>>(&self, y: &mut Y, _x: I) {
66
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
275 y.set_zero();
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
276 }
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
277 }
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
278
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
279 impl<X, F, E1, E2> BoundedLinear<X, E1, E2, F> for SimpleZeroOp
66
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
280 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
281 F: Num,
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
282 X: AXPY<Field = F> + Instance<X> + Norm<E1, F>,
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
283 E1: NormExponent,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
284 E2: NormExponent,
66
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
285 {
110
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 104
diff changeset
286 fn opnorm_bound(&self, _xexp: E1, _codexp: E2) -> DynResult<F> {
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 104
diff changeset
287 Ok(F::ZERO)
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
288 }
66
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
289 }
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
290
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
291 impl<X, F> Adjointable<X, X::DualSpace> for SimpleZeroOp
66
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
292 where
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
293 F: Num,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
294 X: AXPY<Field = F> + Instance<X> + HasDual<F>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
295 X::DualSpace: AXPY<Owned = X::DualSpace>,
66
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
296 {
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
297 type AdjointCodomain = X::DualSpace;
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
298 type Adjoint<'b>
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
299 = SimpleZeroOp
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
300 where
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
301 Self: 'b;
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
302 // () means not (pre)adjointable.
66
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
303
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
304 fn adjoint(&self) -> Self::Adjoint<'_> {
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
305 SimpleZeroOp
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
306 }
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
307 }
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
308
139
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
309 /// A zero operator that can be eitherh dualised or predualised (once).
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
310 /// This is achieved by storing an oppropriate zero.
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
311 pub struct ZeroOp<X, Y: AXPY<Field = F>, C, O, F: Float = f64> {
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
312 codomain_sample: C,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
313 other_sample: O,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
314 _phantoms: PhantomData<(X, Y, F)>,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
315 }
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
316
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
317 impl<'b, X, Y, F> ZeroOp<X, Y, &'b Y, &'b X::DualSpace, F>
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
318 where
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
319 X: HasDual<F>,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
320 Y: HasDual<F>,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
321 Y::Owned: Clone,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
322 F: Float,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
323 {
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
324 pub fn new_dualisable(x_dual_sample: &'b X::DualSpace, y_sample: &'b Y) -> Self {
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
325 ZeroOp {
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
326 codomain_sample: y_sample,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
327 other_sample: x_dual_sample,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
328 _phantoms: PhantomData,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
329 }
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
330 }
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
331 }
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
332
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
333 impl<'b, X, Y, O, F> Mapping<X> for ZeroOp<X, Y, &'b Y, O, F>
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
334 where
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
335 X: Space + Instance<X>,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
336 Y: AXPY<Field = F>,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
337 F: Float,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
338 {
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
339 type Codomain = Y::Owned;
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
340
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
341 fn apply<I: Instance<X>>(&self, _x: I) -> Y::Owned {
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
342 self.codomain_sample.similar_origin()
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
343 }
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
344 }
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
345
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
346 impl<'b, X, Y, O, F> Linear<X> for ZeroOp<X, Y, &'b Y, O, F>
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
347 where
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
348 X: Space + Instance<X>,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
349 Y: AXPY<Field = F>,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
350 F: Float,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
351 {
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
352 }
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
353
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
354 #[replace_float_literals(F::cast_from(literal))]
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
355 impl<'b, X, Y, O, F> GEMV<F, X, Y> for ZeroOp<X, Y, &'b Y, O, F>
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
356 where
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
357 X: Space + Instance<X>,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
358 Y: AXPY<Field = F>,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
359 F: Float,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
360 {
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
361 // Computes `y = αAx + βy`, where `A` is `Self`.
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
362 fn gemv<I: Instance<X>>(&self, y: &mut Y, _α: F, _x: I, β: F) {
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
363 *y *= β;
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
364 }
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
365
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
366 fn apply_mut<I: Instance<X>>(&self, y: &mut Y, _x: I) {
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
367 y.set_zero();
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
368 }
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
369 }
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
370
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
371 impl<'b, X, Y, O, F, E1, E2> BoundedLinear<X, E1, E2, F> for ZeroOp<X, Y, &'b Y, O, F>
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
372 where
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
373 X: Space + Instance<X> + Norm<E1, F>,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
374 Y: AXPY<Field = F>,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
375 Y::Owned: Clone,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
376 F: Float,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
377 E1: NormExponent,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
378 E2: NormExponent,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
379 {
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
380 fn opnorm_bound(&self, _xexp: E1, _codexp: E2) -> DynResult<F> {
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
381 Ok(F::ZERO)
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
382 }
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
383 }
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
384
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
385 impl<'b, X, Y, Xprime, Yprime, F> Adjointable<X, Yprime> for ZeroOp<X, Y, &'b Y, &'b Xprime, F>
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
386 where
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
387 X: HasDual<F, DualSpace = Xprime>,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
388 Y: HasDual<F, DualSpace = Yprime>,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
389 F: Float,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
390 Xprime: AXPY<Field = F, Owned = Xprime>,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
391 Xprime::Owned: AXPY<Field = F>,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
392 Yprime: Space + Instance<Yprime>,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
393 {
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
394 type AdjointCodomain = Xprime;
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
395 type Adjoint<'c>
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
396 = ZeroOp<Yprime, Xprime, &'b Xprime, (), F>
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
397 where
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
398 Self: 'c;
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
399 // () means not (pre)adjointable.
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
400
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
401 fn adjoint(&self) -> Self::Adjoint<'_> {
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
402 ZeroOp {
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
403 codomain_sample: self.other_sample,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
404 other_sample: (),
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
405 _phantoms: PhantomData,
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
406 }
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
407 }
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
408 }
f78885441218 new ZeroOp
Tuomo Valkonen <tuomov@iki.fi>
parents: 133
diff changeset
409
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
410 /*
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
411 /// Trait for forming origins (zeroes) in vector spaces
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
412 pub trait OriginGenerator<X, F: Num = f64> {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
413 fn make_origin(&self) -> X;
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
414 }
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
415
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
416 /// Origin generator for statically sized Euclidean spaces.
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
417 pub struct StaticEuclideanOriginGenerator;
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
418
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
419 impl<X, F: Float> OriginGenerator<X, F> for StaticEuclideanOriginGenerator
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
420 where
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
421 X: StaticEuclidean<F> + Euclidean<F, Output = X>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
422 {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
423 #[inline]
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
424 fn make_origin(&self) -> X {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
425 X::origin()
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
426 }
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
427 }
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
428
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
429 /// Origin generator arbitrary spaces that implement [`AXPY`], based on a sample vector.
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
430 pub struct SimilarOriginGenerator<'a, X>(&'a X);
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
431
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
432 impl<'a, X, F: Float> OriginGenerator<X, F> for SimilarOriginGenerator<'a, X>
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
433 where
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
434 X: AXPY<F, Owned = X>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
435 {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
436 #[inline]
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
437 fn make_origin(&self) -> X {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
438 self.0.similar_origin()
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
439 }
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
440 }
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
441
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
442 pub struct NotAnOriginGenerator;
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
443
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
444 /// The zero operator
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
445 #[derive(Clone, Copy, Debug, Serialize, Eq, PartialEq)]
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
446 pub struct ZeroOp<X, Y, YOrigin, XDOrigin = NotAnOriginGenerator, F: Num = f64> {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
447 y_origin: YOrigin,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
448 xd_origin: XDOrigin,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
449 _phantoms: PhantomData<(X, Y, F)>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
450 }
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
451
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
452 // TODO: Need to make Zero in Instance.
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
453
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
454 impl<X, Y, F, YOrigin, XDOrigin> ZeroOp<X, Y, YOrigin, XDOrigin, F>
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
455 where
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
456 F: Num,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
457 YOrigin: OriginGenerator<Y, F>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
458 {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
459 pub fn new(y_origin: YOrigin, xd_origin: XDOrigin) -> Self {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
460 ZeroOp {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
461 y_origin,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
462 xd_origin,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
463 _phantoms: PhantomData,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
464 }
66
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
465 }
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
466 }
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
467
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
468 impl<X, Y, F, YOrigin, XDOrigin> Mapping<X> for ZeroOp<X, Y, YOrigin, XDOrigin, F>
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
469 where
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
470 F: Num,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
471 YOrigin: OriginGenerator<Y, F>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
472 Y: Space,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
473 X: Space + Instance<X>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
474 {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
475 type Codomain = Y;
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
476
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
477 fn apply<I: Instance<X>>(&self, _: I) -> Y {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
478 self.y_origin.make_origin()
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
479 }
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
480 }
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
481
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
482 impl<X, Y, F, YOrigin, XDOrigin> Linear<X> for ZeroOp<X, Y, YOrigin, XDOrigin, F>
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
483 where
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
484 F: Num,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
485 YOrigin: OriginGenerator<Y, F>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
486 Y: Space,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
487 X: Space + Instance<X>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
488 {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
489 }
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
490
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
491 #[replace_float_literals(F::cast_from(literal))]
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
492 impl<X, Y, F, YOrigin, XDOrigin> GEMV<F, X, Y> for ZeroOp<X, Y, YOrigin, XDOrigin, F>
66
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
493 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
494 F: Num,
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
495 YOrigin: OriginGenerator<Y, F>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
496 Y: Space + AXPY<F>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
497 X: Space + Instance<X>,
66
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
498 {
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
499 // Computes `y = αAx + βy`, where `A` is `Self`.
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
500 fn gemv<I: Instance<X>>(&self, y: &mut Y, _α: F, _x: I, β: F) {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
501 *y *= β;
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
502 }
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
503
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
504 fn apply_mut<I: Instance<X>>(&self, y: &mut Y, _x: I) {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
505 y.set_zero();
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
506 }
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
507 }
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
508
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
509 impl<X, Y, F, YOrigin, XDOrigin, E1, E2> BoundedLinear<X, E1, E2, F>
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
510 for ZeroOp<X, Y, YOrigin, XDOrigin, F>
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
511 where
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
512 F: Num,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
513 YOrigin: OriginGenerator<Y, F>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
514 Y: Space + AXPY<F> + Norm<E2, F>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
515 X: Space + Instance<X> + Norm<E1, F>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
516 E1: NormExponent,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
517 E2: NormExponent,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
518 {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
519 fn opnorm_bound(&self, _xexp: E1, _codexp: E2) -> DynResult<F> {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
520 Ok(F::ZERO)
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
521 }
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
522 }
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
523
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
524 impl<X, Y, Yprime, F, YOrigin, XDOrigin> Adjointable<X, Yprime>
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
525 for ZeroOp<X, Y, YOrigin, XDOrigin, F>
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
526 where
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
527 F: Num,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
528 YOrigin: OriginGenerator<Y, F>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
529 Y: Space + AXPY<F>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
530 X: Space + Instance<X> + HasDual<F>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
531 XDOrigin: OriginGenerator<X::DualSpace, F> + Clone,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
532 Yprime: Space + Instance<Yprime>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
533 {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
534 type AdjointCodomain = X::DualSpace;
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
535 type Adjoint<'b>
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
536 = ZeroOp<Yprime, X::DualSpace, XDOrigin, NotAnOriginGenerator, F>
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
537 where
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
538 Self: 'b;
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
539 // () means not (pre)adjointable.
66
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
540
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
541 fn adjoint(&self) -> Self::Adjoint<'_> {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
542 ZeroOp::new(self.xd_origin.clone(), NotAnOriginGenerator)
66
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
543 }
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
544 }
129
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
545 */
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
546
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
547 /*
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
548 impl<X, Y, Ypre, Xpre, F, YOrigin, XDOrigin> Preadjointable<X, Ypre>
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
549 for ZeroOp<X, Y, YOrigin, XDOrigin, F>
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
550 where
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
551 F: Num,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
552 YOrigin: OriginGenerator<Y, F>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
553 Y: Space + AXPY<F>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
554 X: Space + Instance<X> + HasDual<F>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
555 XDOrigin: OriginGenerator<Xpre, F> + Clone,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
556 Ypre: Space + Instance<Ypre> + HasDual<DualSpace = X>,
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
557 {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
558 type PreadjointCodomain = Xpre;
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
559 type Preadjoint<'b>
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
560 = ZeroOp<Ypre, Xpre, XDOrigin, NotAnOriginGenerator, F>
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
561 where
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
562 Self: 'b;
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
563 // () means not (pre)adjointable.
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
564
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
565 fn adjoint(&self) -> Self::Adjoint<'_> {
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
566 ZeroOp::new(self.xpre_origin.clone(), NotAnOriginGenerator)
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
567 }
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
568 }
d2994e34a5f5 Simplify ZeroOp to SimpleZeroOp, only from X to X. Add Prox for ZeroIndicator. Move F parameter to AXPY::Field.
Tuomo Valkonen <tuomov@iki.fi>
parents: 124
diff changeset
569 */
66
Tuomo Valkonen <tuomov@iki.fi>
parents: 65
diff changeset
570
61
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
571 impl<S, T, E, X> Linear<X> for Composition<S, T, E>
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
572 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
573 X: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
574 T: Linear<X>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
575 S: Linear<T::Codomain>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
576 {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
577 }
61
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
578
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
579 impl<F, S, T, E, X, Y> GEMV<F, X, Y> for Composition<S, T, E>
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
580 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
581 F: Num,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
582 X: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
583 T: Linear<X>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
584 S: GEMV<F, T::Codomain, Y>,
61
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
585 {
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
586 fn gemv<I: Instance<X>>(&self, y: &mut Y, α: F, x: I, β: F) {
61
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
587 self.outer.gemv(y, α, self.inner.apply(x), β)
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
588 }
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
589
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
590 /// Computes `y = Ax`, where `A` is `Self`
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
591 fn apply_mut<I: Instance<X>>(&self, y: &mut Y, x: I) {
61
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
592 self.outer.apply_mut(y, self.inner.apply(x))
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
593 }
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
594
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
595 /// Computes `y += Ax`, where `A` is `Self`
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
596 fn apply_add<I: Instance<X>>(&self, y: &mut Y, x: I) {
61
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
597 self.outer.apply_add(y, self.inner.apply(x))
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
598 }
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
599 }
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
600
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
601 impl<F, S, T, X, Z, Xexp, Yexp, Zexp> BoundedLinear<X, Xexp, Yexp, F> for Composition<S, T, Zexp>
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
602 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
603 F: Num,
124
6aa955ad8122 Transpose loc parameters to allow f64 defaults
Tuomo Valkonen <tuomov@iki.fi>
parents: 110
diff changeset
604 X: Space + Norm<Xexp, F>,
6aa955ad8122 Transpose loc parameters to allow f64 defaults
Tuomo Valkonen <tuomov@iki.fi>
parents: 110
diff changeset
605 Z: Space + Norm<Zexp, F>,
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
606 Xexp: NormExponent,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
607 Yexp: NormExponent,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
608 Zexp: NormExponent,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
609 T: BoundedLinear<X, Xexp, Zexp, F, Codomain = Z>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
610 S: BoundedLinear<Z, Zexp, Yexp, F>,
61
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
611 {
110
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 104
diff changeset
612 fn opnorm_bound(&self, xexp: Xexp, yexp: Yexp) -> DynResult<F> {
61
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
613 let zexp = self.intermediate_norm_exponent;
110
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 104
diff changeset
614 Ok(self.outer.opnorm_bound(zexp, yexp)? * self.inner.opnorm_bound(xexp, zexp)?)
61
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
615 }
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
616 }
05089fbc0310 Compositions
Tuomo Valkonen <tuomov@iki.fi>
parents: 59
diff changeset
617
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
618 /// “Row operator” $(S, T)$; $(S, T)(x, y)=Sx + Ty$.
101
997961aa6eee Add some missing #derives
Tuomo Valkonen <tuomov@iki.fi>
parents: 99
diff changeset
619 #[derive(Clone, Copy, Debug, Serialize, Eq, PartialEq)]
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
620 pub struct RowOp<S, T>(pub S, pub T);
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
621
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
622 impl<A, B, S, T> Mapping<Pair<A, B>> for RowOp<S, T>
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
623 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
624 A: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
625 B: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
626 S: Mapping<A>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
627 T: Mapping<B>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
628 S::Codomain: Add<T::Codomain>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
629 <S::Codomain as Add<T::Codomain>>::Output: Space,
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
630 {
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
631 type Codomain = <S::Codomain as Add<T::Codomain>>::Output;
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
632
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
633 fn apply<I: Instance<Pair<A, B>>>(&self, x: I) -> Self::Codomain {
133
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
634 x.eval_decompose(|Pair(a, b)| self.0.apply(a) + self.1.apply(b))
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
635 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
636 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
637
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
638 impl<A, B, S, T> Linear<Pair<A, B>> for RowOp<S, T>
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
639 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
640 A: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
641 B: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
642 S: Linear<A>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
643 T: Linear<B>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
644 S::Codomain: Add<T::Codomain>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
645 <S::Codomain as Add<T::Codomain>>::Output: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
646 {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
647 }
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
648
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
649 impl<'b, F, S, T, Y, U, V> GEMV<F, Pair<U, V>, Y> for RowOp<S, T>
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
650 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
651 U: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
652 V: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
653 S: GEMV<F, U, Y>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
654 T: GEMV<F, V, Y>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
655 F: Num,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
656 Self: Linear<Pair<U, V>, Codomain = Y>,
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
657 {
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
658 fn gemv<I: Instance<Pair<U, V>>>(&self, y: &mut Y, α: F, x: I, β: F) {
133
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
659 x.eval_decompose(|Pair(u, v)| {
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
660 self.0.gemv(y, α, u, β);
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
661 self.1.gemv(y, α, v, F::ONE);
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
662 })
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
663 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
664
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
665 fn apply_mut<I: Instance<Pair<U, V>>>(&self, y: &mut Y, x: I) {
133
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
666 x.eval_decompose(|Pair(u, v)| {
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
667 self.0.apply_mut(y, u);
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
668 self.1.apply_add(y, v);
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
669 })
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
670 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
671
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
672 /// Computes `y += Ax`, where `A` is `Self`
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
673 fn apply_add<I: Instance<Pair<U, V>>>(&self, y: &mut Y, x: I) {
133
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
674 x.eval_decompose(|Pair(u, v)| {
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
675 self.0.apply_add(y, u);
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
676 self.1.apply_add(y, v);
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
677 })
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
678 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
679 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
680
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
681 /// “Column operator” $(S; T)$; $(S; T)x=(Sx, Tx)$.
101
997961aa6eee Add some missing #derives
Tuomo Valkonen <tuomov@iki.fi>
parents: 99
diff changeset
682 #[derive(Clone, Copy, Debug, Serialize, Eq, PartialEq)]
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
683 pub struct ColOp<S, T>(pub S, pub T);
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
684
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
685 impl<A, S, T> Mapping<A> for ColOp<S, T>
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
686 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
687 A: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
688 S: Mapping<A>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
689 T: Mapping<A>,
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
690 {
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
691 type Codomain = Pair<S::Codomain, T::Codomain>;
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
692
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
693 fn apply<I: Instance<A>>(&self, a: I) -> Self::Codomain {
133
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
694 Pair(a.eval_ref_decompose(|r| self.0.apply(r)), self.1.apply(a))
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
695 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
696 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
697
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
698 impl<A, S, T> Linear<A> for ColOp<S, T>
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
699 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
700 A: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
701 S: Mapping<A>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
702 T: Mapping<A>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
703 {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
704 }
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
705
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
706 impl<F, S, T, A, B, X> GEMV<F, X, Pair<A, B>> for ColOp<S, T>
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
707 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
708 X: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
709 S: GEMV<F, X, A>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
710 T: GEMV<F, X, B>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
711 F: Num,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
712 Self: Linear<X, Codomain = Pair<A, B>>,
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
713 {
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
714 fn gemv<I: Instance<X>>(&self, y: &mut Pair<A, B>, α: F, x: I, β: F) {
133
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
715 x.eval_ref_decompose(|r| self.0.gemv(&mut y.0, α, r, β));
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
716 self.1.gemv(&mut y.1, α, x, β);
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
717 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
718
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
719 fn apply_mut<I: Instance<X>>(&self, y: &mut Pair<A, B>, x: I) {
133
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
720 x.eval_ref_decompose(|r| self.0.apply_mut(&mut y.0, r));
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
721 self.1.apply_mut(&mut y.1, x);
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
722 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
723
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
724 /// Computes `y += Ax`, where `A` is `Self`
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
725 fn apply_add<I: Instance<X>>(&self, y: &mut Pair<A, B>, x: I) {
133
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
726 x.eval_ref_decompose(|r| self.0.apply_add(&mut y.0, r));
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
727 self.1.apply_add(&mut y.1, x);
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
728 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
729 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
730
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
731 impl<A, B, Yʹ, S, T> Adjointable<Pair<A, B>, Yʹ> for RowOp<S, T>
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
732 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
733 A: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
734 B: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
735 Yʹ: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
736 S: Adjointable<A, Yʹ>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
737 T: Adjointable<B, Yʹ>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
738 Self: Linear<Pair<A, B>>,
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
739 // for<'a> ColOp<S::Adjoint<'a>, T::Adjoint<'a>> : Linear<
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
740 // Yʹ,
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
741 // Codomain=Pair<S::AdjointCodomain, T::AdjointCodomain>
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
742 // >,
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
743 {
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
744 type AdjointCodomain = Pair<S::AdjointCodomain, T::AdjointCodomain>;
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
745 type Adjoint<'a>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
746 = ColOp<S::Adjoint<'a>, T::Adjoint<'a>>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
747 where
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
748 Self: 'a;
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
749
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
750 fn adjoint(&self) -> Self::Adjoint<'_> {
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
751 ColOp(self.0.adjoint(), self.1.adjoint())
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
752 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
753 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
754
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
755 impl<A, B, Yʹ, S, T> Preadjointable<Pair<A, B>, Yʹ> for RowOp<S, T>
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
756 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
757 A: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
758 B: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
759 Yʹ: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
760 S: Preadjointable<A, Yʹ>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
761 T: Preadjointable<B, Yʹ>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
762 Self: Linear<Pair<A, B>>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
763 for<'a> ColOp<S::Preadjoint<'a>, T::Preadjoint<'a>>:
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
764 Linear<Yʹ, Codomain = Pair<S::PreadjointCodomain, T::PreadjointCodomain>>,
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
765 {
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
766 type PreadjointCodomain = Pair<S::PreadjointCodomain, T::PreadjointCodomain>;
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
767 type Preadjoint<'a>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
768 = ColOp<S::Preadjoint<'a>, T::Preadjoint<'a>>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
769 where
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
770 Self: 'a;
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
771
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
772 fn preadjoint(&self) -> Self::Preadjoint<'_> {
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
773 ColOp(self.0.preadjoint(), self.1.preadjoint())
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
774 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
775 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
776
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
777 impl<A, Xʹ, Yʹ, R, S, T> Adjointable<A, Pair<Xʹ, Yʹ>> for ColOp<S, T>
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
778 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
779 A: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
780 Xʹ: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
781 Yʹ: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
782 R: Space + ClosedAdd,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
783 S: Adjointable<A, Xʹ, AdjointCodomain = R>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
784 T: Adjointable<A, Yʹ, AdjointCodomain = R>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
785 Self: Linear<A>,
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
786 // for<'a> RowOp<S::Adjoint<'a>, T::Adjoint<'a>> : Linear<
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
787 // Pair<Xʹ,Yʹ>,
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
788 // Codomain=R,
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
789 // >,
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
790 {
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
791 type AdjointCodomain = R;
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
792 type Adjoint<'a>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
793 = RowOp<S::Adjoint<'a>, T::Adjoint<'a>>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
794 where
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
795 Self: 'a;
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
796
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
797 fn adjoint(&self) -> Self::Adjoint<'_> {
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
798 RowOp(self.0.adjoint(), self.1.adjoint())
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
799 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
800 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
801
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
802 impl<A, Xʹ, Yʹ, R, S, T> Preadjointable<A, Pair<Xʹ, Yʹ>> for ColOp<S, T>
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
803 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
804 A: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
805 Xʹ: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
806 Yʹ: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
807 R: Space + ClosedAdd,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
808 S: Preadjointable<A, Xʹ, PreadjointCodomain = R>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
809 T: Preadjointable<A, Yʹ, PreadjointCodomain = R>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
810 Self: Linear<A>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
811 for<'a> RowOp<S::Preadjoint<'a>, T::Preadjoint<'a>>: Linear<Pair<Xʹ, Yʹ>, Codomain = R>,
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
812 {
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
813 type PreadjointCodomain = R;
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
814 type Preadjoint<'a>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
815 = RowOp<S::Preadjoint<'a>, T::Preadjoint<'a>>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
816 where
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
817 Self: 'a;
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
818
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
819 fn preadjoint(&self) -> Self::Preadjoint<'_> {
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
820 RowOp(self.0.preadjoint(), self.1.preadjoint())
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
821 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
822 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
823
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
824 /// Diagonal operator
101
997961aa6eee Add some missing #derives
Tuomo Valkonen <tuomov@iki.fi>
parents: 99
diff changeset
825 #[derive(Clone, Copy, Debug, Serialize, Eq, PartialEq)]
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
826 pub struct DiagOp<S, T>(pub S, pub T);
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
827
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
828 impl<A, B, S, T> Mapping<Pair<A, B>> for DiagOp<S, T>
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
829 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
830 A: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
831 B: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
832 S: Mapping<A>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
833 T: Mapping<B>,
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
834 {
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
835 type Codomain = Pair<S::Codomain, T::Codomain>;
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
836
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
837 fn apply<I: Instance<Pair<A, B>>>(&self, x: I) -> Self::Codomain {
133
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
838 x.eval_decompose(|Pair(a, b)| Pair(self.0.apply(a), self.1.apply(b)))
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
839 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
840 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
841
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
842 impl<A, B, S, T> Linear<Pair<A, B>> for DiagOp<S, T>
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
843 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
844 A: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
845 B: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
846 S: Linear<A>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
847 T: Linear<B>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
848 {
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
849 }
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
850
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
851 impl<F, S, T, A, B, U, V> GEMV<F, Pair<U, V>, Pair<A, B>> for DiagOp<S, T>
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
852 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
853 A: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
854 B: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
855 U: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
856 V: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
857 S: GEMV<F, U, A>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
858 T: GEMV<F, V, B>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
859 F: Num,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
860 Self: Linear<Pair<U, V>, Codomain = Pair<A, B>>,
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
861 {
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
862 fn gemv<I: Instance<Pair<U, V>>>(&self, y: &mut Pair<A, B>, α: F, x: I, β: F) {
133
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
863 x.eval_decompose(|Pair(u, v)| {
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
864 self.0.gemv(&mut y.0, α, u, β);
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
865 self.1.gemv(&mut y.1, α, v, β);
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
866 })
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
867 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
868
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
869 fn apply_mut<I: Instance<Pair<U, V>>>(&self, y: &mut Pair<A, B>, x: I) {
133
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
870 x.eval_decompose(|Pair(u, v)| {
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
871 self.0.apply_mut(&mut y.0, u);
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
872 self.1.apply_mut(&mut y.1, v);
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
873 })
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
874 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
875
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
876 /// Computes `y += Ax`, where `A` is `Self`
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
877 fn apply_add<I: Instance<Pair<U, V>>>(&self, y: &mut Pair<A, B>, x: I) {
133
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
878 x.eval_decompose(|Pair(u, v)| {
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
879 self.0.apply_add(&mut y.0, u);
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
880 self.1.apply_add(&mut y.1, v);
2b13f8a0c8ba Replace Instance ref_instance and decompose by eval_* for flexibility
Tuomo Valkonen <tuomov@iki.fi>
parents: 130
diff changeset
881 })
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
882 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
883 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
884
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
885 impl<A, B, Xʹ, Yʹ, R, S, T> Adjointable<Pair<A, B>, Pair<Xʹ, Yʹ>> for DiagOp<S, T>
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
886 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
887 A: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
888 B: Space,
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
889 Xʹ: Space,
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
890 Yʹ: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
891 R: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
892 S: Adjointable<A, Xʹ>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
893 T: Adjointable<B, Yʹ>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
894 Self: Linear<Pair<A, B>>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
895 for<'a> DiagOp<S::Adjoint<'a>, T::Adjoint<'a>>: Linear<Pair<Xʹ, Yʹ>, Codomain = R>,
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
896 {
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
897 type AdjointCodomain = R;
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
898 type Adjoint<'a>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
899 = DiagOp<S::Adjoint<'a>, T::Adjoint<'a>>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
900 where
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
901 Self: 'a;
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
902
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
903 fn adjoint(&self) -> Self::Adjoint<'_> {
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
904 DiagOp(self.0.adjoint(), self.1.adjoint())
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
905 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
906 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
907
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
908 impl<A, B, Xʹ, Yʹ, R, S, T> Preadjointable<Pair<A, B>, Pair<Xʹ, Yʹ>> for DiagOp<S, T>
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
909 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
910 A: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
911 B: Space,
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
912 Xʹ: Space,
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
913 Yʹ: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
914 R: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
915 S: Preadjointable<A, Xʹ>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
916 T: Preadjointable<B, Yʹ>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
917 Self: Linear<Pair<A, B>>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
918 for<'a> DiagOp<S::Preadjoint<'a>, T::Preadjoint<'a>>: Linear<Pair<Xʹ, Yʹ>, Codomain = R>,
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
919 {
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
920 type PreadjointCodomain = R;
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
921 type Preadjoint<'a>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
922 = DiagOp<S::Preadjoint<'a>, T::Preadjoint<'a>>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
923 where
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
924 Self: 'a;
57
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
925
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
926 fn preadjoint(&self) -> Self::Preadjoint<'_> {
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
927 DiagOp(self.0.preadjoint(), self.1.preadjoint())
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
928 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
929 }
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
930
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
931 /// Block operator
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
932 pub type BlockOp<S11, S12, S21, S22> = ColOp<RowOp<S11, S12>, RowOp<S21, S22>>;
1b3b1687b9ed Add direct products (Pair, RowOp, ColOp, DiagOp)
Tuomo Valkonen <tuomov@iki.fi>
parents: 13
diff changeset
933
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
934 macro_rules! pairnorm {
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
935 ($expj:ty) => {
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
936 impl<F, A, B, S, T, ExpA, ExpB, ExpR>
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
937 BoundedLinear<Pair<A, B>, PairNorm<ExpA, ExpB, $expj>, ExpR, F> for RowOp<S, T>
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
938 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
939 F: Float,
124
6aa955ad8122 Transpose loc parameters to allow f64 defaults
Tuomo Valkonen <tuomov@iki.fi>
parents: 110
diff changeset
940 A: Space + Norm<ExpA, F>,
6aa955ad8122 Transpose loc parameters to allow f64 defaults
Tuomo Valkonen <tuomov@iki.fi>
parents: 110
diff changeset
941 B: Space + Norm<ExpB, F>,
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
942 S: BoundedLinear<A, ExpA, ExpR, F>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
943 T: BoundedLinear<B, ExpB, ExpR, F>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
944 S::Codomain: Add<T::Codomain>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
945 <S::Codomain as Add<T::Codomain>>::Output: Space,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
946 ExpA: NormExponent,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
947 ExpB: NormExponent,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
948 ExpR: NormExponent,
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
949 {
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
950 fn opnorm_bound(
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
951 &self,
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
952 PairNorm(expa, expb, _): PairNorm<ExpA, ExpB, $expj>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
953 expr: ExpR,
110
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 104
diff changeset
954 ) -> DynResult<F> {
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
955 // An application of the triangle inequality bounds the norm by the maximum
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
956 // of the individual norms. A simple observation shows this to be exact.
110
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 104
diff changeset
957 let na = self.0.opnorm_bound(expa, expr)?;
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 104
diff changeset
958 let nb = self.1.opnorm_bound(expb, expr)?;
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 104
diff changeset
959 Ok(na.max(nb))
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
960 }
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
961 }
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
962
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
963 impl<F, A, S, T, ExpA, ExpS, ExpT> BoundedLinear<A, ExpA, PairNorm<ExpS, ExpT, $expj>, F>
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
964 for ColOp<S, T>
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
965 where
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
966 F: Float,
124
6aa955ad8122 Transpose loc parameters to allow f64 defaults
Tuomo Valkonen <tuomov@iki.fi>
parents: 110
diff changeset
967 A: Space + Norm<ExpA, F>,
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
968 S: BoundedLinear<A, ExpA, ExpS, F>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
969 T: BoundedLinear<A, ExpA, ExpT, F>,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
970 ExpA: NormExponent,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
971 ExpS: NormExponent,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
972 ExpT: NormExponent,
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
973 {
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
974 fn opnorm_bound(
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
975 &self,
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
976 expa: ExpA,
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
977 PairNorm(exps, expt, _): PairNorm<ExpS, ExpT, $expj>,
110
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 104
diff changeset
978 ) -> DynResult<F> {
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
979 // This is based on the rule for RowOp and ‖A^*‖ = ‖A‖, hence,
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
980 // for A=[S; T], ‖A‖=‖[S^*, T^*]‖ ≤ max{‖S^*‖, ‖T^*‖} = max{‖S‖, ‖T‖}
110
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 104
diff changeset
981 let ns = self.0.opnorm_bound(expa, exps)?;
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 104
diff changeset
982 let nt = self.1.opnorm_bound(expa, expt)?;
a1278320be26 Use DynResult for Lipschitz factors and operator norm bounds
Tuomo Valkonen <tuomov@iki.fi>
parents: 104
diff changeset
983 Ok(ns.max(nt))
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
984 }
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
985 }
99
9e5b9fc81c52 Quadratic Mappings; Lipschitz trait (moved from pointsource_algs).
Tuomo Valkonen <tuomov@iki.fi>
parents: 74
diff changeset
986 };
59
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
987 }
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
988
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
989 pairnorm!(L1);
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
990 pairnorm!(L2);
9226980e45a7 Significantly simplify Mapping / Apply through Instance
Tuomo Valkonen <tuomov@iki.fi>
parents: 57
diff changeset
991 pairnorm!(Linfinity);
104
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
992
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
993 /// The simplest linear mapping, scaling by a scalar.
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
994 ///
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
995 /// TODO: redefined/replace [`Weighted`] by composition with [`Scaled`].
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
996 pub struct Scaled<F: Float>(pub F);
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
997
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
998 impl<Domain, F> Mapping<Domain> for Scaled<F>
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
999 where
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
1000 F: Float,
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
1001 Domain: Space + ClosedMul<F>,
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
1002 {
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
1003 type Codomain = <Domain as Mul<F>>::Output;
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
1004
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
1005 /// Compute the value of `self` at `x`.
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
1006 fn apply<I: Instance<Domain>>(&self, x: I) -> Self::Codomain {
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
1007 x.own() * self.0
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
1008 }
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
1009 }
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
1010
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
1011 impl<Domain, F> Linear<Domain> for Scaled<F>
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
1012 where
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
1013 F: Float,
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
1014 Domain: Space + ClosedMul<F>,
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
1015 {
e7f1cb4bec78 Norm222
Tuomo Valkonen <tuomov@iki.fi>
parents: 101
diff changeset
1016 }

mercurial