Jupyter notebook (kernel OCaml) usati nel corso di Paradigmi di Programmazione della Laurea in Informatica.
I notebook sono usati sia come strumento didattico (slides interattive e dispense), sia come strumento di sviluppo in OCaml.
L'esecuzione dei notebook in questo repository richiede di installare un certo numero di strumenti (indicativamente OCaml, juptyer, il kernel OCaml di juptyer, l'estensione RISE e le estensioni jupyter_contrib_nbextensions attivando l'estensione "splitcell").
Per semplificare il lavoro, è stato predisposto un container Docker in cui tutti questi strumenti sono già installati e pronti per l'esecuzione dei notebook di questo repository.
E' anche disponibile una versione online del container Docker con i notebook pre-installati, messa a disposizione dall'Università di Pisa per gli studenti del corso. Si tratta di una versione sperimentale, ma è possibile utilizzarla seguendo le indicazioni disponibili nella sezione: Uso di Jupyterhub di Ateneo
In caso di problemi vedi: Troubleshooting
-
Installare Git
-
Installare Docker Desktop (o Docker Engine su linux)
-
Clonare il repository in una cartella locale:
git clone https://github.com/Unipisa/Paradigmi
Questo crea una directory
Paradigmi
al cui interno è presente la directorynotebooks
-
Scaricare l'immagine del container Docker del corso (ATTENZIONE: sono 637MB):
docker pull paradigmi/paradigmi
Potrebbe richiedere privilegi di root su Linux e Mac (lo stesso per i passi seguenti)
-
Creare il container Docker:
docker create -it --privileged --name Paradigmi -p 8888:8888 -v xxxPATHxxx:/mnt/paradigmi/ paradigmi/paradigmi
dove
xxxPATHxxx
va sostituito con il percorso completo della directory contenente i notebook all'interno della copia locale del repository.
Ad esempio:- Windows:
C:\Users\milaz\Paradigmi\notebooks
- macOS
~/Documents/Paradigmi/notebooks
- Windows:
-
Far partire il container Docker:
docker start Paradigmi
oppure premendo il bottone "START" nell'interfaccia grafica di Docker Desktop
-
Aprire i notebook sul proprio browser collegandosi all'indirizzo
127.0.0.1:8888
, oppure premendo il bottone "OPEN IN BROWSER" nell'interfaccia grafica di Docker Desktop -
Verificare che nel browser si apra la pagina di Juptyer con elencate le cartelle
ocaml
eplayground
-
Per terminare l'esecuzione del container, preme sul pulsante "Quit" nel browser, oppure digitare
docker stop Paradigmi
oppure ancora premere il bottone "STOP" nell'interfaccia grafica di Docker Desktop
Su Windows si verifica una notevole occupazione di memoria (oltre 2GB) per l'esecuzione di Docker Desktop. Questo è dovuto in realtà al sottosistema Linux (WSL) incluso nelle ultime versioni di Windows e usato da Docker. In realtà, la memoria necessaria per eseguire il container è molto inferiore. Qualora si verifichino rallentamenti nel computer (soprattutto se Docker Desktop è usato contemporaneamente a Microsoft Teams per seguire le lezioni) si suggerisce di limitare l'occupazione di memoria di WSL creando un file .wslconfig
come segue:
notepad %UserProfile%.wslconfig
(se si usa il terminale standard di Windows)
oppure
notepad $env:USERPROFILE.wslconfig
(se si usa PowerShell)
e scrivere nel file appena creato:
[wsl2]
memory=1GB
Riavviare il computer e lanciare nuovamente Docker Desktop.
- Attenzione alla presenza dei
:
tra il path locale (a cui si fa riferimento nella guida comexxxPATHxxx
)e il path forNito dalla guida (/mnt/paradigmi/ paradigmi/paradigmi
) - Su macOS sostituire
xxxPATHxxx
con~/<path>
non conUser/<path>
- Mancato utilizzo della flag
-v
seguita dal path in alcuni sistemi operativi macOS come Catalina
Sono disponibili, in testing, https://jupyterhub.polo2.sid.unipi.it:8000/ e https://jupyterhubfm.df.unipi.it:8000/, installazioni di jupyterhub su macchine di Ateneo in cui è possibile trovare questo ambiente preconfigurato.
Per maggiori informazioni riferirsi alla relativa guida d'uso.