Editing Community Data Science Course (Spring 2015)

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 60: Line 60:
=== Final Project Proposal ===  
=== Final Project Proposal ===  
:'''Maximum Length:''' 1500 words (~5 pages)
:'''Maximum Length:''' 1500 words (~5 pages)
:'''Due Date:''' May 4th (at 6pm)
:'''Due Date:''' April 27


Building on your project idea assignment, you should describe the specific types of data you will collect, the steps you will take to collect the dataset, the limits and strength of these data for answering the question you have selected, and a description of the kinds of report and visualization you will make.
Building on your project idea assignment, you should describe the specific types of data you will collect, the steps you will take to collect the dataset, the limits and strength of these data for answering the question you have selected, and a description of the kinds of report and visualization you will make.
Line 79: Line 79:
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 and community you have identified and information necessary to frame your question, (b) a description of the how you collected your data, (c) the results.
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 and community you have identified and information necessary to frame your question, (b) a description of the how you collected your data, (c) 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.
You should also share with me the full Python source code you used to collect the data and the dataset itself.


==== Paper and Code ====
I will not be judging the quality or quantity of your code but rather the degree to which you have been successful at answering the ''substantive'' questions you have identified.


Your final project should include detailed information on:
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.
 
* The problem or area you have identified and enough background to understand the rest of your work and its importance or relevance.
* Your research question(s) and/or hypotheses.
* The methods, data, and approach that you used to collect the data plus information on why you think this was appropriate way to approach your question(s).
* The results and findings including numbers, tables, graphics, and figures.
* A discussion of limitations for your work and how you might improve them.
 
