Computer Science Principles Curriculum Framework

 

Searchable & Printable Formats

This resource originally created by Baker Franke for the 2016 CS-Principles curriculum framework and re-implemented by John Meinzen.

P1: Connecting Computing

P2: Creating Computational Artifacts

P3: Abstracting

P4: Analyzing Problems and Artifacts

P5: Communicating

P6: Collaborating

Keyword Search : type keywords you want to search for (separate by space, comma, or line).

 

Line Count:

Big Idea 1 : Creativity

EU 1.1 Creative development can be an essential process for creating computational artifacts.

  • LO 1.1.1 Apply a creative development process when creating computational artifacts. [P2]

  • EK 1.1.1A A creative process in the development of a computational artifact can include, but is not limited to, employing nontraditional, nonprescribed techniques; the use of novel combinations of artifacts, tools, and techniques; and the exploration of personal curiosities.

  • EK 1.1.1B Creating computational artifacts employs an iterative and often exploratory process to translate ideas into tangible form.

 

EU 1.2 Computing enables people to use creative development processes to create computational artifacts for creative expression or to solve a problem.

  • LO 1.2.1 Create a computational artifact for creative expression. [P2]

  • EK 1.2.1A A computational artifact is something created by a human using a computer and can be, but is not limited to, a program, an image, audio, video, a presentation, or a Web page file.

  • EK 1.2.1B Creating computational artifacts requires understanding of and use of software tools and services.

  • EK 1.2.1C Computing tools and techniques are used to create computational artifacts and can include, but are not limited to, programming integrated development environments (IDEs), spreadsheets, 3D printers, or text editors.

  • EK 1.2.1D A creatively developed computational artifact can be created by using nontraditional, nonprescribed computing techniques.

  • EK 1.2.1E Creative expressions in a computational artifact can reflect personal expressions of ideas or interests.

 
  • LO 1.2.2 Create a computational artifact using computing tools and techniques to solve a problem. [P2]

  • EK 1.2.2A Computing tools and techniques can enhance the process of finding a solution to a problem.

  • EK 1.2.2B A creative development process for creating computational artifacts can be used to solve problems when traditional or prescribed computing techniques are not effective.

 
  • LO 1.2.3 Create a new computational artifact by combining or modifying existing artifacts. [P2] 

  • EK 1.2.3A Creating computational artifacts can be done by combining and modifying existing artifacts or by creating new artifacts.

  • EK 1.2.3B Computation facilitates the creation and modification of computational artifacts with enhanced detail and precision.

  • EK 1.2.3C Combining or modifying existing artifacts can show personal expression of ideas.

 
  • LO 1.2.4 Collaborate in the creation of computational artifacts. [P6]

  • EK 1.2.4A A collaboratively created computational artifact reflects effort by more than one person.

  • EK 1.2.4B Effective collaborative teams consider the use of online collaborative tools.

  • EK 1.2.4C Effective collaborative teams practice interpersonal communication, consensus building, conflict resolution, and negotiation.

  • EK 1.2.4D Effective collaboration strategies enhance performance.

  • EK 1.2.4E Collaboration facilitates the application of multiple perspectives (including sociocultural perspectives) and diverse talents and skills in developing computational artifacts.

  • EK 1.2.4F A collaboratively created computational artifact can reflect personal expressions of ideas. 

 
  • LO 1.2.5 Analyze the correctness, usability, functionality, and suitability of computational artifacts. [P4]

  • EK 1.2.5A The context in which an artifact is used determines the correctness, usability, functionality, and suitability of the artifact.

  • EK 1.2.5B A computational artifact may have weaknesses, mistakes, or errors depending on the type of artifact.

  • EK 1.2.5C The functionality of a computational artifact may be related to how it is used or perceived.

  • EK 1.2.5D The suitability (or appropriateness) of a computational artifact may be related to how it is used or perceived.

 

EU 1.3 Computing can extend traditional forms of human expression and experience.

  • LO 1.3.1 Use computing tools and techniques for creative expression. [P2]

  • EK 1.3.1A Creating digital effects, images, audio, video, and animations has transformed industries.

  • EK 1.3.1B Digital audio and music can be created by synthesizing sounds, sampling existing audio and music, and recording and manipulating sounds, including layering and looping.

  • EK 1.3.1C Digital images can be created by generating pixel patterns, manipulating existing digital images, or combining images.

  • EK 1.3.1D Digital effects and animations can be created by using existing software or modified software that includes functionality to implement the effects and animations.

  • EK 1.3.1E Computing enables creative exploration of both real and virtual phenomena.

 

Big Idea 2: Abstraction

