AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Wahrheitstabelle zu bool'schen Ausdruck
Thema durchsuchen
Ansicht
Themen-Optionen

Wahrheitstabelle zu bool'schen Ausdruck

Ein Thema von Medium · begonnen am 12. Dez 2009 · letzter Beitrag vom 12. Dez 2009
Antwort Antwort
Medium

Registriert seit: 23. Jan 2008
3.679 Beiträge
 
Delphi 2007 Enterprise
 
#1

Wahrheitstabelle zu bool'schen Ausdruck

  Alt 12. Dez 2009, 18:08
So, mal was für die Theoretiker unter uns

Ich hab hier eine Tabelle mit 6 Konditionen, und darin sämtliche Verknüpfungen dieser die "wahr" ergeben sollen. Alle anderen sollen "falsch" liefern. Da ich diese 16 Kombis die "wahr" sein sollen ungern alle einzeln abtesten will, suche ich nun nach einem Verfahren wie ich diese Tabelle in einen möglichst kurzen logischen Term überführe, der nur "and", "or", "not" und "xor" beinhaltet.

Meine Tabelle schaut so aus: (blank = 0)
Code:
A | | |1|1| | |1|1| |1| |1| |1| |1|
B | | |1| |1| |1|1| |1| |1|1|1| | |
C | | | |1| |1|1|1| |1| |1| | |1|1|
D |1| | | |1|1|1| |1| |1| |1|1| | |
E | |1| | |1|1| |1|1| |1| | | |1|1|
F | |1| |1| |1| |1| | |1|1| | |1|1|
--+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-|
= |1|1|1|1|1|1|1|1|1|1|1|1|1|1|1|1|
Da bekomm ich eindeutig nen von
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat
Benutzerbild von JasonDX
JasonDX
(CodeLib-Manager)

Registriert seit: 5. Aug 2004
Ort: München
1.062 Beiträge
 
#2

Re: Wahrheitstabelle zu bool'schen Ausdruck

  Alt 12. Dez 2009, 18:16
Du könntest dir den Quine-McCluskey-Algorithmus angucken. Der ist eine maschinenfreundliche Form der KV-Diagramme und genau für solche Problemstellungen gemacht. Dammit kannst du die kürzeste DNF- bzw. CNF-Formel zu einer gegebenen Wahrheitstabelle berechnen.

greetz
Mike
Mike
Passion is no replacement for reason
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.679 Beiträge
 
Delphi 2007 Enterprise
 
#3

Re: Wahrheitstabelle zu bool'schen Ausdruck

  Alt 12. Dez 2009, 18:19
Da ich das nur für diesen einen speziellen Fall brauche, würd' ich es lieber von Hand machen statt gleich ein ganzes Programm dafür zu bauen Allerdings nicht uninteressant!
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu
Online

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
43.142 Beiträge
 
Delphi 12 Athens
 
#4

Re: Wahrheitstabelle zu bool'schen Ausdruck

  Alt 12. Dez 2009, 18:30
Den kürzesten Algo bekommt man so zwar nicht, ber du kannst ja einfach erstmal nah gemeinsamkeiten schauen und diese dann zusammenfassen.
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat
Benutzerbild von JasonDX
JasonDX
(CodeLib-Manager)

Registriert seit: 5. Aug 2004
Ort: München
1.062 Beiträge
 
#5

Re: Wahrheitstabelle zu bool'schen Ausdruck

  Alt 12. Dez 2009, 18:31
Im Wikipedia-Artikel unten sind ein paar Implementierungen verlinkt, unter anderem auch ein Applet. Die kannst du dann dafür verwenden
Allerdings sind das lediglich die minimalen CNF-/DNF-Formeln. Beliebige Kombinationen aus and, or, xor und not könnten evt. noch zu kleineren Formeln führen.

greetz
Mike
Mike
Passion is no replacement for reason
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.679 Beiträge
 
Delphi 2007 Enterprise
 
#6

Re: Wahrheitstabelle zu bool'schen Ausdruck

  Alt 12. Dez 2009, 18:52
Hey das Applet ist cool Für meine Tabelle hat es den vergleichsweise handlichen Term:
(!x5*!x3*x2*!x0)+(!x5*!x4*x1*x0)+(x5*x4*!x1*!x0)+( x5*x3*!x2*x0)
ausgespuckt. Nur wie war das noch, * ist 'oder' und + ist 'und', oder war's umgekehrt?
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu
Online

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
43.142 Beiträge
 
Delphi 12 Athens
 
#7

Re: Wahrheitstabelle zu bool'schen Ausdruck

  Alt 12. Dez 2009, 19:31
+ oder
* und

Code:
Result := (not a and not b and e and f)
  or (a and b and not e and not f)
  or (a and c and not d and f)
  or (not a and b and not c and d and not e);
per Hand und nach einfachen Gemeinsamkeiten suchend:
Code:
(A = B) and (E = F) and (A <> F) and (C = D) // 2 3 6 7
aber hier sind erstmal nur 4 der 16 Möglichkeiten drinnen, also kleiner als das Apllet bekommt man es so schonmal nicht.


Aber hattest du alle Möglichkeiten eingegeben?
Also auch die 0-Ergebnisse ... nicht daß dann was anderes rauskommt.
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat
Medium

Registriert seit: 23. Jan 2008
3.679 Beiträge
 
Delphi 2007 Enterprise
 
#8

Re: Wahrheitstabelle zu bool'schen Ausdruck

  Alt 12. Dez 2009, 20:02
Danke für die Aufklärung!

Bei dem Applet steht bei, dass es reicht die 1-er Fälle einzutragen, und dass Beliebigkeiten auch eingegeben werden müssen. Das hab ich so verstanden, dass der Ergebnisterm wirklich 1:1 zu o.g. Tabelle passt.

Von Hand hatte ich mich auch ein wenig versucht, sogar mit Baum aufstellen und so Krams, hab aber nach ~1h aufgegeben. Ich konnte mich nur noch zu dunkel an meine Theo.-Inf. Vorlesung erinnern: Es reichte nur noch für "da gab es was"
"When one person suffers from a delusion, it is called insanity. When a million people suffer from a delusion, it is called religion." (Richard Dawkins)
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 14:34 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz