Jump to content

Talk:Satisfiability: Difference between revisions

Page contents not supported in other languages.
From Wikipedia, the free encyclopedia
Content deleted Content added
Satisfiability: restate, again.
Line 97: Line 97:


::Meanwhile, I'll try to make small, infrequent, itty-bitty edits, as precise as seems warranted, if/when I get the urge to do so. [[User:Linas|linas]] ([[User talk:Linas|talk]]) 03:14, 21 June 2011 (UTC)
::Meanwhile, I'll try to make small, infrequent, itty-bitty edits, as precise as seems warranted, if/when I get the urge to do so. [[User:Linas|linas]] ([[User talk:Linas|talk]]) 03:14, 21 June 2011 (UTC)

::One more example of satisifiability without first-order-logic: Barendregt, "The Lambda Calculus, Its syntax and semantics" defines theories and models for lambda calculus in pages 75-125. There is a very brief mention of satisfiability on page 100. Obviously, the book never even gets close to discussing anything even vaguely related to logic, much less first-order logic. [[User:Linas|linas]] ([[User talk:Linas|talk]]) 03:37, 21 June 2011 (UTC)

Revision as of 03:37, 21 June 2011

WikiProject iconMathematics Start‑class Low‑priority
WikiProject iconThis article is within the scope of WikiProject Mathematics, a collaborative effort to improve the coverage of mathematics on Wikipedia. If you would like to participate, please visit the project page, where you can join the discussion and see a list of open tasks.
StartThis article has been rated as Start-class on Wikipedia's content assessment scale.
LowThis article has been rated as Low-priority on the project's priority scale.
WikiProject iconPhilosophy: Logic Stub‑class High‑importance
WikiProject iconThis article is within the scope of WikiProject Philosophy, a collaborative effort to improve the coverage of content related to philosophy on Wikipedia. If you would like to support the project, please visit the project page, where you can get more details on how you can help, and where you can join the general discussion about philosophy content on Wikipedia.
StubThis article has been rated as Stub-class on Wikipedia's content assessment scale.
HighThis article has been rated as High-importance on the project's importance scale.
Associated task forces:
Taskforce icon
Logic


Combine this Page with "Boolean satisfiability problem"

This page addresses the same topic, but in much less detail. Suggest merging this page into "Boolean satisfiability problem" by making it the introduction.

I would object strongly to that. This should be the main article, and boolean satisfiability should be a supporting page of this one, not vise versa. Satisfiability is a more general concept than just its boolean/propositional aspect.Greg Bard 21:31, 5 March 2010 (UTC)[reply]

Unfinished

This unfinished sentence was on the page. Anyone care to finish this?

 Validity of propositional formulae is immediately seen to be

It's currently commented out in the wikitext of the page Sam Douglas (talk) 04:38, 5 July 2009 (UTC)[reply]

My fault. I had started to write this sentence, and then decided to add the Reduction of validity to satisfiability section instead, which rendered what I was going to say redudnant. I've deleted it now. — Charles Stewart (talk) 09:45, 5 July 2009 (UTC)[reply]


... solved by Juan Manuel Dato. I had it for years, I hope someone review my code in Python 3.0 http://www.archive.org/details/TheSat3ProblemSolved You can understand the algorithm graphically in http://www.archive.org/details/ExampleInSpanishOfSatInP If you prove the code, the #P problem is not exactly solved, SAT yes. I do not know if there is a bug in the code, I suppose not (obviously). The formula is a list of functors of 3 literals, where negative means the opposite (-1 = ~X1) and 0 means literal always False. So the clausules can be constructed with 1, 2 or 3 literals. Prove it and say if it is right, there are too many technologies hidden yet. —Preceding unsigned comment added by 79.109.169.86 (talk) 18:19, 27 January 2011 (UTC) Here you are a riguorous constructive demonstration http://www.archive.org/details/ConnectionBetweenSat3AndPBetweenMatch-n —Preceding unsigned comment added by 79.109.169.15 (talk) 13:52, 20 March 2011 (UTC)[reply]

Requested move

The following discussion is an archived discussion of a requested move. Please do not modify it. Subsequent comments should be made in a new section on the talk page. No further edits should be made to this section.

The result of the move request was: page moved. Vegaswikian (talk) 00:23, 20 March 2010 (UTC)[reply]



Satisfiability and validitySatisfiability — I think this should be the main article titled "Satisfiability." Greg Bard 21:31, 5 March 2010 (UTC)[reply]

