diff options
| author | Johannes Hofmann <Johannes.Hofmann@gmx.de> | 2007-03-13 18:29:45 +0100 | 
|---|---|---|
| committer | Johannes Hofmann <Johannes.Hofmann@gmx.de> | 2007-03-13 18:29:45 +0100 | 
| commit | 3d907fd76ca23d69bcd7d25367c9c94063490d38 (patch) | |
| tree | 1ecfd01a624536445be6b436bf791b53086bc556 /src/Stitch.cxx | |
| parent | 508490f69a9f5e0023deda70b04b785aa041b8e3 (diff) | |
add devignetting infrastructure
Diffstat (limited to 'src/Stitch.cxx')
| -rw-r--r-- | src/Stitch.cxx | 94 | 
1 files changed, 92 insertions, 2 deletions
| diff --git a/src/Stitch.cxx b/src/Stitch.cxx index f21c140..35c8c99 100644 --- a/src/Stitch.cxx +++ b/src/Stitch.cxx @@ -9,11 +9,16 @@  #include <string.h>  #include <math.h> +#include <gsl/gsl_multifit.h> +  #include <Fl/Fl.H>  #include "OutputImage.H"  #include "Stitch.H" +#define MIN(A,B) ((A)<(B)?(A):(B)) + +  static double pi_d = asin(1.0) * 2.0;  static double deg2rad = pi_d / 180.0; @@ -78,6 +83,78 @@ Stitch::set_output(const char *file, OutputImage *img) {  }  int +Stitch::vignette_calib(GipfelWidget::sample_mode_t m, +	int w, int h, double view_start, double view_end) { + +	view_start = view_start * deg2rad; +	view_end = view_end * deg2rad; + +	double step_view = (view_end - view_start) / w; +	uchar r, g, b; +	int y_off = h / 2; +	int merged_pixel_set; +	double radius = (double) w / (view_end -view_start); + +	double V1 = 6.220359, V2 = -13.874930, V3 = 9.992582; +	int max_samples = 10000, n_samples = 0; +	gsl_matrix *X, *cov; +	gsl_vector *yv,  *c; +	double chisq; + + +	 +	X = gsl_matrix_alloc(max_samples, 3); +	yv = gsl_vector_alloc(max_samples); +	c = gsl_vector_alloc(3); +	cov = gsl_matrix_alloc (3, 3); + +	for (int y=0; y<h; y++) { +		double a_nick = atan((double)(y_off - y)/radius); + +		for (int x=0; x<w; x++) { +			double a_view; +			a_view = view_start + x * step_view; +			double l1 = 0.0, l2 = 0.0; +			double a1, a2; + +			for (int i=0; i<MAX_PICS; i++) { + +				if (gipf[i] == NULL) { +					break; +				} else if (gipf[i]->get_pixel(m, a_view, a_nick, +						&r, &g, &b) == 0) { +					l2 = (double) r + g + b; +					a2 = fabs(gipf[i]->get_angle_off(a_view, a_nick)); + +					if (l1 > 0.0 && n_samples < max_samples) { +						gsl_matrix_set(X, n_samples, 0, l1 * a1 - l2 * a2); +						gsl_matrix_set(X, n_samples, 1, l1 * a1 * a1 - l2 * a2 * a2); +						gsl_matrix_set(X, n_samples, 2, l1 * a1 * a1 * a1 - l2 * a2 * a2 * a2); +						gsl_vector_set(yv, n_samples, l1 - l2); +						n_samples++; +					} +						 +					l1 = l2; +					a1 = a2; +				} +			} +		} +	} + +	gsl_multifit_linear_workspace * work  +           = gsl_multifit_linear_alloc (n_samples, 3); + +	gsl_multifit_linear (X, yv, c, cov, &chisq, work); +         gsl_multifit_linear_free (work); + +	fprintf(stderr, "===> v1 %lf, v2 %lf, v3 %lf (i %d)\n",  +		gsl_vector_get(c,0), gsl_vector_get(c,1), gsl_vector_get(c,2), n_samples); + +	return 0; +} + + +int  Stitch::resample(GipfelWidget::sample_mode_t m,  	int w, int h, double view_start, double view_end) { @@ -89,6 +166,7 @@ Stitch::resample(GipfelWidget::sample_mode_t m,  	int y_off = h / 2;  	int merged_pixel_set;  	double radius = (double) w / (view_end -view_start); +	double V1 = 6.220359, V2 = -13.874930;  	if (merged_image) {  		merged_image->init(w, h); @@ -111,11 +189,22 @@ Stitch::resample(GipfelWidget::sample_mode_t m,  					break;  				} else if (gipf[i]->get_pixel(m, a_view, a_nick,  						&r, &g, &b) == 0) { +					double l2 = (double) r + g + b; +					double a2 = fabs(gipf[i]->get_angle_off(a_view, a_nick)); +					double devign = ( 1 + a2 * V1 + a2 * a2 * V2); + +fprintf(stderr, "==> %lf\n", devign); +					r = (uchar) MIN(rint((double) r * devign), 255); +					g = (uchar) MIN(rint((double) g * devign), 255); +					b = (uchar) MIN(rint((double) b * devign), 255); +  					if (single_images[i]) { -						single_images[i]->set_pixel(x, r, g, b); +						single_images[i]->set_pixel(x, r +							, g, b);  					}  					if (!merged_pixel_set && merged_image) { -						merged_image->set_pixel(x, r, g, b); +						merged_image->set_pixel(x, r, g, +							b);  						merged_pixel_set++;  					}  				} @@ -142,3 +231,4 @@ Stitch::resample(GipfelWidget::sample_mode_t m,  	return 0;  } + | 