EU 2.1 A variety of abstractions built upon binary sequences can be used to represent all digital data.

  • LO 2.1.1 Describe the variety of abstractions used to represent data. [P3]

     

     

     

  • EK 2.1.1A Digital data is represented by abstractions at different levels.

  • EK 2.1.1B At the lowest level, all digital data are represented by bits.

  • EK 2.1.1C At a higher level, bits are grouped to represent abstractions, including but not limited to numbers, characters, and color.

  • EK 2.1.1D Number bases, including binary, decimal, and hexadecimal, are used to represent and investigate digital data.

  • EK 2.1.1E At one of the lowest levels of abstraction, digital data is represented in binary (base 2) using only combinations of the digits zero and one.

    EXCLUSION STATEMENT (for EK 2.1.1E): Two’s complement conversions are beyond the scope of this course and the AP Exam.

  • EK 2.1.1F Hexadecimal (base 16) is used to represent digital data because hexadecimal representation uses fewer digits than binary.

  • EK 2.1.1G Numbers can be converted from any base to any other base.

 
  • LO 2.1.2 Explain how binary sequences are used to represent digital data. [P5]

  • EK 2.1.2A A finite representation is used to model the infinite mathematical concept of a number.

    EXCLUSION STATEMENT (for EK 2.1.2A): Binary representations of scientific notation are beyond the scope of this course and the AP Exam.

  • EK 2.1.2B In many programming languages, the fixed number of bits used to represent characters or integers limits the range of integer values and mathematical operations; this limitation can result in overflow or other errors.

    EXCLUSION STATEMENT (for EK 2.1.2B): Range limitations of any one language, compiler, or architecture are beyond the scope of this course and the AP Exam.

  • EK 2.1.2C In many programming languages, the fixed number of bits used to represent real numbers (as floating-point numbers) limits the range of floating-point values and mathematical operations; this limitation can result in round off and other errors.

  • EK 2.1.2D The interpretation of a binary sequence depends on how it is used.

  • EK 2.1.2E A sequence of bits may represent instructions or data.

  • EK 2.1.2F A sequence of bits may represent different types of data in different contexts.

 

EU 2.2 Multiple levels of abstraction are used to write programs or create other computational artifacts

  • LO 2.2.1 Develop an abstraction when writing a program or creating other computational artifacts. [P2]

     

  • EK 2.2.1A The process of developing an abstraction involves removing detail and generalizing functionality.

  • EK 2.2.1B An abstraction extracts common features from specific examples in order to generalize concepts.

  • EK 2.2.1C An abstraction generalizes functionality with input parameters that allow software reuse.

    EXCLUSION STATEMENT (for EK 2.2.1C): An understanding of the difference between value and reference parameters is beyond the scope of this course and the AP Exam

 
  • LO 2.2.2 Use multiple levels of abstraction to write programs. [P3]

     

  • EK 2.2.2A Software is developed using multiple levels of abstractions, such as constants, expressions, statements, procedures, and libraries.

  • EK 2.2.2B Being aware of and using multiple levels of abstraction in developing programs helps to more effectively apply available resources and tools to solve problems.

 
  • LO 2.2.3 Identify multiple levels of abstractions that are used when writing programs. [P3]

  • EK 2.2.3A Different programming languages offer different levels of abstraction.

    EXCLUSION STATEMENT (for EK 2.2.3A): Knowledge of the abstraction capabilities of all programming languages is beyond the scope of this course and the AP Exam.

  • EK 2.2.3B High-level programming languages provide more abstractions for the programmer and make it easier for people to read and write a program.

  • EK 2.2.3C Code in a programming language is often translated into code in another (lower level) language to be executed on a computer.

  • EK 2.2.3D In an abstraction hierarchy, higher levels of abstraction (the most general concepts) would be placed toward the top and lower level abstractions (the more specific concepts) toward the bottom.

  • EK 2.2.3E Binary data is processed by physical layers of computing hardware, including gates, chips, and components.

  • EK 2.2.3F A logic gate is a hardware abstraction that is modeled by a Boolean function.

    EXCLUSION STATEMENT (for EK 2.2.3F): Memorization of specific gate visual representations is beyond the scope of this course and the AP Exam.

  • EK 2.2.3G A chip is an abstraction composed of low-level components and circuits that perform a specific function.

  • EK 2.2.3H A hardware component can be low level like a transistor or high level like a video card.

  • EK 2.2.3I Hardware is built using multiple levels of abstractions, such as transistors, logic gates, chips, memory, motherboards, special purpose cards, and storage devices.

  • EK 2.2.3J Applications and systems are designed, developed, and analyzed using levels of hardware, software, and conceptual abstractions.

  • EK 2.2.3K Lower level abstractions can be combined to make higher level abstractions, such as short message services (SMS) or email messages, images, audio files, and videos.

 

EU 2.3 Models and simulations use abstraction to generate new understanding and knowledge.

  • LO 2.3.1 Use models and simulations to represent phenomena. [P3]

 

  • EK 2.3.1A Models and simulations are simplified representations of more complex objects or phenomena.

  • EK 2.3.1B Models may use different abstractions or levels of abstraction depending on the objects or phenomena being posed.

  • EK 2.3.1C Models often omit unnecessary features of the objects or phenomena that are being modeled.

  • EK 2.3.1D Simulations mimic real-world events without the cost or danger of building and testing the phenomena in the real world.

 
  • LO 2.3.2 Use models and simulations to formulate, refine, and test hypotheses. [P3]

 

  • EK 2.3.2A Models and simulations facilitate the formulation and refinement of hypotheses related to the objects or phenomena under consideration.

  • EK 2.3.2B Hypotheses are formulated to explain the objects or phenomena being modeled.

  • EK 2.3.2C Hypotheses are refined by examining the insights that models and simulations provide into the objects or phenomena.

  • EK 2.3.2D The results of simulations may generate new knowledge and new hypotheses related to the phenomena being modeled.

  • EK 2.3.2E Simulations allow hypotheses to be tested without the constraints of the real world.

  • EK 2.3.2F Simulations can facilitate extensive and rapid testing of models.

  • EK 2.3.2G The time required for simulations is impacted by the level of detail and quality of the models and the software and hardware used for the simulation.

  • EK 2.3.2H Rapid and extensive testing allows models to be changed to accurately reflect the objects or phenomena being modeled

 

 

Big Idea 3: Data and Information

EU 3.1 People use computer programs to process information to gain insight and knowledge.

  • LO 3.1.1 Find patterns and test hypotheses about digitally processed information to gain insight and knowledge. [P4]

  • EK 3.1.1A Computers are used in an iterative and interactive way when processing digital information to gain insight and knowledge.

  • EK 3.1.1B Digital information can be filtered and cleaned by using computers to process information.

  • EK 3.1.1C Combining data sources, clustering data, and data classification are part of the process of using computers to process information.

  • EK 3.1.1D Insight and knowledge can be obtained from translating and transforming digitally represented information.

  • EK 3.1.1E Patterns can emerge when data is transformed using computational tools.

 
  • LO 3.1.2 Collaborate when processing information to gain insight and knowledge. [P6] 

  • EK 3.1.2A Collaboration is an important part of solving data-driven problems.

  • EK 3.1.2B Collaboration facilitates solving computational problems by applying multiple perspectives, experiences, and skill sets.

  • EK 3.1.2C Communication between participants working on data-driven problems gives rise to enhanced insights and knowledge.

  • EK 3.1.2D Collaboration in developing hypotheses and questions, and in testing hypotheses and answering questions, about data helps participants gain insight and knowledge.

  • EK 3.1.2E Collaborating face-to-face and using online collaborative tools can facilitate processing information to gain insight and knowledge.

  • EK 3.1.2F Investigating large data sets collaboratively can lead to insight and knowledge not obtained when working alone.

 
  • LO 3.1.3 Explain the insight and knowledge gained from digitally processed data by using appropriate visualizations, notations, and precise language. [P5]

  • EK 3.1.3A Visualization tools and software can communicate information about data.

  • EK 3.1.3B Tables, diagrams, and textual displays can be used in communicating insight and knowledge gained from data.

  • EK 3.1.3C Summaries of data analyzed computationally can be effective in communicating insight and knowledge gained from digitally represented information.

  • EK 3.1.3D Transforming information can be effective in communicating knowledge gained from data.

  • EK 3.1.3E Interactivity with data is an aspect of communicating.

 

EU 3.2 Computing facilitates exploration and the discovery of connections in information.

  • LO 3.2.1 Extract information from data to discover and explain connections or trends. [P1]

  • EK 3.2.1A Large data sets provide opportunities and challenges for extracting information and knowledge.

  • EK 3.2.1B Large data sets provide opportunities for identifying trends, making connections in data, and solving problems.

  • EK 3.2.1C Computing tools facilitate the discovery of connections in information within large data sets.

  • EK 3.2.1D Search tools are essential for efficiently finding information.

  • EK 3.2.1E Information filtering systems are important tools for finding information and recognizing patterns in the information.

  • EK 3.2.1F Software tools, including spreadsheets and databases, help to efficiently organize and find trends in information.

    EXCLUSION STATEMENT (for EK 3.2.1F): Students are not expected to know specific formulas or options available in spreadsheet or database software packages.

  • EK 3.2.1G Metadata is data about data.

  • EK 3.2.1H Metadata can be descriptive data about an image, a Web page, or other complex objects.

  • EK 3.2.1I Metadata can increase the effective use of data or data sets by providing additional information about various aspects of that data. 

 
  • LO 3.2.2. Determine how large data sets impact the use of computational processes to discover information and knowledge. [P3]

  • EK 3.2.2A Large data sets include data such as transactions, measurements, texts, sounds, images, and videos.

  • EK 3.2.2B The storing, processing, and curating of large data sets is challenging.

  • EK 3.2.2C Structuring large data sets for analysis can be challenging.

  • EK 3.2.2D Maintaining privacy of large data sets containing personal information can be challenging.

  • EK 3.2.2E Scalability of systems is an important consideration when data sets are large.

  • EK 3.2.2F The size or scale of a system that stores data affects how that data set is used.

  • EK 3.2.2G The effective use of large data sets requires computational solutions.

  • EK 3.2.2H Analytical techniques to store, manage, transmit, and process data sets change as the size of data sets scale. 

 

EU 3.3 There are trade offs when representing information as digital data.

  • LO 3.3.1 Analyze how data representation, storage, security, and transmission of data involve computational manipulation of information. [P4]

  • EK 3.3.1A Digital data representations involve trade-offs related to storage, security, and privacy concerns.

  • EK 3.3.1B Security concerns engender trade-offs in storing and transmitting information.

  • EK 3.3.1C There are trade-offs in using lossy and lossless compression techniques for storing and transmitting data.

  • EK 3.3.1D Lossless data compression reduces the number of bits stored or transmitted but allows complete reconstruction of the original data.

  • EK 3.3.1E Lossy data compression can significantly reduce the number of bits stored or transmitted at the cost of being able to reconstruct only an approximation of the original data.

  • EK 3.3.1F Security and privacy concerns arise with data containing personal information.

  • EK 3.3.1G Data is stored in many formats depending on its characteristics (e.g., size and intended use).

  • EK 3.3.1H The choice of storage media affects both the methods and costs of manipulating the data it contains.

  • EK 3.3.1I Reading data and updating data have different storage requirements. 

 

 

