Learn R Programming

sgs

Implementation of Sparse-group SLOPE (SGS), a sparse-group penalisation regression approach. SGS performs adaptive bi-level selection, controlling the FDR under orthogonal designs. The package also has an implementation of Group SLOPE (gSLOPE), which performs group selection and controls the group FDR under orthogonal designs, as well as group-based OSCAR models. Linear and logistic regression are supported, both with dense and sparse matrix implementations. Both models have strong screening rules to improve computational speed. Cross-validation functionality is also supported. Both models are implemented using adaptive three operator splitting (ATOS) and the package also contains a general implementation of ATOS.

A detailed description of SGS can be found in Feser, F., Evangelou, M. (2023). "Sparse-group SLOPE: adaptive bi-level selection with FDR-control".

gSLOPE was proposed in Brzyski, D., Gossmann, A., Su, W., Bodgan, M. (2019). "Group SLOPE – Adaptive Selection of Groups of Predictors".

The strong screening rules are described in Feser, F., Evangelou, M. (2024). "Strong screening rules for group-based SLOPE models".

Installation

You can install the current stable release from CRAN with

install.packages("sgs")

Your R configuration must allow for a working Rcpp. To install a develop the development version from GitHub run

library(devtools)
install_github("ff1201/sgs")

Example

The code for fitting a basic SGS model is:

library(sgs)
groups = c(rep(1:20, each=3),
           rep(21:40, each=4),
           rep(41:60, each=5),
           rep(61:80, each=6),
           rep(81:100, each=7))

data = gen_toy_data(p=500, n=400, groups = groups, seed_id=3)

model = fit_sgs(X = data$X, y = data$y, groups = groups, vFDR=0.1, gFDR=0.1)
plot(model)

where X is the input matrix, y the response vector, groups a vector containing indices for the groups of the predictors, and vFDR and gFDR are the the target variable/group false discovery rates.

For gSLOPE, run:

library(sgs)
groups = c(rep(1:20, each=3),
           rep(21:40, each=4),
           rep(41:60, each=5),
           rep(61:80, each=6),
           rep(81:100, each=7))

data = gen_toy_data(p=500, n=400, groups = groups, seed_id=3)

model = fit_gslope(X = data$X, y = data$y, groups = groups, gFDR=0.1)
plot(model)

A more extensive example can be found here.

Copy Link

Version

Install

install.packages('sgs')

Monthly Downloads

328

Version

0.3.6

License

GPL (>= 3)

Issues

Pull Requests

Stars

Forks

Maintainer

Fabio Feser

Last Published

April 22nd, 2025

Functions in sgs (0.3.6)

gen_pens

Generate penalty sequences for SGS.
fit_sgs_cv

Fit an SGS model using k-fold cross-validation.
predict.sgs

Predict using one of the following object types: "sgs", "sgs_cv", "gslope", "gslope_cv".
scaled_sgs

Fits a scaled SGS model.
plot.sgs

Plot models of the following object types: "sgs", "sgs_cv", "gslope", "gslope_cv".
fit_sgo_cv

Fit an SGO model using k-fold cross-validation.
fit_sgs

Fit an SGS model.
sgs-package

sgs: Sparse-Group SLOPE: Adaptive Bi-Level Selection with FDR Control
gen_toy_data

Generate toy data.
print.sgs

Prints information for one of the following object types: "sgs", "sgs_cv", "gslope", "gslope_cv".
arma_sparse

Matrix Product in RcppArmadillo.
fit_goscar_cv

Fit a gOSCAR model using k-fold cross-validation.
as_sgs

Fits the adaptively scaled SGS model (AS-SGS).
coef.sgs

Extracts coefficients for one of the following object types: "sgs", "sgs_cv", "gslope", "gslope_cv".
arma_mv

Matrix Product in RcppArmadillo.
fit_goscar

Fit a gOSCAR model.
fit_gslope_cv

Fit a gSLOPE model using k-fold cross-validation.
atos

Adaptive three operator splitting (ATOS).
fit_sgo

Fit an SGO model.
fit_gslope

Fit a gSLOPE model.