(Project id: 0003429 )
Radboud FUS measurement kit is a comprehensive kit allowing precise hydrophone measurements of your TUS transducers for verification, characterization and monitoring overall system performance.
This project is facilitated by the Radboud Focused Ultrasound Initiative. For more information, please visit the website.
- Affordable
- High quality
π€ Stein Fekkes, FUS Initiative, Radboud University
- GitHub: @StefFek-GIT
π€ Margely Cornelissen, FUS Initiative, Radboud University
π€ Erik Dumont, Image Guided Therapy (IGT)
- GitHub: @erikdumontigt
If you use this kit in your research or project, please cite it as follows:
Margely Cornelissen, Stein Fekkes (Radboud University, Nijmegen, The Netherlands) & Erik Dumont (Image Guided Therapy, Pessac, France) (2024), Radboud FUS measurement kit (version 1.0), https://github.com/Donders-Institute/Radboud-FUS-measurement-kit
The hardware files are stored as native solidworks files and as step format. The main assembly file: W0003510-00-01-SonoRover One.SLDASM will contain all references to part files and subassemblies.
This package is developed specifically for Windows operating systems. While it might work in other environments with some modifications, full support is provided only for Windows.
Clone this repository to your desired folder:
-
Git terminal
cd my-folder git clone git@github.com:Donders-Institute/Radboud-FUS-measurement-kit.git
-
GitHub Desktop
- Click on 'Current repository'.
- Click on 'Add' and select 'Clone repository...'.
- Choose 'URL' and paste the following repository URL: https://github.com/Donders-Institute/Radboud-FUS-measurement-kit.git
- Choose your desired folder and clone the repository.
Seamless Integration and Compatibility: The current SonoRover One software utilizes a standardized focused ultrasound driving system software package. This approach allows you to easily incorporate equipment with different communication protocols into the Radboud FUS driving system software, making it available in the SonoRover One system. By following an abstract communication structure, the software can seamlessly operate with equipment from various manufacturers, ensuring consistent, centralized updates and eliminating the need for direct management of communication protocols in both standalone and experimental settings.
Open your command prompt and run the following batch file to set up the virtual environment and install the necessary dependencies. You can use input parameters to customize the environment name or Python interpreter location.
cd your_directory_with_cloned_repository
install_dependencies.bat [VENV_NAME] [PYTHON_INTERPRETER_PATH]
- VENV_NAME: Specify the name for the virtual environment (e.g., MyEnv). If not provided, it defaults to SONOROVER_ONE.
- PYTHON_INTERPRETER_PATH: Specify the path to the Python 3.10 interpreter if itβs not in the default location. For example, C:\Path\To\Python310\python.exe.
The batch file will:
- Create a virtual environment.
- Install the required Python packages.
- Clone the Radboud FUS driving system software repository into the SonoRover One repository.
- Install the Radboud FUS driving system software package.
- Set up necessary environment variables.
After running the batch file, ensure that the virtual environment is activated and dependencies are installed. You can verify this by:
- Checking for the virtual environment in your WORKON_HOME directory.
- Confirming that the required packages are installed.
- Python Version: The script assumes that Python 3.10 is installed. If you have a different version, make sure to adjust the script accordingly or install Python 3.10.
- Environment Variables: The batch file sets environment variables temporarily for the session and permanently if they are not already set. Ensure that WORKON_HOME is correctly configured as needed.
If you encounter issues with the batch file not being recognized or errors during execution, ensure that:
- The batch file has the correct permissions to execute.
- The repository has been cloned correctly and contains the necessary files.
With all dependencies installed, activate your environment in your command prompt.
workon [VENV_NAME]
While the virtual environment is activated, you can install Spyder or any other IDE of your choice. To install Spyder, run:
pip install spyder
After installing Spyder, you can launch it directly from the command line within the activated virtual environment by running:
spyder
To simplify the process of activating the virtual environment and launching your IDE, you can use the provided batch script.
How to use the script:
- Ensure that start_env_and_ide.bat is located in a convenient location, such as the root directory of your project or your desktop.
- Run the script in one of the following ways:
- Open start_venv_and_ide.bat in a text editor and modify the VENV_NAME and IDE variables directly if you prefer not to use command-line arguments. To run the .bat file, just double-click it.
- Using the command prompt:
start_venv_and_ide.bat [VENV_NAME] [IDE]
- VENV_NAME: Specify the name for the virtual environment (e.g., MyEnv). If not provided, it defaults to SONOROVER_ONE.
- IDE: Specify the python interpreter. IF not provided, it defaults to spyder.
The primary script is main. Running this script launches a GUI to set the following parameters:
-
Path and filename of protocol excel file: Select the required protocol Excel file. Refer to the example template here. This file contains sequences with various foci, power outputs, timing parameters, and/or coordinate grids. It is specific to a driving system-transducer combination.
Note: If you change the headers in the Excel file, you must also update the corresponding headers in the code.- Sequence: The sequence number, ranging from 1 to the total number of sequences in the Excel file.
- Modulation: Choose from Square, Linear, or Tukey ramp shapes from the dropdown.
- Ramp duration [us]
- Ramp duration step size [us]: Temporal resolution of ramping, applicable only for the IGT system.
- Pulse duration [us]
- Pulse Repetition Frequency [Hz]
- Pulse Repetition Interval [ms]
- Pulse Train Duration [ms]
- Isppa [W/cmΒ²], Global power [mW], or Amplitude [%]: Select the applicable power parameter for the chosen driving system from the dropdown. Amplitude is used for the IGT system; Isppa or global power is used for the Sonic Concepts system. It is recommended to use global power for the Sonic Concepts system.
Note: If Isppa is chosen, a conversion table in an Excel file (e.g., here) is required with global power in mW and intensity in W/cm2. If you change the headers in the Excel file, you must also update the corresponding headers in the code. - Corresponding value: The value for the selected power parameter.
- Path and filename of Isppa to Global power conversion Excel: Provide the path to the Isppa-global power conversion table. This parameter is skipped if Isppa is not selected.
- Focus [mm]
- Coordinates based on Excel file or parameters on the right?: Choose to define a grid using a coordinate Excel file or by defining grid sizes in this file from the dropdown. Coordinate file examples are here.
Note: Coordinate files allow more flexibility in grid point arrangement. All grids are based on a chosen zero point (for example: focus or exit plane). Headers in the Excel file must match those used in the code. - Path and filename of coordinate Excel: Provide the path to the coordinate Excel file. This parameter is skipped if 'Coordinates based on Excel file' is not selected.
Note: if 'Parameters on the right' is not chosen as input parameter, below parameters are skipped.
- max. Β± x [mm] w.r.t. relative zero: The maximum movement in the Β±x direction in mm relative to the chosen zero point.
- max. Β± y [mm] w.r.t. relative zero: The maximum movement in the Β±y direction in mm relative to the chosen zero point.
- max. Β± z [mm] w.r.t. relative zero: The maximum movement in the Β±z direction in mm relative to the chosen zero point.
- direction_slices: Choose the direction of the slices from the dropdown. Refer to the example image in the protocol template.
- direction_rows: Choose the direction of the rows from the dropdown. Refer to the example image in the protocol template.
- direction_columns: Choose the direction of the columns from the dropdown. Refer to the example image in the protocol template.
- step_size_x [mm]: The grid size in the x-direction.
- step_size_y [mm]: The grid size in the y-direction.
- step_size_z [mm]: The grid size in the z-direction.
-
US Driving System
-
Transducer
-
Operating frequency [kHz]
-
COM port of US driving system: Required for Sonic Concepts driving system.
-
COM port of positioning system
-
Hydrophone acquisition time [us]
-
Picoscope sampling frequency multiplication factor: Minimum multiplication factor is 2.
-
Absolute G code x-coordinate of relative zero: The x-coordinate of the chosen zero point.
-
Absolute G code y-coordinate of relative zero: The y-coordinate of the chosen zero point.
-
Absolute G code z-coordinate of relative zero: The z-coordinate of the chosen zero point.
-
Perform all protocols in sequence without waiting for user input?: If yes, the characterization will proceed through all sequences in the protocol Excel file without stopping for input between sequences.
After all parameters are set, click 'ok' to start the characterization. Log files and an output folder will be created in the same directory as the protocol Excel file.
- Compatibility check of chosen equipment
Contributions, issues, and feature requests are welcome!
Feel free to check the issues page.
If you have any questions, please feel free to reach out to us via email at fus@ru.nl. We'd love to hear from you.
This project is MIT licensed.