Big Idea 4: Algorithms

EU 4.1 Algorithms are precise sequences of instructions for processes that can be executed by a computer and are implemented using programming languages.

  • LO 4.1.1 Develop an algorithm for implementation in a program. [P2]

  • EK 4.1.1A Sequencing, selection, and iteration are building blocks of algorithms.

  • EK 4.1.1B Sequencing is the application of each step of an algorithm in the order in which the statements are given.

  • EK 4.1.1C Selection uses a Boolean condition to determine which of two parts of an algorithm is used.

  • EK 4.1.1D Iteration is the repetition of part of an algorithm until a condition is met or for a specified number of times.

  • EK 4.1.1E Algorithms can be combined to make new algorithms.

  • EK 4.1.1F Using existing correct algorithms as building blocks for constructing a new algorithm helps ensure the new algorithm is correct.

  • EK 4.1.1G Knowledge of standard algorithms can help in constructing new algorithms.

  • EK 4.1.1H Different algorithms can be developed to solve the same problem.

  • EK 4.1.1I Developing a new algorithm to solve a problem can yield insight into the problem.

 
  • LO 4.1.2 Express an algorithm in a language. [P5]

  • EK 4.1.2A Languages for algorithms include natural language, pseudocode, and visual and textual programming languages.

  • EK 4.1.2B Natural language and pseudocode describe algorithms so that humans can understand them.

  • EK 4.1.2C Algorithms described in programming languages can be executed on a computer.

  • EK 4.1.2D Different languages are better suited for expressing different algorithms.

  • EK 4.1.2E Some programming languages are designed for specific domains and are better for expressing algorithms in those domains.

  • EK 4.1.2F The language used to express an algorithm can affect characteristics such as clarity or readability but not whether an algorithmic solution exists.

  • EK 4.1.2G Every algorithm can be constructed using only sequencing, selection, and iteration.

  • EK 4.1.2H Nearly all programming languages are equivalent in terms of being able to express any algorithm.

  • EK 4.1.2I Clarity and readability are important considerations when expressing an algorithm in a language.

 

EU 4.2 Algorithms can solve many but not all computational problems.

  • LO 4.2.1 Explain the difference between algorithms that run in a reasonable time and those that do not run in a reasonable time. [P1]

  • EXCLUSION STATEMENT (for LO 4.2.1): Any discussion of nondeterministic polynomial (NP) is beyond the scope of this course and the AP Exam.

  • EK 4.2.1A Many problems can be solved in a reasonable time.

  • EK 4.2.1B Reasonable time means that the number of steps the algorithm takes is less than or equal to a polynomial function (constant, linear, square, cube, etc.) of the size of the input.

    EXCLUSION STATEMENT (for EK 4.2.1B): Using nonpolynomial functions to describe relationships between the number of steps required by an algorithm and the input size is beyond the scope of this course and the AP Exam.

  • EK 4.2.1C Some problems cannot be solved in a reasonable time, even for small input sizes.

  • EK 4.2.1D Some problems can be solved but not in a reasonable time. In these cases, heuristic approaches may be helpful to find solutions in reasonable time.

 
  • LO 4.2.2 Explain the difference between solvable and unsolvable problems in computer science. [P1]

    EXCLUSION STATEMENT (for LO 4.2.2): Determining whether a given problem is solvable or unsolvable is beyond the scope of this course and the AP Exam.

  • EK 4.2.2A A heuristic is a technique that may allow us to find an approximate solution when typical methods fail to find an exact solution.

  • EK 4.2.2B Heuristics may be helpful for finding an approximate solution more quickly when exact methods are too slow.

    EXCLUSION STATEMENT (for EK 4.2.2B): Specific heuristic solutions are beyond the scope of this course and the AP Exam.

  • EK 4.2.2C Some optimization problems such as “find the best” or “find the smallest” cannot be solved in a reasonable time but approximations to the optimal solution can.

  • EK 4.2.2D Some problems cannot be solved using any algorithm.

 
  • LO 4.2.3 Explain the existence of undecidable problems in computer science. [P1]

  • EK 4.2.3A An undecidable problem may have instances that have an algorithmic solution, but there is no algorithmic solution that solves all instances of the problem.

  • EK 4.2.3B A decidable problem is one in which an algorithm can be constructed to answer “yes” or “no” for all inputs (e.g., “is the number even?”).

  • EK 4.2.3C An undecidable problem is one in which no algorithm can be constructed that always leads to a correct yes-or-no answer.

    EXCLUSION STATEMENT (for EK 4.2.3C): Determining whether a given problem is undecidable is beyond the scope of this course and the AP Exam.

 
  • LO 4.2.4 Evaluate algorithms analytically and empirically for efficiency, correctness, and clarity. [P4]

  • EK 4.2.4A Determining an algorithm’s efficiency is done by reasoning formally or mathematically about the algorithm.

  • EK 4.2.4B Empirical analysis of an algorithm is done by implementing the algorithm and running it on different inputs.

  • EK 4.2.4C The correctness of an algorithm is determined by reasoning formally or mathematically about the algorithm, not by testing an implementation of the algorithm.

    EXCLUSION STATEMENT (for EK 4.2.4C): Formally proving program correctness is beyond the scope of this course and the AP Exam.

  • EK 4.2.4D Different correct algorithms for the same problem can have different efficiencies.

  • EK 4.2.4E Sometimes, more efficient algorithms are more complex.

  • EK 4.2.4F Finding an efficient algorithm for a problem can help solve larger instances of the problem.

  • EK 4.2.4G Efficiency includes both execution time and memory usage.

    EXCLUSION STATEMENT (for EK 4.2.4G): Formal analysis of algorithms (Big-O) and formal reasoning using mathematical formulas are beyond the scope of this course and the AP Exam.

  • EK 4.2.4H Linear search can be used when searching for an item in any list; binary search can be used only when the list is sorted.

 

 

