File R-ZVCV.spec of Package R-ZVCV
# Automatically generated by CRAN2OBS
#
# Spec file for package ZVCV
# This file is auto-generated using information in the package source,
# esp. Description and Summary. Improvements in that area should be
# discussed with upstream.
#
# Copyright (c) 2025 SUSE LINUX GmbH, Nuernberg, Germany.
#
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
# upon. The license for this file, and modifications and additions to the
# file, is the same license as for the pristine package itself (unless the
# license for the pristine package is not an Open Source License, in which
# case the license is the MIT License). An "Open Source License" is a
# license that conforms to the Open Source Definition (Version 1.9)
# published by the Open Source Initiative.
#
# Please submit bugfixes or comments via http://bugs.opensuse.org/
#
%global packname ZVCV
%global rlibdir %{_libdir}/R/library
Name: R-%{packname}
Version: 2.1.3
Release: 0
Summary: Zero-Variance Control Variates
Group: Development/Libraries/Other
License: GPL (>= 2)
URL: http://cran.r-project.org/web/packages/%{packname}
Source: ZVCV_2.1.3.tar.gz
Requires: R-base
Requires: R-Rcpp
Requires: R-glmnet
Requires: R-abind
Requires: R-mvtnorm
Requires: R-Rlinsolve
Requires: R-magrittr
Requires: R-dplyr
Requires: R-RcppArmadillo
Requires: R-BH
Requires: R-cli
Requires: R-generics
Requires: R-glue
Requires: R-lifecycle
Requires: R-pillar
Requires: R-R6
Requires: R-rlang
Requires: R-tibble
Requires: R-tidyselect
Requires: R-vctrs
Requires: R-foreach
Requires: R-shape
Requires: R-RcppEigen
Requires: R-Rdpack
Requires: R-iterators
Requires: R-utf8
Requires: R-rbibutils
Requires: R-pkgconfig
Requires: R-withr
# %%if 0%%{?sle_version} > 120400 || 0%%{?is_opensuse}
# # Three others commonly needed
# BuildRequires: tex(ae.sty)
# BuildRequires: tex(fancyvrb.sty)
# BuildRequires: tex(inconsolata.sty)
# BuildRequires: tex(natbib.sty)
# %else
# BuildRequires: texlive
# %endif
# BuildRequires: texinfo
BuildRequires: fdupes
BuildRequires: R-base
BuildRequires: R-Rcpp-devel
BuildRequires: R-glmnet
BuildRequires: R-abind
BuildRequires: R-mvtnorm
BuildRequires: R-Rlinsolve
BuildRequires: R-magrittr
BuildRequires: R-dplyr
BuildRequires: R-RcppArmadillo-devel
BuildRequires: R-BH-devel
BuildRequires: R-cli
BuildRequires: R-generics
BuildRequires: R-glue
BuildRequires: R-lifecycle
BuildRequires: R-pillar
BuildRequires: R-R6
BuildRequires: R-rlang
BuildRequires: R-tibble
BuildRequires: R-tidyselect
BuildRequires: R-vctrs
BuildRequires: R-foreach
BuildRequires: R-shape
BuildRequires: R-RcppEigen-devel
BuildRequires: R-Rdpack
BuildRequires: R-iterators
BuildRequires: R-utf8
BuildRequires: R-rbibutils
BuildRequires: R-pkgconfig
BuildRequires: R-withr
BuildRequires: gcc gcc-c++ gcc-fortran
Suggests: R-partitions
Suggests: R-ggplot2
Suggests: R-ggthemes
%description
Stein control variates can be used to improve Monte Carlo estimates of
expectations when the derivatives of the log target are available. This
package implements a variety of such methods, including zero-variance
control variates (ZV-CV, Mira et al. (2013)
<doi:10.1007/s11222-012-9344-6>), regularised ZV-CV (South et al., 2023
<doi:10.1214/22-BA1328>), control functionals (CF, Oates et al. (2017)
<doi:10.1111/rssb.12185>) and semi-exact control functionals (SECF,
South et al., 2022 <doi:10.1093/biomet/asab036>). ZV-CV is a parametric
approach that is exact for (low order) polynomial integrands with
Gaussian targets. CF is a non-parametric alternative that offers better
than the standard Monte Carlo convergence rates. SECF has both a
parametric and a non-parametric component and it offers the advantages
of both for an additional computational cost. Functions for applying
ZV-CV and CF to two estimators for the normalising constant of the
posterior distribution in Bayesian statistics are also supplied in this
package. The basic requirements for using the package are a set of
samples, derivatives and function evaluations.
%prep
%setup -q -c -n %{packname}
# the next line is needed, because we build without --clean in between two packages
rm -rf ~/.R
%build
%install
mkdir -p %{buildroot}%{rlibdir}
%{_bindir}/R CMD INSTALL -l %{buildroot}%{rlibdir} %{packname}
test -d %{packname}/src && (cd %{packname}/src; rm -f *.o *.so)
rm -f %{buildroot}%{rlibdir}/R.css
%fdupes -s %{buildroot}%{rlibdir}
#%%check
#%%{_bindir}/R CMD check %%{packname}
%files
%dir %{rlibdir}/%{packname}
%doc %{rlibdir}/%{packname}/DESCRIPTION
%{rlibdir}/%{packname}/INDEX
%{rlibdir}/%{packname}/Meta
%{rlibdir}/%{packname}/NAMESPACE
%doc %{rlibdir}/%{packname}/NEWS.md
%{rlibdir}/%{packname}/R
%{rlibdir}/%{packname}/data
%doc %{rlibdir}/%{packname}/help
%doc %{rlibdir}/%{packname}/html
%{rlibdir}/%{packname}/include
%{rlibdir}/%{packname}/libs
%changelog