Version: | 1.0.6 |
Title: | R Interface to DSDP Semidefinite Programming Library |
Maintainer: | Zhisu Zhu <zhuzhisu@alumni.stanford.edu> |
Description: | R interface to DSDP semidefinite programming library. The DSDP software is a free open source implementation of an interior-point method for semidefinite programming. It provides primal and dual solutions, exploits low-rank structure and sparsity in the data, and has relatively low memory requirements for an interior-point method. |
Imports: | utils, methods |
LazyLoad: | yes |
License: | GPL-3 |
URL: | https://www.mcs.anl.gov/hs/software/DSDP |
NeedsCompilation: | yes |
Packaged: | 2025-06-08 15:41:18 UTC; root |
Repository: | CRAN |
Date/Publication: | 2025-06-08 16:20:02 UTC |
Author: | Zhisu Zhu [aut, cre], Yinyu Ye [aut] (DSDP by Steve Benson, Yinyu Ye and Xiong Zhang) |
R interface to DSDP semidefinite programming library
Description
Rdsdp is the R package providing a R interface to DSDP semidefinite programming library. The DSDP package implements a dual-scaling algorithm to
find solutions (X
, y
) to linear and semidefinite optimization problems of the form
\mbox{(P)} \ \inf\, \mbox{tr}(CX)
\mbox{subject to}\; \mathcal{A}X = b
X \succeq 0
with
(\mathcal{A}X)_i = \mbox{tr}(A_iX)
where X \succeq 0
means X is positive
semidefinite, C
and all A_i
are symmetric matrices of the same
size and b
is a
vector of length m
.
The dual of the problem is
\mbox{(D)} \ \sup\, b^{T}y
\mbox{subject to}\; \mathcal{A}^{*}y + S = C
S \succeq 0
where
\mathcal{A}y = \sum_{i=1}^m y_i A_i.
Matrices C
and A_i
are assumed to be block diagonal
structured, and must be specified that way (see Details).
References
Steven J. Benson and Yinyu Ye:
Algorithm 875: DSDP5 software for semidefinite programming ACM Transactions on Mathematical Software (TOMS) 34(3), 2008
http://web.stanford.edu/~yyye/DSDP5-Paper.pdfSteven J. Benson and Yinyu Ye and Xiong Zhang:
Solving Large-Scale Sparse Semidefinite Programs for Combinatorial Optimization SIAM Journal on Optimization 10(2):443-461, 2000
http://web.stanford.edu/~yyye/yyye/largesdp.ps.gz
Solve semidefinite programm with DSDP
Description
Interface to DSDP semidefinite programming library.
Usage
dsdp(A,b,C,K,OPTIONS=NULL)
Arguments
A |
An object of class |
b |
A numeric vector of length |
C |
An object of class |
K |
Describes the sizes of each block of the sdp problem. It is a list with the following elements:
|
OPTIONS |
A list of OPTIONS parameters passed to dsdp. It may contain any of the following fields: |
- print:
= k
to display output at each k iteration, else = 0 [default 10].- logsummary:
= 1
print timing information if set to 1.- save:
to set the filename to save solution file in SDPA format.
- outputstats:
= 1
to output full information about the solution statistics in STATS.- gaptol:
tolerance for duality gap as a fraction of the value of the objective functions [default 1e-6].
- maxit:
maximum number of iterations allowed [default 1000].
Please refer to DSDP User Guide for additional OPTIONS parameters available.
Details
All problem matrices are assumed to be of block diagonal structure, the input matrix A
must be specified as follows:
The coefficients for nonnegative cone block are put in the first
K$l
columns ofA
.The coefficients for positive semidefinite cone blocks are put after nonnegative cone block in the the same order as those in
K$s
. Thei
th positive semidefinite cone block takes(K$s)[i]
times(K$s)[[i]]
columns, with each row defining a symmetric matrix of size(K$s)[[i]]
.
This function does not check for symmetry in the problem data.
Value
Returns a list of three objects:
X |
Optimal primal solution |
y |
Optimal dual solution |
STATS |
A list with three to eight fields that describe the solution of the problem:
The last five fields are optional, and only available when |
References
Steven J. Benson and Yinyu Ye:
DSDP5 User Guide — Software for Semidefinite Programming Technical Report ANL/MCS-TM-277, 2005
https://www.mcs.anl.gov/hs/software/DSDP/DSDP5-Matlab-UserGuide.pdf
Examples
K=NULL
K$s=c(2,3)
K$l=2
C=matrix(c(0,0,2,1,1,2,c(3,0,1,
0,2,0,
1,0,3)),1,15,byrow=TRUE)
A=matrix(c(0,1,0,0,0,0,c(3,0,1,
0,4,0,
1,0,5),
1,0,3,1,1,3,rep(0,9)), 2,15,byrow=TRUE)
b <- c(1,2)
OPTIONS=NULL
OPTIONS$gaptol=0.000001
OPTIONS$logsummary=0
OPTIONS$outputstats=1
result = dsdp(A,b,C,K,OPTIONS)
Solving semidefinite programs reading from SDPA format files.
Description
Function to read the semidefinite program input data in SDPA format and solve it.
Usage
dsdp.readsdpa(sdpa_filename, options_filename="")
Arguments
sdpa_filename |
The location of the SDPA input file. |
options_filename |
The location of the OPTIONS file [default ""]. |