Big Idea 5 : Programming

EU 5.1 Programs can be developed for creative expression, to satisfy personal curiosity, to create new knowledge, or to solve problems (to help people, organizations, or society).

  • LO 5.1.1 Develop a program for creative expression, to satisfy personal curiosity, or to create new knowledge. [P2]

  • EK 5.1.1A Programs are developed and used in a variety of ways by a wide range of people depending on the goals of the programmer.

  • EK 5.1.1B Programs developed for creative expression, to satisfy personal curiosity, or to create new knowledge may have visual, audible, or tactile inputs and outputs.

  • EK 5.1.1C Programs developed for creative expression, to satisfy personal curiosity, or to create new knowledge may be developed with different standards or methods than programs developed for widespread distribution.

  • EK 5.1.1D Additional desired outcomes may be realized independently of the original purpose of the program.

  • EK 5.1.1E A computer program or the results of running a program may be rapidly shared with a large number of users and can have widespread impact on individuals, organizations, and society.

  • EK 5.1.1F Advances in computing have generated and increased creativity in other fields.

 
  • LO 5.1.2 Develop a correct program to solve problems. [P2]

  • EK 5.1.2A An iterative process of program development helps in developing a correct program to solve problems.

  • EK 5.1.2B Developing correct program components and then combining them helps in creating correct programs.

  • EK 5.1.2C Incrementally adding tested program segments to correct working programs helps create large correct programs.

  • EK 5.1.2D Program documentation helps programmers develop and maintain correct programs to efficiently solve problems.

  • EK 5.1.2E Documentation about program components, such as blocks and procedures, helps in developing and maintaining programs.

  • EK 5.1.2F Documentation about program components, such as code segments and procedures, helps in developing and maintaining programs.

  • EK 5.1.2G Program development includes identifying programmer and user concerns that affect the solution to problems.

  • EK 5.1.2H Consultation and communication with program users is an important aspect of program development to solve problems.

  • EK 5.1.2I A programmer’s knowledge and skill affects how a program is developed and how it is used to solve a problem.

  • EK 5.1.2J A programmer designs, implements, tests, debugs, and maintains programs when solving problems.

 
  • LO 5.1.3 Collaborate to develop a program. [P6]

  • EK 5.1.3A Collaboration can decrease the size and complexity of tasks required of individual programmers.

  • EK 5.1.3B Collaboration facilitates multiple perspectives in developing ideas for solving problems by programming.

  • EK 5.1.3C Collaboration in the iterative development of a program requires different skills than developing a program alone.

  • EK 5.1.3D Collaboration can make it easier to find and correct errors when developing programs.

  • EK 5.1.3E Collaboration facilitates developing program components independently.

  • EK 5.1.3F Effective communication between participants is required for successful collaboration when developing programs.

 

EU 5.2 People write programs to execute algorithms.

  • LO 5.2.1 Explain how programs implement algorithms. [P3]

  • EK 5.2.1A Algorithms are implemented using program instructions that are processed during program execution.

  • EK 5.2.1B Program instructions are executed sequentially.

  • EK 5.2.1C Program instructions may involve variables that are initialized and updated, read, and written.

  • EK 5.2.1D An understanding of instruction processing and program execution is useful for programming.

  • EK 5.2.1E Program execution automates processes.

  • EK 5.2.1F Processes use memory, a central processing unit (CPU), and input and output.

  • EK 5.2.1G A process may execute by itself or with other processes.

  • EK 5.2.1H A process may execute on one or several CPUs.

  • EK 5.2.1I Executable programs increase the scale of problems that can be addressed.

  • EK 5.2.1J Simple algorithms can solve a large set of problems when automated.

  • EK 5.2.1K Improvements in algorithms, hardware, and software increase the kinds of problems and the size of problems solvable by programming.

 

EU 5.3 Programming is facilitated by appropriate abstractions.

  • LO 5.3.1 Use abstraction to manage complexity in programs. [P3]

  • EK 5.3.1A Procedures are reusable programming abstractions.

  • EK 5.3.1B A procedure is a named grouping of programming instructions.

  • EK 5.3.1C Procedures reduce the complexity of writing and maintaining programs.

  • EK 5.3.1D Procedures have names and may have parameters and return values.

  • EK 5.3.1E Parameterization can generalize a specific solution.

  • EK 5.3.1F Parameters generalize a solution by allowing a procedure to be used instead of duplicated code.

  • EK 5.3.1G Parameters provide different values as input to procedures when they are called in a program.

  • EK 5.3.1H Data abstraction provides a means of separating behavior from implementation.

  • EK 5.3.1I Strings and string operations, including concatenation and some form of substring, are common in many programs.

  • EK 5.3.1J Integers and floating-point numbers are used in programs without requiring understanding of how they are implemented.

  • EK 5.3.1K Lists and list operations, such as add, remove, and search, are common in many programs.

  • EK 5.3.1L Using lists and procedures as abstractions in programming can result in programs that are easier to develop and maintain.

  • EK 5.3.1M Application program interfaces (APIs) and libraries simplify complex programming tasks.

  • EK 5.3.1N Documentation for an API/library is an important aspect of programming.

  • EK 5.3.1O APIs connect software components, allowing them to communicate.

 

