在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
开源软件名称(OpenSource Name):rflamary/nonconvex-optimization开源软件地址(OpenSource Url):https://github.com/rflamary/nonconvex-optimization开源编程语言(OpenSource Language):MATLAB 100.0%开源软件介绍(OpenSource Introduction):Non-convex optimization ToolboxThis matlab toolbox propose a generic solver for proximal gradient descent in the convex or non-convex case. It is a complete reimplementation of the GIST algorithm proposed in [1] with new regularization terms such as the lp pseudo-norm with p=1/2. When using this toolbox in your research works please cite the paper Non-convex regularization in remote sensing:
The code solve optimization problems of the form: min_x f(x)+lambda g(x) We provide solvers for solving the following data fitting terms f(x) problems:
The regularization terms g(x) that have been implemented include:
New regularization terms can be easily implemented as discussed in section 3. Start using the toolboxInstallationAll the functions in the toolbox a given in the folder /utils. The unmix folder contains code and data downloaded from the website of Jose M. Bioucas Dias. In order to use the function we recommend to execute the following command addpath(genpath('.')) if you are not working in the root folder of the toolbox or replacing '.' by the location of the folder on your machine. Entry pointsWe recommend to look at the following files to see how to use the toolbox:
Solving your own optimization problemNew regularization termsAll the regularization terms (and theri proximal operators) are defined in the function utils/get_reg_prox.m. If you want to add a regularization term (or a projection), you only need to add a case to the switch beginning line 37 and define two functions:
For a simple example look at the implementations of the Lasso loss (line 124) soft thresholding (Line 128) and loss implementations. note that in order to limit the number of files, the loss and proximal operators functions are all implemented as subfunctions of file utils/get_reg_prox.m. Data fitting termYou can easily change the data fitting term by providing a new loss and gradient functions to the optimization function utils/gist_opt.m. A good starting point is by looking at the least square implementation in utils/gist_least.m. Changing the data fitting term correspond to only code the loss function at Line 63 and the corresponding gradient function at Line 59. Contact and contributorsAknowledgementsWe want to thank Jose M. Bioucas Dias for providing the unmixing dataset and functions on his website. References[1] Gong, P., Zhang, C., Lu, Z., Huang, J., & Ye, J. (2013, June). A General Iterative Shrinkage and Thresholding Algorithm for Non-convex Regularized Optimization Problems. In ICML (2) (pp. 37-45). [2] Candes, E. J., Wakin, M. B., & Boyd, S. P. (2008). Enhancing sparsity by reweighted ? 1 minimization. Journal of Fourier analysis and applications, 14(5-6), 877-905. [3] Xu, Z., Chang, X., Xu, F., & Zhang, H. (2012). L1/2 regularization: A thresholding representation theory and a fast solver. IEEE Transactions on neural networks and learning systems, 23(7), 1013-1027. Copyright 2016 |
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论