AP * Computer Science Principles *

0.0(0)
learnLearn
examPractice Test
spaced repetitionSpaced Repetition
heart puzzleMatch
flashcardsFlashcards
Card Sorting

1/218

encourage image

There's no tags or description

Looks like no tags are added yet.

Study Analytics
Name
Mastery
Learn
Test
Matching
Spaced

No study sessions yet.

219 Terms

1
New cards

Agile software development

An approach to software development that emphasizes a flexible and ready response to meet a shifting target.

2
New cards

Benchmarking

Running a program on many data sets to be sure its performance falls within required limits; timing the same algorithm on two different machines.

3
New cards

Code library

A collection of thoroughly tested object code for various useful tasks.

4
New cards

Coding

The process of translating the detailed designs into computer code.

5
New cards

Divide-and-conquer

A program design strategy in which tasks are broken down into subtasks, which are broken down into sub-subtasks, and so on, until each piece is small enough to code comfortably. These pieces work together to accomplish the total job.

6
New cards

Empirical testing

Designing a special set of test cases and running the program using these test data.

7
New cards

Executable module

The resulting object code after a linker inserts requested code from code libraries.

8
New cards

External documentation

Any materials assembled to clarify the program's design and implementation.

9
New cards

Feasibility study

A step in the software development life cycle that evaluates a proposed project and compares the costs and benefits of various solutions.

10
New cards

Integrated development environment (IDE)

A collection of programs that support software development, such as debuggers, editors, toolkits, and libraries, that lets programmers perform several tasks within the shell of a single application.

11
New cards

Integration testing

After unit testing, integration testing is done to see that the modules communicate the necessary data between and among themselves and that all modules work together smoothly.

12
New cards

Internal documentation

Documentation that is part of the program code itself.

13
New cards

Logic error

An error in the algorithm used to solve a problem.

14
New cards

Object code

Machine language instructions.

15
New cards

Pair programming

Involves two programmers at a single workstation. At any given point in time, one is writing code and the other is actively observing, watching for possible errors

but also thinking about the overall approach.

16
New cards

Problem specification

A step in the software development life cycle that involves

developing a clear, concise, and unambiguous statement of the exact problem the software

is to solve.

17
New cards

Procedural language

A program written in a procedural language consists of sequences of statements that manipulate data items.

18
New cards

Program design phase

A step in the software development life cycle that plans the structure of the software to be written.

19
New cards

Program maintenance

The process of adapting an existing software product due to errors, new system requirements, or changing user needs.

20
New cards

Program verification

Used to prove that if the input data to a program satisfies certain conditions, then, after the program has been run on these data, the output data satisfies certain other conditions.

21
New cards

Regression testing

If anything is changed on an already-tested module, regression testing is done to be sure that this change has not introduced a new error into code that was previously correct.

22
New cards

Runtime error

An error that occurs when the program is run using certain sets of data that result in some illegal operation, such as dividing by zero.

23
New cards

Semantics

The meaning of correctly written programming statements.

24
New cards

Source code

High-level language instructions.

25
New cards

Syntax error

An error that occurs because a program statement fails to follow the correct

rules of syntax.

26
New cards

Technical documentation

Documentation that enables programmers who later have to modify the program to understand the code.

27
New cards

Third-generation language

Another name for high-level programming language as

opposed to machine language (first generation) or assembly language (second generation).

28
New cards

Top-down decomposition

A program design strategy in which tasks are broken down into subtasks, which are broken down into sub-subtasks, and so on, until each piece is small enough to code comfortably. These pieces work together to accomplish the total job.

29
New cards

Syntax

The rules for exactly how programming statements must be written; the grammatical structure of a programming language

30
New cards

Application

(Java) A complete standalone program that resides and runs on a self-contained computer.

31
New cards

External library

A well-written, efficient, and thoroughly tested code module that is separately compiled and then drawn on by any program that wishes to use its capabilities.

32
New cards

Functional programming languages

Views every task in terms of functions. In this context, function means something like a mathematical function—a recipe for taking an argument (or possibly several arguments) and doing something with them to compute a single value.

33
New cards

Knowledge base

Facts and rules about a certain domain of interest.

34
New cards

Open source

Software whose source code is freely available and may be used, distributed, or modified by anyone.

35
New cards

Recursive

Something that is defined in terms of "smaller versions" of itself.

36
New cards

Computational model

A model constructed using algorithmic procedures implemented as computer programs.

37
New cards

Computational steering

A procedure for using a computational model to improve the design of an actual system by continually resetting model parameters to improve system performance.

38
New cards

Computer graphics

The field of computer science that examines the technical problems of displaying visual images on a computer screen.

39
New cards

Continuous model

A model of a system using mathematical equations that describe system performance as a continuous function of time t.

40
New cards

Discrete event simulation

A computational modeling technique that simulates the behavior of a system only at discrete points in time.

41
New cards

Garbage in, garbage out

The term for the fact that the output coming out of a computer model is only as accurate as the assumption used to build the model.

42
New cards

Scientific visualization

The use of images and visualization techniques to make scientific data easier to interpret and understand.

43
New cards

Simulation model

Another term for a computational model.

44
New cards

Statistical distribution

This is a mathematical function that describes the probability of a random quantity taking on certain values.

45
New cards

Stochastic components

Parts of a model that display random behavior.

46
New cards

Uniform random number

Every value in the range from a to b has the same chance of occurring.

47
New cards

Analogy

Arguing about a problem by comparing it to a related problem, which you claim is very similar in terms of its ethical implications and consequences.

48
New cards

Consequentialism

