Latest revision as of 13:56, 12 August 2013
{{#reviewabout:Submissions:Object with states|}}

 Review Summary: The design pattern is intended to allow the representation of objects with states. To this end, the author proposes to define objects as classes with certain properties, and link them to separate individuals that represent the state of the object using a 'hasState' property.
The author does not really discuss related work, most prominently e.g. the perdurants of the DOLCE ontology. Also, I do not think the solution is satisfactory, or at least it is not very generalizable nor very strictly defined. Detailed comments below:
-  It seems ontologically strange to define 'objects' as classes, whereas the states are individuals associated to *instances* of those object classes using the 'hasState' property. A more pragmatic solution would be to decide that all individuals of type 'Object' are also states. One can then individuate an object through time (i.e. through all its states) by chaining these states together using a property of choice. Another option would be to consider all states that are instances of a certain object class to be states of the same object. The object class then represents the object as it exists through time (perhaps this is closest to the currently proposed pattern) 
-  Secondly, it could be argued that there should not be a strict requirement that the states of an object are distinct individuals. For instance, I can be both married and brown-haired at the same time. Distinct individuals is a design decision that the author should argue for explicitly. 
-  The design pattern does not ensure that individual states are only the state of a *single* object. I.e. the has-state property should be inverse functional.
 
Problems: * It seems ontologically strange to define 'objects' as classes, whereas the states are individuals associated to *instances* of those object classes using the 'hasState' property. A more pragmatic solution would be to decide that all individuals of type 'Object' are also states. One can then individuate an object through time (i.e. through all its states) by chaining these states together using a property of choice. Another option would be to consider all states that are instances of a certain object class to be states of the same object. The object class then represents the object as it exists through time (perhaps this is closest to the currently proposed pattern) 
-  Secondly, it could be argued that there should not be a strict requirement that the states of an object are distinct individuals. For instance, I can be both married and brown-haired at the same time. Distinct individuals is a design decision that the author should argue for explicitly. 
-  The design pattern does not ensure that individual states are only the state of a *single* object. I.e. the has-state property should be inverse functional.
 
Relation to Best Practices: The pattern does not really take into account the best practices around this subject. Objects and their states are discussed at length in the literature (though mostly philosophically inspired). It is fair enough that the author takes a pragmatic approach (which is laudable), but consulting related work would most likely improve the quality of the pattern.
Relations to Other Patterns: 
Clear Figures and Illustrations: Yes 
 
Posted: 2013/8/12 Last modified: 2013/08/12