Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
Notebooks
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Iterations
Wiki
Requirements
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Locked files
Build
Pipelines
Jobs
Pipeline schedules
Test cases
Artifacts
Deploy
Releases
Package Registry
Container Registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Code review analytics
Issue analytics
Insights
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
QIM
Tools
Notebooks
Commits
088c9931
Commit
088c9931
authored
1 year ago
by
fima
Browse files
Options
Downloads
Patches
Plain Diff
Simple threshold mask
parent
0aa4ce89
No related branches found
Branches containing commit
No related tags found
No related merge requests found
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
segmentation/mask_from_filtering_and_threshold.ipynb
+12
-12
12 additions, 12 deletions
segmentation/mask_from_filtering_and_threshold.ipynb
with
12 additions
and
12 deletions
segmentation/mask_from_filtering_and_threshold.ipynb
+
12
−
12
View file @
088c9931
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
"cells": [
"cells": [
{
{
"cell_type": "markdown",
"cell_type": "markdown",
"id": "
0f62fd3b
",
"id": "
cc248896
",
"metadata": {},
"metadata": {},
"source": [
"source": [
"# Simple 3D binary mask\n",
"# Simple 3D binary mask\n",
...
@@ -12,7 +12,7 @@
...
@@ -12,7 +12,7 @@
{
{
"cell_type": "code",
"cell_type": "code",
"execution_count": 1,
"execution_count": 1,
"id": "
0a23b431
",
"id": "
871f793a
",
"metadata": {},
"metadata": {},
"outputs": [],
"outputs": [],
"source": [
"source": [
...
@@ -25,7 +25,7 @@
...
@@ -25,7 +25,7 @@
},
},
{
{
"cell_type": "markdown",
"cell_type": "markdown",
"id": "
f9ad6ad1
",
"id": "
1854d8dd
",
"metadata": {},
"metadata": {},
"source": [
"source": [
"## Helper functions"
"## Helper functions"
...
@@ -34,7 +34,7 @@
...
@@ -34,7 +34,7 @@
{
{
"cell_type": "code",
"cell_type": "code",
"execution_count": 2,
"execution_count": 2,
"id": "
7a3aa8a7
",
"id": "
56ccd2a9
",
"metadata": {},
"metadata": {},
"outputs": [],
"outputs": [],
"source": [
"source": [
...
@@ -63,7 +63,7 @@
...
@@ -63,7 +63,7 @@
},
},
{
{
"cell_type": "markdown",
"cell_type": "markdown",
"id": "
7baf5d58
",
"id": "
107f92f4
",
"metadata": {},
"metadata": {},
"source": [
"source": [
"## Load data"
"## Load data"
...
@@ -72,7 +72,7 @@
...
@@ -72,7 +72,7 @@
{
{
"cell_type": "code",
"cell_type": "code",
"execution_count": 3,
"execution_count": 3,
"id": "
1f5d1fb6
",
"id": "
a9b977b3
",
"metadata": {},
"metadata": {},
"outputs": [
"outputs": [
{
{
...
@@ -105,7 +105,7 @@
...
@@ -105,7 +105,7 @@
},
},
{
{
"cell_type": "markdown",
"cell_type": "markdown",
"id": "
66d5b
cc
7
",
"id": "
186f46
cc",
"metadata": {},
"metadata": {},
"source": [
"source": [
"## Apply median filter"
"## Apply median filter"
...
@@ -114,7 +114,7 @@
...
@@ -114,7 +114,7 @@
{
{
"cell_type": "code",
"cell_type": "code",
"execution_count": 4,
"execution_count": 4,
"id": "
47b7de23
",
"id": "
1b1fcba9
",
"metadata": {},
"metadata": {},
"outputs": [
"outputs": [
{
{
...
@@ -147,7 +147,7 @@
...
@@ -147,7 +147,7 @@
},
},
{
{
"cell_type": "markdown",
"cell_type": "markdown",
"id": "
06e9af21
",
"id": "
c17d275c
",
"metadata": {},
"metadata": {},
"source": [
"source": [
"## Get the threshold value"
"## Get the threshold value"
...
@@ -156,7 +156,7 @@
...
@@ -156,7 +156,7 @@
{
{
"cell_type": "code",
"cell_type": "code",
"execution_count": 5,
"execution_count": 5,
"id": "
06bba77b
",
"id": "
aebf7d46
",
"metadata": {},
"metadata": {},
"outputs": [
"outputs": [
{
{
...
@@ -186,7 +186,7 @@
...
@@ -186,7 +186,7 @@
},
},
{
{
"cell_type": "markdown",
"cell_type": "markdown",
"id": "
b2dc8937
",
"id": "
c6e49b28
",
"metadata": {},
"metadata": {},
"source": [
"source": [
"## Make binary mask"
"## Make binary mask"
...
@@ -195,7 +195,7 @@
...
@@ -195,7 +195,7 @@
{
{
"cell_type": "code",
"cell_type": "code",
"execution_count": 6,
"execution_count": 6,
"id": "
9971ddcb
",
"id": "
ec9a9333
",
"metadata": {},
"metadata": {},
"outputs": [
"outputs": [
{
{
...
...
%% Cell type:markdown id:
0f62fd3b
tags:
%% Cell type:markdown id:
cc248896
tags:
# Simple 3D binary mask
# Simple 3D binary mask
author: Felipe Delestro (fima@dtu.dk)
author: Felipe Delestro (fima@dtu.dk)
%% Cell type:code id:
0a23b431
tags:
%% Cell type:code id:
871f793a
tags:
``` python
``` python
import qim3d
import qim3d
import numpy as np
import numpy as np
import scipy.ndimage
import scipy.ndimage
import matplotlib.pyplot as plt
import matplotlib.pyplot as plt
from skimage import filters
from skimage import filters
```
```
%% Cell type:markdown id:
f9ad6ad1
tags:
%% Cell type:markdown id:
1854d8dd
tags:
## Helper functions
## Helper functions
%% Cell type:code id:
7a3aa8a7
tags:
%% Cell type:code id:
56ccd2a9
tags:
``` python
``` python
def viz(vol, cmap="viridis"):
def viz(vol, cmap="viridis"):
qim3d.viz.slice_viz(vol, position=np.linspace(50,100, num=6).astype(int), img_height=4, cmap=cmap)
qim3d.viz.slice_viz(vol, position=np.linspace(50,100, num=6).astype(int), img_height=4, cmap=cmap)
def histogram(vol, vline=None):
def histogram(vol, vline=None):
# Calculate histogram
# Calculate histogram
vol_hist, bin_edges = np.histogram(vol, bins=16)
vol_hist, bin_edges = np.histogram(vol, bins=16)
# Plot histogram
# Plot histogram
fig, ax = plt.subplots(figsize=(6, 4))
fig, ax = plt.subplots(figsize=(6, 4))
ax.bar(bin_edges[:-1], vol_hist, width=np.diff(bin_edges), ec="white", align="edge")
ax.bar(bin_edges[:-1], vol_hist, width=np.diff(bin_edges), ec="white", align="edge")
if vline:
if vline:
ax.axvline(vline, color="#FF3366", linestyle="--")
ax.axvline(vline, color="#FF3366", linestyle="--")
# Adjustments
# Adjustments
ax.spines["right"].set_visible(False)
ax.spines["right"].set_visible(False)
ax.spines["top"].set_visible(False)
ax.spines["top"].set_visible(False)
ax.set_yscale("log")
ax.set_yscale("log")
plt.show()
plt.show()
```
```
%% Cell type:markdown id:
7baf5d58
tags:
%% Cell type:markdown id:
107f92f4
tags:
## Load data
## Load data
%% Cell type:code id:
1f5d1fb6
tags:
%% Cell type:code id:
a9b977b3
tags:
``` python
``` python
# Load data
# Load data
vol = qim3d.io.load("../resources/img3d/shell_225x128x128.tif")
vol = qim3d.io.load("../resources/img3d/shell_225x128x128.tif")
viz(vol)
viz(vol)
histogram(vol)
histogram(vol)
```
```
%% Output
%% Output
%% Cell type:markdown id:
66d5b
cc
7
tags:
%% Cell type:markdown id:
186f46
cc tags:
## Apply median filter
## Apply median filter
%% Cell type:code id:
47b7de23
tags:
%% Cell type:code id:
1b1fcba9
tags:
``` python
``` python
# Median filter
# Median filter
vol = scipy.ndimage.median_filter(vol, size=3)
vol = scipy.ndimage.median_filter(vol, size=3)
viz(vol)
viz(vol)
histogram(vol)
histogram(vol)
```
```
%% Output
%% Output
%% Cell type:markdown id:
06e9af21
tags:
%% Cell type:markdown id:
c17d275c
tags:
## Get the threshold value
## Get the threshold value
%% Cell type:code id:
06bba77b
tags:
%% Cell type:code id:
aebf7d46
tags:
``` python
``` python
# Get the Otsu thresold
# Get the Otsu thresold
thresh = filters.threshold_otsu(vol)
thresh = filters.threshold_otsu(vol)
print (f"Threshold value: {thresh}")
print (f"Threshold value: {thresh}")
histogram(vol, vline=thresh)
histogram(vol, vline=thresh)
```
```
%% Output
%% Output
Threshold value: 63
Threshold value: 63
%% Cell type:markdown id:
b2dc8937
tags:
%% Cell type:markdown id:
c6e49b28
tags:
## Make binary mask
## Make binary mask
%% Cell type:code id:
9971ddcb
tags:
%% Cell type:code id:
ec9a9333
tags:
``` python
``` python
# Make it binary
# Make it binary
vol = vol > thresh
vol = vol > thresh
viz(vol, cmap="gray")
viz(vol, cmap="gray")
```
```
%% Output
%% Output
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment