-
Notifications
You must be signed in to change notification settings - Fork 17
/
convert_stl2triang.m
79 lines (66 loc) · 2.96 KB
/
convert_stl2triang.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
%-------------------------------------------------------------------------%
% Copyright (c) 2020 Modenese L. %
% %
% Author: Luca Modenese %
% email: l.modenese@imperial.ac.uk %
% ----------------------------------------------------------------------- %
% This script should be run after a dataset of stl geometries has been
% refined with the purposes of reducing the size of files for storage
% and distribution, e.g. in GitHub.
% ----------------------------------------------------------------------- %
clear; clc
addpath(genpath('./STAPLE'))
%---------------- USER'S SETTINGS ------------------
% folder where to look for STL files
% dataset_folder = './bone_datasets/VAKHUM_CT';
% dataset_folder = './bone_datasets/TLEM2';
% dataset_folder = './bone_datasets/ICL_MRI';
% dataset_folder = './bone_datasets/JIA_MRI';
dataset_folder = './bone_datasets/__upper';
% folder where to store the resulting triangulations
triang_folder = [dataset_folder, filesep, 'tri'];
%---------------------------------------------------
% if triang_folder unspecified, then it is set to stl_folder plus '_tri'
if isempty(triang_folder) || strcmp(triang_folder,'')
triang_folder = [dataset_folder, filesep, 'tri'];
end
% check if triang folder exists, if it doesn't then create it
if ~isfolder(triang_folder); mkdir(triang_folder); end
% getting list of stl files from the specified folder
stl_folder = fullfile(dataset_folder, 'stl');
list_of_stl = dir([stl_folder, filesep, '*.stl']);
% total number of stl files
N_stl = size(list_of_stl,1);
% looping through all the stl files found in folder
for n = 1:N_stl
% check if directory is empty
if isempty(list_of_stl)==1
error(['There are no stl geometry files in specified folder: ',stl_folder]);
end
% read in stl file
curr_stl_name = list_of_stl(n).name;
[~, name, ext] = fileparts(curr_stl_name);
disp('-------------------')
disp(['GEOMETRY ', curr_stl_name, ' (', num2str(n),'/',num2str(N_stl),')'])
disp('-------------------')
disp(['Processing file : ', fullfile(stl_folder, curr_stl_name)]);
% transform it in triangulation
try
curr_triang = stlread(fullfile(stl_folder, curr_stl_name));
catch
% if Matlab version <2018b then ReadMesh from GIBOC-Core will be
% used.
curr_triang = ReadMesh(fullfile(stl_folder, curr_stl_name));
end
% save it as triangulation matlab file in specified folder
curr_triang_name = [name, '.mat'];
curr_triang_file = fullfile(triang_folder, curr_triang_name);
disp(['Saving triangulation: ', fullfile(triang_folder, curr_triang_name)]);
triang_geom = curr_triang;
save(curr_triang_file, 'triang_geom')
end
% final print
disp('-------------------')
disp('DONE')
% remove paths
rmpath(genpath('./STAPLE'))