The above discussion is preserved as an archive of a requested move. Please do not modify it. Subsequent comments should be made in a new section on this talk page. No further edits should be made to this section.

satisfiability *is not* a semi-decidable problem for FOL

A formula isn't valid iff its negation is satisfiable. If satisfiability were semi-decidable, then unvalidity would be also. Therefore, as validity and unvalidity would be semi-decidable, they would be decidable indeed, which is not possible by Church-Turing *theorem*.

Am I correct? Maybe I'm missing a subtle point. —Preceding unsigned comment added by Corovo (talkcontribs) 15:58, 11 August 2010 (UTC)[reply]

satisfiablity, theories, etc.

Argh, I think I just made a mess of this article by mentioning satisfiability modulo theories. The problem is that the article about interpretations states that interpretations are interpretations of theories, but this isn't really the right idea, because for boolean sat, we have interpretations but not theories in this sense, viz not theory (mathematical logic). This inconsistency needs to be resolved across the set of inter-related articles.linas (talk) 21:59, 13 June 2011 (UTC)[reply]

Satisfiability

The language on satisfiability is, again, vague. In general even satisfiability of a theory in propositional logic is not decidable, and similarly the satisfiability of a variable-free equational theory in the language with only $0$, $1$, $+$, and $=$ is not decidable. This is because the decision process can only look at a finite part of the theory before making a decision, and there could be an inconsistency in the part that was not looked at before the decision procedure halts. Thus the decision process will either say that some satisfiable theories are unsatisfiable, or it will say that some unsatisfiable theories are satisfiable. The only thing that can be decidable, in principle, is satisfiability of a sentence or the satisfiability of a finite set of sentences. The latter is equivalent to the former in many contexts.

On to unification. Unification is simply a deductive system for first-order logic. It is not any stronger or weaker than any other deductive system (natural deduction, Hilbert-style, etc.). All of these allow us to enumerate the provable consequences of a theory. None of them can be used to solve the satisfiability question in for theories, only for sentences in some limited circumstances. — Carl (CBM · talk) 14:51, 16 June 2011 (UTC)[reply]

I've got to run, so can't do anything reasoned for about 12-24 hours. My quick take is that although satisfiability is a topic that is related to first-order logic, it is, in fact, used in many other places as well. So, for example: its important in term-rewriting, but in term re-writing, there are no predicates, no logical connectives, no quantifiers, no concept of true/false; yet satsifiability is closely defined, and algorithms to determine it are developed. So the trick for this article is to have a broad definition that fulfills the general need, and then break it down to that needed by the various different branches. linas (talk) 22:53, 16 June 2011 (UTC)[reply]
There is certainly the "=" predicate, and if you chase the definitions in "Term Rewriting and All That" they do refer to truth in the sense of model theory and first-order logic. For example, definitions 3.5.1 and 3.5.3 define the relation in terms of the model-theoretic satisfaction relation , and the definition of "satisfiable" on page 58 is in terms of substitution (which is a model-theoretic concept) and the relation. I don't have a copy of the book; I requested it from the library, so I should be able to look at it in more detail in a few days. So far I am limited to preview in google books. — Carl (CBM · talk) 00:45, 17 June 2011 (UTC)[reply]
Sorry; not to mis-lead. Of course, one can't do math with using equals signs at some point; and yes, chap 3 does review models in a more-or-less standard sense. As to whether "=" is a predicate or not is debatable. In an informal, vague sense, of course it is. However, in the formal sense, the language (or 'signature') of a term algebra does not contain predicate symbols, or atomic symbols or sentences or connectives. Informally, of course, these are casually used through-out the text to discuss results and to make claims; they just are not placed/used/defined as symbols of the objects under study. Nonetheless, one can still ask questions such as "if I have these two terms, arising from some signature S, under what cases are they equal?" which is a satisfiability problem, even though S is not (the signature of) a predicate logic, or any other kind of logic. linas (talk) 14:30, 17 June 2011 (UTC)[reply]
I think you are thinking of the special case of first-order logic in which the are no predicate symbols other than "=", and where people only look at atomic formulas, which are always of the form . This is how universal algebra is usually done, anyway: it is a special case of first-order logic, which is why model theory and universal algebra are so closely connected.
The definition of "satisfiability of an equation" in the setting of universal algebra seems to be exactly the same as the definition of satisfiability of the equation in first-order logic: is there a structure in which the two terms are equal? In the context of univseral algebra these structures are commonly called "groups", "rings", etc. but they are simply structures from the point of view of logic. — Carl (CBM · talk) 14:48, 17 June 2011 (UTC)[reply]
When you say "universal algebra is usually done as a special case of first-order logic", I will strongly argue that. I've got a book, title "Universal Algebra", Paul Cohen, and I'm pretty sure the words "first order logic" or "predicate logic" never appear anywhere in the book. At some level, yes, the one topic may be considered to be a subset of the other topic, but, in general, a narrower topic will have results and theorems that do not apply to the broader topic. When you say "seems to be the same as", I think its a mistake to try to be all fuzzy-wuzzy about definitions; I think the right approach is to give precise definitions suitable for the subfield, while having an informal intro/overview that does the hand-waving, pointing out that they're all the same, more or less.
Anyway, I propose creating a new subsection of this article, viz 'satisfiability in universal algebra' and moving the mention of unification etc. to that section. Thus it would closely resemble the first few pages of chapter 4 of the book 'term rewriting'. I believe that this should fix all your objections.linas (talk) 15:04, 17 June 2011 (UTC)[reply]
When Term rewriting says "class of algebras" that is exactly the same thing as when a person in first-order logic says "class of models", because an "algebra" in universal algebra is the same as a "model" or "structure" in first-order logic for the same signature. Thus, for example, Def. 3.2.1 in Term rewriting is exactly the definition of structure (mathematical logic) for a signature that has no predicate symbols other than =. If you are claiming there is a difference between satisfiability in universal algebra and satisfaction in first-order logic, can you say exactly what it is? So far I have been unable to find any difference. I will have a copy of Term rewriting here in a couple days that I can look at in more detail, I am a little limited by google books at the moment. — Carl (CBM · talk) 16:19, 17 June 2011 (UTC)[reply]

Are we arguing about something, or are we in violent agreement? I'm not claiming half of the things you seem to say I'm claiming, so I don't understand why this conversation is so argumentative. Honestly, I've never studied first-order logic, I do not possess any books that treat first-order logic as a subject of study; certainly Cohen's Universal algebra doesn't treat it as a topic, nor does the term-rewriting book, nor does Hodges' Model theory book. Yet all of these books touch on satisfiability and do so in a concrete fashion. If you believe that all of these different definitions of satisfiability are the same thing, that's fine. And you're almost surely right, and I think here we agree; at some informal level, I do understand that they're all the same. But the reality is that none of these authors felt compelled to define first-order logic before they could talk about satisfiability; the subject matter didn't call for it. Perhaps this article doesn't need to either; it may be a source of confusion to the student. Informally, we agree its all the same thing. Formally, I have no reference which states, in a formal fashion, that these varying definitions really are all the same thing. linas (talk) 02:06, 18 June 2011 (UTC)[reply]

You're claiming you have a model theory book by Hodges which, somehow, does not use first-order logic? The book by Hodges we cite (A Shorter Model Theory), and every other model theory book I have seen, uses the normal definition of a structure from first-order logic. This isn't "at some informal level": the definition of satisfaction in model theory is exactly the definition in first-order logic, which is the same as the definition in universal algebra. The definition of a structure (called an algebra in universal algebra) is exactly and formally the same in all these fields. This is discussed in detail on p. 58 of Term rewriting and all that where the authors carefully lay out exactly how what they are doing is a special case of validity and satisfiability from first-order logic.
My main concern with the article is that the text you added seems to be too inexact, to the point that it's hard to tell if it's even correct. It also seems to be missing context: the article is about satisfiability of formulas anad theories in general, so if you mean to limit things to a particular class of theories or formulas, the restriction has to be stated explicitly. Unification, for example, cannot be used to decide satisfiability in general (even our article on unification says this). — Carl (CBM · talk) 02:32, 18 June 2011 (UTC)[reply]
As to p 58 of that book, it says no such thing. I've made a number of suggestions in how to allay your concerns; you've rejected all of them. I've no desire to engage in an endless argument. If you think you can be constructive, please act that way. Otherwise, let us terminate this discussion, it does no good. linas (talk) 15:45, 18 June 2011 (UTC)[reply]
I'm trying to be constructive by figuring out exactly what the difference is between "satisfiability" in term rewriting and satisfiability as it is usually defined in first-order logic and model theory (if there is a difference). Until we work out exactly what the difference is in our own heads, I don't see how we can possibly make the article clear about it.
So I've been trying to use the same book you added as a reference to the article, and looking at the definitions there. But until I get an actual printed copy I am forced to use the google books version. Fortunately, it looks like the book as a sort of Rosetta stone on p. 58 that lays everything out. You could help me by just explaining what's going on.
If I am reading p. 58 correctly, the use of 'valid' is exactly the same in first-order logic and in that book, but that book uses 'satisfiable' to mean 'satisfiable in every nonempty model' rather than 'satisfiable in some nonempty model'. If that change is common in term rewriting, and is the only difference in terminology, it should take about one sentence to explain it in this article. Could you tell me if there is some other difference that I haven't noticed yet? — Carl (CBM · talk) 20:57, 18 June 2011 (UTC)[reply]

I don't think there is a difference between satifiability in universal algebra and satisfiability in first-order logic, and in fact the fundamentals of universal algebra are a subset of those of first-order logic. The only difference is that universal algebra uses slightly different terminology and then goes off in a different direction.

Although they historically did not always point it out in their publications, the connection is very well known to universal algebraists. You can ask User:Vaughan Pratt. (IIRC he thinks of himself primarily as a universal algebraist.) Or you can look in Chapter IX of the revised (1981) edition of Paul Cohen's Universal Algebra. Its title is Model theory and universal algebra, and it starts with Chang and Keisler's slogan "universal algebra + logic = model theory". Even the old edition had Chapter V, Relational structures and models, and Chapter VI, Axiomatic model classes. These three chapters are really about first-order model theory. Similarly, Grätzer's Universal Algebra used to end with Chapter 6 (Elements of model theory), Chapter 7 (Elementary properties of algebraic structures) and Chapter 8 (Free $\Sigma$-structures), all of which are about first-order model theory. (In the second (2008) edition there are new appendices which go in a different direction.)

What we need in this article is not a separate definition of satisfiability for universal algebra, but a brief explanation of how first-order satisfiability specialises to that important case. Hans Adler 00:42, 19 June 2011 (UTC)[reply]

PS: I believe the strange definition of satisfiability on p. 58 of Term Rewriting and All That makes sense if we adopt the following POV: We have a set E of Σ-identities, i.e. a variety. Contrary to what a first-order logician would expect, we are not interested in whether a given equation is satisfiable in some member of the variety – under this definition all equations would be satisfiable, since they are satisfied in the one-element Σ-algebra. Instead, we want to know whether the equation is satisfiable in the free E-algebra with countably many generators. Hans Adler 01:03, 19 June 2011 (UTC)[reply]
Sorry I lost my temper. The point I am trying to make is that one can define a workable version of satisfiability before one defines first-order logic, and, specifically, without having to explain what a quantifier is or how to combine them. By doing so, one can avoid a large variety of discussions pertaining to first-order logic, e.g. cardinality, Skolemization, and assorted other baggage. Avoiding this is useful as these can be intimidating to more inexperienced readers. I offer three pieces of evidence that this can be done: (1) of the roughly two-dozen freely-available SMT solvers, only two handle quantifiers. (2) Hodges 'a shorter model theory' defines satisfiability on page 12, the same page where atomic formula & atomic sentence are defined. He does not define first-order logic until page 26. As far as I can tell, Hodges never again discusses satisfiability after this point. (3) The book 'term re-writing', as you will see, once you get it, never defines first-order logic, or refers to it in any way. In fact, I'm pretty sure that book never even uses the there-exists symbol, or the for-all symbol. That book almost never uses any logical connectives either; leafing through the book, I was unable to find any use of a logical connective until page 267! The reason for this is that the book never defines atomic formulas, atomic sentences or predicates (although it does define a dozen or more different kinds of binary relations). Meanwhile, satisfiability, unification and termination occupy half the book, replete with all sorts of algorithms for computing the same. So, to conclude: one simply does not need to invoke first-order logic to define or explain satisifiability. What's more, one can present and discuss various relatively sophisticated algorithms that compute satisfiability, without having to make any appeals at all to first-order logic (or any kind of logic outside of the usual work-a-day computer programming language).
Meanwhile, I'll try to make small, infrequent, itty-bitty edits, as precise as seems warranted, if/when I get the urge to do so. linas (talk) 03:14, 21 June 2011 (UTC)[reply]
One more example of satisifiability without first-order-logic: Barendregt, "The Lambda Calculus, Its syntax and semantics" defines theories and models for lambda calculus in pages 75-125. There is a very brief mention of satisfiability on page 100. Obviously, the book never even gets close to discussing anything even vaguely related to logic, much less first-order logic. linas (talk) 03:37, 21 June 2011 (UTC)[reply]