Skip to content

Latest commit

 

History

History
303 lines (193 loc) · 6.06 KB

chapter2_r.md

File metadata and controls

303 lines (193 loc) · 6.06 KB
theme _class paginate backgroundColor footer marp
gaia
lead
true
Computational Thinking and Social Science | :copyright: Matti Nelimarkka | 2023 | Sage Publishing
true
<style> footer { font-size: small; } </style>

bg left:40% 80%

Chapter 2

Computational Thinking, Algorithms, and Writing Code


Learning goals

  • Understand the role of computational thinking and algorithms in solving social science problems through computation
  • Develop computational thinking skills connected with variables, repetition, and conditions
  • Know how to use variables, repetition, and conditions
  • Know how to read data from files using
  • Know how to use logical expressions to control the flow of programming
  • Recognise programming patterns that can be used in programming

What is programming?

width:30cm

Programming is all about transforming the problem into an algorithm and then turning the algorithm into a computer-understandable formulation.


What is programming?

width:30cm

  1. Computational thinking: Reformulating the problem as an algorithm (the cognitive component of programming)
  2. Programming: Reformulating the algorithm into an executable program (the technical component of programming)

What is programming?

width:30cm

  1. Running the program executes the algorithm and produces results
  2. Results solve the initial problem

Programming: An Example

A problem: Calculate a person’s age using a computer program.

An algorithm:

  1. Print out the person’s name
  2. Calculate the person’s age. Person's age is their dead year subtract by their birth year
  3. Print out the calculated age

Programming: An Example

A Problem: How old was Caligula, the third emperor of ancient Rome? Caligula was born in 12 AD and died in 41 AD.

An algorithm:

  1. Print out ‘Caligula’
  2. Calculate what is 41−12
  3. Print the outcome of the calculation

Programming: An Example

Code is just a text written in a specified syntax.

width:10cm


Programming: An Example

Code is just a text written in a specified syntax.

print("Caligula")
print(41-12)

Learning activity

  • Discuss the code editor you are using
  • Demonstrate Code Example with chosen IDE
  • Ask students to print their own name and age (Exercise 2.10)

Programming: Variables

A variable is a box that has both a label (its name) and some content that gets stored (the value).

Problem: Emperor Caligula reigned from 37 to 41 AD. What proportion of his life was this?


Programming: Variables

An algorithm:

  1. compute the difference between 41 and 12 (how long he lived)
  2. compute the difference between 41 and 37 (the years he was in power)
  3. divide the number of years of his reign by how many years he lived

We need to store results 1 and 2 to memory so we can later access them.


Programming: Variables

We created variables with names 1️⃣ and 2️⃣ to allow us storing them into memory.

1️⃣ = 41-12 2️⃣ = 41-37

Proportion of life as emperor: 2️⃣ ÷ 1️⃣


Programming: Variables

width:10cm


Programming: Variables

year_of_birth <- 12
year_of_death <- 41
age <- year_of_death - year_of_birth

start_of_reign = 37
end_of_reign = 41
reign = end_of_reign - start_of_reign

print("Caligula")
print( reign / age )

Variable types

  • Variables have types: they can be text, numbers etc.
  • We cannot mix apples and oranges
  • What is “five"+5?
var1 <- "5"
var2 <- 5
var1_as_number <- as.numeric( var1 )
print( var1_as_number + var2 )

Learning activity

  • Do exercises 2.8 and 2.9

Doing the same thing again and again

for loop may be used to repeat commands.

width:10cm


Doing the same thing again and again

for loop may be used to repeat commands.

sum <- 0

for( current_number in 1:10) {
  print( paste("Adding", current_number ) )
  sum <- sum + current_number
}

print( paste("The sum is", sum) )

Reading files

bg left:40% 80%

  • Files are read line-by-line, repating the same commands for each line.
  • An iterator is a variable that changes its value after each loop.
data <- read.csv("emperors.txt", header = F)
for( i in 1:nrow(data) ){
  name <- data[i,1]
  birth_year <- data[i,2]
  death_year <- data[i,3]
  start_of_reign <- data[i,4]
  end_of_reign <- data[i,5]
}

Learning activity

  • Do Exercise 2.14
  • Homework assignments: 2.15-2.16

Controlling the execution order

bg left:40% 80%

  • We want to branch the code based on a condition
  • If the condition is truewe do something, if it is falsewe do something else (or do nothing)
  • This is known as if-structure

Programming: If

Problem: Study only emperors who reigned for more than 10 years?

An algorithm:

  1. calculate the length of the emperor’s reign
  2. check whether the reign length is greater than 10 years
    • if it is, then print the details of that emperor (condition is true)
    • if it is not, then do nothing (condition is false)

Programming: If

width:20cm


Programming: If

reign <- end_of_reign - start_of_reign

if( reign > 10 ) {
  print( name )
}

Design patterns and variables' roles

  • The most-wanted holder
  • The gatherer
  • The flag
  • The follower

Learning activity

  • In-class: Do Exercise 2.18
  • In-class: What purposes do each of the four design patterns serve?
  • Homework: Do Exercise 2.19, 2.20, 2.24

Review questions

  1. Why are variables important in programming?
  2. What purposes does a for loop serve?
  3. What purposes does an if structure serve?
  4. What types of logical expressions are there?
  5. Can you sketch out a visual program for the most-wanted holder, gatherer, flag, and follower patterns?