@prefix xsd: . @prefix owl: . @prefix : . @prefix wfdesc: . @prefix xml: . @prefix rdf: . @prefix rdfs: . @prefix skos: . @base . rdf:type owl:Ontology ; owl:versionIRI ; rdfs:comment """This ontology (\"wfdesc\") describes an abstract workflow description structure, which on the top level is defined as a wfdesc:Workflow. A wfdesc:Workflow contains several wfdesc:Process instances, associated using the wfdesc:hasSubProcess property. Each of these (and the workflow itself) wfdesc:hasInput and wfdesc:hasOutput some wfdesc:Parameter (wfdesc:Input or wfdesc:Output). An wfdesc:Artifact is associated with a wfdesc:Parameter using wfdesc:hasArtifact. The wfdesc:Workflow also wfdesc:hasDataLink several wfdesc:DataLink instances, which forms the connection between parameters. Thus this ontology allows the description a direct acyclic graph, or a dataflow. This ontology is meant as an upper ontology for more specific workflow definitions, and as a way to express abstract workflows. The wfprov ontology shows how to link these descriptions to a provenance trace of a workflow execution."""@en . ################################################################# # # Annotation properties # ################################################################# rdfs:comment rdf:type owl:AnnotationProperty . ################################################################# # # Datatypes # ################################################################# ################################################################# # # Object Properties # ################################################################# ### http://purl.org/wf4ever/wfdesc#hasArtifact wfdesc:hasArtifact rdf:type owl:ObjectProperty ; rdfs:comment "This property associates a wfdesc:Parameter with an wfdesc:Artifact which can describe the artifact which would be used/generated on execution of the workflow."@en ; rdfs:subPropertyOf owl:topObjectProperty ; rdfs:range wfdesc:Artifact ; rdfs:domain wfdesc:Parameter . ### http://purl.org/wf4ever/wfdesc#hasDataLink wfdesc:hasDataLink rdf:type owl:ObjectProperty ; rdfs:comment "This property is used to specify the wfdesc:DataLink instances of a given workflow template."@en ; rdfs:subPropertyOf owl:topObjectProperty ; rdfs:range wfdesc:DataLink ; rdfs:domain wfdesc:Workflow . ### http://purl.org/wf4ever/wfdesc#hasInput wfdesc:hasInput rdf:type owl:ObjectProperty ; rdfs:comment "This object property is used to specify the wfdesc:Input parameter of a given wfdesc:Process."@en ; rdfs:range wfdesc:Input ; rdfs:domain wfdesc:Process . ### http://purl.org/wf4ever/wfdesc#hasOutput wfdesc:hasOutput rdf:type owl:ObjectProperty ; rdfs:comment """This object property is used to specify the wfdesc:Output parameter of a given wfdesc:Process. """@en ; rdfs:range wfdesc:Output ; rdfs:domain wfdesc:Process . ### http://purl.org/wf4ever/wfdesc#hasSink wfdesc:hasSink rdf:type owl:ObjectProperty ; rdfs:comment "This property is used to specify the wfdesc:Input parameter that acts as a sink from a given wfdesc:DataLink, consuming data from the link."@en ; rdfs:subPropertyOf owl:topObjectProperty ; rdfs:domain wfdesc:DataLink ; rdfs:range wfdesc:Input . ### http://purl.org/wf4ever/wfdesc#hasSource wfdesc:hasSource rdf:type owl:ObjectProperty ; rdfs:comment "This property is used to specify the wfdesc:Output parameter that acts as a source to a given wfdesc:DataLink, providing data into the link."@en ; rdfs:subPropertyOf owl:topObjectProperty ; rdfs:domain wfdesc:DataLink ; rdfs:range wfdesc:Output . ### http://purl.org/wf4ever/wfdesc#hasSubProcess wfdesc:hasSubProcess rdf:type owl:ObjectProperty ; rdfs:comment """This object property is used to specify that the given workflow contains the given process as part of its definition. Although not a requirement, such sub processes should have wfdesc:DataLink within the containing workflow connecting their parameters with parameters of the containing workflow, or with parameters other contained wfdesc:Process instances. A specialialisation of sub process is wfdesc:hasSubWorkflow where the sub process is a nested wfdesc:Workflow."""@en ; rdfs:range wfdesc:Process ; rdfs:domain wfdesc:Workflow . ### http://purl.org/wf4ever/wfdesc#hasSubWorkflow wfdesc:hasSubWorkflow rdf:type owl:ObjectProperty ; rdfs:comment """This object property is used to associate a workflow template to another workflow template, specifying that the given workflow has the given sub-workflow as a contained process. This is a specialisation of hasProcessTemplate."""@en ; rdfs:range wfdesc:Workflow ; rdfs:domain wfdesc:Workflow ; rdfs:subPropertyOf wfdesc:hasSubProcess . ################################################################# # # Classes # ################################################################# ### http://purl.org/wf4ever/wfdesc#Artifact wfdesc:Artifact rdf:type owl:Class ; rdfs:comment """wfdesc:Artifact is used to provide information about a class of artifacts. For example, it can be used to specify the datatype of a dataset or the structure of a document. An wfdesc:Artifact is associated with a wfdesc:Parameter using wfdesc:hasArtifact. The distinction between a parameter and artifact is that the parameter can be customized to describe the particular role the artifact plays with regards to the process (and can be linked using wfdesc:DataLink) - while the wfdesc:Artifact can describe the syntactic and semantic datatype."""@en . ### http://purl.org/wf4ever/wfdesc#DataLink wfdesc:DataLink rdf:type owl:Class ; rdfs:comment """wfdesc:DataLink is used to represent data dependencies between process templates. It means that the artifact generated at an wfdesc:Output (identified using wfdesc:hasSource) will be used by a wfdescInput (identified using wfdesc:hasSink). The wfdesc:Processes that owns the wfdesc:Parameter instances which are the source and sink of a wfdesc:DataLink must be wfdesc:hasSubProcess of a the same wfdesc:Workflow which wfdesc:hasDataLink the data link, or be be parameters of that same workflow. Thus links can only be made within a wfdesc:Workflow - although ports owned by the workflow itself appear both inside and outside the workflow (in opposite roles)."""@en . ### http://purl.org/wf4ever/wfdesc#Input wfdesc:Input rdf:type owl:Class ; rdfs:subClassOf wfdesc:Parameter ; rdfs:comment """wfdesc:Input represents an input parameter to a wfdesc:Process. This can be compared to a function parameter, command line argument, files read, or parameter set by a user interface. It is out of scope of wfdesc to define the nature or classification of the parameter, such as giving it a name, position or data type. This can be done with subclasses and/or subproperties."""@en . ### http://purl.org/wf4ever/wfdesc#Output wfdesc:Output rdf:type owl:Class ; rdfs:subClassOf wfdesc:Parameter ; rdfs:comment """wfdesc:Output represents an output parameter from a wfdesc:Process. This can be compared to functional return values, stdout/stdin, files written, or results shown in a user interface. It is out of scope of wfdesc to define the nature or classification of the parameter, such as giving it a name, position or data type. This can be done with subclasses and/or subproperties."""@en . ### http://purl.org/wf4ever/wfdesc#Parameter wfdesc:Parameter rdf:type owl:Class ; owl:equivalentClass [ rdf:type owl:Class ; owl:unionOf ( wfdesc:Input wfdesc:Output ) ] ; rdfs:comment """This class represent a parameter of a process template. A wfdesc:Parameter must be a wfdesc:Input, a wfdesc:Output, or both. A parameter is both an wfdesc:Input and wfdesc:Output when it is used on both sides of a subworkflow - see wfdesc:Workflow and wfdesc:DataLink for details."""@en . ### http://purl.org/wf4ever/wfdesc#Process wfdesc:Process rdf:type owl:Class ; rdfs:comment """A wfdesc:Process is used to describe a class of actions that when enacted give rise to processes. A process can have 0 or more wfdesc:Parameter instances associated using wfdesc:hasInput and wfdesc:hasOutput, signifying what kind of parameters the process will require and return. It is out of scope for wfdesc to classify or specify the nature of the process, this should be done by subclassing and additional subproperties, for instance ex:perlScript or ex:restServiceURI"""@en . ### http://purl.org/wf4ever/wfdesc#Workflow wfdesc:Workflow rdf:type owl:Class ; rdfs:subClassOf wfdesc:Process ; rdfs:comment """A wfdesc:Workflow is a directed graph in which the nodes are wfdesc:Process instances and the edges (wfdesc:DataLink instances) represent data dependencies between the constituent process templates. A wfdesc:Workflow defines associated wfdesc:Process using hasProcessTemplate. A specialisation of this property is hasSubWorkflowTemplate, signifying that the process is a WorkflowTemplate itself, which is further described in a similar fashion. As a subclass of wfdesc:Process a wfdesc:Workflow can also define wfdesc:hasInput/wfdesc:hasOutput parameters - these would be inputs taken at workflow execution time, and final outputs of the workflow. (Note: Not all dataflow systems have this concept of workflow parameters) wfdesc:Parameter instances are linked using wfdesc:DataLink instances associated with the wfdesc:Workflow using wfdesc:hasDataLink. A wfdesc:Parameter defined with wfdesc:hasInput on a wfdesc:Workflow is considered an wfdesc:Input \"outside\" the workflow template (ie. if it is a subworkflow), but an wfdesc:Output \"inside\" the workflow template (where it can be connected to a wfdesc:Input of a wfdesc:Process). Thus such parameters can be linked \"through\" the workflow template without having a \"mirrored\" port inside. Example: ## @prefix wfdesc: . :outerWorkflow a wfdesc:Workflow ; wfdesc:hasSubWorkflow :innerWorkflow ; wfdesc:hasSubProcess :procA, :procC . :procA a wfdesc:Process ; wfdesc:hasOutput :param1 . :procC a wfdesc:Process ; wfdesc:hasInput :param2 ; wfdesc:hasOutput :param3 . :innerWorkflow a wfdesc:Workflow ; wfdesc:hasInput :param4 ; wfdesc:hasOutput :param5 ; wfdesc:hasProcess :procB . :procB a wfdesc:Process ; wfdesc:hasInput :param6 ; wfdesc:hasOutput :param7 . :innerWorkflow wfdesc:hasDataLink [ wfdesc:hasSource :param4; wfdesc:hasSink :param6 ], [ wfdesc:hasSource :param7; wfdesc:hasSink :param5 ] . :outerWorkflow wfdesc:hasDataLink [ wfdesc:hasSource :param1; wfdesc:hasSink :param4 ], [ wfdesc:hasSource :param5; wfdesc:hasSink :param2 ] . ## In this example :param1 is the output of :procA. :param1 is the source in a datalink that goes to the input :param4 of the :innerWorkflow. :param4 is however also the source of an inner datalink, going to input :param6 of the nested :procB. From this :param4 is both an wfdesc:Input and wfdesc:Output (which is why these two classes are not disjoint)"""@en . ### http://purl.org/wf4ever/wfdesc#WorkflowInstance wfdesc:WorkflowInstance rdf:type owl:Class ; rdfs:subClassOf wfdesc:Workflow ; rdfs:comment "A wfdesc:WorkflowInstance is a specialisation of a wfdesc:Workflow template which defines all data/parameters/settings that are required to form a wfprov:WorkflowRun."@en . ### Generated by the OWL API (version 3.2.3.1824) http://owlapi.sourceforge.net