SubjectsSubjects(version: 965)
Course, academic year 2024/2025
  
Efficient Text Pattern Matching - AM500001
Title: Efficient Text Pattern Matching
Guaranteed by: Department of Informatics and Chemistry (143)
Faculty: Faculty of Chemical Technology
Actual: from 2024
Semester: winter
Points: winter s.:4
E-Credits: winter s.:4
Examination process: winter s.:
Hours per week, examination: winter s.:2/1, C+Ex [HT]
Capacity: unlimited / unlimited (unknown)
Min. number of students: unlimited
State of the course: taught
Language: English
Teaching methods: full-time
Level:  
Guarantor: Holub Jan prof. Ing. Ph.D.
Interchangeability : N500001
Annotation -
Students get knowledge of efficient algorithms for text pattern matching. They learn to use so called succinct data structures that are efficient in both access time and memory complexity. They will be able to use the knowledge in design of applications that utilize pattern matching.
Last update: Kubová Petra (13.09.2024)
Course completion requirements - Czech

Pro zı́skánı́ zápočtu je potřeba dostatek bodů ze zápočtových testů. Zkouška se skládá z povinné pı́semné a povinné ústnı́ části.

Last update: Kubová Petra (13.09.2024)
Literature -

R: Pokorný J., Dokumentografické informační systémy, Karolinum, 2005, ISBN 80-246-1148-1

R: M.Crochemore, C. Hancart, T. Lecroq: Algorithms on Strings. Cambridge University Press, 2014. ISBN 1107670993

A: Melichar B., Textové informační systémy, Praha, 1994, ISBN 8001012069, 9788001012062

A: W.F. Smyth: Computing Patterns in Strings, Pearson Addison Wesley (UK), 2003, 423 pp. ISBN 0201398397

A: M.Crochemore, W. Rytter: Jewels of Stringology. World Scientific Publishing Company, 2003. ISBN 9810248970

A: G.Navarro, M. Raffinot: Flexible Pattern Matching in Strings. Cambridge University Press, 2008. ISBN 0521039932

Last update: Kubová Petra (13.09.2024)
Syllabus -

1. Introduction, basic definitions, border array.

2. Text full index: Suffix array.

3. Text full index: Suffix tree, LCP construction.

4. Text full index: Factor, suffix automata, on-line construction.

5. Exact pattern matching algorithms.

6. FFT in pattern matching.

7. Succinct data structure: rank & select.

8. Succinct data structure: wavelet tree.

9. FM-Index.

10. Dictionary representation, spell checking.

11. Approximate pattern matching.

12. Pattern matching in bioinformatics and musicology.

13. Pattern matching in bioinformatics and musicology.

Last update: Kubová Petra (13.09.2024)
Learning resources -

https://edux.fit.cvut.cz/courses/MI-EVY/

(login necessary)

Last update: Kubová Petra (13.09.2024)
Learning outcomes -

Students will be able to:

Understand pattern matching as a key task in most applications.

Understand efficient algorithms and data structures for pattern matching (not only in information processing, but also in other fields like security - intrusion detection, virus scans).

Have an extensive overview of such algorithms and data structures.

Last update: Kubová Petra (13.09.2024)
Registration requirements -

Automata and grammars

Last update: Kubová Petra (13.09.2024)
 
VŠCHT Praha