Computational Thinking at school / CompuT

Erasmus plus KA201, Exchange of best practices

Title: CompuT «Computational Thinking at school»

Project code: 2019-1-EL01-KA201-062883

Join our mailing list here

Email erasmus@dide.dod.sch.gr

Summary

The project “Computational Thinking at School” aims to introduce computational thinking and its implications in pedagogies in the educational field. The high impact of Computer Science in science, economy and society has increased the dialogue about the role of Computational Thinking in education. Computer Science is currently considered the fourth great scientific domain along with the traditional Physical, Life and Social Sciences (Rosenbloom, 2004). Wing in 2006 recognized Computational Thinking as a fundamental competency that all literate citizens should develop through compulsory education, to complement the three other core skills, that is, reading, writing and mathematics. (περισσότερα…)

LTTA 2 Meeting Agenda Lisbon, 15-19 NOV 2021

C2. Meeting Agenda Lisbon, 15-19 NOV 2021

LTTA 2 Meeting in Lisbon, 15-19 NOV 2021

Press Release – C2. Meeting in Lisbon, 15-19 NOV 2021

BBC Evaluating solutions test

Visit BBC site to take the test Evaluating solutions test

More tests on Computational Thinking by BBC 

eTwinning / Future Classroom Lab

Students were asked to vote which learning zone they liked in Furure Classroom Lab

et11

Students were asked to express their ideas for Furure Classroom Lab

et12

Link at eTwinning

More eTwinning activities under tag eTwinning

eTwinning/ Code of conduct

Students studied eTwinning code of conduct and completed two activities

  1. vote
  2. express their opinion

et8 et9et10

Link at eTwinning 

More eTwinning activities under tag eTwinning

Computational Thinking Skills

Computational Thinking Skills

dc

Full article here DigitalCareers_CTIAWorksheets_CTdefinitions

Source https://digitalcareers.csiro.au

etwinning /Digital app

Students were asked  “What is your favourite digital application”

Here are the results

et2

Link at eTwinning

More eTwinning activities under tag eTwinning

BBC Evaluation of a solution

How do we evaluate our solution?

There are several ways to evaluate solutions. To be certain that the solution is correct, it is important to ask:

  • does the solution make sense?

Do you now fully understand how to solve the problem? If you still don’t clearly know how to do something to solve our problem, go back and make sure everything has been properly decomposed. Once you know how to do everything, then our problem is thoroughly decomposed.

  • does the solution cover all parts of the problem?

For example, if drawing a cat, does the solution describe everything needed to draw a cat, not just eyes, a tail and fur? If not, go back and keeping adding steps to the solution until it is complete.

  • does the solution ask for tasks to be repeated?

If so, is there a way to reduce repetition? Go back and remove unnecessary repetition until the solution is efficient.

Once you’re happy with a solution, ask a friend to look through it. A fresh eye is often good for spotting errors.

Dry runs

One of the best ways to test a solution is to perform what’s known as a ‘dry run’. With pen and paper, work through the algorithm and trace a path through it.

For example, in Algorithms, a simple algorith was created to ask someone their name and age, and to make a comment based on these. You could try out this algorithm – give it a dry run. Try two ages, 15 and 75. When using age 75, where does the algorithm go? Does it give the right output? If you use age 15, does it take you down a different path? Does it still give the correct output?

If the dry run doesn’t give the right answer, there is something wrong that needs fixing. Recording the path through the algorithm will help show where the error occurs.

Dry runs are also used with completed programs. Programmers use dry runs to help find errors in their program code.

BBC Problems with solutions

Solutions that are not properly decomposed

If computational thinking techniques are applied to the problem of how to bake a cake, on decomposing the problem, it is necessary to know:

  • what kind of cake to bake
  • what ingredients are needed, how much of each ingredient, and when to add it
  • how many people the cake is for
  • how long to bake the cake for
  • what equipment is needed

A diagram of a further decomposition of ingredients would look like this:

bbc eval 1

 

At the moment, a diagram of the further decomposition of equipment would look like this:

bbc eq

The ‘Equipment’ part is not properly broken down (or decomposed). Therefore, if the solution – or algorithm – were created from this, baking the cake would run into problems. The algorithm would say what equipment is needed, but not how to use it, so a person could end up trying to use a knife to measure out the flour and a whisk to cut a lump of butter, for example. This would be wrong and would, of course, not work.

bbc eval 2

Ideally, then, ‘Equipment’ should be decomposed further, to state which equipment is needed and which ingredients each item is used with.

The problem occurred here because the problem of which equipment to use and which ingredients to use it with hadn’t been fully decomposed.

Solutions that are incomplete

If computational thinking techniques are applied to the problem of how to bake a cake, on decomposing the problem, it is necessary to know:

  • what kind of cake to bake
  • what ingredients are needed, how much of each ingredient, and when to add it
  • how many people the cake is for
  • how long to bake the cake for
  • what equipment is needed

However, this is incomplete – part of the problem has been left out. We still need to know:

  • where to bake the cake
  • what temperature to bake the cake at

Therefore, if this information was used to create the solution, the algorithm would say how long the cake should be baked for but it would not state that the cake should be placed in the oven, or the temperature that the oven should be. Even if the cake made it to the oven, it could end up undercooked or burnt to a cinder.

Very important factors have been left out, so the chances of making a great cake are slim.

The problem occurred here because placing the cake in the oven and specifying the oven temperature had not been included, making the solution incomplete.

Solutions that are inefficient

If computational thinking techniques are applied to the problem of how to bake a cake, on decomposing the problem, the solution would state – among other things – that certain quantities of particular ingredients are needed to make the cake.For the first ingredient, it might tell us to go the cupboard, get the ingredient, and bring it back to the table. For the second – and all other ingredients – it might tell us to do the same.If the cake had three ingredients, that would mean three trips to the cupboard. While the program would work like this, it would be unnecessarily long and complicated:

bbc eval 3

It would be more efficient to fetch all the ingredients in one go, and the program would be shorter as a result:

bbc eval 4

The solution is now simpler and more efficient, and has reduced from nine steps to five.

The problem occurred here because some steps were repeated unnecessarily, making the solution inefficient and overly long.

Solutions that do not meet the original design criteria

Solutions should be evaluated against the original specification or design criteria where possible. This makes sure that the solution has not strayed too much from what was originally required, that it solves the original problem and that it is suitable for users.Imagine having to apply computational thinking to the problem of how to bake a cake. On decomposing the problem, it is necessary to know:

  • what kind of cake to bake
  • what ingredients are needed, how much of each ingredient, and when to add it
  • how many people the cake is for
  • how long to bake the cake for
  • what equipment is needed

The first point considers what kind of cake to bake. Often, when devising solutions to problems, a specification for the design is given. For example, the cake may have to be a chocolate cake, which is still quite general, or a chocolate fudge cake with chocolate icing and flakes on top, which is more specific.

To meet the design criteria, it is important to ensure that the exactly right kind of cake is baked. Otherwise the solution may not be fit for purpose.

The problem occurred here because the solution did not meet the original design criteria – it was not exactly what was requested.

Αλλαγή μεγέθους γραμματοσειράς
Αντίθεση