Did you know ... | Search Documentation: |
Pack logtalk -- logtalk-3.86.0/examples/closed_world_assumption/NOTES.md |
This file is part of Logtalk https://logtalk.org/ SPDX-FileCopyrightText: 1998-2023 Paulo Moura <pmoura@logtalk.org> SPDX-License-Identifier: Apache-2.0
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
To load this example and for sample queries, please see the SCRIPT.txt
file.
This example illustrates the difference between declaring a predicate and defining a predicate and the Closed World Assumption (CWA) semantics as implemented in Logtalk when calling predicates and sending messages.
The CWA states that:
When applied to Logtalk (or Prolog), proofs are constructed using predicate definitions. But Logtalk also provides a clear distinction between declaring a predicate and defining a predicate (1). This distinction is translates to the following refined CWA semantics:
(1) This is a necessary requirement for protocols/interfaces: we must be able to declare a predicate without necessarily defining it.