Copyright ©2011 XBRL International Inc., All Rights Reserved.
Circulation of this Proposed Edited Recommendation is unrestricted. This document is normative. Other documents may supersede this document. Recipients are invited to submit comments to formula-feedback@xbrl.org, and to submit notification of any relevant patent rights of which they are aware and provide supporting documentation.
This specification is an extension to the XBRL Specification [XBRL 2.1]. It defines syntax for structures that support the extraction and usage of information from an XBRL instance and its supporting discoverable taxonomy set.
This specification provides building blocks for other extension specifications including for XBRL formulae and for assertions about the expected content of XBRL instances.
1 Introduction
1.1 Background
1.2 Relationship to other work
1.3 Language independence
1.4 Terminology
1.5 Document conventions (non-normative)
1.5.1 Typographic conventions
1.5.1.1 Definition notation
1.5.1.2 Footnote notation
1.5.1.3 Element and attribute notation
1.5.2 Formatting conventions
1.6 Namespaces and namespace prefixes
1.7 XPath usage
1.7.1 XPath evaluation context
1.7.1.1 XPath static context initialisation
1.7.1.2 XPath dynamic context initialisation
2 Aspects
2.1 Dimension aspect tests
2.1.1 Explicit-dimension aspect tests
2.1.2 Typed-dimension aspect tests
2.1.2.1 Default typed-dimension aspect tests
2.1.2.2 Custom typed-dimension aspect tests
2.1.2.2.1 Equality definitions for typed dimensions
2.1.2.2.1.1 Equality-definition relationships
2.2 Aspect models
3 Syntax
3.1 Custom function signatures
3.2 Parameters
3.3 General variables
3.4 XBRL fact variables
3.4.1 Filters
3.4.1.1 Variable-filter relationships
3.4.1.1.1 Variable-filter arcs
3.5 Variable sets
3.5.1 Variable-set relationships
3.5.1.1 Variable arcs
3.5.2 Variable-set-filter relationships
3.5.2.1 Variable-set filter arcs
3.5.3 Implicit filters
3.5.4 Preconditions
3.5.4.1 Variable-set-precondition relationships
4 Variable evaluation
4.1 Binding as a sequence
4.2 Binding to an empty sequence
A Normative schema
B References
C Intellectual property status (non-normative)
D Acknowledgements (non-normative)
E Document history (non-normative)
F Errata corrections in this document
1 Namespaces and namespace prefixes
2 Aspect inclusion in aspects models
1 A normative example
2 A non-normative example
3 An example of poor usage
4 XPath variable references in filter expressions
5 Circular variable references
OCC aspect
OCC value
XML schema
aspect
aspect model
aspect model identifier
aspect test
aspect-matched fact
bind as a sequence
can bind to an empty sequence
complemented variable-filter relationship
complemented variable-set-filter relationship
complete scenario aspect
complete segment aspect
concept aspect
containing element
corresponding attributes
corresponding elements
corresponding typed-dimension values
covering filter
covering variable-filter relationship
covers an aspect
custom function
custom function signature
custom typed-dimension aspect test
default-typed-dimension aspect test
different variable-set evaluation
dimension aspect
dimension aspect test
dimensional aspect model
enclosing element
entity identifier aspect
equality definition
equality-definition relationship
equivalent aspect value
evaluation exception
explicit-dimension aspect test
fact variable
fact variable evaluation
fallback value
filter
filter complement
general variable
general variable evaluation
group-filter
identical fact-variable evaluation
identical variable-set evaluation
input XBRL instance
input fact
location aspect
match
non-XDT scenario aspect
non-XDT segment aspect
non-covering filter
non-dimensional aspect model
non-fallback value
open context component (OCC)
parameter
period aspect
precondition
precondition expression
rfc2119 terminology
same name
satisfied precondition
scenario OCC
scenario OCC aspect
segment OCC
segment OCC aspect
source sequence
typed-dimension aspect test
typed-dimension domain definition
typed-dimension value
uncovered aspect
unit aspect
uses implicit filtering
variable arc
variable dependency
variable evaluation
variable set
variable set's aspect model
variable-filter arc
variable-filter relationship
variable-set evaluation
variable-set filter arc
variable-set relationship
variable-set resource
variable-set-filter relationship
variable-set-precondition relationship
xbrlve:ambiguousAspectValues
xbrlve:ambiguousAspects
xbrlve:cyclicDependencies
xbrlve:duplicateVariableNames
xbrlve:factVariableReferenceNotAllowed
xbrlve:fallbackValueVariableReferenceNotAllowed
xbrlve:filterAspectModelMismatch
xbrlve:multipleTypedDimensionEqualityDefinitions
xbrlve:noCustomFunctionSignature
xbrlve:noProhibitedNamespaceForCustomFunction
xbrlve:parameterCyclicDependencies
xbrlve:parameterNameClash
xbrlve:parameterTypeMismatch
xbrlve:unknownAspectModel
xbrlve:unresolvedDependency
xbrlve:variableNameResolutionFailure
This specification is an extension to the XBRL Specification [XBRL 2.1]. It defines syntax for declaration of two kinds of variables: fact variables that only evaluate to sequences of facts in an XBRL instance and general variables that can evaluate to a broader range of values. This specification also defines syntax for parameters that can be given default values or values that are supplied by processing software.
XBRL variables play an important role in extracting information from an XBRL instance or a discoverable taxonomy set. XBRL variables can also be used to define constants and to define transformations of the information available in other variables.
Every XBRL variable implies an XPath expression. A variable is evaluated by evaluating the implied XPath in the context of an XBRL instance.
The input XBRL instance is the single valid XBRL instance that variables are evaluated against in the processing model for variables.
Note that input XBRL instances are required to be valid with respect to the variable set treating them as an input. They are required to be valid in the sense that they conform to the XBRL 2.1 specification and to any specification contributing to the definition of the variable set's aspect model.
The XPath expressions implied by variables
are evaluated using the <xbrli:xbrl>
element of the
input XBRL instance
as the context item.
As well as defining syntax for variables, this specification defines syntax for signatures of custom functions that can be used in XPath expressions and parameters that can be referenced in XPath expressions. These features are intended to enhance the usability of XBRL variables. They are also intended to form infrastructure for additional extension specifications that make use of XBRL variables.
The syntax for variables and parameters does not support specification of names that can be used as XPath variable references. Instead, names are associated with variables and parameters by the relationships to the resources (formulae, assertions, etc.) that depend on them. This enables variables and parameters to be referred to by different names when used in different contexts.
This flexibility is important because the QNames in XPath variable references are hard coded into XPath expressions. Thus, the names of variables and parameters need to be able to adapt depending on the names used in the XPath variable references that they are being accessed by.
In many applications of XML [XML] the nested structure of XML resources means that XPath [XPATH 2.0] or XQuery [XQUERY 1.0] is a natural and powerful means of selecting required information from XML resources.
For various reasons, the XBRL Specification [XBRL 2.1] makes minimal use of the normal hierarchical structure of XML, instead requiring relatively flat syntax for XBRL instances and for their supporting XML schemas and linkbases.
This design makes it cumbersome to use XPath or XQuery to select data from XBRL instances based on their content and their supporting discoverable taxonomy sets, at least without a library of custom functions.
This specification provides a framework for an alternative syntax for specifying the filters that are to be applied to an XBRL instance to select the required data from them, if it is available. The alternative syntax is extensible in the sense that additional filters can be defined as they are deemed useful.
The alternative syntax is intended to be an improvement over direct use of XPath or XQuery in that allows users to work with the various kinds of relationships that exist in XBRL without burying them in XPath or XQuery contortions.
This specification depends upon the XBRL Specification [XBRL 2.1].
This specification is intended to be augmented with a range of separate filter specifications that provide concise syntax for selecting data from XBRL instances.
The official language of XBRL International's own work products is English and the preferred spelling convention is UK English.
This specification is consistent with the definitions of any of the terms defined in specifications that it depends on.
The key words MUST, MUST NOT, REQUIRED, SHALL, SHALL NOT, SHOULD, SHOULD NOT, RECOMMENDED, MAY, and OPTIONAL, in this specification, are to be interpreted as described in [IETF RFC 2119].
Where this document refers to an XML schema, it is referring to an XML document [XML] that contains a declaration of a schema that is compliant with XML Schema [XML SCHEMA STRUCTURES].
Comments which are informative, but not essential to the understanding of the point at hand, are provided in footnotes. All footnotes are non-normative.
When referring to a specific element, it will be identified by
its namespace prefix and local name. For example, the root
element for a specification container element would be referred to as
<variable:generalVariable>
.
Attributes are also identified by their local name and, where
appropriate, their namespace prefix. Attributes are
distinguished from elements by prefixing them by an
@
symbol. Thus,
@id
refers to the attribute with the name id
.
When referring to any attribute, so long as it has a specific
namespace, the local name is replaced by an asterisk (
*
).
Thus, the notation @xml:*
specifies any attribute
in the namespace
http://www.w3.org/XML/1998/namespace
.
The following highlighting is used for normative technical material in this document:
Text of the normative example.
The following highlighting is used for non-normative examples in this document:
Text of the helpful example.
Next paragraph of the helpful example.
Example 3 shows the formatting for non-normative examples of poor, discouraged or disallowed usage.
The example itself.
Namespace prefixes [XML NAMES] will be used
for elements and attributes in
the form ns:name
where ns
is the
namespace prefix and name
is the local name.
Throughout this specification, the mappings
from namespace prefixes to actual namespaces is consistent
with Table 1.
The prefix column in Table 1 is non normative. The namespace URI column is normative.
Prefix | Namespace URI |
---|---|
variable
|
http://xbrl.org/2008/variable
|
xbrlve
|
http://xbrl.org/2008/variable/error
|
aspectTest
|
http://xbrl.org/2008/variable/aspectTest
|
eg
|
http://example.com/
|
fn
|
http://www.w3.org/2005/xpath-functions
|
link
|
http://www.xbrl.org/2003/linkbase
|
xbrli
|
http://www.xbrl.org/2003/instance
|
xfi
|
http://www.xbrl.org/2008/function/instance
|
xbrldi
|
http://xbrl.org/2006/xbrldi
|
xbrldt
|
http://xbrl.org/2005/xbrldt
|
xl
|
http://www.xbrl.org/2003/XLink
|
xlink
|
http://www.w3.org/1999/xlink
|
xs
|
http://www.w3.org/2001/XMLSchema
|
xsi
|
http://www.w3.org/2001/XMLSchema-instance
|
gen
|
http://xbrl.org/2008/generic
|
iso4217
|
http://www.xbrl.org/2003/iso4217
|
Some attributes and elements, defined by this specification, contain values that are evaluated as XPath 2.0 [XPATH 2.0] expressions. Wherever an XPath expression is mentioned in this specification it refers to an XPath 2.0 expression.
An evaluation exception is defined as any one of a static error, a dynamic error, or a type error for an XPath expression.
All of the XQuery/XPath data models used for XPath processing MUST be constructed using the relevant Post Schema Validation Infoset.
The XPath specification [XPATH 2.0] requires XPath expressions to be evaluated in conjunction with an expression context. This section specifies how the components of the expression context are to be initialised.
A containing element for an XPath expression is defined as the element containing the XPath expression, either as element content or as the content of an attribute on that element.
An enclosing element for an XPath expression is the XPath expression's containing element or any of its ancestors.
The evaluation context for an XPath expression is determined by its containing element.
The components of the expression context divide into those in the static context and those in the dynamic context. The initialisation of the static and dynamic contexts is set out in Section 1.7.1.1 and Section 1.7.1.2 respectively.
XPath 1.0 compatibility mode, a part of the static context,
is always set to false
. Thus, evaluation of XPath expressions
MUST NOT be performed using the XPath 1.0 compatibility mode.
The static context also contains namespaces for variables, functions, elements and attributes.
The namespaces in the static context are those that are in scope for the containing element of the XPath expression.
The static context also contains the
default function namespace which is http://www.w3.org/2005/xpath-functions
.
This means that functions in this namespace do not require a namespace prefix when they
are called.
As required by the XPath 2.0 Specification, an unprefixed variable reference is to a variable that is in no namespace. Care needs to be taken to ensure that the default namespace for element and attribute names is not used when determining the QName for variables with no namespace prefix.
The default namespace, if any, associated with the containing element is only to be used in determining the namespace of functions, element names, and attribute names, in the XPath expression, that have no namespace prefix.
The XML Schema data type of attributes with values that are variable
QNames is variable:QName
. This distinguishes those
attributes from other elements and attributes containing QNames
that have data type xs:QName
.
This distinction prevents the variable QName resolution method
from defaulting to the resolution method for QNames with data
type xs:QName
. This is important because variable
names with no namespace prefix are not to be resolved in the
same way as other QNames with no namespace prefix.
Error code xbrlve:variableNameResolutionFailure MUST be thrown if an attribute containing the QName of a fact variable or general variable specifies a namespace prefix that cannot be resolved to a namespace declaration that is in scope for the containing element.
QNames in each XPath expression MUST be resolvable using the specific resolution rules set out in this specification and the namespace declarations that are in scope for the XPath expression's containing element. See Namespaces in XML [XML NAMES] for more information on namespace declarations and their scope.
The schema definitions in the XPath expression's static context are the those defined for the XML resource containing the XPath expression.
The specification sets out, where necessary how to determine the variables that are in the static context for the XPath expression.
The function signatures in the static context are the core functions defined in [XPATH AND XQUERY FUNCTIONS], the functions defined in the XBRL function registry, the constructor functions for all the atomic types in the static context's schema definitions, and any extension functions bound using implementation-defined mechanisms.
The statically known collations are implementation-defined. However, the set of in-scope collations must always include the Unicode codepoint collation, defined in Section 7.3 of [XPATH AND XQUERY FUNCTIONS]. The default collation to be used by XPath operators and functions in the XPath expression is the unicode collation unless another is specified by a specific function argument.
The base URI in the static context is the base URI of the XPath expression's containing element. The concept of the base URI of a node is defined in the XQuery 1.0 and XPath 2.0 Data Model Specification [XDM].
There are no statically known documents in the static context.
There are no statically known collections in the static context.
The context item in the dynamic context is defined as part of the explanation of each XPath expression container.
The context position is 1
.
Likewise the context size is 1
.
This is because the context item is always in a sequence of one item.
The dynamic context includes the values of the variables in the static context.
The current date, time and timezone are implementation dependent parts of the dynamic context.
There are no available documents in the dynamic context.
There are no available collections in the dynamic context.
The default collection, in the dynamic context, is the empty sequence.
XBRL facts are not just values. They are supported by a wide range of additional information that provides the information necessary to interpret the values contained by XBRL facts.
An aspect is defined as one part of the additional information about an XBRL fact.
All aspect definitions MUST include the definition of the aspect test to use when assessing the equivalency of two values for the aspect being defined.
An aspect test is an XPath expression that defines an equivalence relation for values of its aspect.
Two facts have equivalent values for a given aspect if the aspect test for that aspect evaluates to true.
For two facts, an aspect test can be used to test whether an aspect is not
reported for both facts or is reported with an equivalent value for both facts.
The context item when evaluating all aspect tests is the
<xbrli:xbrl>
element of the input XBRL instance.
Two values for the one aspect match if the aspect test for that aspect returns true when evaluated with two variables, one of which has the first value for the aspect and the other of which has the second value for the aspect.
Two facts are aspect-matched facts if they have exactly the same aspects and, for each of aspect that they both have, the value for that aspect matches for the two facts.
In this specification, an aspect test is expressed in terms of
an XPath expression that contains two
XPath variable references, one, $aspectTest:a
for a variable that is equal
to the first fact in the comparison and the other, $aspectTest:b
for the
variable that is equal to the second fact in the comparison.
This specification defines the following aspects for all facts, including tuples:
<xbrli:xbrl>
element
at the root of the XBRL instance to the element that is the fact itself.
The aspect test for this aspect is:
$aspectTest:a/.. is $aspectTest:b/..
(namespace-uri($aspectTest:a) eq namespace-uri($aspectTest:b)) and (local-name($aspectTest:a) eq local-name($aspectTest:b))
This specification defines the following aspects for all items, but not for tuples:
(xfi:fact-identifier-scheme($aspectTest:a) eq xfi:fact-identifier-scheme($aspectTest:b)) and (xfi:fact-identifier-value($aspectTest:a) eq xfi:fact-identifier-value($aspectTest:b))
xfi:nodes-correspond(xfi:period($aspectTest:a), xfi:period($aspectTest:b))
xfi:nodes-correspond(xfi:segment($aspectTest:a), xfi:segment($aspectTest:b))
for $remainder-a in xfi:fact-segment-remainder($aspectTest:a),
$remainder-b in xfi:fact-segment-remainder($aspectTest:b) return
((count($remainder-a) eq count($remainder-b)) and
(every $i in 1 to count($remainder-a) satisfies
xfi:nodes-correspond($remainder-a[$i],$remainder-b[i]) ))
xfi:nodes-correspond(xfi:scenario($aspectTest:a), xfi:scenario($aspectTest:b))
for $remainder-a in xfi:fact-scenario-remainder($aspectTest:a),
$remainder-b in xfi:fact-scenario-remainder($aspectTest:b) return
((count($remainder-a) eq count($remainder-b)) and
(every $i in 1 to count($remainder-a) satisfies
xfi:nodes-correspond($remainder-a[$i],$remainder-b[i]) ))
This specification defines the following aspect for for numeric items only:
xfi:nodes-correspond(xfi:unit($aspectTest:a), xfi:unit($aspectTest:b))
A dimension aspect test is an aspect test for a dimension aspect.
Dimension aspect tests depend on whether the is an explicit dimension or a typed dimension, and, if the dimension is a typed dimension, whether a equality definition has been associated with the typed-dimension domain definition of the typed dimension.
An explicit-dimension aspect test is a dimension aspect test for an explicit dimension.
Explicit-dimension aspect tests are:
xfi:fact-explicit-dimension-value($aspectTest:a,#dimension) eq xfi:fact-explicit-dimension-value($aspectTest:b,#dimension)
where $aspectTest:a
and $aspectTest:b
are defined as in Section 2, and
#dimension
is the QName of the dimension defining the aspect.
A typed-dimension aspect test is a dimension aspect test for a typed dimension.
A typed dimension value is a value of a typed dimension in an XBRL instance. Syntactically, it is the single XML fragment with root element that is the child element of the typed-dimension's dimension container.
Typed-dimension aspect tests are tests of equality between typed dimension values for the same typed dimension.
A typed-dimension domain definition is the element in an XML Schema that defines
the content model for a typed dimension and that is identified as such by an
@xbrldt:typedDomainRef
attribute on the XML Schema element declaring
a typed dimension.
Note that [DIMENSIONS] allows more than one typed dimension to use the same typed-dimension domain definition.
Typed-dimension aspect tests depend upon whether the typed dimension defining the dimension aspect has a typed-dimension domain definition that, itself, has an equality definition.
A default typed-dimension aspect test is a typed-dimension aspect test for a typed dimension that does not have an equality definition associated with its typed-dimension domain definition.
A custom typed-dimension aspect test is a typed-dimension aspect test for a typed dimension that does have an equality definition associated with its typed-dimension domain definition.
Two element/attribute nodes, A
and B
have the same name if either they both have QName names,
Aqn
and Bqn
, and
the XPath 2.0 expression (Aqn eq Bqn)
evaluates to an effective
Boolean value of true when using the empty sequence as the context item;
or they both have names that are not defined in any namespace,
An
and Bn
, and
the XPath 2.0 expression (An eq Bn)
evaluates to an effective
Boolean value of true
when using the empty sequence as the context item.
Two attribute nodes, A
and B
,
are corresponding attributes
if the following conditions are all satisfied:
A
and B
have the same nameA
and B
,
As
and Bs
,
are the same length and for each item Ai
, at position i
in
As
, the item Bi
at position i
in Bs
,
is such that the XPath 2.0 expression (Ai eq Bi)
evaluates to an effective
Boolean value of true
when using the empty sequence as the context item.
Note that if the attribute nodes, A
and B
, both atomize to
empty sequences then those attribute nodes correspond.
Two element nodes, A
and B
,
are corresponding elements
if the following conditions are all satisfied:
A
and B
have the same nameA
and B
,
As
and Bs
,
are the same length and for each item Ai
, at position i
in
As
, the item Bi
at position i
in Bs
,
is such that the XPath 2.0 expression (Ai eq Bi)
evaluates to an effective
Boolean value of true
when using the empty sequence as the context item.
A
and B
have the same number of attributes [ 1 ] A
, there is a
corresponding attribute
on element node B
.
A
and B
have the same number of child elements.
A
, Ac
,
there is a corresponding child element
of element node B
, Bc
, such that Ac
and Bc
have
the same number of preceding sibling elements.
Note that, as for attribute nodes, if the element nodes,
A
and B
, both atomize to
empty sequences then those element nodes correspond.
Two typed dimension values are corresponding typed-dimension values if they are values for the same typed dimension and their root elements correspond.
The default typed-dimension aspect test is:
(fn:count(xfi:fact-typed-dimension-value($aspectTest:a,#dimension)/*) eq 1) and
(fn:count(xfi:fact-typed-dimension-value($aspectTest:b,#dimension)/*) eq 1) and
(xfi:nodes-correspond(xfi:fact-typed-dimension-value($aspectTest:a,#dimension)/*[1],xfi:fact-typed-dimension-value($aspectTest:b,#dimension)/*[1]))
where $aspectTest:a
and $aspectTest:b
are defined as in Section 2, and
#dimension
is the QName of the dimension defining the aspect.
The custom typed-dimension aspect test is:
(fn:count(xfi:fact-typed-dimension-value($aspectTest:a,#dimension)/*) eq 1) and
(fn:count(xfi:fact-typed-dimension-value($aspectTest:b,#dimension)/*) eq 1) and
(#custom)
where $aspectTest:a
and $aspectTest:b
are defined as in Section 2,
#dimension
is the QName of the dimension defining the aspect, and #custom
is the XPath expression contained by the @test
attribute on the
equality definition that MUST
be associated with the
typed-dimension's domain definition
if the custom typed-dimension aspect test is to be applicable.
An equality definition is a definition of equality between any two values in a
typed-dimension's domain definition.
It is expressed by a <variable:equalityDefinition>
element.
The syntax for the
<variable:equalityDefinition>
element is defined by the normative schema supplied with this specification.
The content of the @test
attribute on
an equality definition
is an XPath expression that is incorporated into the custom typed-dimension aspect tests
of those typed dimensions that use the
typed-dimension domain definitions
that are related to the equality definition by
equality-definition relationships.
The variable $aspectTest:a
, when used in the XPath expression contained by an
equality definition, is equal to the first fact in the comparison of aspect values and
the variable $aspectTest:b
, when used in the XPath expression contained by an
equality definition, is equal to the second fact in the comparison of aspect values.
Error code xbrlve:multipleTypedDimensionEqualityDefinitions MUST be thrown if a typed-dimension domain definition has more than one equality-definition relationship to an equality definition.
An equality-definition relationship is a relationship between a typed-dimension domain definition and an equality definition expressed by an XLink arc.
To declare an equality-definition relationship an XLink arc MUST:
http://xbrl.org/arcrole/2008/equality-definition
The arcrole value,
http://xbrl.org/arcrole/2008/equality-definition
,
is declared in the normative schema supplied with this specification.
Equality-definition relationships MUST be expressed by generic arcs. Violations of this requirement can be detected by validation against the XBRL Specification [XBRL 2.1].
There are a number of different ways that the additional information about an XBRL fact can be separated into a set of aspects. For example, the entity identification information could be treated as a single aspect or it could be treated as an entity identification scheme aspect and an entity identification value aspect. More significantly, the content of a segment or scenario can be treated as a single aspect or it can be broken down into a potentially large number of aspects.
An aspect model is a definition of how the information about a fact will be split into separate aspects.
An aspect model identifier is a text string that can be used to identify an aspect model.
All aspect model definitions MUST specify the aspect model identifier the for the aspect model being defined.
All aspect models MUST include the following aspects:
All aspect models MUST include sufficient aspects to ensure that all content in both the contexts and units of facts is associated with at least one aspect.
An open context component (OCC), is a segment or scenario.
A segment OCC is the OCC for a segment.
A scenario OCC is the OCC for a scenario.
An OCC aspect, is an aspect with a value that is reported by the content of an OCC that remains after removing all content corresponding to other aspect values.
An OCC value is the value of an OCC aspect.
A segment OCC aspect, is the OCC aspect with a value given by the remainder content of the segment.
A scenario OCC aspect, is the OCC aspect with a value given by the remainder content of the scenario.
Because [XBRL 2.1] places so few constraints on the content and meaning of OCCs, all aspect models MUST include two aspects: one segment OCC aspect, and one scenario OCC aspect. Moreover, all aspect model definitions MUST identify their segment OCC aspect and their scenario OCC aspect.
This specification defines two aspect models: the non-dimensional aspect model and the dimensional aspect model.
The non-dimensional aspect model includes all of the aspects defined in this
specification except for
the non-XDT segment aspect,
the non-XDT scenario aspect, and
dimension aspects.
The non-dimensional aspect model has an aspect model identifier equal to non-dimensional
.
The dimensional aspect model includes all of the aspects defined in this
specification except for
the complete segment aspect and
the complete scenario aspect.
The dimensional aspect model has an aspect model identifier equal to dimensional
.
Input XBRL instances for variable sets using the non-dimensional aspect model are only required to conform to the XBRL 2.1 specification [XBRL 2.1]. Input XBRL instances for variable sets using the dimensional aspect model are also required to conform to the XBRL Dimensions specification [DIMENSIONS].
The complete segment aspect is the segment OCC aspect for the non-dimensional aspect model. The complete scenario aspect is the scenario OCC aspect for the non-dimensional aspect model.
The non-XDT segment aspect is the segment OCC aspect for the dimensional aspect model. The non-XDT scenario aspect is the scenario OCC aspect for the dimensional aspect model.
The dimensional and non-dimensional aspect models are summarised in Table 2.
Aspect | Aspect model | |
---|---|---|
Dimensional | Non-dimensional | |
Location | include | include |
Concept | include | include |
Entity identifier | include | include |
Period | include | include |
Unit | include | include |
Complete segment | exclude | include |
Complete scenario | exclude | include |
Non-XDT segment | include | exclude |
Non-XDT scenario | include | exclude |
Dimension | include | exclude |
This specification only provides a textual declaration of syntax constraints when those constraints are not expressed by the normative schema supplied with this specification.
Explanations of elements and attributes are only supplied when explanations are not already provided in other specifications.
Unless explicitly stated otherwise, a reference to a specific element MUST be read as a reference to that element or to any element in its substitution group.
A custom function is an XPath function that is not defined in the XPath and XQuery Functions Specification [XPATH AND XQUERY FUNCTIONS] and that is also not defined in the XBRL Functions registry.
Error code
xbrlve:noProhibitedNamespaceForCustomFunction
MUST be thrown
if a custom function has the namespace
http://www.xbrl.org/2008/function/instance
,
which is reserved for functions in the XBRL functions registry.
A custom function signature is declared by a <variable:function>
element.
The syntax for the
<variable:function>
element is defined by the normative schema supplied with this specification.
Custom functions MAY be used within XPath expressions.
Error code xbrlve:noCustomFunctionSignature MUST be thrown if a custom function is used in an XPath expression but does not have a custom function signature within the discoverable taxonomy set that is being processed.
The @name
attribute on a custom function signature
contains the QName of the custom function.
The value of the @output
attribute on a custom
function signature specifies the data type of the result
produced by evaluating the custom function.
The <variable:input>
elements, if any, of a custom function
signature specify the data types of the custom function's input
parameters. The value of the @type
attribute on
<variable:input>
elements specifies the data type of the
input parameter.
The ordering of the custom function's input parameters matches
the document order of the <variable:input>
child elements
of the custom function signature.
The implementation of a custom function is outside of the scope of this specification.
A parameter is declared by a <variable:parameter>
element and can be given default values, specified as part of their declaration,
or values that are supplied by processing software.
The syntax for the
<variable:parameter>
element is defined by the normative schema supplied with this specification.
The @name
attribute on a parameter
declaration contains the QName of the parameter
being declared. This QName MAY be used within
any XPath expression as a global QName to access the parameter.
Additionally the parameter MAY be referenced by
a QName specified on relationship of the
parameter to a resource that makes use of it.
Error code
xbrlve:parameterNameClash
MUST be thrown
if two parameters in the one
discoverable taxonomy set
have the same QName specified by their @name
attributes.
If the @required
attribute on a parameter declaration
is equal to true
, then the parameter is mandatory;
its value MUST be supplied by
the processing application.
Otherwise, the value of the parameter MAY be supplied
by the processing application. If no value is supplied by the
processing application and if the parameter is
not mandatory, then the supplied value MAY
be computed using the XPath expression given in the
@select
attribute.
The XPath expression of a @select
attribute MAY
include XPath
variable references.
The XPath expression is evaluated using the <xbrli:xbrl>
element of the
input XBRL instance
as the context item.
Error code
xbrlve:parameterCyclicDependencies
MUST be thrown
if there are circular dependencies among the XPath expressions of
@select
attributes of parameters.
A parameter declaration MAY
contain an @as
attribute that
specifies the data type required by the parameter.
Error code xbrlve:parameterTypeMismatch
MUST be thrown if the parameter value,
either supplied by the caller or determined from the
@select
attribute on the parameter,
cannot be converted to the specified data type.
Unlike parameters in the XSLT 2.0 specification [XSLT 2.0], the parameters defined in this specification cannot contain sequence constructors.
A general variable is declared by a <variable:generalVariable>
element.
The syntax for the
<variable:generalVariable>
element is defined by the normative schema supplied with this specification.
The XPath expression implied by a general variable is the
content of the @select
attribute on the general
variable. The context node for evaluation of the
XPath expression is the <xbrli:xbrl>
element of the
input XBRL instance.
The @bindAsSequence
attribute on general variables
has implications for their evaluation as set out in
Section 4.1
A fact variable is declared by a <variable:factVariable>
element.
The syntax for the
<variable:factVariable>
element is defined by the normative schema supplied with this specification.
The @bindAsSequence
attribute on fact variables
has implications for their evaluation, as set out in
Section 4.1
The optional @fallbackValue
attribute on fact variables
also has implications for their evaluation, as set out in
Section 4.2.
The XPath expression implied by a fact variable depends on its filters.
If the @nils
attribute on a fact variable is omitted or is equal to false
then the XPath expression implied by a fact variable begins with:
xfi:non-nil-facts-in-instance(/xbrli:xbrl)
If the @nils
attribute on a fact variable is equal to true
then the XPath expression implied by a fact variable begins with:
xfi:facts-in-instance(/xbrli:xbrl)
This term is followed by an
XPath predicate
that filters the facts in the sequence
produced by the xfi:facts-in-instance(/xbrli:xbrl)
function or the xfi:non-nil-facts-in-instance(/xbrli:xbrl)
function.
The expression in the XPath predicate includes an
XPath expression implied by each of the fact variable's filters.
A fact variable can either use a filter or the filter complement to determine its implied XPath expression. The complement of a filter selects all of those facts that are not selected by the filter.
The XPath expression implied by a filter complement is the
fn:not()
function applied to the XPath expression implied by a filter.
If a fact variable is using a filter rather than its complement,
then the XPath expression implied by that filter is surrounded by
round brackets (
, and )
before inclusion
in the XPath expression implied by the fact variable.
If a fact variable is using a filter complement rather than the filter, then the XPath expression implied by the filter complement is not modified before inclusion in the XPath expression implied by the fact variable.
To obtain the complete XPath expression in the XPath predicate,
the XPath expressions implied by the filters and the filter
complements are combined using the
and
token to form a single
XPath
and-expression.
A filter defines selection criteria for facts in the input XBRL instance.
An input fact is a fact in the input XBRL instance that is being filtered.
Filters express criteria that can be applied to input facts. Such criteria are incorporated into the XPath expressions implied by fact variables.
Filters are declared as
XLink resources
in XLink extended links.
Filters MUST be in the
substitution group
for the abstract
<variable:filter>
element.
A filter can cover an aspect if it selects facts using that aspect as a selection criterion.
An uncovered aspect of a fact variable is an aspect that is not covered by any of the filters that are being used to construct the XPath expression implied by the variable.
Every filter specification MUST indicate the aspects, if any, that it can cover.
A covering filter is a filter that does cover the aspect or aspects that it can cover.
A non-covering filter is a filter that does not cover the aspect or aspects that it can cover.
Whether a filter is covering or non-covering is specified as a part of the association between the filter and the fact variable that utilises it.
All filters MUST imply an XPath expression that represents the essence of the evaluation of a fact as a context item. The XPath expression identifies nature of the processing to include or reject a candidate fact in the filtered result set, but need not necessarily provide the full interface structure, conditional execution, and error coding that might be required.
Every filter specification MUST include such a definition of the XPath expression that is implied by the filter.
The filter implied XPath expression processing operations and function calls imply the processing in terms of XPath operations and function calls, their argument syntax and implied type checking, and operational exceptions, that would result if the implementation embodied the XPath expression. If the implementation instead uses different coding for equivalent operations, function behavior, type checking, and operational exceptions, it should detect and report the same errors and conditions as the XPath alone would report, except where a filter specification provides for different error detection and reporting than the XPath expression would imply. In case a filter specification describes error detection and reporting that differs from what the implied XPath by itself would imply, then the filter specification prevails.
The XPath expression implied by a filter MAY include XPath variable references. Resolution of XPath variable references in the XPath expressions implied by filters is beyond the scope of this specification. Resolution of such XPath variable references needs to be addressed by specifications that build upon this specification. This includes specification of how variables are to be associated with the QNames used for XPath variable references.
Filters that are covering can only select facts that have the aspects that they cover. It is not intended that the implied XPath expression can be successfully applied to facts that don't have the covered aspects. The implementation is expected to provide such coding in its interface structure as appropriate, so that the operations and function arguments of the implied XPath are not expected to accept inapplicable facts.
Filters are not expected to be sequenced in any order, and may be optimized or have results cached when not dependent on other variables of a variable set.
Filters that are not covering, such as the general filter, may have explicit XPath expressions intended for certain
kinds of data, such as numeric operations. Although such a filter may be combined with other filters that
restrict facts to certain concepts of data types, because the filters may be run in any order (and cached)
such expressions need defensive protective coding to prevent execution of restricted operations as needed.
For example in a general filter, numeric operations need to be protected by being in an if
expression that
prevents execution on non-numeric facts, because the general filter can have the explicit XPath expression executed at any time
and with any fact as its context item.
A filter specification MAY specify "XPath usage is identical to that in the
XBRL Variables Specification (with hyperlink to this document)".
If that is specified, a filter with a
variable-filter relationships
to a fact variable MAY have an
XPath expression containing XPath variable references
to variables and parameters, using the QNames of @name
attributes of
a variable set resource's
variable-set relationships.
A fact meets the criteria specified by a
filter only if the result of evaluating the
XPath expression implied by that filter,
using the fact as the context item,
results in an
effective Boolean value
of true
.
If the filter covers an aspect that the fact does not have then the filter results in an
effective Boolean value
of false
without necessarily executing the XPath expression (the aspect applicability
is implemented by an implementation's interfacing code, not necessarily described as part of
the implied XPath expression).
Filters MAY be associated with fact variables in the following three ways:
All methods of associating filters with fact variables identify whether the filter covers aspects and whether the fact variable uses the filter or the filter complement.
A variable-filter relationship is a relationship between an fact variable and a filter expressed by an XLink arc.
To declare a variable-filter relationship an XLink arc MUST:
http://xbrl.org/arcrole/2008/variable-filter
The arcrole value,
http://xbrl.org/arcrole/2008/variable-filter
,
is declared in the normative schema supplied with this specification.
Variable-filter relationships MUST be expressed by variable-filter arcs. Violations of this requirement can be detected by validation against the XBRL Specification [XBRL 2.1].
A complemented variable-filter relationship is a variable-filter relationship
that is expressed by an arc with a @complement
attribute that has a value of true
.
A fact variable with a complemented variable-filter relationship to a filter uses the filter complement in its implied XPath expression rather than the filter itself.
A covering variable-filter relationship is a variable-filter relationship
that is expressed by an arc with a @cover
attribute that has a value of true
.
If a filter is related to a variable by a variable-filter relationship, that filter only covers aspects of the facts being filtered if the variable-filter relationship is covering.
A variable-filter arc is expressed by
the <variable:variableFilterArc>
element.
The syntax for the
<variable:variableFilterArc>
element is defined by the normative schema supplied with this specification.
The XPath expressions implied by variables can include XPath variable references that need to be resolved to other fact or general variables. This reference can only be resolved if the variable implying the XPath expression and the variable being referenced are in the same variable set.
A variable set is a set of fact and/or general variables that are able to reference each-other using XPath variable references.
Variable sets are defined by local XLink resources that are in the
substitution group
for the abstract <variable:variableSet>
element.
Such resources are referred to as variable-set resources.
All variables that have
variable-set relationships
to a variable-set resource are in the variable set defined by that resource.
Variable sets identify their aspect model
using their @aspectModel
attribute. The value of the @aspectModel
attribute on a variable-set resource is the aspect
model identifier of the aspect model to be used when evaluating variables in
the variable set defined by the variable-set resource.
A variable set's aspect model is the aspect model identified by
the @aspectModel
attribute on the variable-set resource defining the
variable set.
Error code xbrlve:unknownAspectModel
MUST be
thrown if the processing software does not recognise the aspect model
identified by the value of an @aspectModel
attribute.
Error code xbrlve:duplicateVariableNames MUST be thrown if two or more variables or parameters in the same variable set have the same name.
Error code xbrlve:filterAspectModelMismatch MUST be thrown if the processing software encounters a variable set in which one or more of the fact variables in the variable set has a filter that can cover an aspect that is not defined in the aspect model of the variable set.
A variable-set relationship is a relationship between a variable-set resource and either a fact variable or a general variable, or a parameter expressed by an XLink arc.
To declare a variable-set relationship an XLink arc MUST:
http://xbrl.org/arcrole/2008/variable-set
The arcrole value,
http://xbrl.org/arcrole/2008/variable-set
,
is declared in
the normative schema
for variables.
Variable-set relationships MUST be expressed by variable arcs. Violations of this requirement can be detected by validation against the XBRL Specification [XBRL 2.1].
The QName of a variable or parameter is specified by the @name
attribute on the variable arc connecting it to a variable
set.
If the QName has no namespace prefix, then it has no namespace, regardless of the default namespace for
the containing element.
Otherwise, the QName is resolved in accordance with [XML NAMES]
using the namespace declarations that are in scope for the variable arc containing
the @name
attribute.
[ 2 ]
When evaluating the variables in a variable-set, XPath variable references with this QName are references to the variable or parameter. Note that, for parameters, this QName MAY differ from the QName given in the parameter declaration.
If this QName is the same as the QName given in a parameter declaration, XPath variable references with this QName are references according to the the variable-set relationship, which overrides the parameter reference.
A variable arc is expressed by the <variable:variableArc>
element.
The syntax for the
<variable:variableArc>
element is defined by the normative schema supplied with this specification.
A variable-set-filter relationship is a relationship between a variable set resource and a filter expressed by an XLink arc.
To declare a variable-set-filter relationship an XLink arc MUST:
http://xbrl.org/arcrole/2008/variable-set-filter
The arcrole value,
http://xbrl.org/arcrole/2008/variable-set-filter
,
is declared in the normative schema supplied with this specification.
Variable-set-filter relationships MUST be expressed by variable-set filter arcs. Violations of this requirement can be detected by validation against the XBRL Specification [XBRL 2.1].
A filter participating in a variable-set-filter relationship is, by definition, associated with each of the fact variables in the variable set defined by the resource that it is related to.
A filter that is associated with a fact variable by a variable-set-filter relationship is referred to as a group filter.
A complemented variable-set-filter relationship is a variable-set-filter relationship
that is expressed by an arc with a @complement
attribute that has a value of true
.
The fact variables in a variable set defined by a resource with a complemented variable-set-filter relationship to a filter use the filter complement in their implied XPath expressions rather than the filter itself.
All filters that are associated with fact variables by variable-set-filter relationships, by definition, do not cover any aspects.
Filters that are associated with fact variables by variable-set-filter relationships MUST NOT imply XPath expressions that include XPath variable references to general variables or fact variables.
Error code xbrlve:factVariableReferenceNotAllowed MUST be thrown if a filter that is associated with fact variables by a variable-set-filter relationship implies an XPath expression that includes an XPath variable reference to a general variable or a fact variable.
A variable-set filter arc is expressed by the <variable:variableSetFilterArc>
element.
The syntax for the
<variable:variableSetFilterArc>
element is defined by the normative schema supplied with this specification.
Fact variables in a variable set MAY be associated with implicit filters, defined in the Implicit filters specification [IMPLICIT FILTERS], as well as filters that are related to them explicitly by variable-filter relationships and variable-set-filter relationships.
A variable set MUST have an @implicitFiltering
attribute that is
equal to true
if its fact variables are to have
implicit filters.
If the @implicitFiltering
attribute is equal to false
then
the fact variables in the variable set are not associated with implicit filters.
A variable set uses implicit filtering if its
@implicitFiltering
attribute equals true
and it does not use implicit filtering if the
@implicitFiltering
attribute equals false
.
The implicit filters, if any, that are associated with the fact variables in a variable set depend on the variable set's aspect model.
If a variable set has a dimensional aspect model, then the fact variable in the variable set are associated with dimensional implicit filters.
If a variable set has a non-dimensional aspect model, then the fact variable in the variable set are associated with non-dimensional implicit filters.
Variable set resources MAY be associated with preconditions by variable-set-precondition relationships. Preconditions define conditions that must be satisfied for a variable set evaluation to occur.
A precondition is expressed by the <variable:precondition>
element.
The syntax for the
<variable:precondition>
element is defined by the normative schema supplied with this specification.
The @test
attribute on a precondition contains an
XPath expression. Its content is referred to as a
precondition expression.
A satisfied precondition is a precondition for which the
precondition expression evaluates to an
effective Boolean value
of true
given the values of the variables in the variable set
that the precondition is associated with.
The
context node
for evaluation of precondition expressions is the
<xbrli:xbrl>
element of the
input XBRL instance.
A variable-set-precondition relationship is a relationship between an variable-set resource and a precondition, expressed by an XLink arc.
To declare a variable-set-precondition relationship an XLink arc MUST:
http://xbrl.org/arcrole/2008/variable-set-precondition
The arcrole value,
http://xbrl.org/arcrole/2008/variable-set-precondition
,
is declared in the normative schema supplied with this specification.
Variable-set-precondition relationships MUST be expressed by generic arcs. Violations of this requirement can be detected by validation against the XBRL Specification [XBRL 2.1].
A general variable evaluation is the evaluation of a general variable against a input XBRL instance.
A fact variable evaluation is the evaluation of a fact variable against a input XBRL instance.
A variable evaluation is either a general variable evaluation or a fact variable evaluation.
Except for the following three special cases, a variable-set evaluation is deemed to have occurred if all variables in the variable set have been evaluated and if all of the preconditions associated with the variable set are satisfied given the evaluations of the variables in the variable set.
The special cases are:
V
, that
has evaluated to a fallback value but that fact variable
could have evaluated to a non-fallback value without
forcing a change in the value of any one of the other fact variables in the variable
set that has not, itself, evaluated to a fallback value and that does not, itself, have a dependency
on fact variable V
.
Error code xbrlve:ambiguousAspects MUST be thrown if the input XBRL instance contains a fact for which the aspects cannot be uniquely determined, given the aspect model of the variable set to be evaluated.
Error code xbrlve:ambiguousAspectValues MUST be thrown if the input XBRL instance contains a fact for which the values of one or more of its aspects cannot be uniquely determined, given the aspect model of the variable set to be evaluated.
Two evaluations of a variable-set for a given input are identical variable-set evaluations if each fact variable evaluation in one variable set evaluation is identical to the evaluation of the same fact variable in the other variable set evaluation.
Two evaluations of a variable-set for a given input are different variable-set evaluations if they are not identical.
Two evaluations of a fact variable are identical fact-variable evaluations if: both evaluations are sequences of the same length and for each item in one of the sequences, there is an identical item in the other sequence.
All variable evaluations begin with evaluation of the XPath expression implied by the variable.
An XPath expression has a variable dependency if the expression includes an XPath variable reference.
Applications are responsible for determining an evaluation order for variables in a variable set that ensures that the variable dependencies for each variable in the variable set are to variables that have already been evaluated.
Error code xbrlve:unresolvedDependency MUST be thrown if there an XPath expression to be evaluated has a variable dependency that cannot be resolved to a variable or parameter.
Error code xbrlve:cyclicDependencies MUST be thrown if there are circular dependencies in the references to variables in a variable set.
Fact variable $a
implies an XPath expression that
includes an XPath variable reference to general variable $b
.
General variable $b
implies an XPath expression that
includes an XPath variable reference to general variable $c
.
General variable $c
implies an XPath expression that
includes an XPath variable reference to fact variable $a
.
Note that a circular set of XPath variable references can involve both fact and general variables.
A source sequence is the sequence obtained by evaluating the XPath expression implied by a general variable or a fact variable.
A variable binds as a sequence if it has a
@bindAsSequence
attribute equal to true
.
Otherwise, it does not bind as a sequence.
The result of a variable evaluation depends upon whether the variable binds as a sequence.
For a general variable that does not bind as a sequence, the result of its evaluation is any one of the items in its source sequence. For a general variable that does bind as a sequence, the result of its evaluation is the source sequence.
For a fact variable, if the source sequence is not empty and if it does not bind as a sequence, then the result of its evaluation is either its fallback value or any one of the facts in its source sequence.
For a fact variable, if the source sequence is not empty and if it does bind as a sequence, then the result of its evaluation is either its fallback value or any sequence of facts in the source sequence that meets the following conditions:
@matches
attribute on the fact variable is omitted or is equal to false
then the evaluation result MUST NOT contain any
aspect-matched facts.
The order of the facts in the evaluation result for fact variables is application dependent. Evaluation results that only differ with regard to the order of the facts that they contain are deemed to be the same evaluation.
The previous section addressed the evaluation of general variables and the evaluation of fact variables when the source sequence is not empty. This section addresses the evaluation of fact variables when the source sequence is empty.
If the source sequence is empty, then the result
of a fact variable evaluation also depends on the
@fallbackValue
attribute on the fact variable.
A fact variable can bind to an empty sequence if it has a
@fallbackValue
attribute.
Otherwise a fact variable cannot bind to an empty sequence and so, if the
source sequence is empty, the fact variable cannot be evaluated.
If a fact variable can bind to an empty sequence, and the source sequence
is empty, then the result of variable evaluation is determined by the
@fallbackValue
attribute.
Specifically, the result of the fact variable evaluation is given by
evaluating the XPath expression contained by the @fallbackValue
attribute,
using the <xbrl:xbrli>
element of the input XBRL instance as
the context node. The parameters in the variable set are in context for the
evaluation of the XPath expression in the @fallbackValue
attribute
but fact and general variables in the variable set are not and so cannot be
referenced from within that XPath expression.
Error code xbrlve:fallbackValueVariableReferenceNotAllowed
MUST be thrown if the @fallbackValue
attribute on
a fact variable references a fact or general variable.
A fallback value is the value of a fact variable that has been
determined on the basis of the content of the @fallbackValue
attribute.
A non-fallback value is the value of a fact variable that has been
determined on the basis of its source sequence rather than the content of the
@fallbackValue
attribute.
The following is the XML schema provided as part of this specification. This is normative. Non-normative versions (which should be identical to these except for appropriate comments indicating their non-normative status) are also provided as separate files for convenience of users of the specification.
NOTE: (non-normative) Following the schema maintenance policy of XBRL International, it is the intent (but is not guaranteed) that the location of non-normative versions of these schemas on the web will be as follows:
http://www.xbrl.org/2008/
- during the drafting process for
this specification this directory should contain a copy of the
most recent published version of the schema at
http://www.xbrl.org/2008/variable.xsd.
This document and translations of it may be copied and furnished to others, and derivative works that comment on or otherwise explain it or assist in its implementation may be prepared, copied, published and distributed, in whole or in part, without restriction of any kind, provided that the above copyright notice and this paragraph are included on all such copies and derivative works. However, this document itself may not be modified in any way, such as by removing the copyright notice or references to XBRL International or XBRL organizations, except as required to translate it into languages other than English. Members of XBRL International agree to grant certain licenses under the XBRL International Intellectual Property Policy (www.xbrl.org/legal).
This document and the information contained herein is provided on an "AS IS" basis and XBRL INTERNATIONAL DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
The attention of users of this document is directed to the possibility that compliance with or adoption of XBRL International specifications may require use of an invention covered by patent rights. XBRL International shall not be responsible for identifying patents for which a license may be required by any XBRL International specification, or for conducting legal inquiries into the legal validity or scope of those patents that are brought to its attention. XBRL International specifications are prospective and advisory only. Prospective users are responsible for protecting themselves against liability for infringement of patents. XBRL International takes no position regarding the validity or scope of any intellectual property or other rights that might be claimed to pertain to the implementation or use of the technology described in this document or the extent to which any license under such rights might or might not be available; neither does it represent that it has made any effort to identify any such rights. Members of XBRL International agree to grant certain licenses under the XBRL International Intellectual Property Policy (www.xbrl.org/legal).
This document could not have been written without the contributions of many people including the participants in the Formula Working Group.
Date | Author | Details |
---|---|---|
18 December 2006 | Geoff Shuetrim |
First internal working draft created, drawing extensively on the previous formula specification drafts. |
23 April 2007 | Geoff Shuetrim |
Added identification of the context node for evaluation of the XPath expression implied by general variables based on the feedback from Masatomo Goto. Made the section on the XPath expression implied by a fact variable a sub-section of the section on fact variables. |
24 April 2007 | Geoff Shuetrim |
Introduced the sections on implicit filtering and distinguished the explicit filtering. Added the section on the evaluation of fact variables to specify how implicit filters are to be introduced into the evaluation of fact variables. |
25 May 2007 | Geoff Shuetrim |
Added a date to the arcrole defined in the specification. |
03 May 2007 | Geoff Shuetrim |
Changed the implicit filtering treatment for facts that have concepts with relationships to dimension hyper-cubes as defined in the XBRL Dimensions Specification. The implicit filter now involves a component for dimensions and a component for everything else in the segment or the scenario. |
07 May 2007 | Geoff Shuetrim |
Removed the requirement that relationships be defined in terms of the concrete arcs that express them. |
08 May 2007 | Geoff Shuetrim |
Added the implicit concept filter. |
29 May 2007 | Geoff Shuetrim |
Changed the name of the implicit sibling filter to the implicit location filter. Refined the algorithm for determining when implicit filters are required. |
13 June 2007 | Geoff Shuetrim |
Simplified the algorithm for inferring the need for implicit filters. Allowed general variables to bind as sequences or individually, analogously to fact variables, based on suggestions and motivating examples provided by Herm Fischer. |
25 June 2007 | Geoff Shuetrim |
Introduced implicit dimension filters and redefined the notion of coverable aspects. Refined the implicit segment and scenario filters to only deal with the content of segments and scenarios that are not reporting values for XDT dimensions. |
24 July 2007 | Hugh Wallis |
Edited for public working draft publication. |
30 September 2007 | Herm Fischer |
Added explanatory diagrams and text to clarify the operation of implicit filters. |
07 November 2007 | Geoff Shuetrim |
Converted the specification to XML format. Added in the definitions and the hyperlinks to the relevant sections of the normative schema. Moved the parameter resource to the variable specification so that it can be used with variables without needing to involve formula evaluation. Removed the language about inclusion of parameters in the DTS when evaluating XPath expressions because these kinds of problems will be covered by XPath evaluation exceptions. Defined an error code for parameter data type mismatches. Moved the material on custom function signatures to the variable specification. |
12 November 2007 | Geoff Shuetrim |
Linked all of the external terminology references back to bibliographic citations. Added a definition of an XPath evaluation exception to the section on XPath usage. This provides a catch all term for static, dynamic and type XPath errors. |
13 November 2007 | Geoff Shuetrim |
Defined a new variable-filter arc to provide for new attributes allowing a filter or its complement to be used for a fact variable and to allow a filter to cover or not cover an aspect. The arc expresses variable-filter relationships. Eliminated the distinction between explicit and implicit filters but enabled the association of filters with fact variables to be extensible so that such associations can be defined using structures other than variable-filter relationships. This opens up the possibility of defining the associations implicitly in a separate specification covering implicit filtering. This change removed the explanatory diagrams and examples provided by Herm Fischer. Added a final section to the specification to define the notion of an aspect of a fact. Following the suggestions from Masatomo Goto and Masaru Uchida, added abstract filter and variable element declarations to the normative schema and required all variables to be in the substitution group for the abstract variable element and all filters to be in the substitution group for the abstract filter element. All of the normative filter schemas have been updated to reflect this change. Changed the custom function signature specification of input parameter order to be based on document order instead of an order attribute to eliminate the need for an error code relating to ambiguous input parameter orderings.
Moved the |
14 November 2007 | Geoff Shuetrim |
Added the complete-segment and complete-scenario aspect definitions to support developments in the matching filter specification. These will support implicit filtering in a system that does not take the XBRL Dimensions Specification [DIMENSIONS] into account. Added the definition of an uncovered aspect to the section on aspects to support the specifications of relative filters and implicit filters. Eliminate mixed content features from the resources defined in this and dependent specifications. Moved the sections on custom function signatures and parameters to the XPath usage section. Removed the boilerplate XPath usage reference to this specification, now that the XPath usage section in this specification is complete. |
15 November 2007 | Geoff Shuetrim |
Weakened the definition of covering an aspect so that a filter covers an aspect if it always uses that aspect in its filtration criteria. This is important because coverage is not just about tying all aspects to specific values but it is also able just finding the aspects that you do not want to match to other fact variables in the group of variables being evaluated. Resolved issue of interaction between aspect coverage and filter complements (filters with the XPath fn:not() function applied to them) by specifying that filter complements do not cover aspects. Moved a paragraph introducing the syntax section to the introduction to fit better with the shift of the parameters and custom function signatures to the XPath usage section. Added the definition of a variable set to the specification to better support structures like implicit filtering. Variable sets are sets of variables that can reference each-other using XPath variable references. This definition enables scoping issues to be clearer in things like the formula specification. |
19 November 2007 | Geoff Shuetrim |
Added the dimensions specification and the XLink specification to the list of references.
As suggested by Victor Morilla,
defined the Formally defined covering and non-covering filters to support the terminology set out in the implicit filter specification. |
23 November 2007 | Geoff Shuetrim |
Fixed up wording problems in the abstract as detected by Jim Richards. Improved the wording in relation to variables that evaluate as sequences. Added a statement to the effect that if all XPath expressions implied by all fact variables in a variable set evaluate to empty sequences, then evaluation of all variables in the variable set and any XPath expressions that reference those variables MUST stop. |
23 November 2007 | Jim Richards |
Reworded definitions for input facts and input XBRL instances so that the terminology being defined is the first part of the definition. Made some minor grammatical corrections. |
26 November 2007 | Jim Richards |
Reworded definitions for sections on Aspects of Facts and Variable Evaluation so that the terminology being defined is the first part of the definition. Made some minor grammatical corrections and re-ordered some paragraphs in the sections mentioned. |
26 November 2007 | Geoff Shuetrim |
Added explanatory material to the introduction on variable and parameter naming.
Added an error code to cover situations where two
parameters in the one DTS have the same value of their
Added in variable-set-filter relationships to address the syntax niceties sought by Victor Morilla. |
27 November 2007 | Geoff Shuetrim |
Incorporated the proposal from Victor Morilla regarding the definition of an evaluation of a variable that is allowed to bind to a sequence of facts. Moved the formula section on implicit filters back to the variable specification and expressed it in terms of a variable-set resource so that the notion of implicit filtering is available for variable usages going beyond formula evaluation.
Provided formal definitions of aspect-models and variable sets
to support a clearer definition of when and how implicit filters
are to be used. Changed how the aspect model to use (what aspects
are defined for the facts being filters) is identified so that we
are not using the Defined the notion of an aspect test to be used to test for the equivalency of the value of an aspect for two different facts. Defined the notion of a variable-set precondition and the notion of a variable-set evaluation, thus enabling preconditions and variable-set evaluations to be used for both formulae and assertions. Added paragraphs to define the evaluation ordering of variables in a variable set. This improves on the ordering of formula-variable relationships that was in the formula specification. Added an error code to cover situations where a variable set resource has variable-set relationships to variables that are in different relationship networks. This blocks situations where an ordering of variables could otherwise need to be defined across networks of relationships. |
28 November 2007 | Victor Morilla |
Corrected a few bibliographic references Added comments on variable-set-filters Added comments on attributes for general variables Comment on context node for most XPath expressions Comments on order of evaluation Included error for cyclic references |
29 November 2007 | Geoff Shuetrim |
Removed explicit ordering of variables in a variable set given that it is no longer needed for implicit filtering, as per suggestion from Victor Morilla. Removed attributes relating to binding process for general variables as per suggestion from Victor Morilla. Refined aspect test definition to cover cases where the aspect is not reported for the facts being tested. |
30 November 2007 | Geoff Shuetrim |
Added in a missing arcrole declaration to the normative schema. Fixed up various cross-link ID attribute values. |
03 December 2007 | Geoff Shuetrim |
Added in a definition of an aspect match to support context and unit construction rules in the formula specification. Added rules to the section on aspect models to require that all aspect models cover all of the required aspects for facts and cover the information that can be contained in segments and scenarios. |
04 December 2007 | Geoff Shuetrim |
Added definitions of different and identical variable-set evaluations. These support extensions such as assertion specifications where assertion results depend on a count of the different possible variable-set evaluations that are possible with a given input XBRL instance. |
05 December 2007 | Geoff Shuetrim |
Modified the normative schemas to make them conform to XML Schema.
Till now, they have not been conformant because all resources were
in the substitution group for the |
07 December 2007 | Geoff Shuetrim |
As recommended by Herm Fischer, added a sentence to variable set evaluation definition to clarify the edge case where the variable set has no variables. |
13 December 2007 | Geoff Shuetrim |
Changed the |
24 December 2007 | Geoff Shuetrim |
Fixed up schema imports in the normative schema to include an import of the generic link schema to support some software that expects such imports when arcrole type declarations refer to elements in those schemas and to include an import of the XBRL 2.1 schemas on the public XII website. |
09 January 2008 | Geoff Shuetrim |
Removed the regular-expression constraint on the |
20 January 2008 | Geoff Shuetrim |
Inserted a new regular expression constraint on the
From feedback by Pablo Navarro Salvador:
fixed up the erroneous reference to a |
29 January 2008 | Geoff Shuetrim |
Removed the obsolete order attribute from the |
30 January 2008 | Geoff Shuetrim |
Relaxed the requirement that data types for custom function signatures be expressed as QNames given the need to deal in sequences. |
31 January 2008 | Geoff Shuetrim |
Standardised the format of the hyperlinks to the normative schema. Corrected an erroneous statement that variable-set filter relationships have to be expressed by filter arcs instead of variable-set filter arcs. |
02 February 2008 | Geoff Shuetrim |
The
Added paragraphs to the sections on general variables and fact variables
pointing to the explanations of the attributes impacting on how they bind
when they are evaluated depending on the |
05 February 2008 | Geoff Shuetrim |
Modified the XBRL functions used to test matches of segment and scenario dimensions to eliminate the need to directly obtain the nodes representing dimension values for the purposes of testing s-equal2 conditions. This is necessary given that some dimensions can have default values. |
12 February 2008 | Geoff Shuetrim |
Fixed the spacing in the definition of binding as a sequence. |
16 February 2008 | Geoff Shuetrim |
Added a missing reference for XQuery. Corrected reference to Pablo in the revision history. |
26 February 2008 | Geoff Shuetrim |
Removed the erroneous Bought the names of the XBRL functions used for the dimension aspect tests into line with the function naming conventions used in the function registry. |
07 March 2008 | Geoff Shuetrim |
Defined a default function namespace. |
08 March 2008 | Geoff Shuetrim |
Changed any to all to improve the clarity of the requirement that aspect models include aspects for whatever content is permitted in segments and scenarios. Added a table summarising the aspects in the dimensional and non-dimensional aspect models.
Eliminated the redundant Fixed grammatical errors in the definition of a precondition. These changes were suggested by Paul Bull. |
10 March 2008 | Geoff Shuetrim |
Grouped the various paragraphs contributing to the definition of a variable set evaluation so that the complete definition is available in a single place rather than having to be pieced together from different sections of the specification. Clarified the reference to XSLT 2.0 sequence constructors as suggested by Phillip Engel. |
13 March 2008 | Geoff Shuetrim |
Created links from terms used in the introduction. Added explanation of the function of parameters to the parameter definition. Clarified motivation for XBRL custom functions by referencing the need to draw on information from the DTS supporting XBRL instances. Flagged that the implementation of custom functions is outside the scope of the variable specification. Changed the reference to a formula processor to a reference to a variable processor. Clarified the wording in relation to sourcing of values for mandatory and non-mandatory parameters. Rearranged sections to minimise references to terms not already defined.
Simplified the definitions of the dimensional and
non-dimensional aspect models to avoid relying on references to the
Defined the unique text string identifier for an aspect model. Clarified that aspect tests are equivalence relations. Relaxed the requirement on the aspects that had to be included in all aspect models. Added an explicit reference to the implicit filtering specification. These changes were in response to feedback by CompSci Resources. |
20 March 2008 | Geoff Shuetrim |
Fixed broken hyperlinks. |
14 April 2008 | Geoff Shuetrim |
Changed |
17 April 2008 | Geoff Shuetrim |
Clarified that a variable set with no preconditions and no variables can be deemed to have evaluated once, as suggested by Herm Fischer. |
23 April 2008 | Geoff Shuetrim |
Removed the error code relating to missing implicit filters, as suggested by Herm Fischer, because it would only be relevant in situations where an aspect model has not been adequately specified. Added error xbrlve:filterAspectModelMismatch that prohibits the usage of explicit filters in a variable set when those explicit filters can cover aspects that are not defined in the aspect model of the variable set in question. This was suggested by Herm Fischer. |
12 June 2008 | Geoff Shuetrim |
Added a new error code that is to be thrown whenever two variables or parameters in the same variable set have the same variable name. This is necessary now that evaluation order is determined based upon dependencies that are reflected in variable names. |
17 June 2008 | Geoff Shuetrim |
Refined the definition of identical fact variable evaluations to handle the case where the fact variable evaluation is the fallback value. |
26 June 2008 | Geoff Shuetrim |
Deleted the sentence requiring that filter complements never cover aspects. Now such filters can cover aspects in the same way that normal filters can. This issue was raised by Victor Morilla. Clarified that variable names with no namespace prefix are not to be resolved using the default namespace for the containing element. This issue was raised by Herm Fischer.
Changed the evaluation context for fallback values to ensure that
fact and general variables are not able to be referenced by the XPath
expressions in |
12 August 2008 | Geoff Shuetrim |
Corrected the definition of identical fact variable evaluations to handle sequences of atomic values as well as sequences of facts. Modified the definition of variable set evaluations and fact variable evaluations to ensure that application dependent evaluation ordering decisions cannot impact on the set of legal variable set evaluations for a formula and a given target XBRL instance. This modification was suggested by Andy Harris. |
13 August 2008 | Geoff Shuetrim |
Removed un-necessary schema limitations on undirected cycles in relationship networks. |
22 August 2008 | Geoff Shuetrim |
Added the
Added the |
25 August 2008 | Geoff Shuetrim |
Added two new error codes: xbrlve:ambiguousAspects and xbrlve:ambiguousAspectValues, to cover situations where the aspect model does not match the information in the XBRL instance well enough to uniquely determine the aspects, and the values of those aspects, for all facts in the instance. Simplified the dimensional aspect model to include only dimension aspects rather than segment dimension aspects and scenario dimension aspects. This simplification is now possible because the base specification WG agreed to require that the one dimension not be reported in both the segment and scenario for a given fact. It is also required because the XDT specification does not always associate a dimension value with a segment or a scenario. This is the case for default dimension values for facts reporting values with dimensions that validate against a conjunction of open hypercubes. Without this simplification the new error codes added today would be thrown for such facts. Moved the definition of an OCC and an OCC aspect to the variable specification from the formula specification so that they can be utilised more generally. Modified the definition of an OCC to be more concrete. Added more explicit requirements on aspect model definitions to ensure that they include one segment OCC aspect and one scenario OCC aspect. |
26 September 2008 | Geoff Shuetrim |
Modified the naming of variables and parameters on variable
arcs to ensure that variable and parameter QNames could not
be inadvertently changed to incorrect values by processing
software that is namespace aware but that does not
understand the special treatment of XPath 2.0 variables with
no namespace. Variable and parameter names are now provided
by two attributes, a Added a definition of aspect-matched facts to replace the notion of duplicate facts as defined in the XBRL 2.1 specification. This also improves terminology support for the consistency assertions specification.
Changed the |
01 October 2008 | Geoff Shuetrim |
Modified the syntax for variable and parameter names once more, reverting to a single attribute that specifies a QName but that uses a restriction on the XML Schema Name type rather than an XML Schema QName type. The specification wording then makes explicit how the value of the name attribute on variable arcs is to be resolved, ensuring that any name attribute value without a QName prefix is resolved to a QName with no namespace. This requires resolution of name attribute values with QName prefixes to be resolved in the usual way, using the namespace declarations that are in scope for the containing variable arc. This approach was universally preferred by the UBMatrix and Fujitsu developers participating in the discussion of variable QName resolution issues. Added a new error code to catch situations where the QName for variables on variable arcs cannot be resolved. |
24 October 2008 | Geoff Shuetrim |
Added Section 2.1 to overcome the inherent limitations of the definition of s-equal2 for dimension aspect tests. |
29 October 2008 | Geoff Shuetrim |
Corrected typographic errors in Section 2.1 as suggested by Victor Morilla. |
04 November 2008 | Geoff Shuetrim |
Corrected function signatures in the implied XPath expressions for dimension aspect tests and removed redundant terms in them, as suggested by Takahide Muramoto. |
06 November 2008 | Geoff Shuetrim |
Renamed the |
17 November 2008 | Geoff Shuetrim |
Clarified that xbrlve:variableNameResolutionFailure is required to be thrown when namespaces cannot be resolved for any attributes that contain fact or general variable QNames. This involved moving the explanation of the error code to the XPath usage section. This change was suggested by Herm Fischer during analysis of conformance suite coverage. |
27 November 2008 | Geoff Shuetrim |
Added a paragraph to Section 1.7 to clarify the
purpose behind using the Added a paragraph to Section 1.7 to be specific that the XQuery/XPath data models used for XPath processing are to be constructed from post XML Schema Validation Infosets. This was a result of feedback from Nathan Summers on the consequences of not being specific in this way. |
15 December 2008 | Geoff Shuetrim |
Updated references to the latest errata-corrected version of the XBRL 2.1 specification. |
19 March 2009 | Geoff Shuetrim |
Changed the term "target XBRL instance" to "input XBRL instance". Ensured that all usages of the terms input XBRL instance and output XBRL instance reference the term definition. Clarified validity requirements in relation to input XBRL instances. Replaced the s-equal functions with nodes-correspond functions in the aspect test definitions to ensure that identical nodes could be deemed to match. Replaced the incorrect xfi:elements-correspond function with the actual xfi:nodes-correspond function. Allowed formulae to not provide custom function declarations for functions in the XBRL functions registry. Defined a new error code for custom functions that have the XBRL functions registry namespace. |
23 March 2009 | Geoff Shuetrim |
Fixed the function arguments for the entity identifier aspect test. Clarified the variable set evaluation explanation regarding the implications of variables that evaluate to fallback values. |
24 March 2009 | Geoff Shuetrim |
Finished a first cut of the sections on static and dynamic context determination. |
26 March 2009 | Geoff Shuetrim |
Specified the default collation as part of the static context initialisation. |
03 May 2009 | Herm Fischer |
Typos fixed per cgh chen as in PR wiki page. Entity identifier aspect XPath function names corrected to match function registry. |
01 December 2009 | Victor Morilla |
Included solution to those conflicting cases where a filter in a variable-filter relationship has a common aspect with a filter in a variable-set-filter relationship. |
07 February 2010 | Victor Morilla |
Changed status to draft proposed edited recommendation. |
12 June 2010 | Herm Fischer |
Commented out preceding revision change of 2009-12-01, WG agreement and wiki notes marked "Victor Morilla 2010-02-12". Reverted from draft proposed edited recommendation to previous recommendation status, with remaining changes of this date by errata. Erratum 1 added. Erratum 2 added. |
11 March 2011 | Herm Fischer |
Updated erratum of 2010-12-09 to clarify that variable-set-relationship QNames override parameter QNames. |
14 March 2011 | Herm Fischer |
Updated xbrlve:parameterCyclicDependencies, suggested by Hitoshi Okumura, removing "multiple", from qualifying parameters that could be cyclic, as a cyclic dependency would occur when a single parameter refers to itself. |
19 September 2011 | David NorthDavid North |
Section 4.2 improved to add an error code for use when a fallback value expression references a fact or general variable. |
06 October 2011 | Herm Fischer |
Section 3.4.1 The description of implied XPath expression is clarified to identify nature of the processing to include or reject a candidate fact in the filtered result set, but no longer necessarily provide the full interface structure, conditional execution, and error coding that might be required. The implied expression's operations and functions parameter checking, operational error conditions, and such, are expected to be implemented by any other type of coding, but raise the errors which would be raised if the XPath expression were itself utilized. Where the filter specification provides different error conditions than implied by the XPath expression operations and functions, then the filter specification prevails. Code in XPath or any other language of interface, static and dynamic error checks, and restriction for processing to only occur on facts having covered aspects, if any, is an implementation issue outside of the suggested XPath. Where a filter covers an aspect of a fact, then the filter is not intended to be operated on candidate facts that do not have the covered aspect, and will have an effective boolean value of false/ Filters are specified as independently executed, with a result that filters (such as general filters that don't necessarily cover specific aspects), that may have XPath expressions with operations are specific to data types, need to have protective if-then coding to assure that they can be processed in any order and applied to any facts (regardless of other filters, fact aspects or data types). |
This appendix contains a list of the errata that have been incorporated into this document. This represents all those errata corrections that have been approved by the XBRL International Formula Working Group up to and including 09 December 2010. Hyperlinks to relevant e-mail threads may only be followed by those who have access to the relevant mailing lists. Access to internal XBRL mailing lists is restricted to members of XBRL International Inc.
Number | Date | Sections | Details |
---|---|---|---|
1. | 12 June 2010 | Section 3.4 | Suggested XPath code referencing xfi:facts-in-instance() and xfi:non-nil-facts-in-instance() (at 1, 2, and 3) were missing the parameter /xbrli:xbrl required parameter. |
2. | 12 June 2010 | Section 2.1.1 | Suggested XPath code for explicit dimension tests was using xfi:nodes-correspond function to compare QName typed results of function xfi:fact-explicit-dimension-value, changed comparison to use the XPath 2.0 "eq" operator. |
3. | 12 June 2010 | Section 3.4.1 | The statement "Resolution of XPath variable references in the XPath expressions implied by filters is beyond the scope of this specification" has been deemed unclear, and a non-normative example has been added to note that filters may use the same XPath variable reference resolution as described in this specification. |
4. | 09 December 2010 | Section 3.2 Section 3.5.1 | The parameters Section 3.2 are clarified as follows: (1) the parameter name may be used as a global variable name, (2) the parameter XPath expressions have the instance's xbrli:xbrl element as the evaluation context item, and (3) circular references among parameters within the XPath expressions raise an error condition Clarification of 2011-03-11 prior to publication of this errata, to Section 3.5.1: (4) variable set relationships with the same name as the parameter name override the access to the parameter by the global variable name, within that variable set. |
@name
attribute on variable arcs is
not the XML Schema QName data type. This goes some way toward ensuring that the
QName value of the @name
attribute will not be resolved incorrectly
by software that is unaware of this specification, based
upon any default namespace declaration in scope for the
containing variable arc.