Misplaced Pages

Negation

Article snapshot taken from[REDACTED] with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
(Redirected from Not (logic)) Logical operation For negation in linguistics, see Affirmation and negation. For other uses, see Negation (disambiguation).

Negation
NOT
Venn diagram of Negation
Definition ¬ x {\displaystyle \lnot {x}}
Truth table ( 01 ) {\displaystyle (01)}
Logic gate
Normal forms
Disjunctive ¬ x {\displaystyle \lnot {x}}
Conjunctive ¬ x {\displaystyle \lnot {x}}
Zhegalkin polynomial 1 x {\displaystyle 1\oplus x}
Post's lattices
0-preservingno
1-preservingno
Monotoneno
Affineyes
Self-dualyes
Logical connectives
NOT ¬ A , A , A ¯ , A {\displaystyle \neg A,-A,{\overline {A}},\sim A}
AND A B , A B , A B , A   &   B , A   & &   B {\displaystyle A\land B,A\cdot B,AB,A\ \&\ B,A\ \&\&\ B}
NAND A ¯ B , A B , A B , A B ¯ {\displaystyle A{\overline {\land }}B,A\uparrow B,A\mid B,{\overline {A\cdot B}}}
OR A B , A + B , A B , A B {\displaystyle A\lor B,A+B,A\mid B,A\parallel B}
NOR A ¯ B , A B , A + B ¯ {\displaystyle A{\overline {\lor }}B,A\downarrow B,{\overline {A+B}}}
XNOR A B , A ¯ B ¯ {\displaystyle A\odot B,{\overline {A{\overline {\lor }}B}}}
equivalent A B , A B , A B {\displaystyle A\equiv B,A\Leftrightarrow B,A\leftrightharpoons B}
XOR A _ B , A B {\displaystyle A{\underline {\lor }}B,A\oplus B}
└nonequivalent A B , A B , A B {\displaystyle A\not \equiv B,A\not \Leftrightarrow B,A\nleftrightarrow B}
implies A B , A B , A B {\displaystyle A\Rightarrow B,A\supset B,A\rightarrow B}
nonimplication (NIMPLY) A B , A B , A B {\displaystyle A\not \Rightarrow B,A\not \supset B,A\nrightarrow B}
converse A B , A B , A B {\displaystyle A\Leftarrow B,A\subset B,A\leftarrow B}
converse nonimplication A B , A B , A B {\displaystyle A\not \Leftarrow B,A\not \subset B,A\nleftarrow B}
Related concepts
Applications
Category

In logic, negation, also called the logical not or logical complement, is an operation that takes a proposition P {\displaystyle P} to another proposition "not P {\displaystyle P} ", written ¬ P {\displaystyle \neg P} , P {\displaystyle {\mathord {\sim }}P} , P {\displaystyle P^{\prime }} or P ¯ {\displaystyle {\overline {P}}} . It is interpreted intuitively as being true when P {\displaystyle P} is false, and false when P {\displaystyle P} is true. For example, if P {\displaystyle P} is "Spot runs", then "not P {\displaystyle P} " is "Spot does not run". An operand of a negation is called a negand or negatum.

Negation is a unary logical connective. It may furthermore be applied not only to propositions, but also to notions, truth values, or semantic values more generally. In classical logic, negation is normally identified with the truth function that takes truth to falsity (and vice versa). In intuitionistic logic, according to the Brouwer–Heyting–Kolmogorov interpretation, the negation of a proposition P {\displaystyle P} is the proposition whose proofs are the refutations of P {\displaystyle P} .

Definition

Classical negation is an operation on one logical value, typically the value of a proposition, that produces a value of true when its operand is false, and a value of false when its operand is true. Thus if statement P {\displaystyle P} is true, then ¬ P {\displaystyle \neg P} (pronounced "not P") would then be false; and conversely, if ¬ P {\displaystyle \neg P} is true, then P {\displaystyle P} would be false.

The truth table of ¬ P {\displaystyle \neg P} is as follows:

P {\displaystyle P} ¬ P {\displaystyle \neg P}
True False
False True

