The KCalc Handbook

The KCalc Handbook

Bernd Johannes Wuebben

Pamela Roberts

Anne-Marie Mahfouf

Revision Applications 16.08 (2016-07-25)

KCalc is a calculator for your desktop environment. In the simple mode it can be used for basic arithmetic operations, but provides advanced modes for scientific, statistical and numeral system calculations.


Chapter 1. Introduction

Chapter 1. Introduction

KCalc offers many more mathematical functions than meet the eye on a first glance. Please study the section on keyboard accelerators and modes in this handbook to learn more about the many functions available.

In addition to the usual functionality offered by most scientific calculators, KCalc offers a number of features, which I think are worthwhile pointing out:

  • KCalc provides trigonometric functions, logic operations, and it is able to do statistical calculations.

  • KCalc allows you to cut and paste numbers from/into its display.

  • KCalc features a results-stack which lets you conveniently recall previous results.

  • You can configure KCalc's display colors and font.

  • You can configure KCalc's precision, the number of displayed digits and the number of digits after the period in the settings dialog.

  • KCalc offers a great number of useful key-bindings, which make using KCalc without using a pointing device easy.

    Hint: pressing (and holding) the Ctrl-key, displays on every button,the corresponding key-binding.

Note

KCalc uses Infix notation which enforces correct order of operations as taught in school; contrary to Immediate execution used by many simple calculators.

Have fun with KCalc!

Bernd Johannes Wuebben

Chapter 2. Usage

Chapter 2. Usage

General Usage

General usage is straight forward and similar to the way most simple scientific calculators operate, but take note of the following special KCalc features:

Result Stack

Each time you left mouse button click on the = button or press your keyboard's Enter or = keys, the display result is written to KCalc's result stack. You can navigate through the result stack with your keyboard's Ctrl+Z and Ctrl+Shift+Z keys.

Percent Function

The percent function works somewhat differently to that on most calculators. However, once understood, its enhanced functionality proves quite useful. See the section about the percent function for further details.

Cut and Paste
  • Pressing Ctrl+C will place the displayed number on to the clipboard.

  • Pressing Ctrl+V will paste the clipboard content into the display if the content of the clipboard is a valid floating point number.

  • It is still possible to copy/paste by clicking on KCalc's display, but this may disappear in future versions.

Advanced functions

When you start KCalc for the first time, the calculator will only display buttons for basic arithmetic computations.

Under the menu entry Settings it is possible to select a mode for KCalc: it is possible to choose Simple or Science or Statistic or Numeral System mode. Please note, that these modes will slightly change as KCalc evolves.

Button Layout

To give easy access to all the functions in advanced modes in KCalc, many keys have a second layout. Click on Shift or press the shortcut Ctrl+2 to make the second layout of the buttons visible.

Simple Mode

Simple Mode

This mode contains only those buttons and functions, which are essential necessary for basic calculations.

If you just want to sum up all items on an invoice this mode may be your choice.

Science Mode

Science Mode

In this mode the left column of buttons is allocated to trigonometric functions:

ButtonsFunction
HypEnter Hyperbolic sub mode. Hyp Sin for example is the hyperbolic sine: sinh
SinCompute the sine
Shift Sin or AsinCompute the inverse sine
CosCompute the cosine
Shift Cos or AcosCompute the inverse cosine
TanCompute the tangent
Shift Tan or AtanCompute the inverse tangent
LogCompute the Log base 10
Shift Log or 10xCompute 10 to the power of x
LnCompute the natural logarithm. That is the log to base e
Shift Ln or exCompute e (the base of the natural logarithm) to the power of x

The second column has buttons for algebraic functions:

ButtonsFunction
ModCompute the remainder in Euclidean division
Shift Mod or IntDivInteger division (integer part of the quotient)
1/xCompute the reciprocal for a number
Shift 1/x or nCmCompute the number of distinct second-operand-element subsets of it that can be formed for any set containing first operand elements (binomial coefficient)
x!Compute the product of all positive integers less than or equal to the current integer operand (factorial)
Compute the square of x
Shift or √xCompute the square root of x
x power y
Shift xy or x1/yx power 1/y
Computes the third (cubic) power of x
Shift or ∛xComputes the third (cubic) root of x
x·10ʸComputes the product of the first operand and decimal exponent of the second operand
Statistical Mode

Statistical Mode

In this mode the left column of buttons is allocated to statistical functions:

Most of the functionality in this mode is centered around the Dat button. To create a data list of numbers, enter a number into the calculator and press Dat. A sequentially increasing number is shown on the display indicating which position in the Data list the number occupies. A traditional calculator only stores three values for statistical functions: The number of discrete items in a list, the sum of the data items entered and the sum of the square of all data items in the list. KCalc differs by actually storing each discrete value, allowing you to calculate the median value of the data.

