Pull content from here and paste into file located at Software engineering topics without the definition listed.
This is a temporary place holder!
Short description: List of definitions of terms and concepts commonly used in computer science
This glossary of computer science is a list of definitions of terms and concepts used in computer science, its sub-disciplines, and related fields, including terms relevant to software, data science, and computer programming
- no=1|In [[software engineering]] and [[computer science, the process of removing physical, spatial, or temporal details((Last name: Colburn, First name: Timothy, Last name: Shute, First name: Gary, Date: 2007-06-05, Title: Abstraction in Computer Science, [[Journal]]: Minds and Machines, [[Language]]: [[English]], Volume: 17, Issue: 2, pages 169–184, [[DOI]]: 10.1007/s11023-007-9061-7, [[ISSN]]: 0924-6495)) or [[attribute|attributes in the study of objects or systems in order to more closely attend to other details of interest;((Journal: Last name: Kramer, First name: Jeff, Date: 2007-04-01, Title: Is abstraction the key to computing?, [[Journal]]: Communications of the ACM, Volume: 50, Issue: 4, pages 36–42, [[DOI]]: 10.1145/1232743.1232745, [[ISSN]]: 0001-0782, cite seerx: 10.1.1.120.6776)) it is also very similar in nature to the process of [[generalization]]. - no=2|The result of this process: an [[Abstract and concrete|abstract]] [[concept]]-[[Object (philosophy)|object]] created by keeping common features or attributes to various concrete objects or systems of study.
- A [[blueprint]] for [[software agent|software agents and [[intelligent control]] systems depicting the arrangement of components. The architectures implemented by [[intelligent agent]]s are referred to as [[cognitive architecture]]s.(([http://hri.cogs.indiana.edu/publications/aaai04ws.pdf Comparison of Agent Architectures] ((https://web.archive.org/web/20080827222057/http://hri.cogs.indiana.edu/publications/aaai04ws.pdf, Date: August 27, 2008 ))
- A class of [[computational model|computational models for [[computer simulation|simulating]] the actions and interactions of autonomous agents (both individual or collective entities such as organizations or groups) with a view to assessing their effects on the system as a whole. It combines elements of [[game theory]], [[complex systems]], [[emergence]], [[computational sociology]], [[multi-agent system]]s, and [[evolutionary programming]]. [[Monte Carlo method]]s are used to introduce randomness.
- In [[database management]], a [[subroutine|function in which the values of multiple rows are grouped together to form a single value of more significant meaning or measurement, such as a [[set, a [[bag, or a [[list.
- An approach to [[software development]] under which requirements and solutions evolve through the collaborative effort of [[Self-organizing communities|self-organizing]] and [[cross-functional team|cross-functional]] teams and their [[Customer|customer(s)]]/[[End user|end user(s)]].(("Collier 2011">Book: Title: Agile Analytics: A Value-Driven Approach to Business Intelligence and Data Warehousing , Last name: Collier, First name: Ken W. , Year: 2011 , [[Publisher]]: [[Pearson]] Education , [[ISBN]]: 9780321669544, pages 121 ff|quote=What is a self-organizing team?)) It advocates adaptive planning, evolutionary development, early delivery, and [[Continual improvement process|continual improvement]], and it encourages rapid and flexible response to change.(("WhatIsAgile">((http://www.agilealliance.org/the-alliance/what-is-agile/, Title: What is Agile Software Development?, Date: 8 June 2013, Access Date: 4 April 2015, [[Publisher]]: Agile Alliance))
- An unambiguous specification of how to solve a class of problems. Algorithms can perform [[calculation]], [[data processing]], and [[automated reasoning]] tasks. They are ubiquitous in computing technologies.
- A method or mathematical process for problem-solving and for engineering [[algorithm|algorithms. The design of algorithms is part of many solution theories of [[operation research]], such as [[dynamic programming]] and [[Divide and conquer algorithm|divide-and-conquer]]. Techniques for designing and implementing algorithm designs are also called algorithm design patterns,((http://ww3.algorithmdesign.net/ch00-front.html, Title: Algorithm Design: Foundations, Analysis, and Internet Examples, Last name: Goodrich, First name: Michael T., [[Author]]: Michael T. Goodrich, Last name: Tamassia, First name: Roberto, [[Author]]: Roberto Tamassia, [[Publisher]]: John [[Wiley]] & Sons, Inc., Year: 2002, [[ISBN]]: 978-0-471-38365-9)) such as the template method pattern and decorator pattern.
- A property of an [[algorithm which relates to the number of [[computational resource]]s used by the algorithm. An algorithm must be [[analysis of algorithms|analyzed]] to determine its resource usage, and the efficiency of an algorithm can be measured based on usage of different resources. Algorithmic efficiency can be thought of as analogous to engineering [[productivity]] for a repeating or continuous process.
- A [[character encoding]] standard for electronic communications. ASCII codes represent text in computers, [[telecommunications equipment]], and other devices. Most modern character-encoding schemes are based on ASCII, although they support many additional characters.
- A set of [[subroutine definitions, [[communication protocols]], and tools for building [[software. In general terms, it is a set of clearly defined methods of communication among various components. A good API makes it easier to develop a [[computer program by providing all the building blocks, which are then put together by the [[programmer]].
- Also simply '''application''' or '''app'''. - [[software|Computer software designed to perform a group of coordinated functions, tasks, or activities for the benefit of the [[user. Common examples of applications include [[word processor]]s, [[spreadsheet]]s, [[accounting software|accounting application]]s, [[web browser]]s, [[media player (software)|media player]]s, aeronautical [[flight simulator]]s, [[console game]]s, and [[Raster graphics editor|photo editor]]s. This contrasts with [[system software, which is mainly involved with managing the computer's most basic running operations, often without direct input from the user. The collective noun ''application software'' refers to all applications collectively.(([[Web Citation]]: Title: Application software, https://www.pcmag.com/encyclopedia/term/37919/application-program, Work: [[PC Magazine]] , [[Publisher]]: [[Ziff Davis]]))
- Also simply '''array'''. - A [[data structure consisting of a collection of ''elements'' ([[value|values or [[variable|variables), each identified by at least one ''array index'' or ''key''. An array is stored such that the position of each element can be computed from its index [[tuple]] by a mathematical formula.((https://xlinux.nist.gov/dads/HTML/array.html, Title: array, Last name: Black, First name: Paul E., Date: 13 November 2008|work=[[Dictionary of Algorithms and Data Structures]], [[Publisher]]: [[National Institute of Standards and Technology]], Access date: 22 August 2010))(("andres">{{cite arXiv, eprint=1008.2909, [[Author]]: Bjoern Andres , [[Author]]: Ullrich Koethe, [[Author]]: Thorben Kroeger, [[Author]]:Hamprecht , Title: Runtime-Flexible Multi-dimensional Arrays and Views for C++98 and C++0x, class=cs.DS , Year: 2010))(("garcia", Journal: Last name: Garcia, First name: Ronald , First name: Andrew, Last name: Lumsdaine, Year: 2005, Title: MultiArray: a C++ library for generic programming with arrays, [[Journal]]: Software: Practice and Experience, Volume: 35, Issue: 2, pages 159–188, [[ISSN]]: 0038-0644, [[DOI]]: 10.1002/spe.630)) The simplest type of data structure is a linear array, also called a one-dimensional array.
- One of many kinds of tangible by-products produced during the development of [[software. Some artifacts (e.g. [[use case]]s, [[class diagram]]s, and other [[Unified Modeling Language]] (UML) models, requirements, and design documents) help describe the function, architecture, and design of software. Other artifacts are concerned with the process of development itself—such as project plans, business cases, and risk assessments.
- Also '''machine intelligence'''. - [[Intelligence]] demonstrated by [[machine]]s, in contrast to the natural intelligence displayed by humans and other animals. In [[computer science, AI research is defined as the study of "[[intelligent agent]]s": devices capable of perceiving their environment and taking actions that maximize the chance of successfully achieving their goals.(("Definition of AI">
Definition of AI as the study of intelligent agents: