Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/mihaitodor/particle_simulation

Simulation of Tumor Fluorescence Time Profiles
https://github.com/mihaitodor/particle_simulation

cancer-detection fluorescence simulation

Last synced: 9 days ago
JSON representation

Simulation of Tumor Fluorescence Time Profiles

Awesome Lists containing this project

README

        

# Simulation of Tumor Fluorescence Time Profiles

This simulation can be run online [here]( https://mihaitodor.github.io/particle_simulation/index.html). For details, please consult the following paper:

> Daly HC, Conroy E, Todor M, Wu D, Gallagher WM, O'Shea DF. An EPR Strategy for Bio-responsive Fluorescence Guided Surgery with Simulation of the Benefit for Imaging. Theranostics 2020; 10(7):3064-3082. doi:10.7150/thno.42702. Available from http://www.thno.org/v10p3064.htm

## Abstract

A successful matching of a PEG group size with the EPR effect for an *off-to-on* responsive NIR-fluorophore conjugate has been accomplished which allows two distinct *in vivo* tumor imaging periods, the first being the switch on during the initial tumor uptake via enhanced permeability into the ROI (as background is suppressed) and a second, later, due to enhanced retention within the tumor. Software simulation (https://mihaitodor.github.io/particle_simulation/index.html), synthetic chemistry, with *in vitro* and *in vivo* imaging have been synergistically employed to identify an optimal PEG conjugate of a bio-responsive NIR-AZA fluorophore for *in vivo* tumor imaging.

## Imaging simulation

The JavaScript framework Three.js https://threejs.org/ was used to build the central animation consisting of the chamber (FOV), inputs and output tubes, EPR zone, target region of interest (ROI) and fluorescent agent. Three.js makes it possible to author complex 3D WebGL-based https://www.khronos.org/webgl/ animations without the effort required for a traditional standalone computer application. It provides a high-level application programming interface (API) which lets the user write code to create various 3D shapes (spheres, boxes, tubes), specify their properties (color, dimensions, position) and how they will move in the scene. The aspect and position of all Three.js shapes can be modified programmatically in real time using simple linear algebra transformations through various Three.js API calls. Additionally, as needed, Three.js contains functionality to enable users to interact with the shapes or change the view in real time using input devices such as a mouse.

The data display chart was built using the JavaScript framework C3.js https://c3js.org/. C3.js provides a high level API for defining various chart properties and allows users to insert new data points programmatically while the animation is running. It is built on top of a library called D3.js https://d3js.org/ that uses scalable vector graphics (SVG) browser technology for rendering and animating charts. The side input menu, which lets users adjust and select various options for controlling the aspect of the animation and chart, was built using the dat.GUI.js https://github.com/dataarts/dat.gui JavaScript framework. This framework provides APIs for creating controls and adding JavaScript callbacks which alter the aspect and behavior of the animation and chart based on user input. It also enables the saving of configurations as a custom profile and exporting of results data shown in the plots as Excel CSV files.

The simulation can be accessed at https://mihaitodor.github.io/particle_simulation/index.html. The software code is available as open source on GitHub https://github.com/mihaitodor/particle_simulation and permits a user to modify and save revised versions. The central animation components (FOV, EPR zone, ROI and tubes) are positioned statically within the Three.js scene. The user can use the mouse and keyboard to interact with this component ensemble and rotate it around by pressing the left click button, zoom in and zoom out by using the scroll wheel and, finally, drag it around by pressing the Ctrl key in combination with the left click button.

At the start of the animation, all the fluorescent agent particles are invisible and they are positioned at the injection site. Each of them is assigned a random velocity vector pointing towards the interior of the FOV. After the initialization routine finishes, the particle animation starts immediately and the particles are released in batches of 100 in random directions every 5 frames. Each frame, every visible particle’s position is advanced along the particle’s rectilinear trajectory by adding the particle’s velocity vector to its current position. Particles do not interact with each other. When a particle interacts with a surface, the following cases are possible:
- if a particle collides with one of the FOV’s boundary walls, it is reflected back;
- if the EPR zone is active and a particle inside it collides with its boundary surface, the particle is either reflected back or it can escape back into the FOV;
- if a particle is inside the ROI and it collides with its boundary surface, the particle is reflected back.

When the EPR zone is enabled, the trajectories of particles crossing it are influenced by a gravity-like effect, being directed towards the ROI. Due to this effect, most particles do not escape back into the FOV after they entered the EPR zone. The velocity of particles in the EPR zone and in the ROI differs by a constant viscosity factor from the velocity in the FOV. The viscosity in the EPR zone is 0.9, thus the velocities of particles inside it are 0.1 x FOV velocities. The viscosity in the ROI is 0.155, so the velocities of particles inside it are 0.845 x FOV velocities. Both the FOV and ROI have a configurable initial delay and clearance rate before fluorophore clearance commences. The clearance rates dictate how many random particles are selected from the FOV (every 20 frames) and how many are selected from the ROI (every 40 frames). The selected particles are positioned at the clearance site. For the purpose of clearance, when the EPR zone is enabled, particles inside it are considered as being in the FOV. The % FOV / ROI distributions over time chart is updated each 30 frames. Depending on the performance of the system on which the simulation is running, the maximum number of frames per second is 60 (as can be observed in the FPS box in the top left corner), so the chart will be updated at most twice per second.

## Simulation interface

![Simulation interface](resources/particle_simulation.png)

## Simulation GUI



Simulation variable features
Simulation selections
Simulation GUI




Relative FOV size
width, height, depth; FOV can be reoriented during simulation by holding down and moving cursor

Simulation GUI


Relative ROI size
radius


Relative EPR zone size
radius


EPR zone enabled
optionality toggle


Flu off/on response
optionality toggle


Flu agent invisible in FOV
optionality toggle allowing off fluorescent agent in FOV to be completely hidden


Fluorescent agent size
radius


Flu. agent quantity
1-10,000


FOV clearance parameters
initial clearance delay
relative rate of clearance


ROI clearance parameters
initial clearance delay
relative rate of clearance


Chart showing relative % of fluorophore in FOV and ROI over time
real-time data plots tracking simulation; charts can be hidden during simulation by toggle function


Pause simulation
simulation can be paused and restarted at any stage


Restart simulation
click revert to reset to original settings


Save data
exported as csv file

## Preset simulations

Simulation | Clearance inputs
------------------------------------------------------------------------------- | -------
Sim-1 - always-on / Sim-3 - off/on responsive ![Graph A](resources/Graph-A.png) | FOV: Initial delay: 250; Rate: 50
ROI: Initial delay: 500; Rate: 25
Sim-2 - always-on / Sim-4 - off/on responsive ![Graph B](resources/Graph-B.png) | FOV: Initial delay: 250; Rate 25
ROI: Initial delay: 750; Rate 10
Sim-5 - always-on / Sim-6 - off/on responsive ![Graph C](resources/Graph-C.png) | EPR zone activated
FOV: Initial delay: 250; Rate 25
ROI: Initial delay: 750; Rate 10

Simulation | Preview
---------- | -----------------------------
Sim-1 | ![Sim-1](resources/Sim-1.gif)
Sim-2 | ![Sim-1](resources/Sim-2.gif)
Sim-3 | ![Sim-1](resources/Sim-3.gif)
Sim-4 | ![Sim-1](resources/Sim-4.gif)
Sim-5 | ![Sim-1](resources/Sim-5.gif)
Sim-6 | ![Sim-1](resources/Sim-6.gif)

© [Department of Chemistry RCSI](https://www.rcsi.com/dublin/about/faculty-of-medicine-and-health-sciences/academic-departments/chemistry) 2019