The v1.1.2 release does not contain any major changes but mainly incremental improvements and bug fixes.
- New
LinOpXRay
for 2D radon transform (Note that the adjoint is not really the adjoint, but only an approximation (up to about 20 dB), - LinOp compatibility with sparse matrices,
Util/estimateNorm.m
for estimation of the norm of an operator,- New
OutputOptiSNR
to print SNR during optimization, - Better summation and multiplication of Map objects with scalars,
- Rename
OpEWSquareRoot
toOpEWSqrt
, - Add some kind of unitary tests,
CostHyperBolic
: Epsilon can be a vector,- non scalar step size in
OptiFBS
Many bug fixes, among them:
- Generalize Compiler option for C/C++ files and reactivate openmp for the Schatten norm
- Better handling of singletons dimensions.
The v1.1.1 release does not contain any major changes but mainly incremental improvements and bug fixes.
- Sfft functions: faster implementation, work with any dimension, new padding option argument.
- Merge LinOpDFT into LinOpSDFT. LinOpDFT remains now as an alias.
- Remove code duplication in SelectorLinOps.
- Add unitary tests (using the provided examples, see /Util/UnitTest/Script.m)
- Add subgradient in CostL1
- Add test for applyAdjointInverse method in checkMap
- Add property for real input in CostComposition. When activated, takes the real part after gradient computation.
- Fix bug in applyHtH and applyHHt of LinOpSummation
- Fix a memory issue in Cost
- Fix bug in the computation of the Lipschitz constant of CostSummation.
- Fix index of the coefficients vetor in the plus method of LinOp
- Fix superclass constructor call in CostReals
The v1.1 release contains a new functionality for GPU computation plus incremental improvements and bug fixes.
- add the functions ones_, zeros_, useGPU, isGPU, gpuCpuConverter
- replace occurences of all() by sum( test)==0
- replace occurences of ones() and zeros() by ones_() and zeros_()
- update the 3D deconvolution example with GPU
- add a page in the documentation dedicated to GPU
- fix a bug in OptiVMLMB compilation (you should recompile it by running installOptimPack.m)
- set saveXopt=false by default in OutputOpti
- add flag isSeparable for Cost classes. Generic implementation of applyProx_ for the sum of a separable cost with an indicator cost.
- add a direct prox computation for the composition of a CostL2 with a Downsampled Convolution
- add CostMixNorm21 a non negativity constrained version of CostMixNorm21
- ADMM can now take a Sum of CostL2Composition in the F0 argument
- remove OutputOptiADMM
The v1.0.1 release does not contain any major changes but mainly incremental improvements and bug fixes.
- New LinOpBroadcastMatrix
- fix pb in makeComposition of LinOpSum other cases in makeComposition btw LinOpDiag and LinOpConv
- LinOpHess is now working for any dimensions, with the choice of the index along which the hessian is computed (Like in LinOpGrad). The method makeHtH return the correct corresponding convolution when the boundary condition is circular
- Adapt MixNormSchatten to the new Hessian functionalities
- makeHtH in LinOpGrad works now for any number of dimensions. It also returns the correct LinOpConv if the gradient is applied to specific dimensions
- LinOpCpx is deprecated as it is not really a LinOp
- New CostLinear
- CostL2 now accept any linop as weighting (metric) operator
- Indicator functions: Move the size parameter at the first place according to what was done for all maps
- add methods computeCost and computeSNR in OutputOpti to facillitate deriving classes
- Fix copy on write side effect in OptiVMLMB
- Fix OptiVMLMB such that the returned value is the last accepted one
- Add OutputOptiADMM which evaluates the Lagrangian instead of the cost function
- OutputOpti can deal with both logical or scalar flags
- Improve doc
- Improve examples
- Faster operation when memoize is off
- Add Conjugate Gradient in Deconv_LS_NoReg
- Remove deprecated
LinOpScaling
, - Improve tests with
CheckLinOp
,CheckMap
and `TestsSummationLinOp' functions - implement methods
makeAdjoint
andmakeInversion
inLinOp
- more simplifications in
Summation
,Composition
,??nversion
forMap
and henceLinOp
andCost
- New
LinOpBroadcast
linear operator - Add
ElementWiseOp
non linear operators:OpEWSquareRoot
,OpEWInverse
andOpEWSSquaredMagnitude
. - New
CostGoodRoughness
cost function - Introduce positivity constraint in
CostL1
- New
CostTV
cost function - Rework
Opti
optimization class - Introduce several
TestCvg
classes to assess convergence of optimization according to different criteria - Automatic download and compilation of OptimPackLegacy for
OptiVMLMB
OptiConjGrad
no longer takes aW
parameter- New
OptiFGP
(Fast gradient proximal) optimization function
- Improve doc
- Implement function
cmpSize
to compare size of vectors - Faster
CostHyperBolic
cost function - Automatic compilation of
C
files needed forCostMixNormSchatt1
cost function - Better examples
- Add functions
GenerateData
andGenerateData
to generate star phantom- More options in `LinOpConv' - Implement
make...
methods in LinOpDFT - Reworked
OutputOpti
printing class