Pobierz konspekt przedmiotu

Transkrypt

Pobierz konspekt przedmiotu
Opis przedmiotu
PRZETWARZANIE DANYCH W JĘZYKACH R I PYTHON
Kod przedmiotu (USOS)
Nazwa przedmiotu
Przetwarzanie danych w językach R i Python
w języku polskim
Nazwa przedmiotu
Data processing in R and Python
w języku angielskim
A. Usytuowanie przedmiotu w systemie studiów
Poziom kształcenia
Forma i tryb
prowadzenia studiów
Kierunek studiów
Profil studiów
Specjalność
Jednostka prowadząca
Jednostka realizująca
Koordynator przedmiotu
Studia drugiego stopnia
Stacjonarne
Informatyka
Profil ogólnoakademicki
Przetwarzanie i analiza danych
Wydział Matematyki i Nauk Informacyjnych
Wydział Matematyki i Nauk Informacyjnych
Dr inż. Marek Gągolewski
[email protected]
prowadzące Dr inż. Marek Gągolewski
Osoby
zajęcia
B. Ogólna charakterystyka przedmiotu
Blok przedmiotów
Poziom przedmiotu
Grupa przedmiotów
Status przedmiotu
Język prowadzenia zajęć
Semestr nominalny
Minimalny numer
semestru
Usytuowanie realizacji
w roku akademickim
Wymagania wstępne /
przedmioty
poprzedzające
Limit liczby studentów
C. Efekty kształcenia i
Przetwarzanie i analiza danych
Zaawansowany
Obowiązkowe
Obowiązkowy
Polski
1 (studia 3SEM), 2 (studia 4SEM)
1
Cel przedmiotu
Kurs omawia najbardziej przydatne techniki programowania w
językach R i Python 3 w pracy analityka danych. W ramach zajęć
student
uzyskuje
praktyczną
umiejętność
zbierania
i
przygotowywania danych do analizy, oraz stosowania i
implementacji wybranych algorytmów maszynowego uczenia się.
Uczestnicy mają możliwość dogłębnego poznania technik
programowania w tych językach, a także najbardziej popularnych
i użytecznych bibliotek. W trakcie zajęć szczególną uwagę
poświęca się sposobom przetwarzania dużych zbiorów danych
(filtrowanie danych, agregacja danych w podgrupach, złączenia)
przy użyciu Apache Spark.
Semestr letni
Znajomość zagadnień programowania strukturalnego i
obiektowego, algorytmów i struktur danych oraz programowania
równoległego i rozproszonego
Liczba grup: bez ograniczeń
sposób prowadzenia zajęć
Efekty kształcenia
Patrz TABELA 1.
Formy zajęć i ich wymiar Wykład
(semestralny)
Ćwiczenia
Laboratorium
30
0
30
1/4
Treści kształcenia
Metody dydaktyczne
Metody i kryteria
oceniania / regulamin
zaliczenia
Metody sprawdzania
efektów kształcenia
Egzamin
Literatura i
oprogramowanie
Projekt
0
Wykład:
1.
Podstawowe atomowe typy danych w języku R.
2.
Działania na wektorach w R. Implementacja wybranych algorytmów maszynowego uczenia się przy użyciu tzw. wektoryzacji.
3.
Typ podstawowy lista. Funkcje. Atrybuty obiektów. Podstawy programowania obiektowego w stylu S3. Typy złożone w
R: macierz, czynnik, ramka danych.
4.
Działania na ramkach danych (filtrowanie danych, złączenia, agregacja danych w podgrupach).
5.
Instrukcja sterująca i pętle. Testy jednostkowe, profilowanie wydajności kodu.
6.
Przetwarzanie napisów przy użyciu wyrażeń regularnych,
obiektów typu data i czas oraz plików.
7.
Środowiska. Leniwa ewaluacja. Niestandardowa ewaluacja.
Środowiskowy model obliczeń. Dynamiczny a leksykalny zasięg zmiennych. Programowanie obiektowe w stylu S4, RefClasses i R6.
8.
Podstawy programowania w języku Python 3. Typy
skalarne i sekwencyjne, iteratory.
9.
Słowniki, zbiory. Funkcje, instrukcje sterujące.
10.
Obliczenia na wektorach, macierzach i innych tablicach
(NumPy)
11.
Przygotowywanie danych do analizy, praca z ramkami
danych (Pandas).
12.
Przetwarzanie napisów i plików, serializacja obiektów,
dostęp do baz danych SQL. Ekstrakcja danych ze stron WWW,
parsowanie plików XML.
13.
Cython
i
Rcpp
–
tworzenie
modułów/pakietów
rozszerzających przy użyciu C++.
14.
Programowanie rozwiązań wsadowych przy użyciu Apache
Spark – wprowadzenie.
15.
PySpark – wprowadzenie do interfejsu Apache Spark dla
języka Python. Podstawowe operacje: scalanie zbiorów
danych na podstawie wartości klucza, agregacja potencjalnie
dużych zbiorów danych.
Laboratorium:
Laboratorium obejmuje praktyczne zastosowanie wiedzy zdobytej
na wykładzie oraz rozwój umiejętności jej użycia w problemach
analizy danych i algorytmach maszynowego uczenia się.
Wykład:
Wykład informacyjny, problemowy, studium przypadku
Laboratorium:
Warsztaty z użyciem komputera, samodzielne rozwiązywanie zadań, burza mózgów
Na zaliczenie składają się oceny zdobyte za rozwiązanie 7 prac
domowych (3 po 20 p., 4 po 10 p.). Na zaliczenie konieczne jest
uzyskanie łącznie ponad 50 p. na 100 p. możliwych. Ostateczna
ocena z przedmiotu wynika z sumy zdobytych punktów: [0, 50] –
2,0; (50, 60] – 3,0; (60, 70] – 3,5; (70, 80] – 4,0; (80, 90] – 4,5;
(90, 100] – 5,0.
Patrz TABELA 1.
Nie
1. M. Gągolewski, M. Bartoszuk, A. Cena, Przetwarzanie i analiza
danych w języku Python, PWN, Warszawa, 2016 (w druku)
2. M. Gągolewski, Programowanie w języku R. Analiza danych, ob-
2/4
liczenia, symulacje, Wydawnictwo Naukowe PWN, 2016 (wyd. II –
w druku)
3. W. McKinney, Python for Data Analysis. Data Wrangling with
Pandas, NumPy, and IPython, O'Reilly Media, 2012
4. W. Richert, L.P. Coelho, Building Machine Learning Systems
with Python, Packt Publishing, 2013
5. E. Bressert, SciPy and NumPy, O'Reilly Media, 2012
6. J.M. Chambers., Programming with Data, Springer, 1998
7. J.M. Chambers, Software for Data Analysis. Programming with
R, Springer, 2008
8. N.S. Matloff, The Art of R Programming: A Tour of Statistical
Software Design, No Starch Press, 2011
9. W.N. Venables, B.D. Ripley, S Programming, Springer, 2000
10. H. Wickham, Advanced R, Chapman&Hall/CRC
11. M. Hamstra, Learning Spark, O'Reilly, 2013
12. M. Frampton, Mastering Apache Spark, Packt, 2015
R 3.3, RStudio, gcc, g++, Python 3.5 (Anaconda), Cython, Jupyter
http://www.gagolewski.com/teaching
Witryna www
przedmiotu
D. Nakład pracy studenta
Liczba punktów ECTS
Liczba godzin pracy
studenta związanych z
osiągnięciem efektów
kształcenia
5
1. godziny kontaktowe – 67 h; w tym
a) obecność na wykładach – 30 h
b) obecność na laboratoriach – 30 h
c) konsultacje – 7 h
2. praca własna studenta – 60 h; w tym
a) zapoznanie z literaturą – 15 h
b) rozwiązywanie prac domowych – 45 h
Razem 127 h, co odpowiada 5 pkt. ECTS
Liczba punktów ECTS na 1. obecność na wykładach – 30 h
zajęciach wymagających 2. obecność na laboratoriach – 30 h
bezpośredniego udziału 3. konsultacje – 7 h
nauczycieli
Razem 67 h, co odpowiada 3 pkt. ECTS
akademickich:
Liczba punktów ECTS,
1. obecność na laboratoriach – 30 h
którą student uzyskuje 2. rozwiązywanie prac domowych – 45 h
w ramach zajęć o
Razem 75 h, co odpowiada 3 pkt. ECTS
charakterze
praktycznym
E. Informacje dodatkowe
Uwagi
-
TABELA 1. EFEKTY PRZEDMIOTOWE
1. Efekty kształcenia i ich odniesienie do charakterystyk drugiego stopnia Polskiej Ramy
Kwalifikacji oraz efektów kształcenia kierunku Informatyka
Odniesienie
Odniesiedo charaktenie do
Efekty
OPIS EFEKTÓW KSZTAŁCENIA
rystyk druefektów
kształceAbsolwent studiów II stopnia na kierunku Inforgiego stopkształcenia
nia dla
matyka
nia Polskiej
dla kierunmodułu
Ramy Kwaliku
fikacji (P7S_)
WIEDZA
W01
Zna kluczowe języki programowania
P7S_WG
PD_W13
wykorzystywane w analizie danych – R i Python
3/4
W02
Zna metody filtrowania, czyszczenia,
podsumowywania i łączenia zbiorów danych
P7S_WG
UMIEJĘTNOŚCI
U01
Potrafi projektować wydajne metody
P7S_UW,
przetwarzania i analizy danych
P7S_UK
U02
Potrafi wykorzystać możliwości równoległego
P7S_UW,
przetwarzania danych do rozwiązywania
P7S_UK
złożonych problemów
U03
Potrafi zaprojektować system wykorzystujący
P7S_UW
metody klasyfikacji i regresji
U04
Dostrzega ograniczenia i słabe strony
P7S_UU
istniejących narzędzi informatycznych
KOMPETENCJE SPOŁECZNE
K01
Posiada zdolność do kontynuacji kształcenia
P7S_UU
oraz świadomość potrzeby samokształcenia w
ramach procesu kształcenia ustawicznego
K02
Potrafi posługiwać się językiem angielskim w
P7S_UO
stopniu umożliwiającym bezproblemową
komunikację w zakresie zagadnień
zawodowych oraz studiowanie dokumentacji
technicznej
2. Formy prowadzenia zajęć i sposób weryfikacji efektów kształcenia
Zamierzone
Forma zajęć
efekty
W01, W02, wykład, laboratoria
U01, U02,
U03, U04,
K01, K02
PD_W05-,
PD_W09-,
PD_W15
PD_U09
PD_U11
PD_U12
PD_U17
PD_K01
PD_K08
Sposób weryfikacji
ocena prac domowych
4/4