Välistav disjunktsioon

Allikas: testwiki
Mine navigeerimisribale Mine otsikasti

Mall:Keeletoimeta

Tehte ABVenni diagramm

OR kuid mitte AND on XOR

Tehte ABCVenni diagramm

Välistav disjunktsioon ehk välistav VÕI (kasutatakse ka termineid mitteekvivalents [1], antiekvivalents, range disjunktsioon [2]) on lausearvutuses binaarne tehe, mis on tõene parajasti siis, kui tema operandidel on erinevad väärtused (kui üks on tõene ja teine väär)[3]

Seda tähistatakse järgmiste infiksoperaatoritega: XOR, EOR, EXOR, , , , , , ja . Poola kujul on vastav operaator J[4]. Argumentide p ja q välistavat disjunktsiooni saab seega muuhulgas tähistada kõikidel järgnevatel viisidel: pq, p q, Jpq.

Tehte XOR eitus on loogiline ekvivalents, mille väljund on tõene parajasti siis, kui mõlemad sisendid on tõesed.

Nimi "välistav või" tuleb sellest, et tavaline disjunktsioon on tõene ka siis, kui mõlemad sisendid on tõesed; välistava või operaator n-ö välistab selle juhtumi ning tagastab sel juhul väära väärtuse. Loomulikus keeles on välistava disjunktsiooni indikaatoriteks väljendid "kas...või"; "emb-kumb". Näiteks lause "Kas järgid seadust või saad karistada" väljendab välistava või tehet.[2]

Üldisemalt on XOR tõene ainult siis, kui paaritu arv sisendeid on tõesed. Ahel XOR tehetest – a XOR b XOR c XOR d (ja nii edasi) – on tõene siis, kui paaritu arv sisenditest on tõesed, ning väär siis, kui paarisarv sisenditest on tõesed.

Notatsioon

Välistava disjunktsiooni tähistus erineb olenevalt teksti valdkonnast või isegi sellest, milliseid omadusi soovitakse antud kontekstis rõhutada. Lisaks lühendile "XOR" kasutatakse ka kõiki järgnevaid sümboleid.

  • +, plussmärk, mille eelis on see, et kõiki tavalisi ringide ja korpuste algebralisi omadusi saab kasutada ilma lisatäpsustusteta; plussmärki kasutatakse ka vahel tavalise disjunktsiooni tähisena.
 p   q  p+q
0 0 0
0 1 1
1 0 1
1 1 0
  • , plussmärk, millel on ring ümber; seda sümbolit kasutatakse matemaatikas ka otsesumma jaoks.
  • J, nagu Jpq
  • Kasutatakse ka tavalise disjunktsiooni sümbolit (), mida on mingil moel muudetud, nagu järgnevalt
    • _
    • ˙
  • ^, sisestusmärk (caret), kasutatakse mitmetes programmeerimiskeeltes, nagu C, C++, C#, D, Java, Perl, Ruby, PHP ja Python, tähistab bitikaupa tehtavat XOR operaatorit; seda ei kasutata programmeerimise kontekstidest väljaspool, sest seda saab liiga kergesti segamini ajada sama sümboli teiste kasutustega
  • , vahel kujutatud ka järgnevalt
    • ><
    • >-<
  • =1, IEC sümboloogias

Tõeväärtustabel

Vasakul pool olevad argumendid kombineeritud XOR tehtega. See on binaarne Walshi maatriks (cf. Hadamardi kood).

Tehte A XOR B tõeväärtustabel näitab, et tehte väärtus on tõene parajasti siis, kui sisendite väärtused on erinevad.

SISEND VÄLJUND
A B AB
TÕENE TÕENE VÄÄR
TÕENE VÄÄR TÕENE
VÄÄR TÕENE TÕENE
VÄÄR VÄÄR VÄÄR

Ekvivalentsid, elimineerimine ja sissejuhatus

Välistavat disjunktsiooni pq võib väljendada ka konjunktsiooni, disjunktsiooni ja eituse kaudu esitada järgnevalt:

pq(pq)¬(pq)

Selle ekvivalentsi tõestus on antud järgmiselt:

pq(p¬q)(¬pq)((p¬q)¬p)((p¬q)q)((p¬p)(¬q¬p))((pq)(¬qq))(¬p¬q)(pq)¬(pq)(pq)

Vahel on ka kasulik kirjutada pq tehet järgmistel viisidel:

