Coder Social home page Coder Social logo

thescorpoi / mi4web Goto Github PK

View Code? Open in Web Editor NEW
5.0 1.0 3.0 287.6 MB

A full web based medical image viewer

Home Page: https://thescorpoi.github.io

License: MIT License

HTML 12.22% JavaScript 69.84% Shell 0.04% Dockerfile 0.01% Batchfile 0.01% CSS 17.46% Stylus 0.30% Python 0.10% TSQL 0.03% PHP 0.01%
3d-medical-images medical-image-segmentation medical-images mpr ohif ohif-viewer visualization

mi4web's Introduction

mi4web

A full web based medical image viewer

The project website can be accessed by this link

About the project

Nowadays, the zero-footprint fully web-based visualization is making its way and gaining wider acceptance within the medical imaging community. Since the level of acceptance is growing up, the necessity of upgrading and building new functionalities and features is mandatory, so that it can continue to gain recognition and grow. One of these applications is OHIF, a zero-footprint, open source and web-based medical imaging viewer, that gives us the ability to add and configure extensions, which makes it very expandable. Therefore , this platform will be the starting point of our project.

Demo

Click on the image to see the demo.

Main goals

Even though OHIF already has a lot of functionalities, it would be helpful for the healthcare professionals to have some additional features such as :

  • Basic transactions for medical image storage and retrieval ;
  • DICOM import and export;
  • Multiplanar image display functionalities;
  • 3D Display tools as VTK plugins;
  • Image Annotation Edition and Storage;
  • Creation of Medical Reports;
  • Admin Interface to manage the application equipment and the access.

Expected Results

If all our goals are accomplished we will have a platform on the web that allows us to visualize image studies using a viewer client in conjunction with a server. Also, the services will have to run on the web and in a client-server structure. Moreover, the visualization of the images will have to allow canonical views and three-dimensional object views and the implemented system will have to be distributed. Finally, we plan to have a platform capable of supporting different users and an admin to manage the users and the application.

Project Documentation

The project documentation can be found in the following page (in documentation section) in our project website, or in the doc directory in this repository.

Arquitecture

In a first view we can separate the architecture into four main modules: Frontend, Backend, Persistence and PACS Server. In the frontend module, since the OHIF viewer was the starting point of the project, the technology selected was React. In the backend module, we have to deal with many aspects, an API is necessary to communicate with the frontend and the server, to generate and process the 3D images it is important to have an image processing component. Also, It is extremely important to have a secure system, because of that an authentication protocol was implemented. In the Persistence Module, we look forward to a simple database, MySQL, to store user profiles mainly.

Information Model

Firstly, we created the table user, which has two descendents, the table not_accepted, which are the users that are yet to be accepted by the administrator, and the table staff, which are the users that were already verified and accepted by the administrator. There is also the table admin, which defines the administrator of our application, having the responsability of checking and accepting users, and manage everything. Lastly, we also have the table chart_info, which provides the information about the number of studies carried out per day.

Deployment Diagram

In a short version, the deployment architecture is basically a server with DICOM images, that store the images, and are able to make and receive queries with help of DICOMWeb API. A viewer, which permits the user to see the visualisation of the DICOM images, and make operations on it. In order to have this deployment, we have 2 virtual machines, on IEETA, the access is only possible in UA network, or using the UA VPN.

Use Case Diagram

How to run the application

If you want to run run the application, you need to enter on viewer directory and run the following command:

yarn install
yarn start

To to put database up, you will need to run the docker-compose file in the root of the repository:

docker-compose up

Run the authentication protocol, and the nodeJS APIS:

Go to the authentication directory and run the following command:

docker-compose up

How to deploy the application on the VMs:

The deploy proccess is fully documented in the deploy directory.

Group members

NMec Name Github Email
98498 Daniel Figueiredo daniff15 [email protected]
98495 André Freixo andre180701 [email protected]
98491 Pedro Sobral TheScorpoi [email protected]
98513 Eva Bartolomeu eva-pomposo [email protected]
98629 Marta Fradique MartaFradique [email protected]

mi4web's People

Contributors

andre180701 avatar daniff15 avatar eva-pomposo avatar martafradique avatar thescorpoi avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar

Watchers

 avatar

mi4web's Issues

WEBSITE - To Do

  • Arranjar Logo para o Projeto
  • Arranjar uma foto melhor para o fundo do site
  • Por no footer os logos (discord footer_images.zip)
  • Nos Goals mudar o título do "Mexer na Imagem"

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.