[-] QZM@lemmy.world 24 points 10 months ago

If you publish in a journal that has closed access, there is generally no fee to publish.

What field are you in? In the life sciences, there's normally a fee to publish closed-access and a higher one for open-access. My last paper was open access and costed about 3500, compared to 1500 pay walled.

[-] QZM@lemmy.world 3 points 1 year ago
[-] QZM@lemmy.world 2 points 1 year ago

This is actually an amazing idea

[-] QZM@lemmy.world 2 points 1 year ago

Wish I could help, but my knowledge is negligible in this regard. However, I believe your question came up before on image.sc. Some people seem to be using NetBeans for debugging?

For example here and maybe here.

Perhaps @MurphysLab@lemmy.ca can help? If not, you could try posting on image.sc?

[-] QZM@lemmy.world 3 points 1 year ago

Always thought it's a play on machine learning, but I'm most probably wrong.

4
submitted 1 year ago* (last edited 1 year ago) by QZM@lemmy.world to c/image_analysis@lemmy.world

I don't really use QuPath, I don't like it. But the person before me used it to annotate images and now I need to transfer these ROIs/Annotations to ImageJ where my pipeline is. Managed to find a good script for exporting with annotations, but it seems this person transformed the images (differently each time fml), and I need them to be the right orientation because I'm transferring those annotations to another set of images of the same samples from another microscope. Needless to say, I need to do some image registration, a very easy task /s. So is there any way to at least revert back to the initial orientation before export so I make the registration easier? I'm using SIFT which isn't really capable of accounting for mirroring/flipping, so that step really needs to be fixed beforehand. Any ideas? Or at the very least, is there a way to extract transformation history from the Metadata or so such that I can at least use that info to programmatically revert in ImageJ?

[-] QZM@lemmy.world -1 points 1 year ago

Potentially controversial comment:

rich people with no morals live longer, because they’re entirely self interested, and being entirely self interested they can afford healthcare, thus living longer than non-conservatives on average.

From a philosophical point of view, everyone with absolutely no exception is "self interested." I believe the idea you're talking about is whether bettering the lives of other has been incorporated in your identity at a young age making your self-interest ultimately beneficial for others. It's a complex topic, but the idea is that you don't really truly do anything for others, ever, but if someone convinced you that if you don't do good by others, then you should be ashamed or that if you do, you're a better person, then you do good for others for your own sake, to view yourself in a better light.

I'm a bit confused about your comment though. Are you arguing that the study found that rich people skew the data because of their longer life? If so, I find that hard to believe given the proportion of "rich people," and the consequently negligible ability to statistically skew a population if it were actually randomly sampled.

[-] QZM@lemmy.world 1 points 1 year ago
[-] QZM@lemmy.world 1 points 1 year ago

I absolutely agree with you about HR writing the postings and the transient obsession with buzzwords. However, I think there's some hard truth to AI displacing classical image analysis approaches or limiting it to pre and post processing. There are many serious issues with AI (deep learning specifically) as an approach for sure, such as black box modeling which gets in the way of rational scientific inquiry, the need for very large data sets for proper convergence, and maybe even hallucination in advanced models. But these issues are a) possibly resolved within a few years with approaches like explainable AI and statistical sampling for the data size perhaps, and b) don't negate the advantages of simpler AI approaches.

For example, I think supervised machine learning is incredibly useful for allowing complex tasks like segmenting weird objects (like glial cells) and there are even some well established deep learning models for segmenting such things too. So it can be very useful to employ such strategies for certain steps in a pipeline, but making the entire pipeline one giant model is very difficult and unreliable.

Digital pathology is becoming a proper field very quickly, I just hope I can find a footing somewhere in it, because I found myself becoming extremely passionate about image analysis and my career future is looking a bit shakey.

[-] QZM@lemmy.world 1 points 1 year ago

It's becoming increasingly clear that image analysis is really heading for being a domain of artificial intelligence. It's a bit scary, because as a physiologist with no background in computer science, I find it very difficult to find positions in bio image analysis since most seem to ask for anything from advanced experience in supervised machine learning to full blown deep learning model development and spatial statistics. But it's a good thing for science, just not for amateurs who would like to build a career in the field like me..

10

This community was inspired by the subreddit ImageJ and of course image.sc. It's meant to be a hub to show and tell your pipelines and codes, ask questions about scripting and approaches in any image processing software, bring new ideas and cool tricks, discuss how the field is evolving from classical towards computer vision and machine learning approaches, and much more. We're still a small community, and we'd love to have you to grow and become a lively hub of discussion of this awesome field.

1

I came across a small script that opens a window with a progress bar that increases after the completion of every iteration in a for loop. It's pretty useful in a big macro cycling through many images. Sometimes you just want to know your progress in batch mode. So here is the helpful script (from https://imagej.nih.gov/ij/macros/ProgressBar.txt):