Negation can be defined in terms of other logical operations. For example, ¬ P {\displaystyle \neg P} can be defined as P {\displaystyle P\rightarrow \bot } (where {\displaystyle \rightarrow } is logical consequence and {\displaystyle \bot } is absolute falsehood). Conversely, one can define {\displaystyle \bot } as Q ¬ Q {\displaystyle Q\land \neg Q} for any proposition Q (where {\displaystyle \land } is logical conjunction). The idea here is that any contradiction is false, and while these ideas work in both classical and intuitionistic logic, they do not work in paraconsistent logic, where contradictions are not necessarily false. As a further example, negation can be defined in terms of NAND and can also be defined in terms of NOR.

Algebraically, classical negation corresponds to complementation in a Boolean algebra, and intuitionistic negation to pseudocomplementation in a Heyting algebra. These algebras provide a semantics for classical and intuitionistic logic.

Notation

The negation of a proposition p is notated in different ways, in various contexts of discussion and fields of application. The following table documents some of these variants:

Notation Plain text Vocalization
¬ p {\displaystyle \neg p} ¬p , 7p Not p
p {\displaystyle {\mathord {\sim }}p} ~p Not p
p {\displaystyle -p} -p Not p
N p {\displaystyle Np} En p
p {\displaystyle p'} p'
  • p prime,
  • p complement
p ¯ {\displaystyle {\overline {p}}} ̅p
  • p bar,
  • Bar p
! p {\displaystyle !p} !p
  • Bang p
  • Not p

The notation N p {\displaystyle Np} is Polish notation.

In set theory, {\displaystyle \setminus } is also used to indicate 'not in the set of': U A {\displaystyle U\setminus A} is the set of all members of U that are not members of A.

Regardless how it is notated or symbolized, the negation ¬ P {\displaystyle \neg P} can be read as "it is not the case that P", "not that P", or usually more simply as "not P".

Precedence

See also: Logical connective § Order of precedence

As a way of reducing the number of necessary parentheses, one may introduce precedence rules: ¬ has higher precedence than ∧, ∧ higher than ∨, and ∨ higher than →. So for example, P Q ¬ R S {\displaystyle P\vee Q\wedge {\neg R}\rightarrow S} is short for ( P ( Q ( ¬ R ) ) ) S . {\displaystyle (P\vee (Q\wedge (\neg R)))\rightarrow S.}

Here is a table that shows a commonly used precedence of logical operators.

Operator Precedence
¬ {\displaystyle \neg } 1
{\displaystyle \land } 2
{\displaystyle \lor } 3
{\displaystyle \to } 4
{\displaystyle \leftrightarrow } 5

Properties

Double negation

Within a system of classical logic, double negation, that is, the negation of the negation of a proposition P {\displaystyle P} , is logically equivalent to P {\displaystyle P} . Expressed in symbolic terms, ¬ ¬ P P {\displaystyle \neg \neg P\equiv P} . In intuitionistic logic, a proposition implies its double negation, but not conversely. This marks one important difference between classical and intuitionistic negation. Algebraically, classical negation is called an involution of period two.

However, in intuitionistic logic, the weaker equivalence ¬ ¬ ¬ P ¬ P {\displaystyle \neg \neg \neg P\equiv \neg P} does hold. This is because in intuitionistic logic, ¬ P {\displaystyle \neg P} is just a shorthand for P {\displaystyle P\rightarrow \bot } , and we also have P ¬ ¬ P {\displaystyle P\rightarrow \neg \neg P} . Composing that last implication with triple negation ¬ ¬ P {\displaystyle \neg \neg P\rightarrow \bot } implies that P {\displaystyle P\rightarrow \bot } .

As a result, in the propositional case, a sentence is classically provable if its double negation is intuitionistically provable. This result is known as Glivenko's theorem.

Distributivity

De Morgan's laws provide a way of distributing negation over disjunction and conjunction:

¬ ( P Q ) ( ¬ P ¬ Q ) {\displaystyle \neg (P\lor Q)\equiv (\neg P\land \neg Q)} ,  and
¬ ( P Q ) ( ¬ P ¬ Q ) {\displaystyle \neg (P\land Q)\equiv (\neg P\lor \neg Q)} .

Linearity

Let {\displaystyle \oplus } denote the logical xor operation. In Boolean algebra, a linear function is one such that:

If there exists a 0 , a 1 , , a n { 0 , 1 } {\displaystyle a_{0},a_{1},\dots ,a_{n}\in \{0,1\}} , f ( b 1 , b 2 , , b n ) = a 0 ( a 1 b 1 ) ( a n b n ) {\displaystyle f(b_{1},b_{2},\dots ,b_{n})=a_{0}\oplus (a_{1}\land b_{1})\oplus \dots \oplus (a_{n}\land b_{n})} , for all b 1 , b 2 , , b n { 0 , 1 } {\displaystyle b_{1},b_{2},\dots ,b_{n}\in \{0,1\}} .

Another way to express this is that each variable always makes a difference in the truth-value of the operation, or it never makes a difference. Negation is a linear logical operator.

Self dual

In Boolean algebra, a self dual function is a function such that:

f ( a 1 , , a n ) = ¬ f ( ¬ a 1 , , ¬ a n ) {\displaystyle f(a_{1},\dots ,a_{n})=\neg f(\neg a_{1},\dots ,\neg a_{n})} for all a 1 , , a n { 0 , 1 } {\displaystyle a_{1},\dots ,a_{n}\in \{0,1\}} . Negation is a self dual logical operator.

Negations of quantifiers

In first-order logic, there are two quantifiers, one is the universal quantifier {\displaystyle \forall } (means "for all") and the other is the existential quantifier {\displaystyle \exists } (means "there exists"). The negation of one quantifier is the other quantifier ( ¬ x P ( x ) x ¬ P ( x ) {\displaystyle \neg \forall xP(x)\equiv \exists x\neg P(x)} and ¬ x P ( x ) x ¬ P ( x ) {\displaystyle \neg \exists xP(x)\equiv \forall x\neg P(x)} ). For example, with the predicate P as "x is mortal" and the domain of x as the collection of all humans, x P ( x ) {\displaystyle \forall xP(x)} means "a person x in all humans is mortal" or "all humans are mortal". The negation of it is ¬ x P ( x ) x ¬ P ( x ) {\displaystyle \neg \forall xP(x)\equiv \exists x\neg P(x)} , meaning "there exists a person x in all humans who is not mortal", or "there exists someone who lives forever".

Rules of inference

See also: Double negation

There are a number of equivalent ways to formulate rules for negation. One usual way to formulate classical negation in a natural deduction setting is to take as primitive rules of inference negation introduction (from a derivation of P {\displaystyle P} to both Q {\displaystyle Q} and ¬ Q {\displaystyle \neg Q} , infer ¬ P {\displaystyle \neg P} ; this rule also being called reductio ad absurdum), negation elimination (from P {\displaystyle P} and ¬ P {\displaystyle \neg P} infer Q {\displaystyle Q} ; this rule also being called ex falso quodlibet), and double negation elimination (from ¬ ¬ P {\displaystyle \neg \neg P} infer P {\displaystyle P} ). One obtains the rules for intuitionistic negation the same way but by excluding double negation elimination.

Negation introduction states that if an absurdity can be drawn as conclusion from P {\displaystyle P} then P {\displaystyle P} must not be the case (i.e. P {\displaystyle P} is false (classically) or refutable (intuitionistically) or etc.). Negation elimination states that anything follows from an absurdity. Sometimes negation elimination is formulated using a primitive absurdity sign {\displaystyle \bot } . In this case the rule says that from P {\displaystyle P} and ¬ P {\displaystyle \neg P} follows an absurdity. Together with double negation elimination one may infer our originally formulated rule, namely that anything follows from an absurdity.

Typically the intuitionistic negation ¬ P {\displaystyle \neg P} of P {\displaystyle P} is defined as P {\displaystyle P\rightarrow \bot } . Then negation introduction and elimination are just special cases of implication introduction (conditional proof) and elimination (modus ponens). In this case one must also add as a primitive rule ex falso quodlibet.

Programming language and ordinary language

"!vote" redirects here. For use of !votes in Misplaced Pages discussions, see Misplaced Pages:Polling is not a substitute for discussion § Not-votes.

As in mathematics, negation is used in computer science to construct logical statements.

if (!(r == t))
{
    /*...statements executed when r does NOT equal t...*/
}

The exclamation mark "!" signifies logical NOT in B, C, and languages with a C-inspired syntax such as C++, Java, JavaScript, Perl, and PHP. "NOT" is the operator used in ALGOL 60, BASIC, and languages with an ALGOL- or BASIC-inspired syntax such as Pascal, Ada, Eiffel and Seed7. Some languages (C++, Perl, etc.) provide more than one operator for negation. A few languages like PL/I and Ratfor use ¬ for negation. Most modern languages allow the above statement to be shortened from if (!(r == t)) to if (r != t), which allows sometimes, when the compiler/interpreter is not able to optimize it, faster programs.

In computer science there is also bitwise negation. This takes the value given and switches all the binary 1s to 0s and 0s to 1s. This is often used to create ones' complement (or "~" in C or C++) and two's complement (just simplified to "-" or the negative sign, as this is equivalent to taking the arithmetic negation of the number).

To get the absolute (positive equivalent) value of a given integer the following would work as the "-" changes it from negative to positive (it is negative because "x < 0" yields true)

unsigned int abs(int x)
{
    if (x < 0)
        return -x;
    else
        return x;
}

To demonstrate logical negation:

unsigned int abs(int x)
{
    if (!(x < 0))
        return x;
    else
        return -x;
}

Inverting the condition and reversing the outcomes produces code that is logically equivalent to the original code, i.e. will have identical results for any input (depending on the compiler used, the actual instructions performed by the computer may differ).

In C (and some other languages descended from C), double negation (!!x) is used as an idiom to convert x to a canonical Boolean, ie. an integer with a value of either 0 or 1 and no other. Although any integer other than 0 is logically true in C and 1 is not special in this regard, it is sometimes important to ensure that a canonical value is used, for example for printing or if the number is subsequently used for arithmetic operations.

The convention of using ! to signify negation occasionally surfaces in ordinary written speech, as computer-related slang for not. For example, the phrase !voting means "not voting". Another example is the phrase !clue which is used as a synonym for "no-clue" or "clueless".

Kripke semantics

In Kripke semantics where the semantic values of formulae are sets of possible worlds, negation can be taken to mean set-theoretic complementation (see also possible world semantics for more).

See also

References

  1. Virtually all Turkish high school math textbooks use p' for negation due to the books handed out by the Ministry of National Education representing it as p'.
  2. Weisstein, Eric W. "Negation". mathworld.wolfram.com. Retrieved 2 September 2020.
  3. "Logic and Mathematical Statements - Worked Examples". www.math.toronto.edu. Retrieved 2 September 2020.
  4. Beall, Jeffrey C. (2010). Logic: the basics (1. publ ed.). London: Routledge. p. 57. ISBN 978-0-203-85155-5.
  5. Used as makeshift in early typewriter publications, e.g. Richard E. Ladner (January 1975). "The circuit value problem is log space complete for P". ACM SIGACT News. 7 (101): 18–20. doi:10.1145/990518.990519.
  6. O'Donnell, John; Hall, Cordelia; Page, Rex (2007), Discrete Mathematics Using a Computer, Springer, p. 120, ISBN 9781846285981.
  7. Egan, David. "Double Negation Operator Convert to Boolean in C". Dev Notes.
  8. Raymond, Eric and Steele, Guy. The New Hacker's Dictionary, p. 18 (MIT Press 1996).
  9. Munat, Judith. Lexical Creativity, Texts and Context, p. 148 (John Benjamins Publishing, 2007).

Further reading

External links

Tables of Truth of composite clauses
Common logical connectives
Philosophy portal
Common logical symbols
 or  & and or ¬  or  ~ not implies implies,
superset
 or  iff | nand universal
quantification
existential
quantification
true,
tautology
false,
contradiction
entails,
proves
entails,
therefore
therefore because
Philosophy portal
icon Mathematics portal
Formal semantics (natural language)
Central concepts
Topics
Areas
Phenomena
Formalism
Formal systems
Concepts
See also
Mathematical logic
General
Theorems (list)
 and paradoxes
Logics
Traditional
Propositional
Predicate
Set theory
Types of sets
Maps and cardinality
Set theories
Formal systems (list),
language and syntax
Example axiomatic
systems
 (list)
Proof theory
Model theory
Computability theory
Related
icon Mathematics portal
Categories:
Negation Add topic