Arrow

From Alliance Doc
Jump to navigation Jump to search
This site replaces the former Compute Canada documentation site, and is now being managed by the Digital Research Alliance of Canada.

Ce site remplace l'ancien site de documentation de Calcul Canada et est maintenant géré par l'Alliance de recherche numérique du Canada.

This page is a translated version of the page Arrow and the translation is 100% complete.
Other languages:

Apache Arrow est une plateforme de développement multilangage pour la gestion des données en mémoire. Elle utilise un format standardisé en colonnes qui organise les données hiérarchiques ou autres afin de permettre des opérations analytiques efficaces. La plateforme offre des bibliothèques de calcul, la transmission sans copie et en continu des données et la communication interprocessus. Parmi les langages pris en charge, on compte C, C++, C#, Go, Java, JavaScript, MATLAB, Python, R, Ruby et Rust.

CUDA

Arrow est aussi disponible avec CUDA.

Question.png
[name@server ~]$ module load gcc/9.3.0 arrow/11 cuda/11.4

Bindings Python

Le module contient des bindings pour plusieurs versions de Python. Pour connaître les versions compatibles, lancez

Question.png
[name@server ~]$ module spider arrow/4.0.0

Pour trouver pyarrow directement, lancez

Question.png
[name@server ~]$ module spider pyarrow

PyArrow

Les bindings Python (appelés PyArrow) s’intègrent avec les objets de première classe NumPy, Pandas, et les objets natifs Python. Ils sont basés sur l'implémentation C++ de Arrow.

1. Chargez les modules requis.

Question.png
[name@server ~]$ module load gcc/9.3.0 arrow/8 python/3.8

2. Importez PyArrow.

Question.png
[name@server ~]$ python -c "import pyarrow"

L’importation est réussie si rien n’est affiché.

Pour plus d'information, consultez la documentation Python.

Autres paquets Python dépendants

L'installation de certains paquets Python est dépendante de PyArrow. Une fois le module arrow chargé, la dépendance à pyarrow sera satisfaite.

Question.png
[name@server ~]$ pip list | grep pyarrow
pyarrow    8.0.0

Format Apache Parquet

Le format de fichier Parquet est disponible.

Pour importer le module Parquet, effectuez les étapes pour pyarrow ci-dessus et lancez ensuite

Question.png
[name@server ~]$ python -c "import pyarrow.parquet"

L’importation est réussie si rien n’est affiché.

Bindings R

Arrow possède une interface avec la bibliothèque Arrow C++ pour permettre l'accès en R de plusieurs de ses fonctionnalités. Ceci inclut l’analyse de grands ensembles de données multifichiers (open_dataset()); la capacité de travailler avec des fichiers individuels de format Parquet (read_parquet(), write_parquet()) et Feather (read_feather(), write_feather()); l'accès à la mémoire et aux messages Arrow.

Installation

1. Chargez les modules requis.

Question.png
[name@server ~]$ module load gcc/9.3.0 arrow/8 r/4.1 boost/1.72.0

2. Spécifiez le répertoire d’installation local.

[name@server ~]$ mkdir -p ~/.local/R/$EBVERSIONR/
[name@server ~]$ export R_LIBS=~/.local/R/$EBVERSIONR/


3. Exportez les variables requises pour vous assurer d’utiliser l'installation du système.

[name@server ~]$ export PKG_CONFIG_PATH=$EBROOTARROW/lib/pkgconfig
[name@server ~]$ export INCLUDE_DIR=$EBROOTARROW/include
[name@server ~]$ export LIB_DIR=$EBROOTARROW/lib


4. Installez les bindings.

Question.png
[name@server ~]$ R -e 'install.packages("arrow", repos="https://cloud.r-project.org/")'

Utilisation

Une fois les bindings installés, il faut les charger.

1. Chargez les modules requis.

Question.png
[name@server ~]$ module load gcc/9.3.0 arrow/8 r/4.1

2. Chargez la bibliothèque.

Question.png
[name@server ~]$ R -e "library(arrow)"
> library("arrow")
Attaching package: ‘arrow’

Pour plus d'information, consultez la documentation Arrow sur R.