This shows you the differences between two versions of the page.
|
isrm:laboratoare:v2:01 [2024/06/28 09:42] mbarbulescu |
isrm:laboratoare:v2:01 [2024/06/28 09:48] (current) mbarbulescu [Task 03: Basic plot] |
||
|---|---|---|---|
| Line 211: | Line 211: | ||
| Apoi urmează o serie de nume de clase din [[https://www.nsnam.org/doxygen/group__attribute.html|sistemul de atribute al ns-3]] (''ns3::Ipv4Header, ns3::TcpHeader'') și cu o listă de trace-uri specifice clasei respective. | Apoi urmează o serie de nume de clase din [[https://www.nsnam.org/doxygen/group__attribute.html|sistemul de atribute al ns-3]] (''ns3::Ipv4Header, ns3::TcpHeader'') și cu o listă de trace-uri specifice clasei respective. | ||
| + | ===== Task 03: Basic plot ===== | ||
| + | Ne propunem să validăm și că funcționează generarea de grafice, lucru pe care îl vom folosi la toate laboratoarele. | ||
| + | Descarcati fișierul de date numit **plotting_data1.csv** ce conține: | ||
| + | <file csv plotting_data1.csv> | ||
| + | # comentarii | ||
| + | # X Y | ||
| + | 1 2 | ||
| + | 2 3 | ||
| + | 3 2 | ||
| + | 4 1 | ||
| + | </file> | ||
| + | |||
| + | Pe baza acestor date, graficul poate fi construit folosind urmatorul template (pe care il puteti folosi si la restul laboratoarelor): | ||
| + | |||
| + | <code python> | ||
| + | import copy | ||
| + | import numpy as np | ||
| + | import matplotlib | ||
| + | import matplotlib.pyplot as plt | ||
| + | |||
| + | # Calea absoluta catre fisierul de date din care citim | ||
| + | # TODO - trebuie inlocuita cu calea corecta | ||
| + | DATA_FILE = 'plotting_data1.csv' | ||
| + | columns = ['x', 'y'] | ||
| + | |||
| + | # Citim datele din fisier | ||
| + | # Argumentul delimiter precizeaza care este delimitatorul dintre coloane | ||
| + | # Argumentul skip_header precizeaza cate linii nu vor fi citite pornind cu inceputul fisierului | ||
| + | # Argumentul names este unul foarte util deoarece permite asocierea de nume pentru coloanele din fisier si | ||
| + | # de asemenea duce la un acces foarte usor al datelor in script. In acest exemplu, names va fi egal cu ['x', 'y'] | ||
| + | # ceea ce inseamna ca putem accesa valorile din prima coloana prin sim_data['x']. | ||
| + | # Argumentul dtype setat specifica modul in care vor fi interpretate coloanele (string-urile ca string-uri, float-urile ca float-uri). | ||
| + | # In absenta acestui argument, valorile din coloane vor fi interpretate ca float. | ||
| + | sim_data = np.genfromtxt(DATA_FILE, delimiter=' ', skip_header=2, names=columns, dtype=None) | ||
| + | |||
| + | def plot_data(sim_data): | ||
| + | data = copy.deepcopy(sim_data) | ||
| + | |||
| + | # Apelul subplots poate fi folosit pentru a crea mai multe subgrafice in cadrul aceluiasi grafic sau in cadrul unor grafice diferite | ||
| + | # Prin figsize se specifica dimensiunea graficului | ||
| + | fig, ax = plt.subplots(figsize=(12,12)) | ||
| + | # Valori stilistice pentru grafic | ||
| + | ax.grid(color='b', alpha=0.5, linestyle='dashed', linewidth=0.5) | ||
| + | # Denumirile axelor Ox si Oy, precum si titlul graficului | ||
| + | plt.xlabel('X values') | ||
| + | plt.ylabel('Y values') | ||
| + | plt.title('A very nice looking plot') | ||
| + | |||
| + | # Aici este construit efectiv graficul. Campul label va fi folosit in cadrul legendei graficului | ||
| + | ax.plot(data['x'], data['y'], label='My plot') | ||
| + | ax.legend() | ||
| + | | ||
| + | plt.savefig("l1t3.png") | ||
| + | |||
| + | if __name__ == '__main__': | ||
| + | plot_data(sim_data) | ||
| + | </code> | ||
| + | |||
| + | Verificați după rulare că în folderul din docker aveți fișierul ''l1t3.png''. De asemenea, pentru că folosim [[https://docs.docker.com/storage/storagedriver/overlayfs-driver/|overlayfs]] puteți accesa de pe mașina fizică/virtuală din care rulați docker-ul din folderul: ''~/.isrm2024/merge/l1t3.png'' presupunând că la build ati folosit ca parametru numele docker image-ului ''isrm2024''. | ||