bc for ''basic calculator'', is "an
arbitrary-precision calculator language" with syntax similar to the
C programming language
C (''pronounced'' '' – like the letter c'') is a general-purpose programming language. It was created in the 1970s by Dennis Ritchie and remains very widely used and influential. By design, C's features cleanly reflect the capabilities of ...
. bc is typically used as either a mathematical scripting language or as an interactive mathematical shell.
Overview
A typical interactive usage is typing the command
bc
on a
Unix
Unix (, ; trademarked as UNIX) is a family of multitasking, multi-user computer operating systems that derive from the original AT&T Unix, whose development started in 1969 at the Bell Labs research center by Ken Thompson, Dennis Ritchie, a ...
command prompt
A command-line interface (CLI) is a means of interacting with software via commands each formatted as a line of text. Command-line interfaces emerged in the mid-1960s, on computer terminals, as an interactive and more user-friendly alternativ ...
and entering a mathematical expression, such as , whereupon will be output. While bc can work with arbitrary precision, it actually defaults to zero digits after the decimal point, so the expression yields (results are truncated, not rounded). This can surprise new bc users unaware of this fact. The option to bc sets the default ''scale'' (digits after the decimal point) to 20 and adds several additional mathematical functions to the language.
History
bc first appeared in
Version 6 Unix in 1975. It was written by
Lorinda Cherry of
Bell Labs
Nokia Bell Labs, commonly referred to as ''Bell Labs'', is an American industrial research and development company owned by Finnish technology company Nokia. With headquarters located in Murray Hill, New Jersey, Murray Hill, New Jersey, the compa ...
as a front end to
dc, an arbitrary-precision calculator written by
Robert Morris and Cherry. dc performed arbitrary-precision computations specified in
reverse Polish notation
Reverse Polish notation (RPN), also known as reverse Łukasiewicz notation, Polish postfix notation or simply postfix notation, is a mathematical notation in which operators ''follow'' their operands, in contrast to prefix or Polish notation ...
. bc provided a conventional programming-language interface to the same capability via a simple
compiler
In computing, a compiler is a computer program that Translator (computing), translates computer code written in one programming language (the ''source'' language) into another language (the ''target'' language). The name "compiler" is primaril ...
(a single
yacc
Yacc (Yet Another Compiler-Compiler) is a computer program for the Unix operating system developed by Stephen C. Johnson. It is a lookahead left-to-right rightmost derivation (LALR) parser generator, generating a LALR parser (the part of a co ...
source file comprising a few hundred lines of code), which converted a
C-like syntax into dc notation and
piped the results through dc.
In 1991,
POSIX
The Portable Operating System Interface (POSIX; ) is a family of standards specified by the IEEE Computer Society for maintaining compatibility between operating systems. POSIX defines application programming interfaces (APIs), along with comm ...
rigorously defined and standardized bc. Four implementations of this standard survive today: The first is the traditional Unix implementation, a front-end to dc, which survives in Unix and
Plan 9 systems. The second is the
free software
Free software, libre software, libreware sometimes known as freedom-respecting software is computer software distributed open-source license, under terms that allow users to run the software for any purpose as well as to study, change, distribut ...
GNU bc, first released in 1991 by Philip A. Nelson. The GNU implementation has numerous extensions beyond the POSIX standard and is no longer a front-end to dc (it is a
bytecode interpreter). The third is a re-implementation by
OpenBSD
OpenBSD is a security-focused operating system, security-focused, free software, Unix-like operating system based on the Berkeley Software Distribution (BSD). Theo de Raadt created OpenBSD in 1995 by fork (software development), forking NetBSD ...
in 2003. The fourth is an independent implementation by Gavin Howard
[An implementation of Unix dc and POSIX bc with GNU and BSD extensions](_blank)
/ref> that is included in Android (operating system)
Android is an operating system based on a modified version of the Linux kernel and other open-source software, open-source software, designed primarily for touchscreen-based mobile devices such as smartphones and tablet computer, tablets. Andr ...
, FreeBSD
FreeBSD is a free-software Unix-like operating system descended from the Berkeley Software Distribution (BSD). The first version was released in 1993 developed from 386BSD, one of the first fully functional and free Unix clones on affordable ...
as of 13.3-RELEASE, and macOS
macOS, previously OS X and originally Mac OS X, is a Unix, Unix-based operating system developed and marketed by Apple Inc., Apple since 2001. It is the current operating system for Apple's Mac (computer), Mac computers. With ...
as of 13.0.
Implementations
POSIX bc
The POSIX standardized bc language is traditionally written as a program in the dc programming language to provide a higher level of access to the features of the dc language without the complexities of dc's terse syntax.
In this form, the bc language contains single-letter variable, array and function names and most standard arithmetic operators, as well as the familiar control-flow constructs (if(cond)...
, while(cond)...
and for(init;cond;inc)...
) from C. Unlike C, an if
clause may not be followed by an else
.
Functions are defined using a define
keyword, and values are returned from them using a return
followed by the return value in parentheses. The auto
keyword (optional in C) is used to declare a variable as local to a function.
All numbers and variable contents are arbitrary-precision numbers whose precision (in decimal places) is determined by the global scale
variable.
The numeric base of input (in interactive mode), output and program constants may be specified by setting the reserved ibase
(input base) and obase
(output base) variables.
Output is generated by deliberately not assigning the result of a calculation to a variable.
Comments may be added to bc code by use of the C /*
and */
(start and end comment) symbols.
Mathematical operators
=Exactly as C
=
The following POSIX bc operators behave exactly like their C counterparts:
+ - * /
+= -= *= /=
++ -- < >
!= <= >=
( )
=Similar to C
=
The modulus operators, %
and %=
behave exactly like their C counterparts only when the global scale
variable is set to 0, i.e. all calculations are integer-only. Otherwise the computation is done with the appropriate scale. a%b
is defined as a-(a/b)*b
. Examples:
$ bc
bc 1.06
Copyright 1991-1994, 1997, 1998, 2000 Free Software Foundation, Inc.
This is free software with ABSOLUTELY NO WARRANTY.
For details type `warranty'.
scale=0; 5%3
2
scale=1; 5%3
.2
scale=20; 5%3
.00000000000000000002
=Conflicting with C
=
The operators
^ ^=
superficially resemble the C bitwise exclusive-or
Exclusive or, exclusive disjunction, exclusive alternation, logical non-equivalence, or logical inequality is a logical operator whose negation is the logical biconditional. With two inputs, XOR is true if and only if the inputs differ (one ...
operators, but are in fact the bc integer exponentiation operators.
Of particular note, the use of the ^
operator with negative numbers does not follow the C operator precedence. -2^2
gives the answer of 4 under bc rather than −4.
="Missing" operators relative to C
=
The bitwise, Boolean and conditional operators:
& , ^ && , ,
&= , = ^= &&= , , =
<< >>
<<= >>=
?:
are not available in POSIX bc.
Built-in functions
The sqrt()
function for calculating square root
In mathematics, a square root of a number is a number such that y^2 = x; in other words, a number whose ''square'' (the result of multiplying the number by itself, or y \cdot y) is . For example, 4 and −4 are square roots of 16 because 4 ...
s is POSIX bc's only built-in mathematical function. Other functions are available in an external standard library.
The scale()
function for determining the precision (as with the scale
variable) of its argument and the length()
function for determining the number of significant decimal digits in its argument are also built-in.
Standard library functions
bc's standard math library (defined with the -l option) contains functions for calculating sine
In mathematics, sine and cosine are trigonometric functions of an angle. The sine and cosine of an acute angle are defined in the context of a right triangle: for the specified angle, its sine is the ratio of the length of the side opposite th ...
, cosine
In mathematics, sine and cosine are trigonometric functions of an angle. The sine and cosine of an acute angle are defined in the context of a right triangle: for the specified angle, its sine is the ratio of the length of the side opposite that ...
, arctangent
In mathematics, the inverse trigonometric functions (occasionally also called ''antitrigonometric'', ''cyclometric'', or ''arcus'' functions) are the inverse functions of the trigonometric functions, under suitably restricted domains. Specific ...
, natural logarithm
The natural logarithm of a number is its logarithm to the base of a logarithm, base of the e (mathematical constant), mathematical constant , which is an Irrational number, irrational and Transcendental number, transcendental number approxima ...
, the exponential function and the two parameter Bessel function
Bessel functions, named after Friedrich Bessel who was the first to systematically study them in 1824, are canonical solutions of Bessel's differential equation
x^2 \frac + x \frac + \left(x^2 - \alpha^2 \right)y = 0
for an arbitrary complex ...
''J''. Most standard mathematical functions (including the other inverse trigonometric functions) can be constructed using these. See external links for implementations of many other functions.
The -l option changes the scale to 20, so things such as modulo may work unexpectedly. For example, writing bc -l
and then the command print 3%2
outputs 0. But writing scale=0
after bc -l
and then the command print 3%2
will output 1.
Plan 9 bc
Plan 9 bc is identical to POSIX bc but for an additional print
statement.
GNU bc
GNU bc derives from the POSIX standard and includes many extensions. It is entirely separate from dc-based implementations of the POSIX standard and is instead written in C. Nevertheless, it is fully backwards compatible as all POSIX bc programs will run unmodified as GNU bc programs.
GNU bc variables, arrays and function names may contain more than one character, some more operators have been included from C, and notably, an if
clause may be followed by an else
.
Output is achieved either by deliberately not assigning a result of a calculation to a variable (the POSIX way) or by using the added print
statement.
Furthermore, a read
statement allows the interactive input of a number into a running calculation.
In addition to C-style comments, a #
character will cause everything after it until the next new-line to be ignored.
The value of the last calculation is always stored within the additional built-in last
variable.
Extra operators
The following logical operator
In logic, a logical connective (also called a logical operator, sentential connective, or sentential operator) is a logical constant. Connectives can be used to connect logical formulas. For instance in the syntax of propositional logic, the ...
s are additional to those in POSIX bc:
&& , , !
They are available for use in conditional statements (such as within an if
statement). Note, however, that there are still no equivalent bitwise or assignment operations.
Functions
All functions available in GNU bc are inherited from POSIX. No further functions are provided as standard with the GNU distribution.
Example code
Since the bc ^
operator only allows an integer power to its right, one of the first functions a bc user might write is a power function with a floating-point exponent. Both of the below assume the standard library has been included:
A "power" function in POSIX bc
/* A function to return the integer part of x */
define i(x)
/* Use the fact that x^y e^(y*log(x)) */
define p(x,y)
Calculating π to 10000 digits
Calculate pi using the builtin arctangent
In mathematics, the inverse trigonometric functions (occasionally also called ''antitrigonometric'', ''cyclometric'', or ''arcus'' functions) are the inverse functions of the trigonometric functions, under suitably restricted domains. Specific ...
function, :
$ bc -lq
scale=10000
4*a(1) # The atan of 1 is 45 degrees, which is pi/4 in radians.
# This may take several minutes to calculate.
A translated C function
Because the syntax of bc is similar to that of C, published numerical functions written in C can often be translated into bc quite easily, which immediately provides the arbitrary precision of bc. For example, in the Journal of Statistical Software (July 2004, Volume 11, Issue 5), George Marsaglia published the following C code for the cumulative normal distribution:
double Phi(double x)
With some necessary changes to accommodate bc's different syntax, and noting that the constant "0.9189..." is actually log(2*PI)/2, this can be translated to the following GNU bc code:
define phi(x)
Using bc in shell scripts
bc can be used non-interactively, with input through a pipe. This is useful inside shell script
A shell script is a computer program designed to be run by a Unix shell, a command-line interpreter. The various dialects of shell scripts are considered to be command languages. Typical operations performed by shell scripts include file manipu ...
s. For example:
$ result=$(echo "scale=2; 5 * 7 /3;" , bc)
$ echo $result
11.66
In contrast, note that the bash shell only performs integer arithmetic, e.g.:
$ result=$((5 * 7 /3))
$ echo $result
11
One can also use the here-string idiom (in bash, ksh, csh):
$ bc -l <<< "5*7/3"
11.66666666666666666666
See also
* dc programming language
* C programming language
C (''pronounced'' '' – like the letter c'') is a general-purpose programming language. It was created in the 1970s by Dennis Ritchie and remains very widely used and influential. By design, C's features cleanly reflect the capabilities of ...
* hoc programming language
References
*
GNU bc manual page
*
7th Edition Unix bc manual page
A comp.compilers article on the design and implementation of C-bc
6th Edition Unix bc source code
the first release of bc, from May 1975, compiling bc syntax into dc syntax
GNU bc source code
External links
Dittmer, I. 1993. Error in Unix commands dc and bc for multiple-precision-arithmetic. SIGNUM Newsl. 28, 2 (Apr. 1993), 8–11.
Collection of useful GNU bc functions
GNU bc
(and a
alpha version
from the Free Software Foundation
from GnuWin32
Gavin Howard bc
- another open source implementation of bc by Gavin Howard with GNU and BSD extensions
X-bc
- A Graphical User Interface to bc
*
- contains functions of trigonometry, exponential functions, functions of number theory and some mathematical constants
*
- contains particle masses, basic constants, such as speed of light in the vacuum and the gravitational constant
{{Plan 9 commands
Software calculators
Cross-platform free software
Free mathematics software
Numerical programming languages
Standard Unix programs
Unix SUS2008 utilities
Plan 9 commands