how can i calculate the fibers orientation angle from fluorescence image?

조회 수: 8 (최근 30일)
abdullah tawfek
abdullah tawfek 2020년 10월 27일
답변: prabhat kumar sharma 2025년 1월 10일
I am doing research in cementitious materials with fiber and now how can I calculate the orientation angle for each fiber from a fluorescence image, is there any image processing tool that I can use it?.
with regards

답변 (1개)

prabhat kumar sharma
prabhat kumar sharma 2025년 1월 10일
Hello Abdullah,
To calculate fiber orientation angles from fluorescence images, you can use image processing techniques to detect and analyze the fibers. MATLAB provides powerful image processing tools that can be helpful for this task. Here’s a general approach to achieve this:Steps to Calculate Fiber Orientation Angles
  1. Preprocessing:
  • Convert the image to grayscale if it's not already.
  • Apply filters to enhance the fibers and reduce noise (e.g., Gaussian, median filtering).
2. Edge Detection:
  • Use edge detection algorithms like Canny, Sobel, or Prewitt to detect the edges of the fibers.
3. Skeletonization:
  • Thin the detected edges to a single-pixel width using skeletonization. This helps in accurately determining the orientation.
4. Hough Transform:
  • Use the Hough Transform to detect lines in the image, which correspond to the fibers.
  • Extract the orientation angle of each line detected.
5. Analysis:
  • Analyze the angles to understand the distribution of fiber orientations.
% Read and preprocess the image
img = imread('your_fluorescence_image.jpg');
grayImg = rgb2gray(img); % Convert to grayscale
filteredImg = imgaussfilt(grayImg, 2); % Apply Gaussian filter
% Edge detection
edges = edge(filteredImg, 'Canny'); % Use Canny edge detector
% Skeletonization
skeleton = bwmorph(edges, 'skel', Inf);
% Hough Transform
[H, theta, rho] = hough(skeleton);
peaks = houghpeaks(H, 5, 'threshold', ceil(0.3 * max(H(:))));
lines = houghlines(skeleton, theta, rho, peaks);
% Plot and analyze lines
figure, imshow(img), hold on
for k = 1:length(lines)
xy = [lines(k).point1; lines(k).point2];
plot(xy(:,1), xy(:,2), 'LineWidth', 2, 'Color', 'green');
% Calculate angle
angle = atan2d(diff(xy(:,2)), diff(xy(:,1)));
fprintf('Fiber %d: Angle = %.2f degrees\n', k, angle);
end
hold off
I hope it helps!

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by