Intro to Programming and Data Science (Summer 2021): Difference between revisions
(Copying content from previous class) |
No edit summary |
||
(35 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
{{Old Class}} | |||
= Course Information = | = Course Information = | ||
:'''COM 674: Introduction to Programming and Data Science''' | :'''COM 674: Introduction to Programming and Data Science''' | ||
:'''Location:''' | :'''Location:''' Discord | ||
:'''Class Hours:''' M-F, 10 am - 12 pm | :'''Class Hours:''' M-F, 10 am - 12 pm | ||
Line 7: | Line 9: | ||
:'''Instructor:''' [https://jeremydfoote.com Jeremy Foote] | :'''Instructor:''' [https://jeremydfoote.com Jeremy Foote] | ||
:'''Email:''' jdfoote@purdue.edu | :'''Email:''' jdfoote@purdue.edu | ||
:'''Office Hours:''' By appointment; | :'''Office Hours:''' By appointment; on Discord | ||
<div style="float:right;">__TOC__</div> | <div style="float:right;">__TOC__</div> | ||
Line 41: | Line 42: | ||
== Readings == | == Readings == | ||
* Required text: '''[https://www.py4e.com/book Python for Everybody]''' by Charles R. Severance. The book is [https://creativecommons.org/licenses/by/3.0/us/ freely licensed] and available online for free. You can also buy the book if you prefer a hard copy. | * Required text: '''[https://www.py4e.com/book Python for Everybody]''' [[https://www.py4e.com/html3/ HTML Version]] [[http://do1.dr-chuck.com/pythonlearn/EN_us/pythonlearn.pdf PDF version]] by Charles R. Severance. The book is [https://creativecommons.org/licenses/by/3.0/us/ freely licensed] and available online for free. You can also buy the book if you prefer a hard copy. | ||
I will list required chapters in the schedule below. In general, you should expect to spend far more time working on programming tasks than reading. Much like math or other technical courses, this course will build on itself every day. You should make every effort to cover the reading and exercise material every day in preparation for the next day. | I will list required chapters in the schedule below. In general, you should expect to spend far more time working on programming tasks than reading. Much like math or other technical courses, this course will build on itself every day. You should make every effort to cover the reading and exercise material every day in preparation for the next day. | ||
Line 53: | Line 54: | ||
== Note About This Syllabus == | == Note About This Syllabus == | ||
Although the core expectations for this class are fixed, the details of readings and assignments may shift based on how the class goes. As a result, there are three important things to keep in mind: | |||
# Although details on this syllabus will change, I will not change readings or assignments less than three days before they are due. If you plan to read more than three days ahead, contact me first. | # Although details on this syllabus will change, I will not change readings or assignments less than three days before they are due. If you plan to read more than three days ahead, contact me first. | ||
# Closely monitor | # Closely monitor Discord. Because this a wiki, you will be able to track every change by clicking the ''history'' button on this page. I will also summarize these changes in a announcements that will be posted in the #announcements channel on Discord. | ||
# I will ask the class for voluntary anonymous feedback frequently. Please let me know what is working and what can be improved. | # I will ask the class for voluntary anonymous feedback frequently. Please let me know what is working and what can be improved. | ||
== Lectures == | == Lectures == | ||
The synchronous part of the course will be held starting at 1pm every day, on Discord. The typical format will be a discussion of the reading for the day followed by a brief lecture about the topic for that week followed by a discussion of the previous day's homework questions followed by optional co-working time to start on the next day's assignment. | |||
I highly encourage | I highly encourage you to attend as many of our synchronous sessions as possible. In general, my teaching style is more conversational than a formal lecture. I prefer that students feel they can "politely interrupt" at any time to seek clarification or make a well-informed point, and the lectures will be much better if I can get real-time feedback about what is and isn't making sense. | ||
== Office hours and email == | == Office hours and email == | ||
Line 75: | Line 76: | ||
# '''Research Project:''' The main outcome of this course will be a research project exploring a social science question using Python, and the bulk of your grade will be based on that project. Submit these via Brightspace | # '''Research Project:''' The main outcome of this course will be a research project exploring a social science question using Python, and the bulk of your grade will be based on that project. Submit these via Brightspace | ||
# '''Coding Challenges:''' There will be daily programming assignments that I will ask you to turn in on Brightspace but which will only be graded as complete/incomplete. I will also randomly assign someone to present their solution to each of the problems | # '''Coding Challenges:''' There will be daily programming assignments that I will ask you to turn in on Brightspace but which will only be graded as complete/incomplete. I will also randomly assign someone to present their solution to each of the problems during our synchronous sessions. | ||
# '''Paper Discussion:''' Each day we will read and discuss a paper which uses computational approaches to address social science questions. | # '''Paper Discussion:''' Each day we will read and discuss a paper which uses computational approaches to address social science questions. | ||
Line 87: | Line 88: | ||
* '''Ensure that your work is replicable''' — You will need to provide code and data for your analysis in a way that makes your work replicable by other researchers. | * '''Ensure that your work is replicable''' — You will need to provide code and data for your analysis in a way that makes your work replicable by other researchers. | ||
''I strongly urge you'' to | ''I strongly urge you'' to work on a project that will further your academic career outside of the class. There are many ways that this can happen. Some obvious options are to prepare a project that you can submit for publication, that you can use as pilot analysis that you can report in a grant or thesis proposal, and/or that fulfills a degree requirement. I prefer that you do projects on your own but it may be possible to work as a small team (maximum 3 people). Team projects are expected to be more ambitious than individual projects. Preliminary assignments will help you to develop your idea and to get feedback from me and others. | ||
There are several intermediate milestones and deadlines to help you accomplish a successful research project. Unless otherwise noted, all deliverables should be submitted via Brightspace. | There are several intermediate milestones and deadlines to help you accomplish a successful research project. Unless otherwise noted, all deliverables should be submitted via Brightspace. | ||
Line 93: | Line 94: | ||
=== Project idea and dataset identification === | === Project idea and dataset identification === | ||
;Due date: May | ;Due date: May 19 | ||
;Maximum length: 500 words (~1-2 pages) | ;Maximum length: 500 words (~1-2 pages) | ||
Line 99: | Line 100: | ||
* An abstract of the proposed study including the topic, research question, theoretical motivation, object(s) of study, and anticipated research contribution. | * An abstract of the proposed study including the topic, research question, theoretical motivation, object(s) of study, and anticipated research contribution. | ||
* An identification of the dataset you will use and a description of the columns or type of data it will include. If you do not currently have access to these data, explain why and when you will. | * An identification of the dataset you will use and a description of the columns or type of data it will include. If you do not currently have access to these data, explain why not and when you will have access (If you need ideas, [[Data_Into_Insights_(Spring_2021)/Final_project#Datasets|this page]] from one of my undergrad classes lists some open datasets). | ||
* A short (several sentences) description of how the project will fit into your career trajectory. | * A short (several sentences) description of how the project will fit into your career trajectory. | ||
=== Project planning document === | === Project planning document === | ||
;Due date: May | ;Due date: May 27 | ||
;Maximum length: ~4-5 pages | ;Maximum length: ~4-5 pages | ||
Line 116: | Line 117: | ||
=== Project presentation and report === | === Project presentation and report === | ||
;Report due date: June | ;Report due date: June 11 | ||
;Maximum length: 4000 words (~15 pages) | ;Maximum length: 4000 words (~15 pages) | ||
;Presentation due date: June | ;Presentation due date: June 10 | ||
;Maximum length: 8 minutes | ;Maximum length: 8 minutes | ||
Line 142: | Line 143: | ||
Nearly every day I will give you a set of coding challenges before the end of class that will involve writing code or adding to code that I've given you. These coding challenges will be turned in on Brightspace but will not be graded. I encourage you to work together on these challenges but to make sure that you understand the concepts yourself. | Nearly every day I will give you a set of coding challenges before the end of class that will involve writing code or adding to code that I've given you. These coding challenges will be turned in on Brightspace but will not be graded. I encourage you to work together on these challenges but to make sure that you understand the concepts yourself. | ||
Each day I will randomly select a set of students to share their solutions to a selected exercise on | Each day I will randomly select a set of students to share their solutions to a selected exercise. This will involve putting your solution on Discord at least one hour before the next day's lecture starts, and being prepared to walk us through the solution. If you can't figure out the problem that's been assigned to you, then explain where you got stuck and what you tried. I encourage you to also use Discord to ask and answer each other's questions as you work on the assignments. We will use some of our lecture time to review the problems and I will make sure that a correct solution is posted by the end of that day. As you will see over the course of the module, there are many possible solutions to many programming problems and my own approaches will often be different than yours. That's completely fine! Coding is a creative act! | ||
== Paper Discussions == | == Paper Discussions == | ||
Every day we will review a paper that uses computational methods. On the first day, I will ask you to sign up to lead the discussion | Every day we will review a paper that uses computational methods. On the first day, I will ask you to sign up to lead the discussion for one of these papers. When leading the discussion, you will prepare a presentation as though you were presenting the paper at a conference and then lead a discussion about it. | ||
== Reflection papers == | == Reflection papers == | ||
Line 160: | Line 156: | ||
= Grades = | = Grades = | ||
This course will follow a "self-assessment" philosophy. I am more interested in helping you to learn things that will be useful to you than in assigning grades. The university still requires grades, so you will be leading the evaluation of your work. | This course will follow a "self-assessment" philosophy. I am more interested in helping you to learn things that will be useful to you than in assigning grades. The university still requires grades, so you will be leading the evaluation of your work. In week two and again at the end of the course, you will reflect on what you have accomplished thus far, how it has met, not met, or exceeded expectations, based both on rubrics and personal goals and objectives. At each of these stages you will receive feedback on your assessments. By the end of the semester, you should have a clear vision of your accomplishments and growth, which you will turn into a grade. As the instructor-of-record, I maintain the right to disagree with your assessment and alter grades as I see fit, but any time that I do this it will be accompanied by an explanation and discussion. These personal assessments, reflecting both honest and meaningful reflection of your work will be the most important factor in final grades. | ||
I suggest that we use the following rubric in our assessment: | I suggest that we use the following rubric in our assessment: | ||
* | * 25%: class participation, including attendance, participation in discussions and group work, and significant effort towards weekly assignments. | ||
* 5%: Final Project Idea. | * 5%: Final Project Idea. | ||
* 10%: Final Project Proposal. | * 10%: Final Project Proposal. | ||
* | * 40%: Final Project paper/Jupyter notebook. | ||
* 20%: Final Presentation including your slides and presentation. | * 20%: Final Presentation including your slides and presentation. | ||
Line 203: | Line 199: | ||
'''NOTE''': This section will be modified throughout the course to meet the class's needs. Check back in often. | '''NOTE''': This section will be modified throughout the course to meet the class's needs. Check back in often. | ||
There are links to each day's slides. Note that these are slides from an earlier version of the class and will typically be updated the day of each class. | |||
== Day 1: Introduction to Python and Computational Thinking (May | == Day 1: Introduction to Python and Computational Thinking (May 17) == | ||
'''Assignment Due:''' | '''Assignment Due:''' | ||
Line 216: | Line 212: | ||
'''Agenda:''' | '''Agenda:''' | ||
* Class overview and expectations — We'll walk through this syllabus. | * Class overview and expectations — We'll walk through this syllabus. | ||
* [[ | * [[/Day_1_Coding_Challenge| Day 1 Coding challenge]] - Includes installing Python and going through a number of exercises. | ||
* [https://jeremydfoote.com/ | * [https://jeremydfoote.com/Intro-to-Programming-and-Data-Science/day_1/lecture/day_1.html Today's slides] | ||
'''By the end of class you will:''' | '''By the end of class you will:''' | ||
Line 223: | Line 219: | ||
* Have written your first program in the python language. | * Have written your first program in the python language. | ||
== Day 2: Variables, conditionals, and functions (May | == Day 2: Variables, conditionals, and functions (May 18) == | ||
''' | '''Assignments Due:''' | ||
* Finish Day 1 exercises and tutorials | * Finish Day 1 exercises and tutorials | ||
* Fill out this [https://docs.google.com/forms/d/e/1FAIpQLSfUiGogs2jDXIHaXz1ooVBZFkRF2NdMaf00IgZvk7f69rby9w/viewform?usp=sf_link short survey] | * Fill out this [https://docs.google.com/forms/d/e/1FAIpQLSfUiGogs2jDXIHaXz1ooVBZFkRF2NdMaf00IgZvk7f69rby9w/viewform?usp=sf_link short survey] | ||
* Sign up to be a discussant [https://docs.google.com/spreadsheets/d/1uSo-Ya5DghaLu1BYk94EVU2kBVmExRWwOa1586GbFUU/edit?usp=sharing here] ( | * Sign up to be a discussant [https://docs.google.com/spreadsheets/d/1uSo-Ya5DghaLu1BYk94EVU2kBVmExRWwOa1586GbFUU/edit?usp=sharing here] | ||
* [[/Day_2_Coding_Challenges|Day 2 Coding Challenge]] (turn in on Brightspace) | |||
'''Readings (before class):''' | '''Readings (before class):''' | ||
* Bit By bit, [https://www.bitbybitbook.com/en/1st-ed/introduction/ Introduction] | |||
* Python for Everybody, chapters 1-4 | * Python for Everybody, chapters 1-4 | ||
* | * [https://github.com/jdfoote/Intro-to-Programming-and-Data-Science/raw/summer2021/day_2/day_2.ipynb Today's Jupyter Notebook] | ||
** [https://purdue.brightspace.com/d2l/le/content/306917/viewContent/6387775/View Notebook walkthrough] | |||
'''Agenda:''' | '''Agenda:''' | ||
* | * Review Day 1 and Day 2 Exercises | ||
* [https://jeremydfoote.com/ | * [https://jeremydfoote.com/Intro-to-Programming-and-Data-Science/day_2/lecture/day_2.html Today's slides] | ||
* Introduce wordplay project | |||
== Day 3: Iteration, strings, and lists (May 19) == | |||
== Day 3: Iteration, strings, and lists (May | |||
'''Assignment Due:''' | '''Assignment Due:''' | ||
* Final project dataset and idea (turn in on Brightspace). | * Final project dataset and idea (turn in on Brightspace). | ||
* | * [[/Day_3_Coding_Challenges|Day 3 Coding Challenge]] | ||
'''Readings:''' | '''Readings:''' | ||
* Python for Everybody | * Python for Everybody | ||
chapters_to_read = [5, 6, 8] | chapters_to_read = [5, 6, 8] | ||
* [https://github.com/jdfoote/Intro-to-Programming-and-Data-Science/raw/summer2021/day_3/day_3.ipynb Today's Jupyter Notebook] | |||
** [https://purdue.brightspace.com/d2l/le/content/306917/viewContent/6390578/View Notebook walkthrough] | |||
* Foote, J., Shaw, A., & Hill, B.M. (2017). [https://jeremydfoote.com/files/foote_computational_2017.pdf Computational analysis of social media scholarship]. In Burgess, J., Poell, T., Marwick, A. (Eds.), The Sage Handbook of Social Media. Sage. | * Foote, J., Shaw, A., & Hill, B.M. (2017). [https://jeremydfoote.com/files/foote_computational_2017.pdf Computational analysis of social media scholarship]. In Burgess, J., Poell, T., Marwick, A. (Eds.), The Sage Handbook of Social Media. Sage. | ||
** Discussant: | ** Discussant: Juan Pablo | ||
'''Agenda:''' | '''Agenda:''' | ||
* Programming principles (iteration, strings, and lists) | * Programming principles (iteration, strings, and lists) | ||
* Go over last day's assignment | * Go over last day's assignment | ||
* [https://jeremydfoote.com/Intro-to-Programming-and-Data-Science/day_3/lecture/day_3.html Today's slides] | |||
* [https://jeremydfoote.com/ | |||
== Day 4: Reading from and writing to files (May | == Day 4: Reading from and writing to files (May 20) == | ||
'''Assignment Due:''' | '''Assignment Due:''' | ||
* [[ | * [[/Day 4 Coding Challenges|Day 4 Coding Challenges]] | ||
'''Readings:''' | '''Readings:''' | ||
Line 275: | Line 268: | ||
read(chapter) | read(chapter) | ||
book.close() | book.close() | ||
* [https://github.com/jdfoote/Intro-to-Programming-and-Data-Science/raw/summer2021/day_4/day_4.ipynb Today's Jupyter Notebook] | |||
** [https://purdue.brightspace.com/d2l/le/content/306917/viewContent/6399269/View Notebook walkthrough] | |||
* Nelson, Laura K. 2017. "[https://doi.org/10.1177%2F0049124117729703 Computational Grounded Theory: A Methodological Framework]." Sociological Methods and Research. | * Nelson, Laura K. 2017. "[https://doi.org/10.1177%2F0049124117729703 Computational Grounded Theory: A Methodological Framework]." Sociological Methods and Research. | ||
** Discussant: | ** Discussant: Beth Ann | ||
'''Agenda:''' | '''Agenda:''' | ||
* Reading from and writing to files | * Reading from and writing to files | ||
* [https:// | * [https://jeremydfoote.com/Intro-to-Programming-and-Data-Science/day_4/lecture/day_4.html Today's slides] | ||
== Day 5: Dictionaries and Tuples (May 21) == | |||
== Day 5: Dictionaries and Tuples (May | |||
'''Assignment Due:''' | '''Assignment Due:''' | ||
* [[ | * [[/Day 5 Coding Challenges|Day 5 Coding Challenges]] | ||
* Do the [[/Twitter_authentication_setup|Twitter Authentication Setup]] | |||
'''Readings:''' | '''Readings:''' | ||
* Python for Everybody, chapters 9 and 10 | * Python for Everybody, chapters 9 and 10 | ||
* [https://github.com/jdfoote/Intro-to-Programming-and-Data-Science/raw/summer2021/day_5/day_5.ipynb Today's Jupyter Notebook] | |||
** [https://purdue.brightspace.com/d2l/le/content/306917/viewContent/6415595/View Video walkthrough] | |||
* Margolin, D. B., Hannak, A., & Weber, I. (2018). [https://doi.org/10.1080/10584609.2017.1334018 Political Fact-Checking on Twitter: When Do Corrections Have an Effect?] Political Communication, 35(2), 196–219. | * Margolin, D. B., Hannak, A., & Weber, I. (2018). [https://doi.org/10.1080/10584609.2017.1334018 Political Fact-Checking on Twitter: When Do Corrections Have an Effect?] Political Communication, 35(2), 196–219. | ||
** Discussant: | ** Discussant: Katelyn | ||
'''Agenda:''' | '''Agenda:''' | ||
* Dictionaries | * Dictionaries | ||
* Tuples | * Tuples | ||
* [https:// | * [https://jeremydfoote.com/Intro-to-Programming-and-Data-Science/day_5/lecture/day_5.html Today's slides] | ||
== Day 6: Dataframes and Visualization (May 24) == | |||
== Day 6: Dataframes and Visualization (May | |||
'''Assignment Due:''' | '''Assignment Due:''' | ||
* | * [[/Day 6 Coding Challenges|Day 6 Coding Challenges]] | ||
'''Readings:''' | '''Readings:''' | ||
* [https://github.com/jdfoote/Intro-to-Programming-and-Data-Science/raw/summer2021/day_6/day_6.ipynb Day 6 notebook] | |||
** [https://purdue.brightspace.com/d2l/le/content/306917/viewContent/6419983/View Notebook walkthrough] | |||
* Benefield, G. A., Shen, C., & Leavitt, A. (2016). [https://doi.org/10.1145/2818048.2819935 Virtual Team Networks: How Group Social Capital Affects Team Success in a Massively Multiplayer Online Game]. Proceedings of the 19th ACM Conference on Computer-Supported Cooperative Work & Social Computing, 679–690. | * Benefield, G. A., Shen, C., & Leavitt, A. (2016). [https://doi.org/10.1145/2818048.2819935 Virtual Team Networks: How Group Social Capital Affects Team Success in a Massively Multiplayer Online Game]. Proceedings of the 19th ACM Conference on Computer-Supported Cooperative Work & Social Computing, 679–690. | ||
** Discussant: | ** Discussant: Anna | ||
'''Agenda:''' | '''Agenda:''' | ||
* Dataframes and visualization | * Dataframes and visualization | ||
* [https:// | * [https://jeremydfoote.com/Intro-to-Programming-and-Data-Science/day_6/lecture/day_6.html Today's slides] | ||
== Day 7: Dataframes and visualization (continued) (May 25) == | |||
== Day 7: Dataframes and visualization (continued) (May | |||
'''Assignment Due:''' | '''Assignment Due:''' | ||
* | * [[/Day 7 Coding Challenges|Day 7 Coding Challenges]] | ||
'''Readings:''' | '''Readings:''' | ||
* Lazer, D., & Radford, J. (2017). Data ex Machina: Introduction to Big Data. Annual Review of Sociology, 43(1), 19–39. | * [https://github.com/jdfoote/Intro-to-Programming-and-Data-Science/raw/summer2021/day_7/day_7.ipynb Day 7 notebook] | ||
** Discussant: | ** [https://purdue.brightspace.com/d2l/le/content/306917/viewContent/6429518/View Notebook walkthrough] | ||
* Lazer, D., & Radford, J. (2017). [https://doi.org/10.1146/annurev-soc-060116-053457 Data ex Machina: Introduction to Big Data]. Annual Review of Sociology, 43(1), 19–39. | |||
** Discussant: Yong | |||
'''Agenda:''' | '''Agenda:''' | ||
* Visualizations in Seaborn | * Visualizations in Seaborn | ||
* [https:// | * [https://jeremydfoote.com/Intro-to-Programming-and-Data-Science/day_7/lecture/day_7.html Today's slides] | ||
== Day 8: Collecting Data with APIs (May | == Day 8: Collecting Data with APIs (May 26) == | ||
'''Assignment Due:''' | '''Assignment Due:''' | ||
* | * [[/Day 8 Coding Challenges|Day 8 Coding Challenges]]. | ||
* | ** [https://youtu.be/TASX3evcgG4 Video instructions to install tweepy] | ||
'''Readings:''' | '''Readings:''' | ||
* [https://github.com/jdfoote/Intro-to-Programming-and-Data-Science/raw/summer2021/day_8/day_8.ipynb Intro to APIs Notebook] | |||
** (Long) [https://purdue.brightspace.com/d2l/le/content/306917/viewContent/6430558/View walkthrough of notebook] | |||
* Kieran Healy and James Moody (2014). “[https://doi.org/10.1146/annurev-soc-071312-145551 Data Visualization in Sociology].” American Review of Sociology. 40: 105-28. | * Kieran Healy and James Moody (2014). “[https://doi.org/10.1146/annurev-soc-071312-145551 Data Visualization in Sociology].” American Review of Sociology. 40: 105-28. | ||
** Discussant: | ** Discussant: Pearlynne | ||
'''Agenda:''' | '''Agenda:''' | ||
* Introduce the [https://2.python-requests.org/en/master/ requests] library | * Introduce the [https://2.python-requests.org/en/master/ requests] library | ||
* Discuss the main kinds of online data gathering: downloading, scraping, and APIs. | * Discuss the main kinds of online data gathering: downloading, scraping, and APIs. | ||
* [https:// | * [https://jeremydfoote.com/Intro-to-Programming-and-Data-Science/day_8/lecture/day_8.html Today's slides] | ||
== Day 9: Collecting Data with APIs (continued) (May | == Day 9: Collecting Data with APIs (continued) (May 27) == | ||
'''Assignment Due:''' | '''Assignment Due:''' | ||
* Start on [[Intro to Programming and Data Science (Summer 2021)/Day 9 Coding Challenges|Day 9 Coding Challenges]] | |||
* First [[Self_Assessment_Reflection | self-assessment reflection]] is due (on Brightspace). | * First [[Self_Assessment_Reflection | self-assessment reflection]] is due (on Brightspace). | ||
* Project Planning Document Due | * Project Planning Document Due | ||
Line 371: | Line 353: | ||
'''Readings:''' | '''Readings:''' | ||
* [https://github.com/jdfoote/Intro-to-Programming-and-Data-Science/raw/summer2021/day_9/day_9.ipynb Day 9 Notebook] | |||
** [https://purdue.brightspace.com/d2l/le/content/306917/viewContent/6437812/View Notebook walkthrough] | |||
* Python for Everybody, Chapter 13 | * Python for Everybody, Chapter 13 | ||
* Vitak, J., Shilton, K., & Ashktorab, Z. (2016). [https://doi.org/10.1145/2818048.2820078 Beyond the Belmont Principles: Ethical Challenges, Practices, and Beliefs in the Online Data Research Community]. Proceedings of the 19th ACM Conference on Computer-Supported Cooperative Work & Social Computing, 941–953. | * Vitak, J., Shilton, K., & Ashktorab, Z. (2016). [https://doi.org/10.1145/2818048.2820078 Beyond the Belmont Principles: Ethical Challenges, Practices, and Beliefs in the Online Data Research Community]. Proceedings of the 19th ACM Conference on Computer-Supported Cooperative Work & Social Computing, 941–953. | ||
** Discussant: | ** Discussant: Casey Lynn | ||
* (Optional) Williams, M. L., Burnap, P., & Sloan, L. (2017). [https://doi.org/10.1177/0038038517708140 Towards an Ethical Framework for Publishing Twitter Data in Social Research: Taking into Account Users’ Views, Online Context and Algorithmic Estimation]: Sociology. | * (Optional) Williams, M. L., Burnap, P., & Sloan, L. (2017). [https://doi.org/10.1177/0038038517708140 Towards an Ethical Framework for Publishing Twitter Data in Social Research: Taking into Account Users’ Views, Online Context and Algorithmic Estimation]: Sociology. | ||
* (Optional) Salganik, M. [https://www.bitbybitbook.com/en/1st-ed/ethics/ Ethics] chapter from Bit By Bit. | * (Optional) Salganik, M. [https://www.bitbybitbook.com/en/1st-ed/ethics/ Ethics] chapter from Bit By Bit. | ||
Line 381: | Line 366: | ||
'''Agenda:''' | '''Agenda:''' | ||
* A workflow for doing work with APIs | * A workflow for doing work with APIs | ||
* [https:// | * Ethics of digital trace data | ||
* [https://jeremydfoote.com/Intro-to-Programming-and-Data-Science/day_9/lecture/day_9.html Today's slides] | |||
== Day 10: Introduction to Computational Text Analysis ( | == Day 10: Introduction to Computational Text Analysis (May 28) == | ||
'''Assignment Due:''' | '''Assignment Due:''' | ||
* [[ | * [[/Day 9 Coding Challenges|Day 9 Coding Challenges]] | ||
* [[ | * [[/Day 10 Coding Challenges|Day 10 Coding Challenges]] | ||
'''Readings:''' | '''Readings:''' | ||
* [https://github.com/jdfoote/Intro-to-Programming-and-Data-Science/raw/summer2021/day_10/day_10.ipynb Today's Notebook] | |||
** [https://purdue.brightspace.com/d2l/le/content/306917/viewContent/6445663/View Notebook walkthrough] | |||
* Christopher A. Bail et al. 2018. [https://doi.org/10.1073/pnas.1804840115 Exposure to opposing views on social media can increase political polarization]. PNAS 115(37): 9216-9221 | * Christopher A. Bail et al. 2018. [https://doi.org/10.1073/pnas.1804840115 Exposure to opposing views on social media can increase political polarization]. PNAS 115(37): 9216-9221 | ||
** Discussant: | ** Discussant: Caitlyn | ||
'''Agenda:''' | '''Agenda:''' | ||
* [https:// | * [https://jeremydfoote.com/Intro-to-Programming-and-Data-Science/day_10/lecture/day_10.html Today's slides] | ||
'''Resources:''' | '''Resources:''' | ||
Line 406: | Line 388: | ||
* [https://github.com/jdfoote/Intro-to-Programming-and-Data-Science/blob/master/resources/solutions/Twitter_answers.ipynb My answers to the Day 8 problems] | * [https://github.com/jdfoote/Intro-to-Programming-and-Data-Science/blob/master/resources/solutions/Twitter_answers.ipynb My answers to the Day 8 problems] | ||
== Day 11: Data cleaning and operationalization (June 1) == | |||
== Day 11: Data cleaning and operationalization (June | |||
'''Assignment Due:''' | '''Assignment Due:''' | ||
* [ | * [https://github.com/jdfoote/Intro-to-Programming-and-Data-Science/raw/summer2021/day_11/day_11.ipynb Day 11 Coding Challenges] | ||
'''Readings:''' | '''Readings:''' | ||
* [https://github.com/jdfoote/Intro-to-Programming-and-Data-Science/raw/summer2021/day_11/day_11.ipynb Today's Notebook] | |||
** [https://purdue.brightspace.com/d2l/le/content/306917/viewContent/6450755/View Notebook walkthrough] | |||
* Robert K. Merton. 1948. [https://www-jstor-org.ezproxy.lib.purdue.edu/stable/2087142?sid=primo&origin=crossref&seq=1#metadata_info_tab_contents The Bearing of Empirical Research Upon the Development of Social Theory]. American Sociological Review 13(5): 505-515. | * Robert K. Merton. 1948. [https://www-jstor-org.ezproxy.lib.purdue.edu/stable/2087142?sid=primo&origin=crossref&seq=1#metadata_info_tab_contents The Bearing of Empirical Research Upon the Development of Social Theory]. American Sociological Review 13(5): 505-515. | ||
* Sara Klingenstein, Tim Hitchcock, and Simon DeDeo. 2014. [https://www.ncbi.nlm.nih.gov/pmc/articles/PMC4084475/ The civilizing process in London’s Old Baily]. Proceedings of the National Academy of Sciences 111(26): 9419-9424. | * Sara Klingenstein, Tim Hitchcock, and Simon DeDeo. 2014. [https://www.ncbi.nlm.nih.gov/pmc/articles/PMC4084475/ The civilizing process in London’s Old Baily]. Proceedings of the National Academy of Sciences 111(26): 9419-9424. | ||
** Discussant: | ** Discussant: Jeremy | ||
'''Resources:''' | '''Resources:''' | ||
* [https:// | * [https://jeremydfoote.com/Intro-to-Programming-and-Data-Science/day_11/lecture/day_11.html Today's slides] | ||
== Day 12: Organizing and storing computational projects (June | == Day 12: Organizing and storing computational projects (June 2) == | ||
'''Assignment Due:''' | '''Assignment Due:''' | ||
* Day | * [[/Day_12_Coding_Challenges|Day 12 Coding Challenges]] | ||
'''Readings:''' | '''Readings:''' | ||
* [https://youtu.be/-_mjC3lAKL4 Video introducing a way to organize code and data] (from the Spring 2020 version of the class) | |||
* [https://www.youtube.com/watch?v=SWYqp7iY_Tc Git & GitHub Crash Course For Beginners] - YouTube video (not by me) introducing Git and Github | |||
* [https://learngitbranching.js.org/ Interactive git branching tutorial] | |||
* DellaPosta, D., Shi, Y., & Macy, M. (2015). [https://doi.org/10.1086/681254 Why Do Liberals Drink Lattes]? American Journal of Sociology, 120(5), 1473–1511. | * DellaPosta, D., Shi, Y., & Macy, M. (2015). [https://doi.org/10.1086/681254 Why Do Liberals Drink Lattes]? American Journal of Sociology, 120(5), 1473–1511. | ||
** Discussant: | ** Discussant: Lucy | ||
'''Agenda:''' | '''Agenda:''' | ||
* Tour of Github | * Tour of Github | ||
* [https://jeremydfoote.com/ | * [https://jeremydfoote.com/Intro-to-Programming-and-Data-Science/day_12/lecture/day_12.html Today's slides] | ||
'''Resources:''' | '''Resources:''' | ||
== Day 13: Statistical summaries and tests (June 3) == | |||
== Day 13: Statistical summaries and tests (June | |||
'''Assignment Due:''' | '''Assignment Due:''' | ||
* [[/Day_13_Coding_Challenges|Day 13 Coding Challenges]] | |||
* [[ | |||
'''Readings:''' | '''Readings:''' | ||
* [https://github.com/jdfoote/Intro-to-Programming-and-Data-Science/raw/summer2021/day_13/day_13.ipynb Day 13 Notebook] | |||
** [https://purdue.brightspace.com/d2l/le/content/306917/viewContent/6459652/View Notebook walkthrough] | |||
* Tan, C. (2018). [https://aaai.org/ocs/index.php/ICWSM/ICWSM18/paper/view/17811 Tracing community genealogy: How new communities emerge from the old]. Proceedings of the Twelfth International Conference on Web and Social Media (ICWSM ’18), 395–404. | * Tan, C. (2018). [https://aaai.org/ocs/index.php/ICWSM/ICWSM18/paper/view/17811 Tracing community genealogy: How new communities emerge from the old]. Proceedings of the Twelfth International Conference on Web and Social Media (ICWSM ’18), 395–404. | ||
** Discussant: | ** Discussant: | ||
'''Agenda:''' | '''Agenda:''' | ||
* [https:// | * [https://jeremydfoote.com/Intro-to-Programming-and-Data-Science/day_13/lecture/day_13.html Today's slides] | ||
== Day 14: Screen scraping (June | == Day 14: Screen scraping (June 4) == | ||
'''Assignment Due:''' | '''Assignment Due:''' | ||
'''Readings:''' | '''Readings:''' | ||
* Shaw, A., & Hill, B. M. (2014). [https://doi.org/10.1111/jcom.12082 Laboratories of oligarchy? How the iron law extends to peer production]. Journal of Communication, 64(2), 215–238. | * Shaw, A., & Hill, B. M. (2014). [https://doi.org/10.1111/jcom.12082 Laboratories of oligarchy? How the iron law extends to peer production]. Journal of Communication, 64(2), 215–238. | ||
** Discussant: | ** Discussant: | ||
* [https://towardsdatascience.com/ethics-in-web-scraping-b96b18136f01 Ethics in Web Scraping] by James Densmore | * [https://towardsdatascience.com/ethics-in-web-scraping-b96b18136f01 Ethics in Web Scraping] by James Densmore | ||
Line 481: | Line 451: | ||
* [https://youtu.be/daUuC-PMZc4 Very brief lecture on web scraping from Spring 2020]. | * [https://youtu.be/daUuC-PMZc4 Very brief lecture on web scraping from Spring 2020]. | ||
== Day 15-17: Work on final project (June | == Day 15-17: Work on final project (June 7-9) == | ||
'''Agenda:''' | '''Agenda:''' | ||
Line 495: | Line 465: | ||
* [https://bbengfort.github.io/snippets/2018/06/22/corenlp-nltk-parses.html Tutorial on syntax parsing in Python] (It's complicated!) | * [https://bbengfort.github.io/snippets/2018/06/22/corenlp-nltk-parses.html Tutorial on syntax parsing in Python] (It's complicated!) | ||
== Day 18: Final project presentation (June | == Day 18: Final project presentation (June 10) == | ||
'''Assignment Due:''' | '''Assignment Due:''' | ||
Line 509: | Line 479: | ||
== Day 19: Final Paper Due (June | == Day 19: Final Paper Due (June 11) == | ||
'''Assignment Due:''' | '''Assignment Due:''' | ||
* Final paper due | * Final paper due | ||
* [[ | * [[/Final_self_reflection|Final self reflection]] due | ||
= Administrative Notes = | = Administrative Notes = |
Latest revision as of 20:59, 18 August 2022
This is an old version of the course and is kept for information only. Some links may be broken or may point to content that has been updated since this course was taught
Course Information[edit]
- COM 674: Introduction to Programming and Data Science
- Location: Discord
- Class Hours: M-F, 10 am - 12 pm
Instructor[edit]
- Instructor: Jeremy Foote
- Email: jdfoote@purdue.edu
- Office Hours: By appointment; on Discord
Course Overview and Learning Objectives[edit]
This is an exciting time to be a social scientist and especially a Communication scholar! An increasing amount of our lives---and our interactions---are stored digitally. Social scientists are increasingly using that data to ask and answer questions about how the social world works. I firmly believe that computational tools have created a new frontier in the social sciences which those who develop computational skills can explore.
This class is an introduction into that world. The course is intended to give students an introduction to programming principles, the Python programming language, and data science tools and approaches. However, this is not a computer science class or a statistics class, and no prior programming experience is required or expected. We will focus on gaining access to data and basic data manipulation rather than complex statistical methods.
The main goal of the class is to help you to complete a preliminary, independent, data-centric project. As part of this project, you (on your own or in a team) will write software to collect data from web APIs, process and clean that data, and produce statistics, hypothesis tests, and graphical visualizations that address questions you are interested in.
I will consider this class a complete success if, at the end, every student can:
- Write or modify a program to collect a dataset from a publicly available data source.
- Read web API documentation and write Python software to parse and understand a new and unfamiliar web API.
- Understand and follow basic version control practices.
- Use digital data to effective answer a substantively interesting question and to present this data effectively in the context of both a formal presentation and a written report.
- Identify multiple ways that computational approaches are being used for social science research.
- Feel comfortable taking more advanced computational methods courses or learning new techniques on your own.
Required resources and texts[edit]
Laptop[edit]
Windows, Mac OS, and Linux are all fine but an iPad or Android tablet won't work. We're going to install software during the class that requires about 5GB of extra space and you'll be working on projects for homework. For the classroom assignments, nothing is terribly intensive, but your own data collection could tax the resources of an older machine.
If for some reason your laptop dies mid-course, please contact me so we can get your new one up to speed.
Readings[edit]
- Required text: Python for Everybody [HTML Version] [PDF version] by Charles R. Severance. The book is freely licensed and available online for free. You can also buy the book if you prefer a hard copy.
I will list required chapters in the schedule below. In general, you should expect to spend far more time working on programming tasks than reading. Much like math or other technical courses, this course will build on itself every day. You should make every effort to cover the reading and exercise material every day in preparation for the next day.
- Other readings: Throughout the module we will read and discuss examples of computational social science that I find particularly well done or interesting. Many are available through the Purdue library. I will also make all of them available on Brightspace. If you come across additional examples that you think the class would benefit from, please suggest them to me.
- Optional readings: Matthew Salganik's book 'Bit by Bit: Social Research in the Digital Age' is a wonderful introduction to computational social science. We will not be discussing it in class but I highly recommend it.
Course logistics[edit]
Note About This Syllabus[edit]
Although the core expectations for this class are fixed, the details of readings and assignments may shift based on how the class goes. As a result, there are three important things to keep in mind:
- Although details on this syllabus will change, I will not change readings or assignments less than three days before they are due. If you plan to read more than three days ahead, contact me first.
- Closely monitor Discord. Because this a wiki, you will be able to track every change by clicking the history button on this page. I will also summarize these changes in a announcements that will be posted in the #announcements channel on Discord.
- I will ask the class for voluntary anonymous feedback frequently. Please let me know what is working and what can be improved.
Lectures[edit]
The synchronous part of the course will be held starting at 1pm every day, on Discord. The typical format will be a discussion of the reading for the day followed by a brief lecture about the topic for that week followed by a discussion of the previous day's homework questions followed by optional co-working time to start on the next day's assignment.
I highly encourage you to attend as many of our synchronous sessions as possible. In general, my teaching style is more conversational than a formal lecture. I prefer that students feel they can "politely interrupt" at any time to seek clarification or make a well-informed point, and the lectures will be much better if I can get real-time feedback about what is and isn't making sense.
Office hours and email[edit]
- I will hold office hours by appointment. If you come with a programming question, I will expect that you have already tried to solve it yourself in multiple ways and that you have discussed it with a classmate. This policy lets me have time to help more students, but it's also a useful strategy. Often just trying to explain your code can help you to recognize where you've gone wrong.
- I am also available by email. You can reach me at jdfoote@purdue.edu. I try hard to maintain a boundary between work and home and I typically respond only on weekdays during business hours (~9-5) but during the week I will generally respond within 24 hours.
Assignments[edit]
There will be three main types of assignments. Each is discussed in detail below but here is a brief summary:
- Research Project: The main outcome of this course will be a research project exploring a social science question using Python, and the bulk of your grade will be based on that project. Submit these via Brightspace
- Coding Challenges: There will be daily programming assignments that I will ask you to turn in on Brightspace but which will only be graded as complete/incomplete. I will also randomly assign someone to present their solution to each of the problems during our synchronous sessions.
- Paper Discussion: Each day we will read and discuss a paper which uses computational approaches to address social science questions.
Research project[edit]
As a demonstration of your learning in this course, you will design and carry out a quantitative research project, start to finish. This means you will all:
- Design and describe a plan for a study — The study you design should involve quantitative analysis and should be something you can complete at least a first pass on during this module.
- Find a dataset — You should very quickly identify a dataset you will use to complete this project.
- Analyze, visualize, report, and interpret your data — You will do this in both a short paper and a short presentation.
- Ensure that your work is replicable — You will need to provide code and data for your analysis in a way that makes your work replicable by other researchers.
I strongly urge you to work on a project that will further your academic career outside of the class. There are many ways that this can happen. Some obvious options are to prepare a project that you can submit for publication, that you can use as pilot analysis that you can report in a grant or thesis proposal, and/or that fulfills a degree requirement. I prefer that you do projects on your own but it may be possible to work as a small team (maximum 3 people). Team projects are expected to be more ambitious than individual projects. Preliminary assignments will help you to develop your idea and to get feedback from me and others.
There are several intermediate milestones and deadlines to help you accomplish a successful research project. Unless otherwise noted, all deliverables should be submitted via Brightspace.
Project idea and dataset identification[edit]
- Due date
- May 19
- Maximum length
- 500 words (~1-2 pages)
Early on, I want you to identify and describe your final project. Your description should be short and can be either paragraphs or bullets. It should include the following:
- An abstract of the proposed study including the topic, research question, theoretical motivation, object(s) of study, and anticipated research contribution.
- An identification of the dataset you will use and a description of the columns or type of data it will include. If you do not currently have access to these data, explain why not and when you will have access (If you need ideas, this page from one of my undergrad classes lists some open datasets).
- A short (several sentences) description of how the project will fit into your career trajectory.
Project planning document[edit]
- Due date
- May 27
- Maximum length
- ~4-5 pages
The project planning document is a basic shell/outline of an empirical quantitative research paper. The planning document should focus around three big questions:
- Why are you planning to do this analysis? Make sure to introduce any background information about the topic, the community, your business, or anything else that will be required to properly contextualize your study.
- How will you get the data to analyze? Describe the data sources will you collect and how they will be collected.
- How will you analyze the data? Describe the visualizations, tables, or statistical tests that you will produce.
One approach that I have found helpful is outlined on this wiki page.
Project presentation and report[edit]
- Report due date
- June 11
- Maximum length
- 4000 words (~15 pages)
- Presentation due date
- June 10
- Maximum length
- 8 minutes
The project report[edit]
You will craft a Jupyter Notebook that will ideally provide the foundation for a high quality short research paper that you might revise and submit for publication. I do not expect the report to be ready for publication, but it should contain polished drafts of all the necessary components of a scholarly quantitative empirical research study. In terms of the structure, please see the page on the structure of a quantitative empirical research paper.
The great thing about a Jupyter Notebook is that it allows you to provide data, code, and any documentation sufficient to enable the replication of all analysis and visualizations. If that is not possible/appropriate for some reason, please talk to me so that we can find another solution.
Because the emphasis in this class is on methods and because I'm not an expert in each of your fields, I'm happy to assume that your paper, proposal, or thesis chapter has already established the relevance and significance of your study and has a comprehensive literature review, well-grounded conceptual approach, and compelling reason why this research is important. As a result, you need not focus on these elements of the work in your written submission. Instead, feel free to start with a brief summary of the purpose and importance of this research followed by an introduction of your research questions or hypotheses. If you provide more detail, that's fine, but I won't give you detailed feedback on these parts and they will not figure prominently in my assessment of the work.
Jupyter Notebooks do not have all of the tools for citations that Word or LaTeX or even Google Docs have, so while I expect you to cite related work it is OK if it isn't as polished as citation management software would make it.
The presentation[edit]
The presentation will provide an opportunity to share a brief summary of your project and findings with the other members of the class. 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. Since you will all give other research presentations throughout your career, I strongly encourage you to take the opportunity to refine your academic presentation skills.
I anticipate that most people will either create a PowerPoint presentation or will walk us through their Jupyter Notebook. All presentations will need to be a maximum of 8 minutes long. Concisely communicating an idea in the time allotted is an important skill in its own right. Presentations should be uploaded to the Discussion forum on Brightspace created for this purpose.
Daily Coding Challenges[edit]
Nearly every day I will give you a set of coding challenges before the end of class that will involve writing code or adding to code that I've given you. These coding challenges will be turned in on Brightspace but will not be graded. I encourage you to work together on these challenges but to make sure that you understand the concepts yourself.
Each day I will randomly select a set of students to share their solutions to a selected exercise. This will involve putting your solution on Discord at least one hour before the next day's lecture starts, and being prepared to walk us through the solution. If you can't figure out the problem that's been assigned to you, then explain where you got stuck and what you tried. I encourage you to also use Discord to ask and answer each other's questions as you work on the assignments. We will use some of our lecture time to review the problems and I will make sure that a correct solution is posted by the end of that day. As you will see over the course of the module, there are many possible solutions to many programming problems and my own approaches will often be different than yours. That's completely fine! Coding is a creative act!
Paper Discussions[edit]
Every day we will review a paper that uses computational methods. On the first day, I will ask you to sign up to lead the discussion for one of these papers. When leading the discussion, you will prepare a presentation as though you were presenting the paper at a conference and then lead a discussion about it.
Reflection papers[edit]
As discussed in more detail below, two times during the course I will ask you to respond to a set of reflection questions. These questions are intended to help you to think about what you have learned and accomplished and to craft goals for the remainder of the course. They are also an important way for me to gather feedback about how the course is going so that I can adjust.
Grades[edit]
This course will follow a "self-assessment" philosophy. I am more interested in helping you to learn things that will be useful to you than in assigning grades. The university still requires grades, so you will be leading the evaluation of your work. In week two and again at the end of the course, you will reflect on what you have accomplished thus far, how it has met, not met, or exceeded expectations, based both on rubrics and personal goals and objectives. At each of these stages you will receive feedback on your assessments. By the end of the semester, you should have a clear vision of your accomplishments and growth, which you will turn into a grade. As the instructor-of-record, I maintain the right to disagree with your assessment and alter grades as I see fit, but any time that I do this it will be accompanied by an explanation and discussion. These personal assessments, reflecting both honest and meaningful reflection of your work will be the most important factor in final grades.
I suggest that we use the following rubric in our assessment:
- 25%: class participation, including attendance, participation in discussions and group work, and significant effort towards weekly assignments.
- 5%: Final Project Idea.
- 10%: Final Project Proposal.
- 40%: Final Project paper/Jupyter notebook.
- 20%: Final Presentation including your slides and presentation.
My interpretation of grade levels (A, B, C, D/F) is the following:
A: Reflects work the exceeds expectations on multiple fronts and to a great degree. Students reaching this level of achievement will:
- Do what it takes to learn the programming principles and techniques, including looking to outside sources if necessary.
- Engage thoughtfully with an ambitious research project.
- Take intellectual risks, offering interpretations based on synthesizing material and asking for feedback from peers.
- Sharing work early allowing extra time for engagement with others.
- Write reflections that grapple meaningfully with lessons learned as well as challenges.
- Complete most, if not all programming assignments at a high level.
B: Reflects strong work. Work at this level will be of consistently high quality. Students reaching this level of achievement will:
- Be more safe or consistent than the work described above.
- Ask meaningful questions of peers and engage them in fruitful discussion.
- Exceed requirements, but in fairly straightforward ways - e.g., an additional post in discussion every week.
- Compose complete and sufficiently detailed reflections.
- Complete many of the programming assignments.
C: This reflects meeting the minimum expectations of the course. Students reaching this level of achievement will:
- Turn in and complete required assignments on time.
- Be collegial and continue discussion, through asking simple or limited questions.
- Compose reflections with straightforward and easily manageable goals and/or avoid discussions of challenges.
- Not complete programming assignments or turn some in in a hasty or incomplete manner.
D/F: These are reserved for cases in which students do not complete work or participate. Students may also be impeding the ability of others to learn.
Schedule[edit]
NOTE: This section will be modified throughout the course to meet the class's needs. Check back in often.
There are links to each day's slides. Note that these are slides from an earlier version of the class and will typically be updated the day of each class.
Day 1: Introduction to Python and Computational Thinking (May 17)[edit]
Assignment Due:
- None
Required Readings:
Agenda:
- Class overview and expectations — We'll walk through this syllabus.
- Day 1 Coding challenge - Includes installing Python and going through a number of exercises.
- Today's slides
By the end of class you will:
- Have a working python environment on your personal laptop.
- Have written your first program in the python language.
Day 2: Variables, conditionals, and functions (May 18)[edit]
Assignments Due:
- Finish Day 1 exercises and tutorials
- Fill out this short survey
- Sign up to be a discussant here
- Day 2 Coding Challenge (turn in on Brightspace)
Readings (before class):
- Bit By bit, Introduction
- Python for Everybody, chapters 1-4
- Today's Jupyter Notebook
Agenda:
- Review Day 1 and Day 2 Exercises
- Today's slides
- Introduce wordplay project
Day 3: Iteration, strings, and lists (May 19)[edit]
Assignment Due:
- Final project dataset and idea (turn in on Brightspace).
- Day 3 Coding Challenge
Readings:
- Python for Everybody
chapters_to_read = [5, 6, 8]
- Today's Jupyter Notebook
- Foote, J., Shaw, A., & Hill, B.M. (2017). Computational analysis of social media scholarship. In Burgess, J., Poell, T., Marwick, A. (Eds.), The Sage Handbook of Social Media. Sage.
- Discussant: Juan Pablo
Agenda:
- Programming principles (iteration, strings, and lists)
- Go over last day's assignment
- Today's slides
Day 4: Reading from and writing to files (May 20)[edit]
Assignment Due:
Readings:
book = open('Python for Everybody', 'r') for chapter in book: if chapter == '7': read(chapter) book.close()
- Today's Jupyter Notebook
- Nelson, Laura K. 2017. "Computational Grounded Theory: A Methodological Framework." Sociological Methods and Research.
- Discussant: Beth Ann
Agenda:
- Reading from and writing to files
- Today's slides
Day 5: Dictionaries and Tuples (May 21)[edit]
Assignment Due:
Readings:
- Python for Everybody, chapters 9 and 10
- Today's Jupyter Notebook
- Margolin, D. B., Hannak, A., & Weber, I. (2018). Political Fact-Checking on Twitter: When Do Corrections Have an Effect? Political Communication, 35(2), 196–219.
- Discussant: Katelyn
Agenda:
- Dictionaries
- Tuples
- Today's slides
Day 6: Dataframes and Visualization (May 24)[edit]
Assignment Due:
Readings:
- Day 6 notebook
- Benefield, G. A., Shen, C., & Leavitt, A. (2016). Virtual Team Networks: How Group Social Capital Affects Team Success in a Massively Multiplayer Online Game. Proceedings of the 19th ACM Conference on Computer-Supported Cooperative Work & Social Computing, 679–690.
- Discussant: Anna
Agenda:
- Dataframes and visualization
- Today's slides
Day 7: Dataframes and visualization (continued) (May 25)[edit]
Assignment Due:
Readings:
- Day 7 notebook
- Lazer, D., & Radford, J. (2017). Data ex Machina: Introduction to Big Data. Annual Review of Sociology, 43(1), 19–39.
- Discussant: Yong
Agenda:
- Visualizations in Seaborn
- Today's slides
Day 8: Collecting Data with APIs (May 26)[edit]
Assignment Due:
Readings:
- Intro to APIs Notebook
- (Long) walkthrough of notebook
- Kieran Healy and James Moody (2014). “Data Visualization in Sociology.” American Review of Sociology. 40: 105-28.
- Discussant: Pearlynne
Agenda:
- Introduce the requests library
- Discuss the main kinds of online data gathering: downloading, scraping, and APIs.
- Today's slides
Day 9: Collecting Data with APIs (continued) (May 27)[edit]
Assignment Due:
- Start on Day 9 Coding Challenges
- First self-assessment reflection is due (on Brightspace).
- Project Planning Document Due
Readings:
- Day 9 Notebook
- Python for Everybody, Chapter 13
- Vitak, J., Shilton, K., & Ashktorab, Z. (2016). Beyond the Belmont Principles: Ethical Challenges, Practices, and Beliefs in the Online Data Research Community. Proceedings of the 19th ACM Conference on Computer-Supported Cooperative Work & Social Computing, 941–953.
- Discussant: Casey Lynn
- (Optional) Williams, M. L., Burnap, P., & Sloan, L. (2017). Towards an Ethical Framework for Publishing Twitter Data in Social Research: Taking into Account Users’ Views, Online Context and Algorithmic Estimation: Sociology.
- (Optional) Salganik, M. Ethics chapter from Bit By Bit.
- (Optional) Crawford, K., & Finn, M. (2015). The limits of crisis data: Analytical and ethical challenges of using social and mobile data to understand disasters. GeoJournal, 80(4), 491–502.
Agenda:
- A workflow for doing work with APIs
- Ethics of digital trace data
- Today's slides
Day 10: Introduction to Computational Text Analysis (May 28)[edit]
Assignment Due:
Readings:
- Today's Notebook
- Christopher A. Bail et al. 2018. Exposure to opposing views on social media can increase political polarization. PNAS 115(37): 9216-9221
- Discussant: Caitlyn
Agenda:
Resources:
Day 11: Data cleaning and operationalization (June 1)[edit]
Assignment Due:
Readings:
- Today's Notebook
- Robert K. Merton. 1948. The Bearing of Empirical Research Upon the Development of Social Theory. American Sociological Review 13(5): 505-515.
- Sara Klingenstein, Tim Hitchcock, and Simon DeDeo. 2014. The civilizing process in London’s Old Baily. Proceedings of the National Academy of Sciences 111(26): 9419-9424.
- Discussant: Jeremy
Resources:
Day 12: Organizing and storing computational projects (June 2)[edit]
Assignment Due:
Readings:
- Video introducing a way to organize code and data (from the Spring 2020 version of the class)
- Git & GitHub Crash Course For Beginners - YouTube video (not by me) introducing Git and Github
- Interactive git branching tutorial
- DellaPosta, D., Shi, Y., & Macy, M. (2015). Why Do Liberals Drink Lattes? American Journal of Sociology, 120(5), 1473–1511.
- Discussant: Lucy
Agenda:
- Tour of Github
- Today's slides
Resources:
Day 13: Statistical summaries and tests (June 3)[edit]
Assignment Due:
Readings:
- Day 13 Notebook
- Tan, C. (2018). Tracing community genealogy: How new communities emerge from the old. Proceedings of the Twelfth International Conference on Web and Social Media (ICWSM ’18), 395–404.
- Discussant:
Agenda:
Day 14: Screen scraping (June 4)[edit]
Assignment Due:
Readings:
- Shaw, A., & Hill, B. M. (2014). Laboratories of oligarchy? How the iron law extends to peer production. Journal of Communication, 64(2), 215–238.
- Discussant:
- Ethics in Web Scraping by James Densmore
Agenda:
- If you are interested in doing web scraping, then look at this incredible mini-course on the topic. It is all done with Jupyter Notebooks and you have all of the prerequisite knowledge to understand it.
- Very brief lecture on web scraping from Spring 2020.
Day 15-17: Work on final project (June 7-9)[edit]
Agenda:
- I will be available to answer questions and provide help
Additional Resources:
- Regular Expressions
- List Comprehensions
- Network Analysis
- Getting data from Reddit
- Classes and Object-oriented programming (This is a set of videos)
- Tutorial on syntax parsing in Python (It's complicated!)
Day 18: Final project presentation (June 10)[edit]
Assignment Due:
- Final project presentations
- Prepare a presentation and post it on Brightspace
Readings:
- NONE
Agenda:
- We will listen to and respond to each other's projects
Day 19: Final Paper Due (June 11)[edit]
Assignment Due:
- Final paper due
- Final self reflection due
Administrative Notes[edit]
Attendance Policy[edit]
Attendance is very important and it will be difficult to make up for any classes that are missed. It is expected that students communicate well in advance to faculty so that arrangements can be made for making up the work that was missed. It is the your responsibility to seek out support from classmates for notes, handouts, and other information.
Incomplete[edit]
A grade of incomplete (I) will be given only in unusual circumstances. The request must describe the circumstances, along with a proposed timeline for completing the course work. Submitting a request does not ensure that an incomplete grade will be granted. If granted, you will be required to fill out and sign an “Incomplete Contract” form that will be turned in with the course grades. Any requests made after the course is completed will not be considered for an incomplete grade.
Academic Integrity[edit]
While I encourage collaboration, I expect that any work that you submit is your own. Basic guidelines for Purdue students are outlined here but I expect you to be exemplary members of the academic community. Please get in touch if you have any questions or concerns.
Nondiscrimination[edit]
I strongly support Purdue's policy of nondiscrimination (below). If you feel like any member of our classroom--including me--is not living up to these principles, then please come and talk to me about it.
Purdue University is committed to maintaining a community which recognizes and values the inherent worth and dignity of every person; fosters tolerance, sensitivity, understanding, and mutual respect among its members; and encourages each individual to strive to reach his or her own potential. In pursuit of its goal of academic excellence, the University seeks to develop and nurture diversity. The University believes that diversity among its many members strengthens the institution, stimulates creativity, promotes the exchange of ideas, and enriches campus life.
Students with Disabilities[edit]
Purdue University strives to make learning experiences as accessible as possible. If you anticipate or experience physical or academic barriers based on disability, you are welcome to let me know so that we can discuss options. You are also encouraged to contact the Disability Resource Center at: drc@purdue.edu or by phone: 765-494-1247.
Emergency Preparation[edit]
In the event of a major campus emergency, I will update the requirements and deadlines as needed.
Mental Health[edit]
If you or someone you know is feeling overwhelmed, depressed, and/or in need of mental health support, services are available. For help, such individuals should contact Counseling and Psychological Services (CAPS) at 765-494-6995 during and after hours, on weekends and holidays, or by going to the CAPS office of the second floor of the Purdue University Student Health Center (PUSH) during business hours.
Acknowledgements[edit]
This course is heavily based on earlier courses taught by Tommy Guy and Mako Hill at the University of Washington as well as a course taught by Laura Nelson at Northeastern University.