If you want inspiration for how people use data science to communicate this kinds of findings broadly and effectively, take a look at great sources of data journalism including [http://fivethirtyeight.com/ Five Thirty Eight] or [http://www.nytimes.com/upshot/ The Upshot at the New York Times]. Both of these publish an large amount of excellent examples of data analysis aimed at broader non-technical audiences like the ones you'll be communicating with and quite a bit of their work is actually done using Python and web APIs!  A simple Five Thirty Eight story will include a clear question, a brief overview of the data sources and method, a figure or two plus several paragraphs walking through the results, followed by a nice conclusion. I'm asking you to try to produce something roughly like this.
 
Keep in mind that most stories on Five Thirty Eight are under 1000 words and I'm giving up to 4,5000 words to show me what you've learned. As a result, you should do ''more'' than FiveThirtyEight does in a single story. You can ask and answer more questions, you can provide more background, context, and justification, you can provide more details on your methods and data sources, you can show us more graphs, you can discuss the implications of your findings more. You to use the space I've given you to show off what you've done and what you've learned!
 
Finally, you should also share with me the full Python source code you used to collect the data and the dataset itself. Keep in mind that I will not be judging the quality or quantity of your code but rather the degree to which you have been successful at answering the ''substantive'' questions you have identified.
 
==== Presentation ====
 
Your presentation should do everything that your paper does and should provide me with a very clear idea of what to expect in your final 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 too 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.
 
;Presentation Order: You '''must''' sign up for a presentation slot by editing [https://docs.google.com/spreadsheets/d/1P_saUgq1UEjg42KXRDXPa5pdaLTOKVUf2evEwmQWrUY/edit#gid=0 this spreadsheet]. If you are not on the sheet by Monday June 1st at 12:00pm, I will add you.
 
;Slides: You are encouraged to use slides for your talk but I will need your slides ahead of class. If you want to submit slides, you must upload slides in PDF format to [https://canvas.uw.edu/courses/963931/assignments/2816622 the assignment page in Canvas] by 12:00pm on Monday June 1st. I'm going to get everything in order on my laptop before class so we can make quick transitions. Because time will be very tight, if you do not submit slides, or if you submit them late, you will not be able to use slides for your talk. There will not be time in class for me to able to load your slides onto the computer.


=== Participation ===
=== Participation ===
Line 192: Line 170:
=== Week 4: April 20 ===
=== Week 4: April 20 ===


<!-- '''Readings:'''
'''Readings:'''


* Python for Informatics: [http://www.pythonlearn.com/html-009/book013.html Chapter 12  Networked programs] and [http://www.pythonlearn.com/html-009/book014.html Chapter 13  Using Web Services] (Moved from the previous week)
* Python for Informatics: [http://www.pythonlearn.com/html-009/book013.html Chapter 12  Networked programs] and [http://www.pythonlearn.com/html-009/book014.html Chapter 13  Using Web Services] (Moved from the previous week)
-->


'''Class Schedule''':
'''Class Schedule''':
Line 203: Line 180:
* Project time — We'll begin working on [[Community Data Science Course (Spring 2015)/Wikipedia API projects|a series of projects using the Wikipedia API]].
* Project time — We'll begin working on [[Community Data Science Course (Spring 2015)/Wikipedia API projects|a series of projects using the Wikipedia API]].


'''Resources''':
=== Week 5: April 27 ===


* [[Community Data Science Course (Spring 2015)/Day 4 Lecture|Day 4 Lecture]]
* [[Community Data Science Course (Spring 2015)/Wikipedia API projects|Wikipedia API projects]]
* [[Community Data Science Course (Spring 2015)/Day 4 Coding Challenges|Day 4 Coding Challenges]]
=== Week 5: April 27 ===


'''Assignment Due:''' Code solving challenges in in the Wikipedia API project from last week.
'''Assignment Due:''' Code solving challenges in in the Wikipedia API project from last week.
Line 220: Line 192:


* Review — We'll walk through answers to the assignments for last week as a group.
* Review — We'll walk through answers to the assignments for last week as a group.
* Lecture — [[Community Data Science Course (Spring 2015)/Day 5 Lecture|Interactive class lecture]] covering user-defined functions, debugging, filesystem input, and putting things together into a "real" program.
* Lecture — Interactive class lecture covering <code>while</code> loops, user-defined functions, debugging, filesystem output, and putting things together into a "real" program.
* Project time — We'll begin modifying the program we walk through in class to adapt it toward our needs and we'll pick out ideas for next steps and challenges for the coming week..
* Project time — We'll begin modifying the program we walk through in class to adapt it toward our needs and we'll pick out ideas for next steps and challenges for the coming week..
'''Resources:'''
* [[Community Data Science Course (Spring 2015)/Day 5 Lecture|Day 5 Lecture]]
* '''Day 5 Project:''' [[Harry Potter on Wikipedia]]
* [[Community Data Science Course (Spring 2015)/Day 5 Coding Challenges|Day 5 Coding Challenges]]


=== Week 6: May 4 ===
=== Week 6: May 4 ===
Line 245: Line 211:


* Review — We'll walk through answers to the assignments for last week as a group.
* Review — We'll walk through answers to the assignments for last week as a group.
* Lecture — Interactive class lecture covering Python objects and classes and using Tweepy to collect data from Twitter.
* Lecture — Interactive class lecture covering code abstraction, Python objects and classes and using Tweepy to collect data from Twitter.
* Project time — [[Community Data Science Course (Spring 2015)/Day 6 Project|Twitter API project]]
* Project time — Twitter API challenges.
 
'''Resources:'''
 
* '''Day 6 Project:''' [[Community Data Science Course (Spring 2015)/Day 6 Project|Day 6 Project]]
* [[Community Data Science Course (Spring 2015)/Day 6 Coding Challenges|Day 6 Coding Challenges]]
* [[Twitter words of warning]]


=== Week 7: May 11 ===
=== Week 7: May 11 ===
Line 262: Line 222:
'''Readings:'''
'''Readings:'''


* Python for Informatics: [http://www.pythonlearn.com/html-009/book005.html Chapter 4 Functions] and [http://www.pythonlearn.com/html-009/book012.html Chapter 11 Regular expressions]
* Python for Informatics: [http://www.pythonlearn.com/html-009/book005.html Chapter 4 Functions] and [http://www.pythonlearn.com/html-009/book012.html Chapter 11 Regular expressions]


'''Class Schedule:'''
'''Class Schedule:'''


* Review — We'll walk through answers to the assignments for last week as a group.
* Review — We'll walk through answers to the assignments for last week as a group.
* Lecture — Interactive class lecture on regular expressions and pattern matching
* Lecture — Interactive class lecture counting and powerful "group by" functionality using dictionaries and exporting and simple graphing of processed data using Google Docs , LibreOffice, Microsoft Excel, etc.
* Project time — Working on regular expressions and independent projects
* Project time — Graphing and work on challenges that use either the Twitter and/or Wikipedia data that we've collected in the two previous sessions.


=== Week 8: May 18 ===
=== Week 8: May 18 ===


'''Class Schedule:'''


* Final Project — We'll through expectations for final projects.
'''Assignment Due:'''
* Lecture — We'll walk through a series of common challenges people are having on their projects.
 
* Project time — We'll spend the majority of class focused on creating space for students to work on their individual final projects.
* Code solving challenges in created at the end of previous class.


'''Optional Readings:'''
'''Readings:'''


* Python for Informatics: [http://www.pythonlearn.com/html-009/book016.html Chapter 15 Visualizing Data]
* Python for Informatics: [http://www.pythonlearn.com/html-009/book016.html Chapter 15 Visualizing Data]
* Python for Data Analysis: ''Chapter 8 Plotting and Visualization''
* Python for Data Analysis: ''Chapter 8 Plotting and Visualization''
'''Class Schedule:'''
* Review — We'll walk through answers to the assignments for last week as a group.
* Lecture — Interactive class on using Python to creating visualization using MatPlotLib. Graphing and work on challenges on data on gender and Wikipedia.
* Project time — Project time will be devoted to Q&A focused on individual final projects.


=== Week 9: May 25 ===
=== Week 9: May 25 ===
Line 287: Line 252:
{{divbox|Note|May 25th is Memorial day and is a University Holiday. Because UW policy requires that we meet 10 times, we will meeting as scheduled. That said, because the building will lock at 6pm, we will be meeting half an hour early at '''5:30pm'''. Please do not be late!}}
{{divbox|Note|May 25th is Memorial day and is a University Holiday. Because UW policy requires that we meet 10 times, we will meeting as scheduled. That said, because the building will lock at 6pm, we will be meeting half an hour early at '''5:30pm'''. Please do not be late!}}


'''Class Schedule:'''
'''Readings:'''


* Final Project — We'll through expectations for final projects.
* Python for Data Analysis: ''Chapter 4 NumPy Basics: Arrays and Vectorized Computation'' and ''Chapter 5 Getting Started with pandas''
* Lecture — We'll walk through a series of common challenges people are having on their projects.
* Project time — We'll spend the majority of class focused on creating space for students to work on their individual final projects.


'''Optional Readings:'''
'''Class Schedule:'''


* Python for Data Analysis: ''Chapter 4 NumPy Basics: Arrays and Vectorized Computation'' and ''Chapter 5 Getting Started with pandas''
* Review — We'll walk through answers to the assignments for last week as a group.
* Lecture — Interaction lecture on [http://www.numpy.org/ num.py], [http://pandas.pydata.org/ pandas], doing basic statistical tests using [http://statsmodels.sourceforge.net/ Statmodels].
* Project time — Project time will be devoted to Q&A focused on individual final projects.


=== Week 10: June 1 ===
=== Week 10: June 1 ===
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)

Template used on this page: