Recent years have seen the integration of computer science, mathematicsa and statistics, together with real-world domain knowledge, into a new research and applications field: data science.4 Just as data science integrates knowledge and skills from computer science, statistics, and a real-world application domain, data thinking, we propose, integrates computational thinking, statistical thinking, and domain thinking.
Computational thinking was first introduced by Papert13 and, a quarter of a century later, was illuminated and elaborated on by Wing.15 As it turns out, exploring the novelty of data thinking uncovers new facets of computational thinking.
In this Viewpoint, we first present our interpretation of the concept of data thinking and then, based on insights gained from the discussion about data thinking, we propose a timely need has emerged to introduce data thinking into computer science education along with computational thinking, in the context of various real-world domains using real-life data.
Data Thinking
Computational thinking is commonly defined as a set of cognitive and social skills that are applied in problem-solving processes. The discussion about computational thinking was reopened by Wing in 2006 and the term has since been interpreted through different prisms as a collection of various skills required for problem solving. Some of these common skills are problem formulation, problem decomposition, organization and logical analysis of data, data representation using models and simulations, abstraction, suggestion and assessment of multiple solutions to a given problem, implementation of the chosen solution, and generalization. Computational thinking deals with cognitive skills and can, therefore, be implemented independent of technology. Like other educators (for example, Yadav et al.17), however, we propose computational thinking must be viewed in the context of up-to-date technologies. Another essential aspect is that acquiring and applying computational thinking skills are not limited to the context of computer science; rather, can and should be applied in various contexts.9,16
The term statistical thinking was coined by Deming7 and developed by Moore.11 It has since received a great deal of attention and discussion within the statistics education community, and voices have emerged, calling for statistical thinking for all.14 Statistical thinking is associated with understanding the essence, characteristics, and variability of real-life data and its importance for solving real-life problems is.6 According to Ben-Zvi and Garfield,3 statistical thinking “involves an understanding of why and how statistical investigations are conducted and the ‘big ideas’ that underlie statistical investigations.” Statistical thinking includes: the understanding that variation exists in any data source and that real-life data contains outliers, errors, biases, and variance; when and how to use specific statistical data analysis methods; the nature of sampling and how to infer from samples to populations; statistical models and their usage; the context of a given problem when performing investigations and drawing conclusions; the entire process of statistical inquiry; and the relevance of critique and evaluation of inquiry results.3
Data thinking integrates computational thinking, statistical thinking, and domain thinking.
Examining the data science thinking skills in relation to the disciplines that make up data science, we suggest each discipline contributes its unique thinking skills: computer science brings computational thinking, statistics brings statistical thinking, with each domain bringing the thinking skills rooted in the said domain of knowledge as well. Accordingly, our interpretation of data thinking integrates computational thinking, statistical thinking, and domain thinking (see the accompanying figure). Specifically,b data thinking is the understanding a solution to a real-life problem should not be based only on data and algorithms, but also on the domain knowledge-driven rules that govern them. Data thinking asks whether the data offers a good representation of the real-life situation. It also addresses how data was collected and asks, “Can the data collection be improved?”. It is the understanding data is not just numbers to be stored in an adequate data structure, but these numbers have a meaning that derives from the domain knowledge. Data thinking is understanding any process or calculation performed on the data should preserve the meaning of the relevant knowledge domain. It analyzes the data not only logically but also statistically, using visualizations and statistical methods to find patterns as well as irregular phenomena. Data thinking is understanding that problem abstraction is domain-dependent, and generalization is subject to biases and variance in the data. It is understanding lab testing is not enough, and real-life implementation will always encounter unexpected data and situations, and so improving the models and the solution for a given problem is a continuous process that includes, among other activities, constant and iterative monitoring and data collection.
Figure. Data Science and Data Thinking: a) Data science integrates computer science, mathematics, and statistics, as well as a real-world domain. b) Data thinking integrates computational thinking, statistical thinking, and domain thinking.
To illustrate our claims regarding the added value of data thinking for problem-solving processes that stem from its combination of computational thinking, statistical thinking, and domain thinking, we present an example from our own domain: education. Consider the problem of the dropout rate in higher education. From a computational thinking perspective, a model may be suggested that monitors and checks students’ progress, from their entrance into higher-education institutes, through all possible study curricula, to their graduation. We can also consider additional aspects, such as the students’ attributes before embarking on higher education. By adding such considerations, we can predict their success and accept only those students with the highest probability of graduating. Such research is indeed being carried out using machine learning to predict student success (see Alyahyan and Düştegör1). But this solution may be biased: by adding statistical thinking, we can question whether the available data is indeed the best for this task. Using current student data, we in fact intensify biases of the existing admission system12 by overlooking those applicants who were not accepted, and their potential for success is, therefore, not measured. Building on our domain knowledge of education, we suggest that other factors influencing success, such as motivation, should be added to the prediction model. Thus, using domain knowledge, we can further improve our computational and statistical models. In conclusion, we generate the prediction model based on computational thinking, statistical thinking, and domain thinking, that is, based on data thinking.
Revisiting Computational Thinking in the Era of Data Science
While computer science and statistics are a discipline of their own, data science integrates domain knowledge and thinking with computational thinking and statistical thinking. We argue that such a connection between computational thinking and domain thinking can be beneficial not only in the context of data science but also in the context of computer science and in the context of the domain itself. We emphasize the two sides of this coin: the potential contribution of computational thinking to domain understanding and the potential contribution of domain knowledge to computational thinking. Due to space limitations, we will not elaborate here on the mutual connections between statistical thinking and computational thinking.
Computational thinking with data can improve the understanding of domain knowledge. The two aspects borrowed from data thinking—real domain knowledge and real-life data—are relevant in order to illustrate the mutual contribution of computational thinking and domain thinking. First, many real-life processes can be interpreted as algorithms for which computational thinking is required. For example, the attachment of a virus to a cell and its reproduction using the cell’s bio-factory can be described as an algorithm as can the spread of a pandemic. Second, nowadays, we learn new domain knowledge using big data, which is collected in vast volumes, variability, and velocity. Interpreting big data, which is too vast for the human mind to grasp, requires computational thinking skills. For example, abstraction is required in order to analyze the relationship between a problem and the data collected to solve, with the objective of extracting valuable information from the vast collection of available data.
Real-life data should be used for incorporating data thinking into learning environments that aim to develop computational thinking.
Domain thinking can improve computational thinking. In order to integrate data thinking and, specifically, domain knowledge into a learning environment that aims to develop computational thinking, real-life data should be used. While some initiatives to teach computer science in a real-world context exist,2,5 this is the exception, and “traditional introductory programming courses often take their examples and assignments from the domains of puzzles, games, and abstract mathematics. For instance, students might be shown how to reverse a list or assigned to compute the Fibonacci sequence.”2 A recent comprehensive literature review on computer science introductory courses revealed this assertion still holds true.10 One may claim teaching computational thinking with real data using domain knowledge might introduce a high cognitive load. We suggest, however, that adding domain knowledge can increase the problem’s relevance and introduce a different kind of complexity that exists in real life.
Conclusion
With the increasing acknowledgment of the importance of understanding data, we suggest all people living in the 21st century should acquire data thinking skills in addition to computational thinking skills. In practice, we argue that just as computational thinking is currently being acknowledged and taught beyond the scope of computer science education, so should data thinking be taught beyond the scope of data science education. Specifically, we suggest the use of data thinking in the context of computer science education is not only relevant but also vital. Among the many implementations that arise from this claim, we highlight the relevance of working with real data in computer science education.
Join the Discussion (0)
Become a Member or Sign In to Post a Comment