Go to file
junos ca85131ed2 Use refactored methods. 2023-07-03 21:18:15 +02:00
.idea Add an old script to test JCQ reversal. 2023-07-03 14:23:55 +02:00
config Define QUESTIONNAIRE IDs and use them. 2023-07-03 17:09:40 +02:00
data Merge branch 'master' into ml_pipeline 2022-11-16 17:46:01 +01:00
exploration Use refactored methods. 2023-07-03 21:18:15 +02:00
features Fix trailing whitespace. 2023-07-03 21:17:40 +02:00
images Further adapts RAPIDS and add graphical examples. 2021-12-08 19:20:53 +01:00
machine_learning Add confusion matrices for all methods. 2023-05-31 17:41:50 +02:00
participants Incorporate DB query for usernames into snakemake workflow. 2021-12-01 18:14:27 +01:00
presentation Remove and ignore results. 2023-05-16 16:22:29 +02:00
rapids@059774bda1 Update rapids and add regex=True. 2023-05-10 15:12:27 +02:00
statistical_analysis [WIP] Continue factor analysis. 2023-07-03 20:10:45 +02:00
test [WIP] Fix tests to use pyprojroot. 2021-10-29 12:07:12 +02:00
.flake8 Define QUESTIONNAIRE IDs and use them. 2023-07-03 17:09:40 +02:00
.gitignore Export SAM data. 2023-07-03 18:25:40 +02:00
.gitmodules Add the rapids fork submodule. 2021-11-17 12:47:42 +01:00
.pre-commit-config.yaml Disable jupytext pre-commit again. 2023-07-03 18:24:37 +02:00
README.md Add info about updating RAPIDS. 2021-12-15 20:21:59 +01:00
pyproject.toml Start using pre-commit hooks. 2023-04-24 15:38:54 +02:00
setup.py Update URL call. 2023-05-16 16:17:53 +02:00
straw2analysis.Rproj Use conda Python environment with R. 2023-07-03 14:51:07 +02:00

README.md

STRAW2analysis

All analysis for the STRAW project.

To install:

  1. Create a conda virtual environment from the environment.yml file.

    cd config
    conda env create --file environment.yml
    conda activate straw2analysis
    

    If you have already created this environment, you can update it using:

    conda deactivate
    conda env update --file environment.yml
    conda activate straw2analysis
    

    To use this environment in the Jupyter notebooks under ./exploration/, you can select it under Kernel > Change kernel after running:

    ipython kernel install --user --name=straw2analysis
    
  2. Provide a file called .env to be used by python-dotenv which should be placed in the top folder of the application and should have the form:

    DB_PASSWORD=database-password
    

RAPIDS

To install RAPIDS, follow the instructions on their webpage.

Here, I include additional information related to the installation and specific to the STRAW2analysis project. The installation was tested on Windows using Ubuntu 20.04 on Windows Subsystem for Linux (WSL2).

Custom configuration

Credentials

As mentioned under Database in RAPIDS documentation, a credentials.yaml file is needed to connect to a database. It should contain:

PSQL_STRAW:
  database: staw
  host: 212.235.208.113
  password: password
  port: 5432
  user: staw_db

wherepassword needs to be specified as well.

Possible installation issues

Missing dependencies for RPostgres

To install RPostgres R package (used to connect to the PostgreSQL database), an error might occur:

------------------------- ANTICONF ERROR ---------------------------
Configuration failed because libpq was not found. Try installing:
   * deb: libpq-dev (Debian, Ubuntu, etc)
   * rpm: postgresql-devel (Fedora, EPEL)
   * rpm: postgreql8-devel, psstgresql92-devel, postgresql93-devel, or postgresql94-devel (Amazon Linux)
   * csw: postgresql_dev (Solaris)
   * brew: libpq (OSX)
If libpq is already installed, check that either:
  (i)  'pkg-config' is in your PATH AND PKG_CONFIG_PATH contains a libpq.pc file; or
  (ii) 'pg_config' is in your PATH.
If neither can detect , you can set INCLUDE_DIR
and LIB_DIR manually via:
  R CMD INSTALL --configure-vars='INCLUDE_DIR=... LIB_DIR=...'
--------------------------[ ERROR MESSAGE ]----------------------------
  <stdin>:1:10: fatal error: libpq-fe.h: No such file or directory
compilation terminated.

The library requires libpq for compiling from source, so install accordingly.

Timezone environment variable for tidyverse (relevant for WSL2)

One of the R packages, tidyverse might need access to the TZ environment variable during the installation. On Ubuntu 20.04 on WSL2 this triggers the following error:

> install.packages('tidyverse')

ERROR: configuration failed for package xml2
System has not been booted with systemd as init system (PID 1). Can't operate.
Failed to create bus connection: Host is down
Warning in system("timedatectl", intern = TRUE) :
  running command 'timedatectl' had status 1
Error in loadNamespace(j <- i[[1L]], c(lib.loc, .libPaths()), versionCheck = vI[[j]]) :
  namespace xml2 1.3.1 is already loaded, but >= 1.3.2 is required
Calls: <Anonymous> ... namespaceImportFrom -> asNamespace -> loadNamespace
Execution halted
ERROR: lazy loading failed for package tidyverse

This happens because WSL2 does not use the timedatectl service, which provides this variable.

~$ timedatectl
System has not been booted with systemd as init system (PID 1). Can't operate.
Failed to create bus connection: Host is down

and later

Warning message:
In system("timedatectl", intern = TRUE) :
  running command 'timedatectl' had status 1
Execution halted

This can be amended by setting the environment variable manually before attempting to install tidyverse:

export TZ='Europe/Ljubljana'

Possible runtime issues

Unix end of line characters

Upon running rapids, an error might occur:

/usr/bin/env: python3\r: No such file or directory

This is due to Windows style end of line characters. To amend this, I added a .gitattributes files to force git to checkout rapids using Unix EOL characters. If this still fails, dos2unix can be used to change them.

System has not been booted with systemd as init system (PID 1)

See the installation issue above.

Update RAPIDS

To update RAPIDS, first pull and merge origin, such as with:

git fetch --progress "origin" refs/heads/master
git merge --no-ff origin/master

Next, update the conda and R virtual environment.

R -e 'renv::restore(repos = c(CRAN = "https://packagemanager.rstudio.com/all/__linux__/focal/latest"))'