EU 5.4 Programs are developed, maintained, and used by people for different purposes.

  • LO 5.4.1 Evaluate the correctness of a program. [P4]

  • EK 5.4.1A Program style can affect the determination of program correctness.

  • EK 5.4.1B Duplicated code can make it harder to reason about a program.

  • EK 5.4.1C Meaningful names for variables and procedures help people better understand programs.

  • EK 5.4.1D Longer code segments are harder to reason about than shorter code segments in a program

  • EK 5.4.1E Locating and correcting errors in a program is called debugging the program.

  • EK 5.4.1F Knowledge of what a program is supposed to do is required in order to find most program errors.

  • EK 5.4.1G Examples of intended behavior on specific inputs help people understand what a program is supposed to do.

  • EK 5.4.1H Visual displays (or different modalities) of program state can help in finding errors.

  • EK 5.4.1I Programmers justify and explain a program’s correctness.

  • EK 5.4.1K Correctness of a program depends on correctness of program components, including code segments and procedures

  • EK 5.4.1M The functionality of a program is often described by how a user interacts with it.

  • EK 5.4.1N The functionality of a program is best described at a high level by what the program does, not at the lower level of how the program statements work to accomplish this.

 

EU 5.5 Programming uses mathematical and logical concepts.

  • LO 5.5.1 Employ appropriate mathematical and logical concepts in programming. [P1]

  • EK 5.5.1A Numbers and numerical concepts are fundamental to programming.

  • EK 5.5.1B Integers may be constrained in the maximum and minimum values that can be represented in a program because of storage limitations.

    EXCLUSION STATEMENT (for EK 5.5.1B): Specific range limitations of all programming languages are beyond the scope of this course and the AP Exam.

  • EK 5.5.1C Real numbers are approximated by floating-point representations that do not necessarily have infinite precision.

    EXCLUSION STATEMENT (for EK 5.5.1C): Specific sets of values that cannot be exactly represented by floating point numbers are beyond the scope of this course and the AP Exam.

  • EK 5.5.1D Mathematical expressions using arithmetic operators are part of most programming languages.

  • EK 5.5.1E Logical concepts and Boolean algebra are fundamental to programming.

  • EK 5.5.1F Compound expressions using and, or, and not are part of most programming languages.

  • EK 5.5.1G Intuitive and formal reasoning about program components using Boolean concepts helps in developing correct programs.

  • EK 5.5.1H Computational methods may use lists and collections to solve problems.

  • EK 5.5.1I Lists and other collections can be treated as abstract data types (ADTs) in developing programs.

  • EK 5.5.1J Basic operations on collections include adding elements, removing elements, iterating over all elements, and determining whether an element is in a collection. 

 

 

Big Idea 6: The Internet

EU 6.1 The Internet is a network of autonomous systems.

  • LO 6.1.1 Explain the abstractions in the Internet and how the Internet functions. [P3]

  • EXCLUSION STATEMENT (for LO 6.1.1): Specific devices used to implement the abstractions in the Internet are beyond the scope of this course and the AP Exam.

  • EK 6.1.1A The Internet connects devices and networks all over the world.

  • EK 6.1.1B An end-to-end architecture facilitates connecting new devices and networks on the Internet.

  • EK 6.1.1C Devices and networks that make up the Internet are connected and communicate using addresses and protocols.

  • EK 6.1.1D The Internet and the systems built on it facilitate collaboration.

  • EK 6.1.1E Connecting new devices to the Internet is enabled by assignment of an Internet protocol (IP) address.

  • EK 6.1.1F The Internet is built on evolving standards, including those for addresses and names.

    EXCLUSION STATEMENT (for EK 6.1.1F): Specific details of any particular standard for addresses are beyond the scope of this course and the AP Exam.

  • EK 6.1.1G The domain name system (DNS) translates domain names to IP addresses.

  • EK 6.1.1H The number of devices that could use an IP address has grown so fast that a new protocol (IPv6) has been established to handle routing of many more devices.

  • EK 6.1.1I Standards such as hypertext transfer protocol (HTTP), IP, and simple mail transfer protocol (SMTP) are developed and overseen by the Internet Engineering Task Force (IETF).

 