// Progress Bar
//
// This macro demonstrates how to display status
// information and a progress bar in a text window. 
// It uses the Plugins>New>Text Window command
// to open a text window without a menu bar.

  title = "[Progress]";
  run("Text Window...", "name="+ title +" width=25 height=2 monospaced");
  for (i=0; i<100; i++) {
     print(title, "\\Update:"+i+"/"+100+" ("+(i*100)/100+"%)\n"+getBar(i, 100));
     wait(200);
  }
  print(title, "\\Close");

  function getBar(p1, p2) {
        n = 20;
        bar1 = "--------------------";
        bar2 = "********************";
        index = round(n*(p1/p2));
        if (index<1) index = 1;
        if (index>n-1) index = n-1;
        return substring(bar2, 0, index) + substring(bar1, index+1, n);
  }

Note: if you using other nested for loops, ensure that the variable you choose isn't the same as the one here (i), except of course the for loop you're actually trying to find track the process of. Happy macroing!

1

First of all, I am so happy that we're getting more and more members. Thank you all for joining!

I'm going to post the first question on here. Ideally, we should always try to post example images when asking a question, but I'm hypocritically not doing it mainly because I think it's a straightforward question.

I'm trying to do some analysis on histology images using ImageJ macro scripting (IJM language), and at some point in the script I have the coordinates of an approximate center of a cell, derived from it's cell body center of mass. However, my downstream quantification requires that I skeletonize. But now the coords may or may not fall on the 1-pixel wide skeleton. I need it to fall on it for subsequent analysis, so I want to find the nearest non-zero pixel to these coords on the skeleton image.

I did come up with an approach, and the script is enclosed below. But.. it's a bit slow, and it needs to be much faster because the script is gigantic.

The approach simply makes a circle centered on the coords I have, and the circle is only 10 pixels in radius, because it appears that's enough to capture the skeleton's nearest white pixel in all cases. Then I iterate through every pixel in this circular ROI computing its euclidean distance from my coords only if it's non-zero (white).

Question: So you see how it's not a quick approach, and if there is a plugin to do this instead, it would be so much faster because it's skipping the wrapping. For context, this is part of a nested for loop for many many objects in many many regions in hundreds of images.

Here is the code:

// Making a circular 10-px radius ROI centered on coords
makeEllipse(CoordX-10, CoordY, CoordX+10, CoordY, 1);
Roi.getContainedPoints(containedX, containedY);
// Iterating through all pixels contained in the search circle
// Euclidean distance is calculated for non-zero pixels and tabulated
Table.create("Non-Zero Contained Pixels");
for (p = 0; p < containedX.length; p++) {
	value = getPixel(containedX[p], containedY[p]);
	selectWindow("Non-Zero Contained Pixels");
	// Keeping indexing for the table independent of the loop as many pixels will be skipped
	outOfLoopSize = Table.size;
	if (value == 255) {
		distance = sqrt(pow(containedX[p]-CoordX, 2)+pow(containedY[p]-CoordY, 2));
		Table.set("CoordIndex", outOfLoopSize, p);
		Table.set("Distance", outOfLoopSize, distance); 
	}
}
selectWindow("Non-Zero Contained Pixels");
// Sorting by distance and setting new coordinates
Table.sort("Distance");
Table.update;
nearestNeighbor = Table.get("CoordIndex", 0);
// Setting the new seed pixel for downstream quantification
seedX = containedX[nearestNeighbor];
seedY = containedY[nearestNeighbor];
close("Non-Zero Contained Pixels");
// Add computed seed for Sholl analysis
// i refers to a much larger for loop, just writing this for contextual information for this script excerpt
selectWindow("Skeleton" + i);
run("Select None");
Overlay.clear
updateDisplay();
makePoint(seedX, seedY, "small yellow hybrid");

Thanks a lot! And keep spreading the word :D

[-] QZM@lemmy.world 17 points 1 year ago

That last neighbor bit.

Editor: remember, you need to have a statement about negatives or limitations, can't have only positives.

Writer: uhh you got it, boss, I'm sure I can think of something.

1

I know I'm not posting anything, but I didn't abandon the place lol. I'm just waiting to have at least ten or so members, because it's a problem-solution oriented community, so we need someone to come in and drop a problem so people can offer solutions. I'm very inexperienced in these things, so I have no idea how to promote this place to grow it, any ideas?

1
submitted 1 year ago by QZM@lemmy.world to c/askscience@lemmy.world

I want this place to succeed and grow, so let's get active!

1

Kinda sad, I'm the only one here lol. But given the beginning of the downfall of Reddit, I thought I'd migrate here and make a community about my interests. I hope whoever joins spreads the word and we can make this a lively, informative, and helpful community for all image analysts out there. I mostly work with FIJI (ImageJ) and ilastik, and I hope all the new joiners have other expertise that can diversify this community more and more.

QZM

joined 1 year ago
MODERATOR OF