-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathStep5.Rmd
129 lines (106 loc) · 5.22 KB
/
Step5.Rmd
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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
# Step 5: Test data and future directions
## Public datasets
The pipeline with default settings (smoothing and color clusters of k-means in VNS function) used for the [Maynard, Collado-Torres et al, Nature Neuroscience, 2021](https://doi.org/10.1038/s41593-020-00787-0) LIBD data has been applied on the [public datasets](https://support.10xgenomics.com/spatial-gene-expression/datasets) provided by 10x Genomics. To demonstrate the utility of the pipeline on different datasets we chose images obtained from different tissues, in particular a [breast tissue](https://support.10xgenomics.com/spatial-gene-expression/datasets/1.1.0/V1_Breast_Cancer_Block_A_Section_1) sample with high density of cells and a [human heart tissue](https://support.10xgenomics.com/spatial-gene-expression/datasets/1.1.0/V1_Human_Heart) sample with low density of cells. Decent segmentation results were obtained with the default settings on the human heart tissue image given the low image resolution. With the number of color clusters changed from 5 (default) to 3 for breast tissue, the highly clustered cells were detected.
### Heart Tissue
Below is the full code for analyzing the heart tissue sample with low density of cells.
```Matlab
code = '/path to the code/VistoSeg/code';
addpath(genpath(code))
fname = '/path to the file/V1_Human_Heart_image.tif';
N = 5;
VNS(fname,N)
Importing capture area
Elapsed time is 12.898534 seconds.
Performing smoothening and contrast adjustment
Elapsed time is 15.198035 seconds.
Performing rgb to Lab color space conversion
Elapsed time is 17.632075 seconds.
Applying Kmeans
Elapsed time is 277.069572 seconds.
saving outputs
Starting parallel pool (parpool) using the 'local' profile ...
Connected to the parallel pool (number of workers: 2).
Elapsed time is 161.220875 seconds.
M=1;
refineVNS(fname,M)
loading data
Elapsed time is 3.157618 seconds.
refining segmentations
Elapsed time is 36.612378 seconds.
saving final segmentations
Elapsed time is 1.899226 seconds.
spotspotcheck
loading.....
93741 cells detected
4992 spots detected
counting nuclei per spot
100 spots finished in time 32.3861s
200 spots finished in time 61.5043s
300 spots finished in time 98.5936s
400 spots finished in time 141.2028s
500 spots finished in time 182.9503s
600 spots finished in time 222.0649s
700 spots finished in time 263.1166s
800 spots finished in time 303.7525s
900 spots finished in time 343.7924s
.
.
.
```
Zoomed in versions from `spotspotcheck` are shown below for better visualization.
<img src="images/human_heart_HE.png" title="Image 1" width="350"/> <img src="images/human_heart_BW.png" title="Image 2" width="350"/>
Here are the final output files:
1. Output from `spotspotcheck` [tissue_spot_counts.csv](https://github.com/LieberInstitute/VistoSeg/blob/main/pipeline_outputs/spotspotcheck/tissue_spot_counts_heart.csv)
2. Final nuclei segmentations: [nuclei.mat](https://github.com/LieberInstitute/VistoSeg/blob/main/pipeline_outputs/refineVNS/V1_Human_Heart_image_nuclei.mat)
### Breast Tissue
Below is the full code for analyzing the breast tissue sample with a high density of cells. Note that `N` was changed from the default of 5 to 3.
```Matlab
code = '/path to the code/VistoSeg/code';
addpath(genpath(code))
fname = '/path to the file/V1_Human_Heart_image.tif';
N = 3;
VNS(fname,N)
Importing capture area
Elapsed time is 42.738974 seconds.
Performing smoothening and contrast adjustment
Elapsed time is 180.821916 seconds.
Performing rgb to Lab color space conversion
Elapsed time is 77.897834 seconds.
Applying Kmeans
Elapsed time is 1909.580117 seconds.
saving outputs
Starting parallel pool (parpool) using the 'local' profile ...
Connected to the parallel pool (number of workers: 2).
Elapsed time is 352.156689 seconds.
M = 1
refineVNS(fname,M)
loading data
Elapsed time is 10.504537 seconds.
refining segmentations
Elapsed time is 229.784656 seconds.
saving final segmentations
Elapsed time is 18.292739 seconds.
mask = '/path to the file/V1_Breast_Cancer_Block_A_Section_1_image_nuclei.mat';
jsonname = '/path to the file/scalefactors_json.json';
posname = '/path to the file/tissue_positions_list.csv';
countNuclei(mask, jsonname, posname)
loading data
Elapsed time is 10.565088 seconds.
576311 cells detected
4992 spots detected
counting nuclei per spot
100 spots finished in time 602.9623s
200 spots finished in time 1305.658s
.
.
.
```
Below images are the raw Histology `.tif` file of breast tissue and the extracted/segmented nuclei.
<img src="images/tissue_hires_image.png" title="Image 1" width="350"/> <img src="images/Breast_nuclei.png" title="Image 2" width="350"/>
Here are the final output files:
1. Output from `spotspotcheck` [tissue_spot_counts.csv](https://github.com/LieberInstitute/VistoSeg/blob/main/pipeline_outputs/spotspotcheck/tissue_spot_counts_breast.csv)
2. Final nuclei segmentations: [nuclei.mat](https://github.com/LieberInstitute/VistoSeg/blob/main/pipeline_outputs/refineVNS/V1_Human_Heart_image_nuclei.mat)
## Future directions
Below is a non-comprehensive list of future directions. Please [get in touch with us](https://github.com/LieberInstitute/VistoSeg/issues) if you have suggestions.
1. Integrate Atlas Aligner for brain region identification.
2. Integrate [VAMPIRE](https://doi.org/10.1038/srep18437) for cell morphology detection.