Mohammed Qasem, PhD, MSc, BSc
Contact
ATS Assistant Lecturer, Augustana - Sciences
- mqasem@ualberta.ca
- Phone
- (780) 679-1116
- Address
- 
                                
                                    2 - 331  Faith & Life Centre
                                        4901-46 AveCamrose ABT4V 2R3
Overview
Area of Study / Keywords
Program: Computing Science and Mathematics
About
Mohammed Qasem is an assistant lecturer at the department of computing science. He started working at Augustana in July of 2019. Prior to arriving at Augustana, he has taught introductory programming courses, visual programming, logic design, computer architecture, and operating systems. He also worked at Manitoba Hydro International as a Software Developer. His research centers mostly on three areas: (i) ant-inspired clustering models and their applications to dynamic real-world clustering problems; (ii) semi-supervised classification and clustering; (iii) aspect-based sentiment analysis.
Research
A swarm of organisms, following simple rules, can achieve incredible intelligent tasks. This natural behaviour is called Swarm Intelligence (SI) and is pervasive through diverse ecological systems. An individual ant, for instance, can perform minimal functions, but an ant colony can perform complicated, intelligent tasks such as building bridges, creating superhighways, collecting and sorting piles of food and waging war. More interestingly, such tasks are achieved without central control and beyond the comprehension of any single ant. A colony of ants is self-organized by a process called stigmergy, a small action by individual ant stimulates others to behave differently, leading to a new pattern of behaviour — likewise, flocks of birds, herds of animals, schools of fish and beehives. Very generally, Dr. Qasem primary field of research interest is SI. Within SI, he focused on ant-inspired algorithms with their applications to data analytics. His doctoral research centers on developing two clustering algorithms, inspired by how real ants sort their nests, and their application to classifying large-scale dynamic data. Dr. Qasem current research work focuses on swarm intelligence for social network mining.
Teaching
Teaching philosophy in a nutshell
“All students can learn and succeed, but not in the same way and not in the same day”.
– William G. Spady
My role as a facilitator (rather than a traditional instructor) is central to my teaching philosophy. I perceive myself as a facilitator in the sense that I take responsibility for the learning environment: it is my responsibility to find out the best approach for teaching computing science in different classes.
Fall 2019
AUCSC 450 Parallel and Distributed Systems
AUCSC 310 Algorithm Design and Analysis
Past Courses
Digital Logic Design
Computer Architecture and Organization
Operating System Concepts
Visual Programming
C/C++ Programming
Data Structures
Computer Science Fundamentals
Courses
AUCSC 218 - Web Design, Development and Scripting
Introduction to modern web architectures and technologies. Web platforms and standards. Client-side/server-side programming and web languages (e.g. HTML, JavaScript, PHP, CSS, Node.js). Introduction to internet security. Design and implementation of a simple web application. Prerequisite: one of AUCSC 113 (2023) or AUSCI 135, or AUCSC 111.
AUCSC 310 - Algorithm Design and Analysis
Algorithm design techniques (divide-and-conquer, dynamic programming, the greedy method). Merge-sort and the analysis of divide-and-conquer algorithms with recurrence relations; bucket-sort, radix-sort, and the lower bound on sorting; comparison of sorting algorithms. Trees, binary trees, search trees, their implementation, traversal, and search and update operations. Introduction to graph theory; data structures for the representation of graphs, digraphs, and networks, and their associated algorithms (traversal, connected components, topological sorting, minimum- spanning trees, shortest paths, transitive closure). Dynamic equivalence relations and union-find sets; amortized analysis. String matching. Prerequisites: AUCSC 112, or AUCSC 211 and AUSCI 235; and AUMAT 250.
AUCSC 330 - Database Management Systems I
Introduction to current database management systems in theory and practice. Topics include relational database design (including entity-relationship modelling, relational schema, and normal forms); relational algebra, use of a query language (typically SQL) and other components of a current database management system; overview of database system architecture, file structures (including B-tree indices), query processing, and transaction management; new directions. Prerequisites: AUCSC 112, or AUCSC 211 or AUSCI 235. Corequisite: AUMAT 250.
AUCSC 395 - Directed Study I
Intensive study of a specific area of Computing Science as defined by the student and a supervising instructor, including completion of a software project in the selected area. Prerequisite: 9 units of senior-level Computing Science. Notes: Admission to AUCSC 395 normally requires a minimum GPA of 3.0 in Computing Science. An Application for Individual Study must be completed and approved before registration in the course.
AUCSC 401 - Professional Practicum I
A four-month work experience placement focused on gaining practical experience in software development and/or information systems, and an appreciation of the demands and responsibilities of the computing profession. Upon completion of the work experience term, the student must submit a report to the Department which summarizes, evaluates, and reflects on the work performed and the knowledge and experience gained during the placement. Prerequisites: At least 18 units in Computing Science, third-year standing, and consent of the Department. Note: Participation in the practicum is by application only, and is restricted to Computing Science majors.
AUMAT 353 - Applied Probability
Introduction to elementary probability theory and stochastic processes with a special emphasis on their applications in science. Topics include basics of probability, random variables, functions of random variables, random vectors, random processes and their classification, well-known random processes including the Bernoulli process, random walk process, Gaussian process, Poisson process, and Markov process. Prerequisite: AUMAT 250.
AUSCI 430 - Ethical Issues in Computing and Mathematics
This course explores a variety of ethical issues related to computing and mathematics. Students will study ethical theory, professional codes of ethics, and apply them to make moral decisions. Topics involve information privacy and security, surveillance, cryptography, data mining, intellectual property and copyrights, computer crime and abuse, etc. The course includes extensive writing assignments and oral presentations. Prerequisite: At least 15 units in Computing Science or Mathematics or at least third-year standing. Note: Credit may be obtained for only one of AUCSC 490 (2021) and AUSCI 430.