Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add experiments for different minibatch normalizations #264

Open
wants to merge 62 commits into
base: main
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
62 commits
Select commit Hold shift + click to select a range
2c948a3
Add experiments for different minibatch normalizations
anwai98 May 16, 2024
52a0601
Update patch shapes
anwai98 May 16, 2024
0c4f17d
Add script to submit all batch jobs
anwai98 May 16, 2024
303b8a4
Add inference scripts
anwai98 May 17, 2024
76ca13a
Add livecell results
anwai98 May 17, 2024
c3a61d7
Add napari visualization
anwai98 May 17, 2024
e90a7f2
Merge branch 'verify-norm' of https://github.com/anwai98/torch-em int…
anwai98 May 17, 2024
92501f2
Minor fix to boundary evaluation
anwai98 May 17, 2024
91b38d3
Add boundaries result
anwai98 May 17, 2024
5ec72f2
Add mouse embryo training
anwai98 May 17, 2024
587b9ed
Add inference for all other datasets
anwai98 May 21, 2024
7da423f
Merge branch 'main' into verify-norm
anwai98 May 21, 2024
9cd5135
Add visualization scripts
anwai98 May 21, 2024
97fe427
Split up inference-eval schemes
anwai98 May 21, 2024
45c8734
Update prediction saving mode
anwai98 May 21, 2024
0c1bfa2
Update paths
anwai98 May 22, 2024
9b669e3
Compress predictions
anwai98 May 22, 2024
6955d3e
Merge branch 'main' into verify-norm
anwai98 Jun 11, 2024
dce0f7a
Add all remaining results
anwai98 Jun 12, 2024
089fd62
Add new analysis scripts
anwai98 Jun 12, 2024
479b352
Comment out visualization scripts
anwai98 Jun 12, 2024
3f85870
Update normalization for inference
anwai98 Jun 14, 2024
0bdbcbb
Add new results
anwai98 Jun 14, 2024
61f9627
Merge branch 'main' into verify-norm
anwai98 Jun 17, 2024
be32576
Add labels to visible layers
anwai98 Jun 19, 2024
1e09cb0
Merge branch 'main' into verify-norm
anwai98 Jul 16, 2024
8847ab4
Merge branch 'main' into verify-norm
anwai98 Sep 16, 2024
45dbd85
Replace mouse embryo with gonuclear
anwai98 Sep 16, 2024
369af03
Update GoNuclear dataset for returning different target types
anwai98 Sep 16, 2024
b7a4136
Merge branch 'main' into verify-norm
anwai98 Sep 16, 2024
8e934d4
Refactor loader kwargs
anwai98 Sep 16, 2024
93afcda
Update patch shapes
anwai98 Sep 17, 2024
01b5659
Change rescaling at inference
anwai98 Sep 17, 2024
510c148
Increase compression opts
anwai98 Sep 17, 2024
1a75bed
Remove old evaluation scripts
anwai98 Sep 17, 2024
68bf472
Minor refactor to visual analysis scripts
anwai98 Sep 17, 2024
63ca4b1
Explore noise augmentation parameters for livecell
anwai98 Sep 18, 2024
be17391
Make per dataset script submission flexible
anwai98 Sep 18, 2024
56c383f
Add more results
anwai98 Sep 18, 2024
d20ebaa
Merge branch 'verify-norm' of https://github.com/anwai98/torch-em int…
anwai98 Sep 18, 2024
bfcdbba
Uncomment storing files to segmentation
anwai98 Sep 18, 2024
15a17af
Replace volume-level watershed with elf seeded watershed:
anwai98 Sep 18, 2024
614bdd0
Show instance labels per experiment
anwai98 Sep 19, 2024
31e5c45
Add scripts to extract patch-wise max intensity and skip empty patches
anwai98 Sep 19, 2024
7841071
Update function to skip empty blocks
anwai98 Sep 19, 2024
aed7b05
Change intensity threshold for filtering empty slices
anwai98 Sep 19, 2024
674b65a
Update storing data to h5 files
anwai98 Sep 19, 2024
0d2fb10
Merge branch 'main' into verify-norm
anwai98 Sep 19, 2024
f1cd70f
Add multicut for plantseg boundary segmentations
anwai98 Sep 19, 2024
5b2b195
Add plantseg instance segmentation results
anwai98 Sep 20, 2024
742b228
Filter out older results
anwai98 Sep 20, 2024
9866d6a
Refactor visualization scripts for plantseg
anwai98 Sep 20, 2024
c317d4d
Merge branch 'main' into verify-norm
anwai98 Sep 23, 2024
9749ab0
Refactor augmentations
anwai98 Sep 23, 2024
2bce50a
Move multicut segmentation to torch_em module
anwai98 Sep 23, 2024
eed8765
Merge remote-tracking branch 'anwai/verify-norm' into verify-norm
anwai98 Sep 23, 2024
52e30ac
Refactor analysis script to adapt with plantseg
anwai98 Sep 23, 2024
c6d6274
Add find boundaries to plantseg labels
anwai98 Sep 23, 2024
573aae9
Add plantseg quantitative results
anwai98 Sep 23, 2024
af0bf25
Merge branch 'main' into verify-norm
anwai98 Oct 1, 2024
82d9fa8
Make eval-train mode in inference modular for experiments
anwai98 Oct 1, 2024
7ab7e28
Merge branch 'main' into verify-norm
anwai98 Oct 7, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Refactor augmentations
anwai98 committed Sep 23, 2024
commit 9749ab0c0b3fece981ccf5059833fec637f1fdee
37 changes: 23 additions & 14 deletions experiments/misc/normalization/common.py
Original file line number Diff line number Diff line change
@@ -45,19 +45,30 @@ def get_experiment_name(dataset, task, norm, model_choice):


class MultipleRawTransforms:
def __init__(self, p=0.3, norm=None, blur_kwargs={}, gaussian_kwargs={}, poisson_kwargs={}, contrast_kwargs={}):
def __init__(
self, p=0.3, norm=None, blur_kwargs={}, gaussian_kwargs={},
poisson_kwargs={}, additive_poisson_kwargs={}, contrast_kwargs={}
):
self.norm = fetch_transforms.normalize_percentile if norm is None else norm
aug1 = transforms.Compose([
self.norm,
transforms.RandomApply([fetch_transforms.GaussianBlur(**blur_kwargs)], p=p),
transforms.RandomApply([fetch_transforms.PoissonNoise(**poisson_kwargs)], p=p/2),
# transforms.RandomApply([fetch_transforms.AdditivePoissonNoise(**poisson_kwargs)], p=p/2),
transforms.RandomApply([fetch_transforms.AdditiveGaussianNoise(**gaussian_kwargs)], p=p/2),
])
aug2 = transforms.RandomApply([fetch_transforms.RandomContrast(**contrast_kwargs)], p)
augs = [self.norm]

if gaussian_kwargs is not None:
augs.append(transforms.RandomApply([fetch_transforms.GaussianBlur(**blur_kwargs)], p=p))
if poisson_kwargs is not None:
augs.append(transforms.RandomApply([fetch_transforms.PoissonNoise(**poisson_kwargs)], p=p/2))
if additive_poisson_kwargs is not None:
augs.append(
transforms.RandomApply([fetch_transforms.AdditivePoissonNoise(**additive_poisson_kwargs)], p=p/2)
)
if gaussian_kwargs is not None:
augs.append(transforms.RandomApply([fetch_transforms.AdditiveGaussianNoise(**gaussian_kwargs)], p=p/2))
if contrast_kwargs is not None:
aug2 = transforms.RandomApply([fetch_transforms.RandomContrast(**contrast_kwargs)], p)

self.raw_transform = fetch_transforms.get_raw_transform(
normalizer=self.norm, augmentation1=aug1, augmentation2=aug2
normalizer=self.norm,
augmentation1=transforms.Compose(augs),
augmentation2=aug2
)

def __call__(self, raw):
@@ -74,10 +85,8 @@ def get_dataloaders(dataset, task):
"num_workers": 16, "download": True, "sampler": sampler,
"raw_transform": MultipleRawTransforms(
p=0.3,
# NOTE: for poisson noise below
poisson_kwargs={"multiplier": (20, 30)} if dataset == "livecell" else None,
# NOTE: for additive poisson noise below
# poisson_kwargs={"lam": (0.0, 0.3)} if dataset == "livecell" else None,
poisson_kwargs=None if dataset == "livecell" else {},
additive_poisson_kwargs={"lam": (0.0, 0.2)} if dataset == "livecell" else {},
),
}