attempt_score.php 3.35 KB
Newer Older
0815-xyz's avatar
0815-xyz committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle.  If not, see <http://www.gnu.org/licenses/>.

/**
 * This class provides access to various numeric representations of a score.
 *
 * @copyright  2013 Middlebury College {@link http://www.middlebury.edu/}
 * @copyright  2022 onwards Vitaly Potenko <potenkov@gmail.com>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */

namespace mod_adaptivequiz\local\questionanalysis;

use mod_adaptivequiz\local\catalgo;

class attempt_score {

    /** @var float $measuredabilitylogits The measured ability of the attempt in logits. */
    protected $measuredabilitylogits = null;

    /** @var float $standarderrorlogits The standard error in the score in logits. */
    protected $standarderrorlogits = null;

    /** @var float $lowestlevel The lowest level of question in the adaptive quiz. */
    protected $lowestlevel = null;

    /** @var float $highestlevel The highest level of question in the adaptive quiz. */
    protected $highestlevel = null;

    /**
     * Constructor
     *
     * @return void
     */
    public function __construct ($measuredabilitylogits, $standarderrorlogits, $lowestlevel, $highestlevel) {
        $this->measuredabilitylogits = $measuredabilitylogits;
        $this->standarderrorlogits = $standarderrorlogits;
        $this->lowestlevel = $lowestlevel;
        $this->highestlevel = $highestlevel;
    }

    /**
     * Answer the measured ability in logits.
     *
     * @return float
     */
    public function measured_ability_in_logits () {
        return $this->measuredabilitylogits;
    }

    /**
     * Answer the standard error in logits.
     *
     * @return float
     */
    public function standard_error_in_logits () {
        return $this->standarderrorlogits;
    }

    /**
     * Answer the measured ability as a fraction 0-1.
     *
     * @return float
     */
    public function measured_ability_in_fraction () {
        return catalgo::convert_logit_to_fraction($this->measuredabilitylogits);
    }

    /**
     * Answer the standard error a fraction 0-0.5.
     *
     * @return float
     */
    public function standard_error_in_fraction () {
        return catalgo::convert_logit_to_percent($this->standarderrorlogits);
    }

    /**
     * Answer the measured ability on the adaptive quiz's scale
     *
     * @return float
     */
    public function measured_ability_in_scale () {
        return catalgo::map_logit_to_scale($this->measuredabilitylogits, $this->highestlevel, $this->lowestlevel);
    }

    /**
     * Answer the standard error on the adaptive quiz's scale
     *
     * @return float
     */
    public function standard_error_in_scale () {
        return catalgo::convert_logit_to_percent($this->standarderrorlogits) * ($this->highestlevel - $this->lowestlevel);
    }
}