A school of thought in ethics that focuses on the consequences of an act to determine if the act is good or bad.

49
New cards

Cyberbullying

Humiliating, taunting, threatening or invading someone's privacy using the Internet, Web, or other type of electronic technology.

50
New cards

Ethics

The study of how to decide if something is morally right or wrong.

51
New cards

Hacktivism

Hacking that is intended as political activism.

52
New cards

Peer-to-peer file sharing

The sharing of files between two equal participants on a network. This is distinct from the client-server model in which the two sides serve very different roles--one side only sending information (the server) and the other side only receiving information (the client).

53
New cards

Computer science

The study of algorithms, including their mathematical properties, hardware and linguistic realizations, and their applications.

54
New cards

Computing agent

The entity (machine, robot, person, or thing) that executes the steps of an algorithm.

55
New cards

High-level programming language

A programming language that uses both natural language constructs and mathematical notation.

56
New cards

Infinite loop

The repetitive execution of a block of operations that will never end. This is a fatal error when it occurs in an algorithm.

57
New cards

Sequential operation

An algorithmic operation that carries out a single task and then moves on to the next operation in sequence.

58
New cards

Algorithm discovery

The process of finding an algorithmic solution to a given problem. Computation: An algorithmic operation that carries out a single numeric computation and stores the result.

59
New cards

Computation

An algorithmic operation that carries out a single numeric computation and stores the result.

60
New cards

Conditional statements

Operations that ask a question and select the next instruction to carry out based on the answer to that question.

61
New cards

Continuation condition

The true/false condition that will determine when the iteration has been completed.

62
New cards

Control operations

Operations that alter the normal sequential flow of control within an algorithm.

63
New cards

Input

An operation that causes data values from the outside world to be brought into the algorithm.

64
New cards

Iteration

The repetitive execution of a block of operations.

65
New cards

Output

An operation that causes computed values to be sent to the outside world for viewing or saving.

66
New cards

Primitive operation

An operation that can be directly understood by the computing agent executing the algorithm and which does not have to be further clarified or explained.

67
New cards

Pseudocode

A notation used to design algorithms. It uses English constructs, mathematical notation and an informal algorithmic structure designed to look like a high-level programming language.

68
New cards

Sorting

The task of putting a list of values into numeric or alphabetical order.

69
New cards

Boolean expression

An expression that can evaluate only to true or false.

70
New cards

Gigabyte

One billion bytes.

71
New cards

Program

an algorithm that is written in a programming language that runs on a computer

72
New cards

Control Structures

a block of programming that determines which part of the program is executed next. There are three types of structures: sequence, selection, and repetition.

73
New cards

Computational Artifact

an object created by a human being that involves the use of computation in some way, for example a mobile app or a web page.

74
New cards

Event Driven Programming

a programming approach whereby the program's behavior is controlled by writing code that responds to various events that occur, such as Button clicks.

75
New cards

Hardware

the large and small physical components that make up a computers such as the computer's keyboard or its processor.

76
New cards

Software

the computer programs that make up a computer system such as the mobile apps we will be creating in this course.

77
New cards

Abstraction

one of the seven big ideas of the CS Principles curriculum. An abstraction is a simplified and general representation of some complex object or process. One example --we'll encounter many in this course, including abstractions used in computer programming -- would be a Google map.

78
New cards

Binary Number

a number written in the binary system, a system that uses only two digits, 0s and 1s.

79
New cards

Blacklist

in internet terminology, a generic term for a list of email addresses or IP addresses that are origination with known spammers

80
New cards

Character

any symbol that requires one byte of storage

81
New cards

Cyberspace

a metaphor for describing the non-physical terrain created by computer systems

82
New cards

Data

data is distinct information that is formatted in a special way. Data exists in a variety of forms, like text on paper or bytes stored in electronic memory

83
New cards

Data Center

are physical or virtual infrastructures used by enterprises to house computer, server and networking systems and components for the company's IT (information technology) needs

84
New cards

Data Network

a telecommunications network which allows computers to exchange data

85
New cards

Disk Drive

a randomly addressable and rewritable storage device

86
New cards

Intellectual Property

refers to any property that is created using original thought. Traditional intellectual property include patents, copyrights, and trademarks.

87
New cards

Network

a group of two or more computer systems linked together

88
New cards

Processor

short for microprocessor or CPU

89
New cards

Social Networking

a social structure made of nodes that are generally individuals or organizations. A social network represents relationships and flows between people, groups, organizations, animals, computers, or other information/knowledge processing entities

90
New cards

Whitelist

a generic name for a list of email address or IP addresses that are considered to be spam free

91
New cards

Analog

a device or system that represents changing values as continuously variable physical quantities

92
New cards

Cloud Computing

comparable to grid computing, cloud computing relies on sharing resources rather than having local servers handle applications.

93
New cards

Cryptography

the art of protecting information by transforming it into an unreadable format, called cipher text

94
New cards

Digital

any system based on discontinuous data or events. Computers are digital machines because at the basic level they can distinguish between just two values, 0 and 1.

95
New cards

Digital Signal Processing

(DSP) refers to manipulating analog information

96
New cards

Download

to copy data (usually an entire file) from a main source to a peripheral device

97
New cards

Megabyte

used to describe data storage, 1,048,576 bytes (abbreviated MB)

98
New cards

Megapixel

one million pixels, used in reference to the resolution of a graphics device

99
New cards

Modeling

process of representing a real-world object of phenomenon as a set of mathematical equations.

100
New cards

OCR

optical character recognition, the branch of computer science that involves reading text from paper and translating the images into a form that the computer can manipulate