EU 6.2 Characteristics of the Internet influence the systems built on it.

  • LO 6.2.1 Explain characteristics of the Internet and the systems built on it. [P5]

  • EK 6.2.1A The Internet and the systems built on it are hierarchical and redundant.

  • EK 6.2.1B The domain name syntax is hierarchical.

  • EK 6.2.1C IP addresses are hierarchical.

  • EK 6.2.1D Routing on the Internet is fault tolerant and redundant.

 
  •  

  • LO 6.2.2 Explain how the characteristics of the Internet influence the systems built on it. [P4]

  • EK 6.2.2A Hierarchy and redundancy help systems scale.

  • EK 6.2.2B The redundancy of routing (i.e., more than one way to route data) between two points on the Internet increases the reliability of the Internet and helps it scale to more devices and more people.

  • EK 6.2.2C Hierarchy in the DNS helps that system scale.

  • EK 6.2.2D Interfaces and protocols enable widespread use of the Internet.

  • EK 6.2.2E Open standards fuel the growth of the Internet.

  • EK 6.2.2F The Internet is a packet-switched system through which digital data is sent by breaking the data into blocks of bits called packets, which contain both the data being transmitted and control information for routing the data.

    EXCLUSION STATEMENT (for EK 6.2.2F): Specific details of any particular packet-switching system are beyond the scope of this course and the AP Exam.

  • EK 6.2.2G Standards for packets and routing include transmission control protocol/Internet protocol (TCP/IP).

    EXCLUSION STATEMENT (for EK 6.2.2G): Specific technical details of how TCP/IP works are beyond the scope of this course and the AP Exam.

  • EK 6.2.2H Standards for sharing information and communicating between browsers and servers on the Web include HTTP and secure sockets layer/transport layer security (SSL/TLS).

    EXCLUSION STATEMENT (for EK 6.2.2H): Understanding the technical aspects of how SSL/TLS works is beyond the scope of this course and the AP Exam.

  • EK 6.2.2I The size and speed of systems affect their use.

  • EK 6.2.2J The bandwidth of a system is a measure of bit rate—the amount of data (measured in bits) that can be sent in a fixed amount of time.

  • EK 6.2.2K The latency of a system is the time elapsed between the transmission and the receipt of a request.

 

EU 6.3 Cybersecurity is an important concern for the Internet and the systems built on it.

  • LO 6.3.1 Identify existing cybersecurity concerns and potential options to address these issues with the Internet and the systems built on it. [P1]

  • EK 6.3.1A The trust model of the Internet involves trade-offs.

  • EK 6.3.1B The DNS was not designed to be completely secure.

  • EK 6.3.1C Implementing cybersecurity has software, hardware, and human components.

  • EK 6.3.1D Cyber warfare and cyber crime have widespread and potentially devastating effects.

  • EK 6.3.1E Distributed denial-of-service attacks (DDoS) compromise a target by flooding it with requests from multiple systems.

  • EK 6.3.1F Phishing, viruses, and other attacks have human and software components.

  • EK 6.3.1G Antivirus software and firewalls can help prevent unauthorized access to private data.

  • EK 6.3.1H Cryptography is essential to many models of cybersecurity.

    EXCLUSION STATEMENT (for EK 6.3.1I): Specific mathematical functions used in cryptography are beyond the scope of this course and the AP Exam.

  • EK 6.3.1I Cryptography has a mathematical foundation.

  • EK 6.3.1J Open standards help ensure cryptography is secure.

  • EK 6.3.1K Symmetric encryption is a method of encryption involving one key for encryption and decryption.

    EXCLUSION STATEMENT (for EK 6.3.1K): The methods used in encryption are beyond the scope of this course and the AP Exam.

  • EK 6.3.1L Public key encryption, which is not symmetric, is an encryption method that is widely used because of the functionality it provides.

    EXCLUSION STATEMENT (for EK 6.3.1L): The mathematical methods used in public key cryptography are beyond the scope of this course and the AP Exam.

  • EK 6.3.1M Certificate authorities (CAs) issue digital certificates that validate the ownership of encrypted keys used in secured communications and are based on a trust model.

    EXCLUSION STATEMENT (for EK 6.3.1M): The technical details of the process CAs follow are beyond the scope of this course and the AP Exam

 

 

Big Idea 7: Global Impact

EU 7.1 Computing enhances communication, interaction, and cognition.

  • LO 7.1.1 Explain how computing innovations affect communication, interaction, and cognition. [P4]

  • EK 7.1.1A Email, SMS, and chat have fostered new ways to communicate and collaborate.

  • EK 7.1.1B Video conferencing and video chat have fostered new ways to communicate and collaborate.

  • EK 7.1.1C Social media continues to evolve and fosters new ways to communicate.

    EXCLUSION STATEMENT (for EK 7.1.1C): Detailed knowledge of any social media site is beyond the scope of this course and the AP Exam.

  • EK 7.1.1D Cloud computing fosters new ways to communicate and collaborate.

  • EK 7.1.1E Widespread access to information facilitates the identification of problems, development of solutions, and dissemination of results.

  • EK 7.1.1F Public data provides widespread access and enables solutions to identified problems.

  • EK 7.1.1G Search trends are predictors.

  • EK 7.1.1H Social media, such as blogs and Twitter, have enhanced dissemination.

  • EK 7.1.1I Global Positioning System (GPS) and related technologies have changed how humans travel, navigate, and find information related to geolocation.

  • EK 7.1.1J Sensor networks facilitate new ways of interacting with the environment and with physical systems.

  • EK 7.1.1K Smart grids, smart buildings, and smart transportation are changing and facilitating human capabilities.

  • EK 7.1.1L Computing contributes to many assistive technologies that enhance human capabilities.

  • EK 7.1.1M The Internet and the Web have enhanced methods of and opportunities for communication and collaboration.

  • EK 7.1.1N The Internet and the Web have changed many areas, including e-commerce, health care, access to information and entertainment, and online learning.

  • EK 7.1.1O The Internet and the Web have impacted productivity, positively and negatively, in many areas.

 
  • LO 7.1.2 Explain how people participate in a problem- solving process that scales. [P4]

  • EK 7.1.2A Distributed solutions must scale to solve some problems.

  • EK 7.1.2B Science has been impacted by using scale and “citizen science” to solve scientific problems using home computers in scientific research.

  • EK 7.1.2C Human computation harnesses contributions from many humans to solve problems related to digital data and the Web.

  • EK 7.1.2D Human capabilities are enhanced by digitally enabled collaboration.

  • EK 7.1.2E Some online services use the contributions of many people to benefit both individuals and society.

  • EK 7.1.2F Crowdsourcing offers new models for collaboration, such as connecting people with jobs and businesses with funding.

  • EK 7.1.2G The move from desktop computers to a proliferation of always-on mobile computers is leading to new applications.

 

