GMU CS-584 Syllabus

Theory and Applications of Data Mining


Course Summary

The acceleration of technological advancements has led to the generation of an unprecedented volume of data. Data mining, a pivotal discipline at the intersection of computer science, statistics, and artificial intelligence, seeks to delineate insightful patterns from this extensive dataset. This domain not only encompasses applications such as credit rating and fraud detection but also extends to areas like genomics, climatology, quantum mechanics, and complex systems analysis. It emphasizes theoretical methodologies rooted deeply in statistical and computational models and explores the adaptability and versatility of these methods across diverse domains.

This course is structured to offer an in-depth exploration into the theoretical underpinnings of data mining techniques. Concurrently, it underscores their broad applications by providing case studies and hands-on coding sessions. Students will be equipped with both the knowledge and skills to navigate the realm of data mining.

Class Time and Location

Time: Friday 10:30 am-1:10 pm

Date Range: Aug 25, 2023 - Dec 13, 2023

Location: East 201

Instructor

Name: Keren Zhou

Email: kzhou6@gmu.edu

Office: ENGR 5315

Office Hour: Friday 2:00pm - 3:00pm

Teaching Assistants

Name: Long Cao Thanh Doan

Office Hour: Tuesday 3:00pm - 4:00pm

Office: ENGR 4456

Piazza Moderator Hours: Monday - Wednesday 12pm

Name: Xue Yu

Office Hour: Thursday 11:00am -12:00pm

Office: BUCH D215

Piazza Moderator Hours: Wednesday 12pm - Friday

Prerequisites

Grade of C or better in CS 310 and STAT 344

Course Objectives

  1. To provide a comprehensive understanding of data mining techniques, elucidating both their potential and limitations.
  1. To instill proficiency in integrating data mining insights with software packages, with an emphasis on data analysis in Python.
  1. To facilitate hands-on experience, enabling students to conceptualize, design, and execute data mining projects.

Textbooks

  1. Introduction to Data Mining
  1. Data Mining: Concepts and Techniques, 3rd Edition (Optional) It’s OK to use the fourth edition
  1. A Programmer's Guide to Data Mining (Optional)

Honor Code

Please follow GMU’s honor code policy:

To promote a stronger sense of mutual responsibility, respect, trust, and fairness among all members of the George Mason University community and with the desire for greater academic and personal achievement, we, the student members of the university community, have set forth this honor code: Student members of the George Mason University community pledge not to cheat, plagiarize, steal, or lie in matters related to academic work

And the CS department has its own policy.

Please do note there has been revisions to the honor code policy:

Unless permission to do so is granted by the instructor, you (or your group, if a group assignment) may not: … - use assistive technology, artificial intelligence, or other tools to complete assignments which can generate, translate, or otherwise create/correct code or answers (many types of assistive technology may be permitted, but you must ask permission)

Disability Accommodations

Should you possess documented evidence of a learning disability or any other condition that could impact your academic achievements, kindly ensure this documentation is registered with the Office of Disability Services. Subsequently, please initiate a conversation with the professor regarding potential accommodations.

Course Structure

Assignments

Throughout this course, students will complete up to three practical assignments. Each assignment must be done individually, while the project will be chosen and conducted in groups. Further details about the assignments will be available on the Blackboard system.

Project

Central to this course is the semester project, closely tied to subjects broached during the lectures. Students have the autonomy to select their own project themes. Collaboration is encouraged, with projects typically involving teams of 2-4 participants. Piazza is available as a resource for sharing thoughts or for seeking team partners.

For project submissions, each group needs to make a single collective submission.

Project Inspiration

There are two categories of topics you can choose for the project:

Option 1: Graph mining challenges

  1. Frequent subgraph mining on GPUs
  1. Frequent subgraph mining on CPUs

You can choose either topic 1 or topic 2.

Your proposed solution must be faster than the existing implementation, either by designing new algorithms or by optimizing the code, to achieve full scores.

Partial credit (up to 90%) will be given based on the same standard as those who choose option 2. Reimplement the algorithms correctly using another language (e.g., Rust) can receive partial credits.

Option 2: Explore interesting ideas on open source datasets or your own dataset

Project Components

  1. Project Proposal (2 pages in PDF, 10% of project grade): Your blueprint should encapsulate:
    • The problem
    • Anticipated hurdles
    • Pertinent previous studies and their limitations
    • Data sources to be utilized
    • Evaluation methodology

    Ensure all group member names are inscribed in the submitted document.

  1. Mid-term Review (3-5 pages in PDF, 20% of project grade): Initiate the shaping of your review by expounding on:
    • Data
      • Outline the utilized data and any relevant acquisition techniques.
    • Proposed Technique
      • Detail your approach, requisite definitions, and possibly a conceptual proof.
    • Preliminary Trials
      • Share initial findings.
    • Progress and Upcoming Endeavors
      • Recapitulate your trajectory and highlight any alterations from the initial blueprint.

    All group member names must be enumerated in the submitted document.

  1. Final Report and Code (5-10 pages PDF + CODE, 50% of project grade):

    A. Report Layout (25% of project grade): The format should mirror that of a scholarly article, encompassing at least:

    • Abstract
    • Introduction
    • Data
    • Methods
    • Experiments
    • Related Work
    • Conclusions
    • Division of Work

    B. Code (25% of project grade): Nest your code within a "CODE" directory with a README file, including instructions to run the tests and validate results

    Compile into a zip file, inclusive of the pdf and the CODE/ directory. Always inscribe all group member names in the pdf.

  1. Presentation (10 mins, 20% of the project grade): Presentations will be graded on the following aspects:
    • Content depth and accuracy
    • Clarity of presentation
    • Ability to engage the audience and answer questions
    • Time management

Grading

Schedule (subject to change)

Week DateTopicReadingsTimeline
1August 25, 2023IntroductionCh 1, 2.1
2September 1, 2023Data Preprocessing & PythonCh 2.2, 2.3
3September 8, 2023Data MeasurementCh 2.4HW1 out
4September 15, 2023Classification-1Ch 3Proposal due
5September 22, 2023Classification-2Ch 4
6September 29, 2023Clustering-1Ch 7HW2 out
7October 6, 2023Clustering-2Ch 8HW1 due
8October 13, 2023Midterm ExamHW3 out
9October 20, 2023Outlier DetectionCh 9Mid-term Review Due
10October 27, 2023Pattern Mining-1Ch 5HW2 due
11November 3, 2023Pattern Mining-2Ch 6
12November 10, 2023NetworksMEJN, PajekHW3 due
13November 17, 2023Invited Talk
14November 24, 2023ThanksgivingFinal Report/Code Due
15December 1, 2023Project Presentation
16December 8, 2023No class

Related Materials (Optional)