In the
software development process
In software engineering, a software development process or software development life cycle (SDLC) is a process of planning and managing software development. It typically involves dividing software development work into smaller, parallel, or s ...
, a reference implementation (or, less frequently, sample implementation or model implementation) is a program that implements all requirements from a corresponding specification. The reference implementation often accompanies a
technical standard
A technical standard is an established Social norm, norm or requirement for a repeatable technical task which is applied to a common and repeated use of rules, conditions, guidelines or characteristics for products or related processes and producti ...
, and demonstrates what should be considered the "correct" behavior of any other implementation of it.
Characteristics and examples
Reference implementations of algorithms, for instance
cryptographic algorithm
In cryptography, encryption (more specifically, encoding) is the process of transforming information in a way that, ideally, only authorized parties can decode. This process converts the original representation of the information, known as pla ...
s, are often the result or the input of
standardization
Standardization (American English) or standardisation (British English) is the process of implementing and developing technical standards based on the consensus of different parties that include firms, users, interest groups, standards organiza ...
processes. In this function they are often dedicated to the
public domain
The public domain (PD) consists of all the creative work to which no Exclusive exclusive intellectual property rights apply. Those rights may have expired, been forfeited, expressly Waiver, waived, or may be inapplicable. Because no one holds ...
with their
source code
In computing, source code, or simply code or source, is a plain text computer program written in a programming language. A programmer writes the human readable source code to control the behavior of a computer.
Since a computer, at base, only ...
as
public domain software. Examples are the first
CERN's httpd,
Serpent cipher,
base64 variants, and
SHA-3. The
Openwall Project maintains a list of several algorithms with their reference
source code
In computing, source code, or simply code or source, is a plain text computer program written in a programming language. A programmer writes the human readable source code to control the behavior of a computer.
Since a computer, at base, only ...
in the public domain.
A reference implementation may or may not be production quality. For example, the
Fraunhofer reference implementation of the
MP3 standard usually does not compare favorably to other common implementations, such as
LAME, in listening tests that determine sound quality. In contrast,
CPython, the reference implementation of the
Python programming language,
is also the implementation most widely used in production.
Testing
Testing the implementation-vs-specification relationship further enhances the
production's inter-process efficiencies:
References
{{Reflist
Test items
Software engineering terminology