-
Notifications
You must be signed in to change notification settings - Fork 55
QTIWorks conformance and implementation notes
This document summarises QTIWorks' support for (and conformance of) the QTI 2.1 specification. It is currently written against Draft 13 (July 2012).
The discussion in this section follows the chapters of the QTI 2.1 "Assessment Test, Section and Item Information Model" document, starting with chapter 4.
The assessmentItem
class is fairly well implemented in QTIWorks right up to the level of rendering and delivery.
The itemSessionControl
class is partly implemented in the base qtiworks-jqtiplus
module, but needs refactored. This is only really used for delivering items within tests.
QTIWorks supports the delivery of single assessmentItem
s, using the notion of an item delivery to configure aspects of the process, which features some concepts from the itemSessionControl
class (normally only used in test delivery) as well as a number of other options.
- QTIWorks supports all three types of Item Variables.
- All combinations of
baseType
andcardinality
are implemented.- The base
qtiworks-jqtiplus
module implements thefile
type quite sparsely and fills in the details within theqtiworks-engine
code module. If you are using JQTI+ for your own projects then you will need to do a bit of work to fill in these details to suit yourself.
- The base
-
record
variables assume additional characteristics if they resemble the special "Maths Content" variables used by the MathAssess extensions and if the MathAssess extension package has been registered.
This is all fully implemented. Note that correctResponse
may not be useful in some types of questions.
These are all supported.
However note that the management of duration is currently not fully implemented in the QTIWorks engine.
Fully implemented with the following caveats and clarifications:
- The
interpretation
andlongInterpretation
attributes are implemented but never used. - The word positive in the context of
normalMaximum
is assumed to be strictly greater than zero, including the legal float value +0.
This is fully implemented, subject to the following notes and clarifications:
- The
base
attribute on theflow
abstract class is supported but not used. This property is renamed asbaseUri
in theqtiworks-jqtiplus
code module in order to avoid a clash with a property of the same name in thestringInteraction
abstract class. Reading and writing of this property from XML prefixes this element to put it in the XML namespace. - The expansion of template variables in
param
is not currently implemented.
MathML is supported subject to the following notes:
- The only validation performed on MathML is schema validation.
- Rendering of content MathML is not currently supported. We will most likely use the simplest implementation, which is to perform a Content MathML to Presentation MathML transform. This works OK but provides no control over notations used. The results should be acceptable in UK contexts.
This is supported subject to the following notes:
- the
view
attribute is not currently used in item delivery. - the
use
attribute onrubricBlock
is not presently supported. - the current implementation of
printedVariable
is deficient and needs updated to support all format types and the new attributes added since draft 2.
The stylesheet
class is implemented but only supported at item level as far as rendering goes. There are currently no plans to support it within individual blocks (e.g. rubricBlock
)
All interactions are supported, though a few are not implemented (as far as delivery and rendering goes) and many of the graphic ones have rather dated implementations. Further details:
- The
orientation
attribute is not implemented anywhere yet. - The
placeholderText
attribute ofstringInteraction
is never used in rendering. - The
textFormat
atribute ofextendedTextInteraction
is never used in rendering. - Various
min
attributes are fully supported but never form part of the candidate's interactions with the resulting entry widget while interacting:associationInteraction
,hotspotInteraction
,matchInteraction
,selectPointInteraction
. - The new
minAssociates
attribute ofgraphicAssocationInteraction
is not currently implemented at all. - Neither
mediaInteraction
anddrawingInteraction
are supported at the rendering & deliver layer (i.e. within theqtiworks-engine
code module) and there are currently no plans to implement these. Volunteers for adding functionality for these are welcome! - The following interactions are rendered using rather old-fashioned Java applets, which could all do with replacement:
associateInteraction
graphicAssociateInteraction
graphicGapMatchInteraction
graphicOrderInteraction
hostspotInteraction
positionObjectInteraction
selectPointInteraction
- The following interactions have rather dated rendering and could do with updating:
matchInteraction
gapMatchInteraction
QTIWorks supports all aspects of response processing.
All of the standard QTI 2.1 response processing templates listed in the spec are supported, and the original QTI 2.0 templates are also included for completeness. The information model is not amazingly clear on the use of .xml
file extensions for templates, which has lead to confusion amongst authors, so we support both here. Note that the standard RP templates are always loaded from an internal cache.
This is supported and rendered acceptably.
Template processing is supported in full, subject to the following notes:
-
templateConstraint
currently runs up to 100 times before failing. There is no way to specify the number of times to run within the question, which some people felt would be useful.
Development of tests is due to start in Q4 2012.
The Java information model in qtiworks-jqtiplus
supports most of the classes in the information model, with the excepption of assessmentSectionRef
.
This will be refactored completed during test development.
As above.
As above.
All expressions (with the exception of those used in tests only) have been fully implemented, subject to the following general notes and caveats:
- Expressions supporting
integerOrVariableRef
and friends need a bit more work to clarify what should happen if the resulting value does not satisfy the constraints stated. The specification is silent on this issue. See below for further notes on how QTIWorks has implemented each of these. - The "double-dotted" variable references described in the
variable
class were added to QTI 2.1 very late and are not yet supported. - The
definition
attribute ofcustomOperator
is never used. Registration of a newcustomOperator
is done via theJqtiExtensionPackage
Java class. - There are a number of corner-cases that the spec is not explicit on, especially in the case of arithmetic operators. The results in these situations are usually reasonable but perhaps not expected.
Further notes on specific expressions:
-
anyN
: If eithermin
ormax
is a variable reference that evaluates to NULL, then any NULLs are replaced with the integer 0 and a runtime warning will be recorded. -
randomInteger
: Ifmin
is a variable reference that evaluates to NULL then it will be replaced with 0 and a runtime warning will be recorded. Likewise, ifmax
evaluates to NULL then it is replaced with the resulting value ofmin
plus 1; ifstep
evaluates to NULL then it is replaced with 1. -
randomFloat
: Ifmin
is a variable reference that evaluates to NULL then it will be replaced with 0 and a runtime warning will be recorded. Likewise, ifmax
evaluates to NULL then it is replaced with the resulting value ofmin
plus 1. If the resulting value ofmin
is greater thanmax
then NULL is returned. -
index
: Ifn
is a variable reference and evaluates to NULL or an integer outside the bounds of the container, then NULL is returned. -
repeat
: IfnumberRepeats
is a variable reference that evaluates to NULL or an integer less than 1, then NULL is returned. -
equal
: If no tolerance value is given, then both are treated as 0.0. (The spec is not very precise here.) If either tolerance value is a variable reference that evaluates to NULL or a non-positive number, then NULL is returned. -
equalRounded
&roundTo
: Iffigures
is a variable reference that evaluates to NULL or an integer outside the constraints of theroundingMode
, then NULL is returned. -
patternMatch
: Ifpattern
is a variable reference that evaluates to NULL then NULL is returned.
The include
class has never been implemented and we currently have no plans to support this.
All data types are supported, with the exception of string256
which is silently treated as a string
. Care should be taken by clients using the qtiworks-jqtiplus
module to ensure that string256
is suitably limited if the results are going to be serialized to XML in order for it to be valid.
This is not supported and we have no plans to add support for this for the time being. The model in qtiworks-jqtiplus
should be rich enough to support this (at least in the sense of reflecting the spec and reading/writing XML), so a third party would be welcome to add support for this.
The model for this is largely complete but needs some further work.
This is not supported and there are no plans to add support for this.
QTIWorks includes a full implementation of the MathAssess extensions, implemented by the qtiworks-mathassess
code module and the helper module qtiworks-mathassess-glue
.
The base qtiworks-jqtiplus
code module includes an API for third parties to write and register their own exceptions. This API is currently subject to change but is reasonably simple.