⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sparcholfun.m

📁 斯坦福大学Grant和Boyd教授等开发的凸优化matlab工具箱
💻 M
字号:
% L = sparcholfun(L,X,pars,absd)% SPARCHOL Fast block sparse Cholesky factorization.%    L = sparchol(L,X,pars) uses only tril(X); triu(X) is assumed%    to be its transpose. The sparse Cholesky factor will be%    placed in the fields L.L, L.d; the symbolic factorization fields%    remain unchanged.%    On input, L should be the symbolic factorization structure of X,%    as created by SYMBCHOL.%    Performs LDL' factorization of X(L.perm,L.perm).%%   There are important differences with CHOL(X(L.perm,L.perm))':%%   -  SPARCHOL uses the supernodal partition L.XSUPER,%    to use dense linear algebra on dense subblocks.%    This explains the performance benefit of SPARCHOL over CHOL.%%   -  SPARCHOL never fails.%%   - To solve "X*y = b", use%    >> L = sparchol(symbchol(X),X);%    >> L.d(find(L.skip)) = inf;%    >> y = sparbwslv(L, sparfwslv(L,b) ./ L.d);%% SEE ALSO symbchol, sparfwslv, sparbwslv, [symbfact, symmmd, chol].function L = sparcholfun(L,X,absd) %   %   This file is part of SeDuMi 1.05 %   Copyright (C) 2001 Jos F. Sturm %     Dept. Econometrics & O.R., Tilburg University, the Netherlands. %     Supported by the Netherlands Organization for Scientific Research (NWO). %   Affiliation SeDuMi 1.03 and 1.04Beta (2000): %     Dept. Quantitative Economics, Maastricht University, the Netherlands. %   Affiliations up to SeDuMi 1.02 (AUG1998): %     CRL, McMaster University, Canada. %     Supported by the Netherlands Organization for Scientific Research (NWO). %  %   This program is free software; you can redistribute it and/or modify %   it under the terms of the GNU General Public License as published by %   the Free Software Foundation; either version 2 of the License, or %   (at your option) any later version. %  %   This program is distributed in the hope that it will be useful, %   but WITHOUT ANY WARRANTY; without even the implied warranty of %   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the %   GNU General Public License for more details. %  %   You should have received a copy of the GNU General Public License %   along with this program; if not, write to the Free Software %   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. %   cholpars.canceltol = 1E-10;   cholpars.maxu      = 5E8;   cholpars.abstol    = 1e-20;     pars.chol = cholpars;% ----------------------------------------% Numerical block sparse Cholesky of X% ---------------------------------------- if nargin > 3   [L.L,L.d,L.skip,L.add] = mexsparchol(L,X,pars,absd); else   [L.L,L.d,L.skip,L.add] = mexsparchol(L,X,pars); end% ------------------------------------------------------------% For numerical reasons, "blkchol" may skip instable pivots,% or add on the diagonal. Such pivots are then listed in L.{skip,add}.% ------------------------------------------------------------

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -