Deep Learning-based Automatic Searching for Graphene
An automated graphene scanning robotic system. The system uses a USB-controlled microscope platform to automatically scan samples and a custom-designed simple auto-focusing program. Additionally, a deep learning model is employed to recognize graphene, accelerating the preparation process. This robotic system will save researchers several hours, with the task of scanning graphene samples being entirely handled by the robot.
Graphene is currently one of the most popular two-dimensional materials. It is only one atom thick but has a hardness exceeding that of diamond. Its discovery could potentially lead to the invention of quantum computers. Currently, the Advanced Quantum Technology Research Center at Cheng Kung University primarily uses mechanical exfoliation to prepare graphene. However, this method requires researchers to spend several hours observing multiple samples under a microscope (Figure 1) and searching for the light purple target material in the samples (Figure 2). These steps are highly standardized, and if computerized, it would save researchers a significant amount of time.
- Control the Microscope: Scan the entire sample and take photos.
- Graphene Detection: Use a deep learning model to recognize whether graphene is present in the photos.
- Save Detection Results: Store the detection results in a specified folder, which includes the recognized images and the coordinates of the target on the microscope platform.
- Coordinate Navigation: Allow the user to input coordinates to move the microscope to the specified position.
microscope automatic scanning and focusing video
The program is divided into three parts: Coordinate Creator, Microscope Controller, and TensorFlow Object Detection.
- Coordinate Creator: The main program first calls the Coordinate Creator to plan the microscope scanning path. The microscope will scan the entire sample in an S-shaped pattern according to this path.
- Microscope Controller: This part is responsible for moving and focusing the microscope, and it returns the captured images to the main program.
- TensorFlow Object Detection: The main program sends the images to TensorFlow Object Detection for recognition. The recognition results are then stored in a designated folder.
Below are the recognition results output by the deep learning model, which include target locations (bounding boxes), object classes (class labels), and confidence scores (confidences). In the example image:
- Green Box: Indicates the position of the graphene.
- Object Class: The identified class is "graphene".
- Confidence Score: The confidence level is 94%.
-
coordinate creator
The Coordinate Creator allows users to set the microscope's magnification, the substrate's edge length, and the microscope's starting position. With these three parameters, the program will return a one-dimensional array containing the coordinates of the positions to be scanned.
-
microscope controller
The microscope controller communicates with the microscope's moving platform via USB, successfully moving the microscope to the specified coordinates. However, an unexpected issue arose: the stage was tilted, causing the captured photos to be out of focus. To address this, I decided to design my own focusing module. First, I adjusted the focus at the same position and captured multiple photos. Using OpenCV, I assessed the clarity of each photo and adjusted the focus to the position with the highest clarity. This simple autofocus system was thus completed.
-
TensorFlow Object Detection
Google provides a comprehensive Object Detection API, allowing for the flexible replacement of object detection algorithms. In this case, I used the Hourglass Network to extract target features and the CenterNet algorithm for object detection.
The system controls the microscope to scan the entire sample and take photos. After scanning, TensorFlow is used to check for the presence of graphene. The detection results are stored in the "Detection result" folder, which contains the recognized images and a text file (txt) that records the coordinates of the images. Users can input these coordinates to move the microscope to the specified position. To achieve this goal, the program consists of three main parts:
- Microscope Movement: Controls the microscope to scan the sample according to the predefined path.
- Focusing and Capturing Photos: Adjusts the focus and captures images, storing them for analysis.
- Recognition: Uses TensorFlow Object Detection to identify graphene in the captured images and stores the results.
- coordinate_creator.py
- Plans the microscope scanning path.
- After entering the starting coordinates, the program will display the intended scanning path.
- getCCDphoto.py
- Captures images from the microscope.
- Includes a feature for clarity analysis.
- microscope_controller.py
- Controls the microscope module and includes an autofocus function.
- Uses clarity analysis to find the optimal focus position.
- graphene_detection.py
- Identifies graphene and saves the results.
- main.py
- The main program.
- Users run this file to start the scanning process.
- Pandas
- PyWin32
- OpenCV
- PySerial
- TensorFlow 2 Object Detection API
In vscode, it can be installed with pip:
python -m pip install -r requirements.txt
Before running this file, you should replace the folder named my_model by your own model