Taking Time Seriously
A long-standing issue among BFO users and developers has concerned how best to represent time. Importantly, issues concerning time in BFO stem from implementations of BFO in restricted formal languages such as the Web Ontology Language (OWL). OWL does not allow for direct representation of relations with arity higher than two. To illustrate the issue, consider modeling a vehicle having an engine part at some time, but losing that engine part at another. An expressive language such as First-Order Logic (FOL) would permit the following representation:
(A) has_part(vehicle, engine, time_1) & ~has_part(vehicle, engine, time_2)
Since FOL allows using ternary relations. OWL's restriction to at most binary relations precludes expressions like (A); indeed, there is no simple, straightforward way to represent the content of (A) in OWL. Given the need to represent time and change in many domains and the wide use of OWL in ontology circles, proposals have been offered by users of BFO for representing such phenomena within the binary constraints of OWL. Examples include:
Each is a plausible avenue of research in the interest of more rigorous representations of time in restricted formal languages. Details for each can be viewed at the above links.
While time is certainly within the scope of BFO, there are nevertheless reasons to refrain from providing significant constraints on time in BFO:
Scientific domains do not treat time uniformly. Economists, for example, measure economic constructs using time series, i.e. presuming a model of discrete time, whereas physicists typically treat time as continuous. This observation speaks in favor of BFO remaining neutral on questions over the discreteness of continuity of time.
Not all scientific domains require a robust characterization of time, e.g. the domain of mathematics has no obvious need for time.
Given community goals, even if users need some characterization of time, they do not always need a robust characterization of time, e.g. Open Biological and Biomedical Ontology Foundry users have, for many years, employed a formally weak representation of time with great success.
This last point is worth belaboring. Deploying a BFO-based, robust, formalization of time can be costly, involving re-educating users, updating existing ontologies, perhaps even rewriting portions of codebases, etc. OBO users have not often had a need for such rigor, and so do not have a need to bear such costs. A charitable reading of early criticisms of the Temporalized Relations strategy - which provides a rather robust formalization of time in BFO - makes just this point. On the other hand, there are reasons that speak in favor of providing formal guidance for modeling time in BFO:
Other foundry efforts, such as the Industrial Ontology Foundry which uses BFO as its top-level architecture, anticipate the need for a rigorous formalization of time.
Recent work demonstrating the importance of rigorous axiomatization of ontologies used to supplement machine learning pipelines with minimal datasets, suggests rigorous BFO formalizations of time ontologies may be useful in such contexts.
What these observations suggest is that while there are strong motivations for BFO providing - perhaps significant - guidance to users who require a robust formalization of time, imposing any specific formalization of time on all users would be in some cases unnecessarily onerous. To satisfy needs of the community then, the BFO development team encourages a strategy of developing and deploying Temporal Extensions which will provide users options for representing time in their domains.
When evaluating the need for an ontologically robust characterization of time, we recommend users identify specific motivating use cases for their target domain, perhaps codified as competency questions. As a starting point, we recommend developers users reflect on the design patterns and use cases concerning time and change found in the article Basic Formal Ontology: Case Studies. There the authors present seven design patterns based on the FOL implementation of BFO.
Temporal Extensions of BFO are artifacts designed to represent extensions of the OWL formalization of BFO - located in the "bfo-core.owl" file - that impose axiom constraints concerning time and change. Temporal Extensions of BFO should be represented in some serialization of RDF, e.g. ttl, owl.
With respect to BFO, the scope of Temporal Extensions should include treatment of the following classes:
Temporal Region and subclasses
Spatiotemporal Region
As well as the following relations and their inverses (where applicable):
continuant part of
proper continuant part of
participates in
concretizes
located in
member part of
generically depends on
material bases of
occupies spatial region
spatially projects onto
BFO is a top-level ontology designed to provide a common hierarchy across all scientific research; as a consequence, interoperability is its main motivation. It is thus incumbent on developers to demonstrate not only that their preferred formalization of time conforms to BFO, but also that interpretations, formal mappings, or provable containments exists across temporal extensions. This is, admittedly, considerable work, but it is a consequence of sustaining interoperability, which our community prizes.