CSTA Standards
 2AP13

Decompose problems and subproblems into parts to facilitate the design, implementation, and review of programs [See: Defining Table Functions; Method Chaining.]
 2AP14

Create procedures with parameters to organize code and make it easier to reuse. [See: Defining Functions; Defining Table Functions.]
 2AP17

Systematically test and refine programs using a range of test cases [See: Defining Functions; Defining Table Functions; Method Chaining.]
 2AP19

Document programs in order to make them easier to follow, test, and debug. [See: Defining Functions; Defining Table Functions.]
 2DA07

Represent data using multiple encoding schemes. [See: Introduction to Computational Data Science; Starting to Program; Displaying Categorical Data.]
 2DA08

Collect data using computational tools and transform the data to make it more useful and reliable. [See: Displaying Categorical Data; Table Methods.]
 3AAP17

Decompose problems into smaller components through systematic analysis, using constructs such as procedures, modules, and/or objects. [See: Defining Table Functions; Method Chaining.]
 3AAP18

Create artifacts by using procedures within a program, combinations of data and procedures, or independent but interrelated programs. [See: Defining Table Functions; Method Chaining.]
 3ADA11

Create interactive data visualizations using software tools to help others better understand realworld phenomena. [See: Displaying Categorical Data; Data Displays and Lookups.]
K12CS Standards
 68.Algorithms and Programming.Control

Programmers select and combine control structures, such as loops, event handlers, and conditionals, to create more complex program behavior. [See: Method Chaining.]
 68.Algorithms and Programming.Modularity

Programs use procedures to organize code, hide implementation details, and make code easier to reuse. Procedures can be repurposed in new programs. Defining parameters for procedures can generalize behavior and increase reusability. [See: Defining Functions; Defining Table Functions.]
 68.Algorithms and Programming.Variables

Programmers create variables to store data values of selected types. A meaningful identifier is assigned to each variable to access and perform operations on the value by name. Variables enable the flexibility to represent different situations, process different sets of data, and produce varying outputs. [See: Defining Functions.]
 68.Data and Analysis.Inference and Models

People transform, generalize, simplify, and present large data sets in different ways to influence how other people interpret and understand the underlying information. Examples include visualization, aggregation, rearrangement, and application of mathematical operations. [See: Data Displays and Lookups.]
 912.Algorithms and Programming.Control

Programmers consider tradeoffs related to implementation, readability, and program performance when selecting and combining control structures. [See: Method Chaining.]
 912.Algorithms and Programming.Modularity

Complex programs are designed as systems of interacting modules, each with a specific role, coordinating for a common overall purpose. These modules can be procedures within a program; combinations of data and procedures; or independent, but interrelated, programs. Modules allow for better management of complex tasks. [See: Defining Functions; Defining Table Functions; Method Chaining.]
 912.Data and Analysis.Visualization and Transformation

Data can be transformed to remove errors, highlight or expose relationships, and/or make it easier for computers to process. [See: Data Displays and Lookups.]
 P3

Recognizing and Defining Computational Problems [See: Method Chaining.]
 P4

Developing and Using Abstractions [See: Defining Functions; Defining Table Functions.]
 P5

Creating Computational Artifacts [See: Displaying Categorical Data.]
 P7

Communicating About Computing [See: Introduction to Computational Data Science.]
NextGen Science Standards
 HSSEP41

Analyze data using tools, technologies, and/or models (e.g., computational, mathematical) in order to make valid and reliable scientific claims or determine an optimal design solution. [See: Data Displays and Lookups; Method Chaining.]
 HSSEP46

Analyze data to identify design features or characteristics of the components of a proposed process or system to optimize it relative to criteria for success. [See: Table Methods.]
 HSSEP53

Apply techniques of algebra and functions to represent and solve scientific and engineering problems. [See: Defining Functions; Defining Table Functions.]
Oklahoma Standards
 OK.7.AP.A.01

Select and modify an existing algorithm in natural language or pseudocode to solve complex problems. [See: Starting to Program.]
 OK.8.AP.C.01

Develop programs that utilize combinations of nested repetition, compound conditionals, procedures without parameters, and the manipulation of variables representing different data types. [See: Making Flags; Starting to Program.]
 OK.8.AP.PD.02

Incorporate existing code, media, and libraries into original programs of increasing complexity and give attribution. [See: Defining Functions.]
 OK.8.DA.S.01

Analyze multiple methods of representing data and choose the most appropriate method for representing data. [See: Displaying Categorical Data; Data Displays and Lookups.]
 OK.A1.A.1.1

Use knowledge of solving equations with rational values to represent and solve mathematical and realworld problems (e.g., angle measures, geometric formulas, science, or statistics) and interpret the solutions in the original context. [See: Defining Functions.]
 OK.A1.A.3

Generate equivalent algebraic expressions and use algebraic properties to evaluate expressions and arithmetic and geometric sequences. [See: Order of Operations.]
 OK.A1.A.3.1

Solve equations involving several variables for one variable in terms of the others. [See: Problem Decomposition.]
 OK.A1.F.1.2

Identify the dependent and independent variables as well as the domain and range given a function, equation, or graph. Identify restrictions on the domain and range in realworld contexts. [See: Applying Functions.]
 OK.A1.F.1.3

Write linear functions, using function notation, to model realworld and mathematical situations. [See: Defining Functions.]
 OK.L1.AP.M.01

Break down a solution into procedures using systematic analysis and design. [See: Defining Table Functions; Method Chaining.]
 OK.L1.AP.M.02

Create computational artifacts by systematically organizing, manipulating and/or processing data. [See: Table Methods.]
 OK.PA.A.1.1

Recognize that a function is a relationship between an independent variable and a dependent variable in which the value of the independent variable determines the value of the dependent variable. [See: Domain and Range.]
 OK.PA.A.1.2

Use linear functions to represent and explain realworld and mathematical situations. [See: Restating the Problem; Character Animation.]
 OK.PA.A.1.3

Identify a function as linear if it can be expressed in the form y = mx + b or if its graph is a straight line. [See: Solving Word Problems.]
 OK.PA.A.3

Generate equivalent numerical and algebraic expressions and use algebraic properties to evaluate expressions. [See: Order of Operations.]
 OK.PA.A.3.1

Use substitution to simplify and evaluate algebraic expressions. [See: Defining Values.]