pq=¬((pq)(¬p¬q))
pq(p¬q)(¬pq)
pq(pq)(¬p¬q)

Viimast ekvivalentsi saab tõestada, kasutades eelnevalt mainitud tõestuse neljandal real kaks korda De Morgani seadusi.

Välistav disjunktsioon on samuti samaväärne loogilise ekvivalentsiga, implikatsiooni ja ekvivalentsi teisendusreeglite tõttu.

Kokkuvõttes on meil järgnevad samaväärsused matemaatilises notatsioonis ja tehnilises notatsioonis (engineering notation):

pq(p¬q)(¬pq)=pq+pq(pq)(¬p¬q)=(p+q)(p+q)(pq)¬(pq)(p+q)(pq)

Omadused

kommutatiivsus: jah

AB          BA
        

assotsiatiivsus: jah

A (BC)          (AB) C
                 

distributiivsus: Välistaval võil ei kehti distributiivsus ühegi binaarse funktsiooniga (isegi mitte iseendaga), aga loogilisel konjunktsioonil kehtib distributiivsus välistava võiga. C(AB)=CCB

idempotentsus: ei

A A          0 A
        

monotoonsus: ei

AB          (AC) (BC)
                 

tõesust säilitav: ei

Kui kõik sisendid on tõesed, ei ole väljund tõene

AB          AB
        

väärsust säilitav: jah

Kui kõik sisendid on väärad, on ka väljund väär.

AB          AB
        

Walshi spektrum: (2,0,0,-2)

Mittelineaarsus: 0 (funktsioon on lineaarne)

Kasutades binaarseid väärtuseid tõese (1) ja väära (0) jaoks, siis käitub välistav disjunktsioon täpselt nagu liitmine mooduli 2 järgi.

"Välistav või" loomulikus keeles

"Eesti keele seletav sõnaraamat" selgitab lausestruktuuri "kas ... või" järgnevalt [5]:Mall:Quote

Rakendusi informaatikas

XOR loogikavärava tavapärane tähistus

Loogikatehted

Nimber liitmine on mittenegatiivsetele täisarvudele binaarsüsteemis vastav välistava või tehe. See on ka vektorite liitmine (/2)4korral.

Välistavat võid kasutatakse tihti bitikaupa tehtavaid loogikatehetes. Näited:

  • 1 XOR 1 = 0
  • 1 XOR 0 = 1
  • 0 XOR 1 = 1
  • 0 XOR 0 = 0

Nagu eespool mainitud, on välistav disjunktsioon ekvivalentne liitmine modulo 2-ga. Kahe n-bitise stringi välistav disjunktsioon on ekvivalentne standardse liitmisvektoriga vektorruumis (/2)n.

Informaatikas on välistaval disjunktsioonil mitmeid kasutusi:

  • See ütleb, millal on kaks bitti üksteisest erinevad
  • Seda saab kasutada kontrollitava bittide muutjana (otsustav sisend määrab ära, kas teise sisendi väärtust muuta või mitte).
  • Selle abil saab kindlaks teha, kas bitte väärtusega 1 on paaritu arv. (ABCDE on tõene parajasti siis, kui paaritu arv muutujaid on tõesed).

Mõnes arvutiarhitektuuris on efektiivsem hoiustada registris väärtust null nii, et XOR-itakse register iseendaga (bitid, mis XOR-itakse iseendaga tagastavad alati nulli) selle asemel, et nulli väärtust liigutada ja hoiustada.

Arvutigraafikas kasutatakse välisata disjunktsiooni tehet esemete liigutamise kujutamiseks.[1]

Kodeeringud

Peale ASCII koodide on välistav või kodeeritud kui U+22BB ⊻ XOR (HTML &#8891;) ja U+2295 ⊕ CIRCLED PLUS (HTML &#8853; · &oplus;).

Viited

Mall:Viited

Välislingid

Mall:Loogiline tehe

  1. 1,0 1,1 Viitamistõrge: Vigane <ref>-silt. Viide nimega :0 on ilma tekstita.
  2. 2,0 2,1 Viitamistõrge: Vigane <ref>-silt. Viide nimega :1 on ilma tekstita.
  3. Viitamistõrge: Vigane <ref>-silt. Viide nimega wolfram on ilma tekstita.
  4. Viitamistõrge: Vigane <ref>-silt. Viide nimega 9y0Fo on ilma tekstita.
  5. Viitamistõrge: Vigane <ref>-silt. Viide nimega TMmva on ilma tekstita.