EU 7.2 Computing enables innovation in nearly every field.

  • LO 7.2.1 Explain how computing has impacted innovations in other fields. [P1]

  • EK 7.2.1A Machine learning and data mining have enabled innovation in medicine, business, and science.

  • EK 7.2.1B Scientific computing has enabled innovation in science and business.

  • EK 7.2.1C Computing enables innovation by providing the ability to access and share information.

  • EK 7.2.1D Open access and Creative Commons have enabled broad access to digital information.

  • EK 7.2.1E Open and curated scientific databases have benefited scientific researchers. 

  • EK 7.2.1F Moore’s law has encouraged industries that use computers to effectively plan future research and development based on anticipated increases in computing power.

  • EK 7.2.1G Advances in computing as an enabling technology have generated and increased the creativity in other fields.

 

EU 7.3 Computing has a global affect -- both beneficial and harmful -- on people and society.

  • LO 7.3.1 Analyze the beneficial and harmful effects of computing. [P4]

  • EK 7.3.1A Innovations enabled by computing raise legal and ethical concerns.

  • EK 7.3.1B Commercial access to music and movie downloads and streaming raises legal and ethical concerns.

  • EK 7.3.1C Access to digital content via peer-to-peer networks raises legal and ethical concerns.

  • EK 7.3.1D Both authenticated and anonymous access to digital information raise legal and ethical concerns.

  • EK 7.3.1E Commercial and governmental censorship of digital information raise legal and ethical concerns.

  • EK 7.3.1F Open source and licensing of software and content raise legal and ethical concerns.

  • EK 7.3.1G Privacy and security concerns arise in the development and use of computational systems and artifacts.

  • EK 7.3.1H Aggregation of information, such as geolocation, cookies, and browsing history, raises privacy and security concerns.

  • EK 7.3.1I Anonymity in online interactions can be enabled through the use of online anonymity software and proxy servers.

  • EK 7.3.1J Technology enables the collection, use, and exploitation of information about, by, and for individuals, groups, and institutions.

  • EK 7.3.1K People can have instant access to vast amounts of information online; accessing this information can enable the collection of both individual and aggregate data that can be used and collected.

  • EK 7.3.1L Commercial and governmental curation of information may be exploited if privacy and other protections are ignored.

  • EK 7.3.1M Targeted advertising is used to help individuals, but it can be misused at both individual and aggregate levels.

  • EK 7.3.1N Widespread access to digitized information raises questions about intellectual proper ty.

  • EK 7.3.1O Creation of digital audio, video, and textual content by combining existing content has been impacted by copyright concerns.

  • EK 7.3.1P The Digital Millennium Copyright Act (DMCA) has been a benefit and a challenge in making copyrighted digital material widely available.

  • EK 7.3.1Q Open source and free software have practical, business, and ethical impacts on widespread access to programs, libraries, and code.

 

EU 7.4 Computing innovations influence and are influenced by the economic, social, and cultural contexts in which they are designed and used.

  • LO 7.4.1 Explain the connections between computing and real-world contexts, including economic, social, and cultural contexts. [P1]

  • EK 7.4.1A The innovation and impact of social media and online access varies in different countries and in different socioeconomic groups.

  • EK 7.4.1B Mobile, wireless, and networked computing have an impact on innovation throughout the world.

  • EK 7.4.1C The global distribution of computing resources raises issues of equity, access, and power.

  • EK 7.4.1D Groups and individuals are affected by the “digital divide” — differing access to computing and the Internet based on socioeconomic or geographic characteristics.

  • EK 7.4.1E Networks and infrastructure are supported by both commercial and governmental initiatives.

 

EU 7.5 An investigative process is aided by effective organization and selection of resources. Appropriate technologies and tools facilitate the accessing of information and enable the ability to evaluate the credibility of sources.

  • LO 7.5.1 Access, manage, and attribute information using effective strategies. [P1]

  • EK 7.5.1A Online databases and libraries catalog and house secondary and some primary sources.

  • EK 7.5.1B Advance search tools, Boolean logic, and key words can refine the search focus and/or limit search results based on a variety of factors (e.g., data, peer-review status, type of publication).

  • EK 7.5.1C Plagiarism is a serious offense that occurs when a person presents another’s ideas or words as his or her own. Plagiarism may be avoided by accurately acknowledging sources.

 
  • LO 7.5.2 Evaluate online and print sources for appropriateness and credibility. [P5]

  • EK 7.5.2A Determining the credibility of a source requires considering and evaluating the reputation and credentials of the author(s), publisher(s), site owner(s), and/or sponsor(s).

  • EK 7.5.2B Information from a source is considered relevant when it supports an appropriate claim or the purpose of the investigation.