This project is a web application developed that allows administrators of multi-choice question tests an opportunity to identify items that violate psychometric test industry norms for good item characteristics (i.e. too hard, too easy, negative discrimination).
Users are able to upload student response and answer data, and this software will:
- automatically produce student and question locations, and calculate statistics such as percentage correct and discrimination using IRT analysis
- recommend and allow users to remove poor questions
- visualize students and questions in a dot-plot
- select grade boundaries based on the distribution of students and questions
- export data to a format suitable for upload into Canvas
This allows users to reduce poor identifiers of true student ability and so increase the effectiveness of test questions.
Please see this Google Document for the latest installation information and rationale on design decisions.
View instructions on how to install Python for your operating system here: https://www.python.org/downloads/.
You must install Python 3.5 only. This is the only version that rpy2 is compatible with.
Ensure you can run pip from the command-line.
View instructions on how to install pip here: https://packaging.python.org/tutorials/installing-packages/
For Ubuntu, python-pip is in the universe repository.
sudo apt-get install software-properties-common
sudo apt-add-repository universe
sudo apt-get update
sudo apt-get install python3-pip
View instructions on how to install Flask here: http://flask.pocoo.org/docs/0.12/installation/
Select a mirror to install R here: https://cran.r-project.org/mirrors.html
For Ubuntu, you can try these commands.
To remove R:
sudo apt-get remove r-base-core
To install R:
sudo apt-get install libxml2-dev
sudo echo "deb http://cran.rstudio.com/bin/linux/ubuntu xenial/" | sudo tee -a /etc/apt/sources.list
gpg --keyserver keyserver.ubuntu.com --recv-key E298A3A825C0D65DFD57CBB651716619E084DAB9
gpg -a --export E084DAB9 | sudo apt-key add -
sudo apt-get update
sudo apt-get install r-base-core=3.4.3-1xenial0
sudo apt-get -y build-dep libcurl4-gnutls-dev
sudo apt-get -y install libcurl4-gnutls-dev
Make sure to update your R_HOME and PATH environment variables with the R installation directory.
export R_HOME=/usr/lib/R
export PATH=/usr/lib/R:$PATH
export PATH=/usr/lib/R/bin:$PATH
Replace /usr/lib/R with the location of your R installation directory if you are not using Ubuntu. Append the three lines above to your ~/.bashrc file if you would like these directories to persist.
Run pip3 install rpy2
to install rpy2. .
See also: http://rpy.sourceforge.net/rpy2/doc-dev/html/overview.html
Ubuntu users may also wish to try sudo apt install python-rpy2
.
Type git clone https://github.com/genericity/mirt
to download the contents of the repository at https://github.com/genericity/mirt to a folder called mirt
.
Open R (type r
or R
from the commandline) and type:
remove.packages('mirt') # In case you have installed MIRT already.
install.packages('devtools')
library('devtools')
install_local('mirt')
You may have to install additional packages for devtools to be installed. For Ubuntu, type these commands to install the appropriate libraries.
sudo apt-get install libssl-dev
sudo apt-get install libcurl4-openssl-dev
Type quit()
to exit R. Type y
to save your changes.
Create a new directory and enter it via the commandline.
Extract the downloaded files to this directory.
Open Python (type python3
from the commandline) and type:
from index import init_db
init_db()
This sets up the SQLite database.
Type quit()
to exit Python.
To run in development mode, type into the command-line:
export FLASK_APP=index.py
python3 -m flask run
To run while logging errors, type into the commandline:
sudo python3 index.py &
or, to log:
sudo python3 index.py >> log.txt 2>&1 &
The current stable version on the server is served using uWSGI and NGINX. There are other options to deploy Flask projects, but any version chosen should be multiprocessed to avoid concurrency issues while using R and rpy2.
The following instructions are written as if you are running the tool with an account named user
and the project resides in a directory named flask_project
.
(Optional) Set up a virtual environment using virtualenv if you wish.
sudo pip3 install virtualenv
virtualenv myprojectenv
source myprojectenv/bin/activate
Install uWSGI and NGINX.
pip3 install uwsgi flask
sudo apt-get install uwsgi-plugin-python
sudo apt-get install python3-pip python3-dev nginx
Make sure your files are owned by the account that will be running NGINX/uWSGI and that they can be executed.
sudo chmod -R 0770 flask_project/
sudo chown -R user:www-data flask_project/
Edit your /etc/nginx/nginx.conf
file. Inside the http {}
block, add these lines.
server {
listen 80;
location / {
include uwsgi_params;
uwsgi_pass 127.0.0.1:3033;
proxy_read_timeout 3600;
proxy_http_version 1.1;
proxy_set_header Connection "";
}
}
Ensure that the run-script is runnable.
cd flask_project
chmod +x run.sh
Open flask_project.ini and replace the directory in the chdir line to your current working directory.
Finally, run the tool using the run-script. If the tool is already running, it will be restarted.
./run.sh
This will also tail
the error log so that you can observe for any errors. Hit Ctrl - C
to close the error log (this will not close the server).
Point your web browser to your server's IP to see the running tool.
Unit tests can be run by navigating to the test directory (cd test
) and running:
python -m unittest -v test_test
Open R (type r
or R
from the commandline) and type:
install.packages("ltm")
Select a mirror to install the ltm package and all dependencies.
Type quit()
to exit R. Type y
to save your changes.
There's a bug in one of them (Annotation plugin for Chart.js) that prevents objects from being redrawn. So, without fixing the bug (as I've done locally here), it's impossible to have the sliders you see on the graph be draggable.
The other library (Chart.js) doesn't allow custom callbacks after drawing elements onto the graph. So, without adding a way to hook into the rendering cycle, it's impossible to draw the labels on the central y-axis on the graph.