ButtonsFunction
NRecall the number of data items entered
Shift N or ΣxDisplay the sum of all data items entered
MeaDisplay the mean of the data items entered
Shift Mea or Σx²Display the sum of the square of all data items entered
σNDisplay the standard deviation (n)
Shift σN or σN-1 Display the population standard deviation (n-1)
MedDisplay the median
DatEnter a data item
Shift Dat or CDatClear last data item entered
CStClear the store of all data item entered

The next two columns hold the buttons with trigonometric and algebraic functions described in the Science mode section.

Numeral System Mode

Numeral System Mode

This mode contains buttons and functions to calculate in binary, hexadecimal, octal and decimal.

You select the numeral system with the radio buttons on the right. To insert a hexadecimal number for example, just do the following: Select Hex from the radio buttons. Then enter a number and note, that you can use the letters A to F for numbers larger than 9. If you would like to see this number in binary, just select Bin from the radio buttons.

Binary, octal and hexadecimal numbers can be displayed as groups of digits separated by whitespaces. Such grouping can improve readability of numbers. For example, hexadecimal number AF1C42 can be displayed as AF 1C 42 with separation every second digit. Grouping can be turned off or tweaked. Select SettingsConfigure KCalc... to bring up the configuration dialog and change the setting on General page as appropriate.

You may want to select Show Bit Edit from the Settings menu to see selected bits.

There are logic operators available in this mode. These operators are:

ButtonsFunction
ANDTwo numbers are logically anded
ORTwo numbers are logically ored
XORTwo numbers are logically exclusive ored
LshLeft shift the value
RshRight shift the value
CmpPerform a 1's complement

The second column holds the buttons with algebraic functions described in the Science mode section.

The third column with the buttons A to F is enabled only in Hex mode.

Memory Operations

Memory Operations

KCalc supports the memory operations given by standard calculators plus six slots to hold constants.

Standard Memory Operations

KCalc can remember results of operations for you, and re-use them in later calculations. You can access these functions via several buttons labeled MR, MS, M+ and MC.

MS

The MS button stores the currently displayed result in memory.

M+

The M+ button adds the current result to the one in memory. So, if you had stored a 20, and the current result is a 5, your memory would contain 25 when you press it. If the memory is empty, it acts like MS and simply stores the result.

MR

The MR button gets the value stored in memory and puts it in the display.

MC

The MC button clears the memory.

If a value is stored in memory a M will appear in the status bar, next to the calculator mode indicator

Constants

The six constants buttons C1 to C6 will only be visible after activating the item Constants Buttons in the menu Settings of the menu bar. They are available in Science mode and Statistics mode

To see the value stored in each constant hover the button with the mouse pointer.

To store the number shown in the KCalc display in one of the six constants, first press Shift followed by the desired button key C1 up to C6.

To use the value stored in any of the constants in a calculation, just press the desired button (C1 to C6), and the corresponding number will appear in the display.

It is possible to change the label of the constants button to make it easier to remember which button holds which constant. Click with the right mouse button on one of the buttons C1 to C6. A popup menu appears, in which you select Set Name.

There are many (mostly physical) predefined constants, which can be put on any of the six buttons C1 - C6 by selecting the desired constant in the popup menu that appears after right clicking on one of the constant buttons and selecting Choose from List. Though the predefined constants can also be accessed via the Constants in the menu bar, storing it on a constants button is very handy, if the number is used frequently.

Single Key Accelerators

Single Key Accelerators

To simplify entering calculations from the keyboard KCalc has single key accelerators for most functions. For example entering 7R or 7r will calculate the reciprocal of 7 (1/7).

During a computation, you can always press Ctrl to make each button display its key-binding.

