ThreeB 1.1
|
FitSpots driver for interactive (GUI) operation and debugging. More...
#include <tag/printf.h>
#include <tr1/tuple>
#include <algorithm>
#include <climits>
#include <iomanip>
#include <map>
#include <cvd/image_io.h>
#include <cvd/image_convert.h>
#include <cvd/glwindow.h>
#include <cvd/morphology.h>
#include <cvd/connected_components.h>
#include <cvd/draw.h>
#include <cvd/gl_helpers.h>
#include <cvd/vector_image_ref.h>
#include <cvd/videodisplay.h>
#include <gvars3/instances.h>
#include <gvars3/GStringUtil.h>
#include <gvars3/GUI_readline.h>
#include "storm_imagery.h"
#include "multispot5.h"
#include "multispot5_place_choice.h"
#include "utility.h"
Go to the source code of this file.
Classes | |
class | GraphicsGL |
Graphics class which draws information to the screen using OpenGL. More... | |
Functions | |
double | lim (double x) |
Image< byte > | scale (const SubImage< double > &i, double ctr, double rng) |
void | draw_bbox (const BBox &bbox) |
void | watch_var (void *, string comm, string d) |
bool | watch_update () |
void | GUI_Pause (int n=0) |
vector< vector< ImageRef > > | get_regions (const SubImage< double > &log_ratios) |
void | mmain (int argc, char **argv) |
int | main (int argc, char **argv) |
Variables | |
map< string, string > | watch |
FitSpots driver for interactive (GUI) operation and debugging.
Definition in file multispot5_gui.cc.
double lim | ( | double | x | ) |
Definition at line 34 of file multispot5_gui.cc.
Referenced by scale().
{
return min(max(x, 0.), 1.);
}
Image<byte> scale | ( | const SubImage< double > & | i, |
double | ctr, | ||
double | rng | ||
) |
Definition at line 40 of file multispot5_gui.cc.
References lim().
Referenced by mmain(), select_random_element(), and NegativeFreeEnergy::variance_from_sample().
{ Image<byte> s(i.size()); for(int r=0; r < i.size().y; r++) for(int c=0; c < i.size().x; c++) Pixel::DefaultConversion<float, byte>::type::convert(lim((i[r][c] - ctr)/rng), s[r][c]); return s; }
void draw_bbox | ( | const BBox & | bbox | ) |
Definition at line 49 of file multispot5_gui.cc.
Referenced by GraphicsGL::draw_bbox(), GraphicsGL::draw_krap(), and mmain().
{ glBegin(GL_LINES); glVertex(bbox.first); glVertex2i(bbox.first.x, bbox.first.y + bbox.second.y); glVertex2i(bbox.first.x, bbox.first.y + bbox.second.y); glVertex(bbox.first+ bbox.second); glVertex(bbox.first+ bbox.second); glVertex2i(bbox.first.x + bbox.second.x, bbox.first.y); glVertex2i(bbox.first.x + bbox.second.x, bbox.first.y); glVertex(bbox.first); glEnd(); }
void watch_var | ( | void * | , |
string | comm, | ||
string | d | ||
) |
Definition at line 69 of file multispot5_gui.cc.
References watch.
Referenced by mmain().
{ vector<string> vs = ChopAndUnquoteString(d); if(vs.size() != 1) { cerr << "Error: " << comm << " takes 1 argument: " << comm << " gvar\n"; return; } watch[vs[0]] = GV3::get_var(vs[0]); }
bool watch_update | ( | ) |
void GUI_Pause | ( | int | n = 0 | ) |
Definition at line 100 of file multispot5_gui.cc.
{ if(!GV3::get<int>("headless", 0, 1)) { glFlush(); gvar3<int> pause("pause", 1, 1); if(n != 0) *pause = n; (*pause)--; while(*pause == 0) { GUI_Widgets.process_in_crnt_thread(); usleep(10000); } } }
vector<vector<ImageRef> > get_regions | ( | const SubImage< double > & | log_ratios | ) |
Definition at line 260 of file multispot5_gui.cc.
Referenced by mmain().
{ gvar3<double> radius("radius", 0, 1); //Set the liklihood ratio threshold/spot density prior //same thing. double threshold = GV3::get<double>("threshold", 0, -1); int edge = GV3::get<int>("edge", 0, -1); //Threshold image Image<byte> thresholded(log_ratios.size(), 0); for(int r=0; r < thresholded.size().y; r++) for(int c=0; c < min(thresholded.size().x, edge); c++) thresholded[r][c] = 255 * (log_ratios[r][c] > threshold); //Dilate Image<byte> dilated = morphology(thresholded, getDisc(*radius), Morphology::BinaryDilate<byte>()); transform(dilated.begin(), dilated.end(), dilated.begin(), bind1st(multiplies<int>(), 255)); //Connected components of dilated image vector<ImageRef> fg; for(int r=0; r < thresholded.size().y; r++) for(int c=0; c < min(thresholded.size().x, edge); c++) if(dilated[r][c]) fg.push_back(ImageRef(c, r)); vector<vector<ImageRef> > regions; connected_components(fg, regions); return regions; }
void mmain | ( | int | argc, |
char ** | argv | ||
) |
Definition at line 295 of file multispot5_gui.cc.
References boundingbox(), draw_bbox(), get_regions(), load_and_normalize_images(), scale(), watch_update(), and watch_var().
Referenced by main().
{ GUI.RegisterCommand("watch", watch_var); GUI.LoadFile("multispot5.cfg"); int lastarg = GUI.parseArguments(argc, argv); if(lastarg >= argc) { cerr << "Specify the images to load\n"; exit(1); } //Load the log_ratios image. //We will use this as a starting point for searching for spots. Image<double> log_ratios; try { log_ratios = img_load(GV3::get<string>("log_ratios", "", -1)); } catch(Exceptions::All e) { cerr << "Error loading " << GV3::get<string>("log_ratios", "") << ": " << e.what << endl; exit(1); } Vector<2> log_ratios_zoom = GV3::get<Vector<2> >("log_ratios_zoom", "", -1); //Load the raw data, and then load the spot parameters. vector<string> files(argv + lastarg, argv + argc); vector<Image<float> > ims = load_and_normalize_images(files); //How far away from eash spot to look: //double spot_sigmas = GV3::get<double>("sigmas", 0., -1); gvar3<int> cluster_to_show("cluster_to_show", 0, -1); gvar3<int> use_largest("use_largest", 0, 1); vector<vector<ImageRef> > regions; GLWindow win(log_ratios.size()); glEnable(GL_BLEND); glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); glEnable(GL_LINE_SMOOTH); readline_in_current_thread line("> "); gvar3<bool> start_processing("process", 0, 1); gvar3<int> show_thresholded("show_thresholded", 0, 1); Image<Rgb<byte> > reg(log_ratios.size(), Rgb<byte>(0,0,0)); bool first = true; BBox cbox = make_pair(ImageRef_zero, ImageRef_zero); for(;;) { double centre = GV3::get<double>("centre", 0, -1); double range = GV3::get<double>("range", 0, -1); line.poll(); win.make_current(); GUI_Widgets.process_in_crnt_thread(); if(watch_update() || first) { first = 0; regions = get_regions(log_ratios); //Colourize regions reg.fill(Rgb<byte>(0,0,0)); for(unsigned int i=0; i < regions.size(); i++) { Rgb<byte> c; do { c.red = rand()%255; c.green = rand()%255; c.blue = rand()%255; } while(min(c.red, min(c.green, c.blue)) < 128 && min(abs(c.red - c.green), min(abs(c.red - c.blue), abs(c.green - c.blue))) < 64); for(unsigned int j=0; j < regions[i].size(); j++) reg[regions[i][j]] = c; } } if(*use_largest && !regions.empty()) { *cluster_to_show=0; for(unsigned int i=1; i < regions.size(); i++) if(regions[i].size() > regions[*cluster_to_show].size()) *cluster_to_show = i; } else *cluster_to_show = max(min(*cluster_to_show, (int)regions.size() - 1), 0); if(!regions.empty()) cbox = boundingbox(regions[*cluster_to_show]); if(!regions.empty() && *start_processing) { GraphicsGL graphics; place_and_fit_spots(ims, regions[*cluster_to_show], log_ratios, GV3::get<string>("save_spots"), graphics); *start_processing=0; } if(*show_thresholded) glDrawPixels(reg); else glDrawPixels(scale(log_ratios, centre, range)); if(cbox.second != ImageRef_zero) draw_bbox(cbox); if(win.has_events()) { vector<GLWindow::Event> e; win.get_events(e); for(unsigned int i=0; i < e.size(); i++) { if(e[i].type == GLWindow::Event::RESIZE) { ImageRef newsize = e[i].size; ImageRef imsize = log_ratios.size(); ImageRef size=imsize; float old_r = (float)imsize.x / imsize.y; float new_r = (float)newsize.x / newsize.y; glViewport(0, 0, newsize.x, newsize.y); glMatrixMode(GL_PROJECTION); glLoadIdentity(); double zoom; if(new_r > old_r) //Then use the y axis zoom = newsize.y / (float)size.y; else zoom = newsize.x / (float)size.x; glOrtho(-.5/zoom, (newsize.x-1.5)/zoom, (newsize.y-1.5)/zoom, -.5/zoom, -1 , 1); glPixelZoom(zoom,-zoom); glRasterPos2f(0, 0); } } } win.swap_buffers(); usleep(100000); } }
int main | ( | int | argc, |
char ** | argv | ||
) |
Definition at line 459 of file multispot5_gui.cc.
References mmain().
{ try{ mmain(argc, argv); } catch(Exceptions::All e) { cerr << "Fatal error: " << e.what << endl; } }
map<string, string> watch |
Definition at line 67 of file multispot5_gui.cc.
Referenced by watch_update(), and watch_var().