PerceptionMD (PMD) is a tool for conducting observer studies in radiology. MD refers to both the medical field but also to the fact that it uses markdown-like files to define experiments.
Several other softwares inspired the development, most notably PsychoPy and ViewDEX but there are crucial differences.
Unlike PsychoPy, PerceptionMD is tailored for medical imaging, especially for pairwise comparison of 3D volumes, e.g. CT volumes. The main differences compared to ViewDEX are:
- PMD's main focus is on pairwise comparison studies
- PMD is written in Python, every installation automatically distributes the source code
- PMD's license allows studying the source code and encourages modifications and improvements, as long as the AGPL 3.0 license is respected. (Briefly: if you sell or publish your modifications, it should be published your modifications under the same license.) (Remark: the windows installer is generated from NSIS script file. The AGPL v3 license does not apply to the NSIS install system. You can check NSIS license here )
- pairwise comparison of volumes (all possible pairs)
- comparison to a reference volume
- RAW and DICOM file formats
- support for overlay volumes, e.g. PET-CT
- adjustable display parameters (color maps, display window, opacity, etc.)
- textual input (e.g. observer's age, free text response, etc.)
- choice screens (e.g. accepting terms)
- conditional execution (e.g., if terms are not accepted, then the experiment terminates.)
- "method of adjustment", e.g. adjustable blending of two images until the composite's noise level is equivalent with the reference image's noise level. (For instance, some CT reconstruction technique blend FBP and IR images in order to reduce dose. In this case, 3 volumes are needed: a baseline FBP, a dose reduced FBP and a dose reduced IR.)
- plugin subsystem: features, like blending, could be implemented as plugins. This would simplify the customization of the software.
- VGA and ROC/FROC could be implemented, but ViewDEX is available, so I don't plan it at the moment.
- any other feature based on user feedbacks (none at the moment)
The main platform is Linux, but Windows is also more or less supported. On Linux both Python2 and Python3 are supported, but on Windows Python3 has issues with the compilers, and it is really hard to set up every dependencies. (Most notably kivy and cython are quite problematic on Windows with 64bit Python.)
You might need administrative privileges, but if python and cython are already installed, then you might use 'pip' in '--user' mode.
First install python, cython, and pygame or SDL and kivy. E.g. on Ubuntu:
apt-get install python cython python-pygame python-kivy
pip install https://github.com/dvolgyes/perceptionmd/zipball/master
This is the most simple solution, however, it wastes some resources. The installer downloads a Miniconda distribution, and installs 'kivy' package for python2 with all the dependencies. Then it downloads the PerceptionMD source code, and installs some shortcuts and registers the uninstaller.
This is a very simple process, but it downloads around 300MB from the internet, and uses around 1.3GB after extraction.
This method is much more resource-friendly, however, you need to install Python, Cython, etc. on your own. When you have a working environment, then the installation is:
pip install -r requirements_win.txt
pip install git+https://github.com/dvolgyes/perceptionmd
Execute the "PerceptionMD.py" file with "example" as parameter. This will trigger a 3 page long demo, and the log file will be saved in the working directory. (The script location depends on the python version and if the package was installed as a site package or a local package.)
The windows installer places a shortcut into the Start Menu, clicking on the shortcut will start the demo study.
In case of manual install, executing the
Please read the Language_description.md file for the details. Examples will be placed in the "Examples" directory.
A brief demonstration video is available at https://www.youtube.com/watch?v=ApLbgmZEcT0. This is more or less what is expected when the program is called with "example" as command line parameter.
This is a one man project at this moment, so my options for independent testing is a bit limited. Automated builds on Travis and Semaphore try to catch obvious errors, and most of the code is covered by some tests. However, large part of the code is related to the GUI and user input, and these aspect are hard to test automatically.
If you find a bug:
- Please check if you are using the latest code, it might be already fixed.
- If it exists in the latest code, then please, report the bug, and try to describe it as precisely as you can. If I cannot reproduce it, then I cannot fix it.
Any feedback is very appreciated. Patches and improvements are even more welcomed.
I will try to fix every issue but this is not a commercial product, and I don't offer any kind of 'official' support.