KeyFunctionNotes
HHypHyperbolic as in Hyp Sin, the sinh
SSin 
CCos 
TTan 
NLnlog base e
LLoglog base 10
Ctrl-2 ShiftSecond function for this button. e.g. if you want arcsin type Ctrl-2 s
\+/-Change sign
[x^2 
^x^y 
!x!Factorial
Ex10yExponent
<LshLeft shift
>RshRight shift.
&ANDLogical AND
x or *XMultiply
//Divide
DDatEnter data item in statistical mode
|ORLogical OR. Note: Shift OR is XOR
R1/xReciprocal
Enter= 
Return= 
Backspace<=Delete last number
PgUpCClear
EscCClear
PgDownACClear all
DelACClear all
:Modremainder of dividing
Alt+1 to Alt+6C1use the value stored in C1 to C6
Chapter 3. Comments on Specific Functions

Chapter 3. Comments on Specific Functions

Mod and IntDiv

Mod gives the remainder of dividing the displayed number by the next input number.

22 Mod 8 = will give the result 6

22.345 Mod 8 = will give the result 6.345

Shift IntDiv does integer division of the displayed number by the next input number.

22 Shift IntDiv 8 = will give the result 2

22.345 Shift IntDiv 8 = also gives 2

%

%

Used instead of the = key, % interprets the final operation carried out in the current calculation as follows:

  • If the final operator is + or - the second argument is interpreted as percentage of the first operand.

  • If the final operator is * divide the result of the multiplication by 100.

  • If the final operator is / give the left operand as a percentage of the right operand.

  • In all other cases the % key gives identical results to the = key.

Examples:

150 + 50 % gives 225 (150 plus 50 percent of this amount)

42 * 3 % gives 1.26 (42 * 3 / 100)

45 / 55 % gives 81.81... (45 is 81.81.. percent of 55)

Lsh and Rsh

Lsh and Rsh

Lsh left shifts the integer part of the displayed value (multiplies it by 2) n times, where n is the next input number, and gives an integer result (base is set to Bin):

10 Lsh 3 = gives 80 (10 multiplied by 2 three times).

10.345 Lsh 3 = also gives 80.

Rsh right shifts the value (performs an integer divide by 2) n times.

16 Rsh 2 = gives 4 (16 divided by 2 twice).

16.999 Rsh 2 = also gives 4.

Cmp, And, Or and Xor

Cmp, And, Or and Xor

The Cmp, And and Or functions perform bitwise logical operations and therefore appear more meaningful if the base is set to Hex, Oct or Bin rather than Dec. In the following examples base is set to Bin.

Cmp performs a 1's complement (inverts the bits).

101 Cmp gives 111...111010

AND does a logical AND.

101 AND 110 = gives 100

OR does the logical OR.

101 OR 110 = gives 111

XOR performs the logical XOR (exclusive OR) operation.

101 XOR 110 = gives 11

Chapter 4. Questions and Answers

Chapter 4. Questions and Answers

4.1. How do I get e, the Euler number?
4.2. How do I get two fixed digits after the period?
4.3. What about Precision?

4.1.

How do I get e, the Euler number?

Press 1 Shift ex in the KCalc window, press 1 Ctrl+2 N on the keyboard or use the ConstantsMathematics menu.

4.2.

How do I get two fixed digits after the period?

Select Settings Configure KCalc... on the menubar, this will bring up the configuration dialog. Check Set decimal precision and adjust the spin control so that it shows a 2.

4.3.

What about Precision?

The main factor determining the precision of KCalc is whether your libc and libmath supports the C data type long double. If this is the case, KCalc will detect this at compile time and use it as its fundamental data type to represent numbers.

Adjust the Precision in KCalc's Configure dialog so that the above computations work correctly. I recommend a precision of 14 if the fundamental data type for your copy of KCalc is long double, otherwise 8 or 10.

Higher precision doesn't necessarily lead to better results. Play with the precision and you will see what I mean.

Chapter 5. Command Reference

Chapter 5. Command Reference

Menu Items

A brief overview of some special menu items in KCalc:

ConstantsMathematics

Display Pi, Euler Number or Golden Ratio.

ConstantsElectromagnetism

Display Light Speed, Elementary Charge, Impedance of Vacuum, Permeability of Vacuum or Permittivity of Vacuum.

ConstantsAtomic & Nuclear

Display Planck's Constant, Elementary Charge or Fine-Structure Constant.

ConstantsThermodynamics

Display Boltzmann Constant, Atomic Mass Unit, Molar Gas Constant, Stefan-Boltzmann Constant or Avogadro's Number.

ConstantsGravitation

Display Constant of Gravitation or Earth Acceleration.

SettingsSimple Mode

Displays the simple math buttons.

SettingsScience Mode

Displays trigonometric and science buttons.

SettingsStatistic Mode

Displays statistic buttons.

SettingsNumeral System Mode

Displays logic buttons and allows changing the numeral system.

SettingsConstants Buttons

Display constants buttons. They are available in science mode and statistic mode.

SettingsShow Bit Edit

Displays a bit edit field. Click on a bit to toggle it. Only available in numeral system mode.

Additionally KCalc has the common File, Edit, Settings and Help menu items, for more information read the sections about the Menus in the KDE Fundamentals.

Chapter 6. Credits and License

Chapter 6. Credits and License

KCalc Program Copyright (c):

Bernd Johannes Wuebben 1996-2000

The KDE Team 2000-2008

Evan Teran 2008-2013

  • Bernd Johannes Wuebben

  • Evan Teran

  • Espen Sand

  • Chris Howells

  • Aaron J. Seigo

  • Charles Samuels

  • David Johnson

KCalc was inspired by Martin Bartlett's xfrmcalc, whose stack engine is still part of KCalc.

Documentation Copyright (c) 2001,2002,2005, 2006,2010:

  • Bernd Johannes Wuebben

  • Pamela Roberts

  • J Hall

  • Anne-Marie Mahfouf

  • Eike Krumbacher

This documentation is licensed under the terms of the GNU Free Documentation License.

This program is licensed under the terms of the GNU General Public License.