Editing Community Data Science Course (Spring 2017)

From CommunityData
Warning: You are not logged in. Your IP address will be publicly visible if you make any edits. If you log in or create an account, your edits will be attributed to your username, along with other benefits.

The edit can be undone. Please check the comparison below to verify that this is what you want to do, and then publish the changes below to finish undoing the edit.

Latest revision Your text
Line 2: Line 2:
:'''COM597I''' - Department of Communication
:'''COM597I''' - Department of Communication
:'''Instructor:''' [http://guyrt.github.com Richard Thomas (Tommy) Guy]  
:'''Instructor:''' [http://guyrt.github.com Richard Thomas (Tommy) Guy]  
:'''Course Website''': We will use Canvas for assignments and, and [https://canvas.uw.edu/courses/1153277/discussion_topics discussion]. Everything else will be linked on this page.
:'''Course Website''': We will use Canvas for [https://todo Announcements], [https://todo Assignments], and [https://todo discussion]. Everything else will be linked on this page.
:'''Course Catalog Description:'''
:'''Course Catalog Description:'''


Line 56: Line 56:
:'''Maximum Length:''' 600 words (~2 pages double spaced)
:'''Maximum Length:''' 600 words (~2 pages double spaced)
:'''Due Date:''' Week 3
:'''Due Date:''' Week 3
:'''Drop box:''' TODO on canvas




Line 87: Line 88:
I expect that your reports will include text from the first two assignments and reflect comprehensive documentation of your project. Each project should include: (a) the description of the question you have identified and information necessary to frame your question, (b) a description of the how you collected your data, (c) the results, (d) a description of the scope or limitations of your conclusion.
I expect that your reports will include text from the first two assignments and reflect comprehensive documentation of your project. Each project should include: (a) the description of the question you have identified and information necessary to frame your question, (b) a description of the how you collected your data, (c) the results, (d) a description of the scope or limitations of your conclusion.


A successful project will tell a compelling, defensible story in prose and plots and will contain source code sufficient to reproduce the results.
A successful project will tell a compelling story and will engage with, and improve upon, the course material to teach an audience that includes me, your classmates, and Comm Lead students taking this class in future years how to take advantage of community data science more effectively. The very best papers will give us all a new understanding of some aspect of course material and change the way I teach some portion of this course in the future.


==== Paper and Code ====
==== Paper and Code ====
Line 109: Line 110:
==== Presentation ====
==== Presentation ====


Your presentation should provide me with a very clear idea of what to expect in your final paper. However, don't treat it as a comprehensive overview of your paper: I would rather you tell a subset of the story well than the whole story in a rushed fashion. For instance, you can give a completely successful presentation by describing the motivation and walking through one plot in your paper. I'm going to give you all at least a paragraph of feedback after your talk. This will be an opportunity for me to see a preview of your paper and give you a sense for what I think you can improve. It's to your advantage to both give a compelling talk and to give me a sense for your project.
Your presentation should provide me with a very clear idea of what to expect in your final paper. However, don't treat it as a comprehensive overview of your paper: I would rather you tell a subset of the story well than the whole story in a rushed fashion. I'm going to give you all at least a paragraph of feedback after your talk. This will be an opportunity for me to see a preview of your paper and give you a sense for what I think you can improve. It's to your advantage to both give a compelling talk and to give me a sense for your project.


;Timing: All presentations will need to be '''a maximum of 7 minutes long'' with additional 2-3 minutes for questions and answers. Timing is going to be tight and I'm going to set an alarm and stop presentations that go too long. Concisely communicating an idea in the time allotted is an important skill in its own right.
;Timing: All presentations will need to be '''a maximum of 7 minutes long'' with additional 2-3 minutes for questions and answers. Timing is going to be tight and I'm going to set an alarm and stop presentations that go too long. Concisely communicating an idea in the time allotted is an important skill in its own right.




;Slides: You are encouraged to use slides for your talk but I will need your slides ahead of class. See link at top of this section. Please keep in mind that your slides are meant to be additive, not a teleprompter.
;Slides: You are encouraged to use slides for your talk but I will need your slides ahead of class. See link at top of this section.


=== Participation ===
=== Participation ===
Line 133: Line 134:


== Schedule ==
== Schedule ==
'''This section will be updated weekly'''  This section will be modified throughout the course to introduce the week's material and any hand-ins. Check back in weekly.


=== Week 1: March 30 ===
=== Week 1: March 30 ===
Line 145: Line 144:


* Class overview and expectations — We'll walk through this syllabus.
* Class overview and expectations — We'll walk through this syllabus.
* [[Community_Data_Science_Course_%28Spring_2017%29/Day_1_Exercise|Day 1 Exercise]] — You'll install software including the Python programming language and run through a series of exercises.
* [[Community_Data_Science_Course_%28Spring_2016%29/Day_1_Exercise|Day 1 Exercise]] — You'll install software including the Python programming language and run through a series of exercises.
* [[Community_Data_Science_Course_%28Spring_2017%29/Day_1_Tutorial|Day 1 Tutorial]] — You'll work through a self-guided tutorial introducing you to some basic concepts. When you're done, you'll meet with me and I'll check you off.
* [[Community_Data_Science_Course_%28Spring_2016%29/Day_1_Tutorial|Day 1 Tutorial]] — You'll work through a self-guided tutorial introducing you to some basic concepts. When you're done, you'll meet with a member of the teaching team and we'll check you off.
 
* A few interesting links we discussed in class are [[Community_Data_Science_Course_%28Spring_2017%29/DataSources|here]]
* Hints
** For exercise 5, look at chapter 3 of the textbook. This introduces "if" statements.


'''By the end of class you will:'''
'''By the end of class you will:'''
Line 156: Line 151:
* Have a working python environment on your personal laptop.
* Have a working python environment on your personal laptop.
* Have written your first program in the python language.
* Have written your first program in the python language.
=== Week 2: April 6 ===
'''Assignment Due (nothing to turn in):'''
* Read chapters 2 and 3 of Python for Informatics:
** [http://www.pythonlearn.com/html-009/book003.html Chapter 2, Variables, Expressions, and Statements]
** [http://www.pythonlearn.com/html-009/book004.html Chapter 3, Conditional Execution]
* Finish setup, tutorial and code academy in the [[Community Data Science Course (Spring 2016)/Day 1 Exercise|week 01 exercises]].
'''Class Schedule:'''
* Discuss a successful final project from last year.
* [[Community_Data_Science_Course_%28Spring_2017%29/Day_2_Lecture|Lecture notes]]
* Review material from last week: variables, assignments, if statements
* Introduce new material: loops and lists
* Project time — We'll begin working on the [[wordplay]] independent projects independently or in small groups.
Here are your [[Community_Data_Science_Course_(Spring_2017)/Day_2_Coding_Challenges|Exercises]]
* Sample solutions can be found here: [https://github.com/guyrt/teaching/tree/master/2017/Com597I/wordplay github]
'''By the end of class you will:'''
* Have written a program with loops and lists.
* Have a better understanding of the expectations for your final project, and be ready to hand in your initial assignment.
[https://goo.gl/forms/4hV5bMo4mHabeIEH2 Take my poll! ]
=== Week 3: April 13 ===
'''Assignment Due:'''
Final project idea (turn in on canvas)
Finish Wordplay examples
Reading
* Read chapter 4, 5 of Python for Informatics:
** [http://www.pythonlearn.com/html-009/book005.html Chapter 4, Functions] (this is mostly new)
** [http://www.pythonlearn.com/html-009/book006.html Chapter 5, Iteration] (this is mostly review)
'''Course plan:'''
* Go over last week's assignment.
* Dictionaries and aggregations [[Community Data Science Course (Spring 2016)/Day 3 Notes]]
* A break! Let's really aim for 7:30 this time.
* Statistics! Let's discuss summary statistics for a data set. The full data is [https://github.com/guyrt/teaching/tree/master/2017/Com597I/summary here] or you can download the course material as a [https://github.com/guyrt/teaching/archive/master.zip zip file].
* Project time — We'll begin working on a series of project based on the [http://mako.cc/teaching/2015/cdsw-autumn/babynames.zip Baby names] project.
* [[Community Data Science Course (Spring 2017)/Day 3 Coding Challenges|Day 3 Coding Challenges]]
'''Resources:'''
* [[Python_data_types_cheat_sheet]] A cheat sheet with everything we've covered in class so far including today.
=== Week 4: April 20 ===
'''Assignment Due:'''
Finish Baby Names examples.
Reading
* Read chapter 10 of Python for Informatics
** [http://www.pythonlearn.com/html-270/book010.html Chapter 10, Dictionaries] (this is review)
** [http://www.pythonlearn.com/html-270/book008.html Chapter 8, Files] (this is new)
'''Course plan:'''
[[Community Data Science Course (Spring 2017)/Day 4 Notes|Day 4 Plan]]
=== Week 5: April 26 ===
'''Assignment Due:'''
Turn in the single homework question from last week.
'''Course plan:'''
* Pivot tables!  You will need the SDOT data set from last week.
[[Community Data Science Course (Spring 2017)/Day 5 Notes|Day 5 Plan]]
=== Week 6: May 4 ===
'''Course plan: '''
* Go over challenge assignment and odds ratios again.
* downloading data from the internet using APIs 
[[Community Data Science Course (Spring 2017)/Day 6 Notes|Day 6 Plan]]
=== Week 7: May 11 ===
'''Assignment Due:'''
Final Project Proposal
'''Course plan:'''
* Visualization! [[Community Data Science Course (Spring 2017)/Day 7 Notes|Day 7 Plan]]
* Cleaning data in Python. [[Community Data Science Course (Spring 2017)/Day 7 Exercise|Day 7 Exercise]]
=== Week 8: May 18 ===
Here is the solution to last week's assignment: https://github.com/guyrt/teaching/blob/master/2017/Com597I/Week7/solution.py
'''Course plan:'''
* Introducing the ipython notebook, which is a way to write a document that includes both python and text.
* Self-guided visualization tutorial in python.  [https://github.com/guyrt/teaching/blob/master/2017/Com597I/visualization/VisualizationNotebook.ipynb Download here]  Save the file in a new directory in your desktop and open it with <code>jupyter notebook</code>
* If you have questions about your final project, or you want to spend some time on your python code while help is readily available, you can do that in class.
=== Week 9: May 25 ===
'''Course plan:'''
* Project time!
=== Week 10: June 1 ===
''' Final Project Presentation '''
''' Final project paper tentatively due June 8 '''


== Administrative Notes ==
== Administrative Notes ==
Please note that all contributions to CommunityData are considered to be released under the Attribution-Share Alike 3.0 Unported (see CommunityData:Copyrights for details). If you do not want your writing to be edited mercilessly and redistributed at will, then do not submit it here.
You are also promising us that you wrote this yourself, or copied it from a public domain or similar free resource. Do not submit copyrighted work without permission!

To protect the wiki against automated edit spam, we kindly ask you to solve the following CAPTCHA:

Cancel Editing help (opens in new window)