|
@@ -262,9 +262,17 @@ run_simple_reconstruction (Params *params, gchar **argv)
|
|
|
UfoBaseScheduler *sched = NULL;
|
|
|
UfoTaskNode *radio_reader = NULL;
|
|
|
UfoTaskNode *dark_reader = NULL;
|
|
|
- UfoTaskNode *flat_reader = NULL;
|
|
|
- UfoTaskNode *flat_avg = NULL;
|
|
|
+ UfoTaskNode *flat_before_reader = NULL;
|
|
|
+ UfoTaskNode *flat_before_stack = NULL;
|
|
|
+ UfoTaskNode *flat_before_median = NULL;
|
|
|
+ UfoTaskNode *flat_after_reader = NULL;
|
|
|
+ UfoTaskNode *flat_after_stack = NULL;
|
|
|
+ UfoTaskNode *flat_after_median = NULL;
|
|
|
+ UfoTaskNode *flat_interpolate = NULL;
|
|
|
UfoTaskNode *ffc = NULL;
|
|
|
+ UfoTaskNode *copy = NULL;
|
|
|
+ UfoTaskNode *sum = NULL;
|
|
|
+ UfoTaskNode *sum_writer = NULL;
|
|
|
GError *error = NULL;
|
|
|
|
|
|
if (!params_okay (params)) {
|
|
@@ -280,24 +288,58 @@ run_simple_reconstruction (Params *params, gchar **argv)
|
|
|
update_reader (radio_reader, params);
|
|
|
|
|
|
if (with_flat_field_correction (params)) {
|
|
|
- flat_avg = make_task (data->pm, "averager");
|
|
|
- flat_reader = make_task (data->pm, "reader");
|
|
|
+ gchar *sum_name;
|
|
|
+
|
|
|
+ flat_before_reader = make_task (data->pm, "reader");
|
|
|
+ flat_before_stack = make_task (data->pm, "stack");
|
|
|
+ flat_before_median = make_task (data->pm, "flatten");
|
|
|
+
|
|
|
+ flat_after_reader = make_task (data->pm, "reader");
|
|
|
+ flat_after_stack = make_task (data->pm, "stack");
|
|
|
+ flat_after_median = make_task (data->pm, "flatten");
|
|
|
+
|
|
|
+ flat_interpolate = make_task (data->pm, "interpolate");
|
|
|
+
|
|
|
dark_reader = make_task (data->pm, "reader");
|
|
|
ffc = make_task (data->pm, "flat-field-correction");
|
|
|
|
|
|
+ copy = UFO_TASK_NODE (ufo_copy_task_new ());
|
|
|
+ sum = make_task (data->pm, "flatten-inplace");
|
|
|
+ sum_writer = make_task (data->pm, "writer");
|
|
|
+
|
|
|
+ g_object_set (flat_before_stack, "num-items", 21, NULL);
|
|
|
+ g_object_set (flat_after_stack, "num-items", 21, NULL);
|
|
|
+
|
|
|
g_object_set (ffc,
|
|
|
"dark-scale", params->dark_scale,
|
|
|
"absorption-correction", TRUE,
|
|
|
NULL);
|
|
|
|
|
|
- g_object_set (flat_reader, "path", params->flats, NULL);
|
|
|
+ sum_name = g_strdup_printf ("%s.sum.tif", params->output);
|
|
|
+ g_object_set (sum_writer,
|
|
|
+ "filename", sum_name,
|
|
|
+ NULL);
|
|
|
+ g_free (sum_name);
|
|
|
+
|
|
|
+ g_object_set (flat_before_reader, "path", params->flats, NULL);
|
|
|
+ g_object_set (flat_after_reader, "path", params->flats_after, NULL);
|
|
|
g_object_set (dark_reader, "path", params->darks, NULL);
|
|
|
|
|
|
- ufo_task_graph_connect_nodes (data->graph, flat_reader, flat_avg);
|
|
|
+ ufo_task_graph_connect_nodes (data->graph, flat_before_reader, flat_before_stack);
|
|
|
+ ufo_task_graph_connect_nodes (data->graph, flat_before_stack, flat_before_median);
|
|
|
+ ufo_task_graph_connect_nodes (data->graph, flat_after_reader, flat_after_stack);
|
|
|
+ ufo_task_graph_connect_nodes (data->graph, flat_after_stack, flat_after_median);
|
|
|
+ ufo_task_graph_connect_nodes_full (data->graph, flat_before_median, flat_interpolate, 0);
|
|
|
+ ufo_task_graph_connect_nodes_full (data->graph, flat_after_median, flat_interpolate, 1);
|
|
|
+
|
|
|
ufo_task_graph_connect_nodes_full (data->graph, radio_reader, ffc, 0);
|
|
|
ufo_task_graph_connect_nodes_full (data->graph, dark_reader, ffc, 1);
|
|
|
- ufo_task_graph_connect_nodes_full (data->graph, flat_avg, ffc, 2);
|
|
|
- ufo_task_graph_connect_nodes (data->graph, ffc, data->pad);
|
|
|
+ ufo_task_graph_connect_nodes_full (data->graph, flat_interpolate, ffc, 2);
|
|
|
+ ufo_task_graph_connect_nodes (data->graph, ffc, copy);
|
|
|
+
|
|
|
+ ufo_task_graph_connect_nodes (data->graph, copy, data->pad);
|
|
|
+ ufo_task_graph_connect_nodes (data->graph, copy, sum);
|
|
|
+ ufo_task_graph_connect_nodes (data->graph, sum, sum_writer);
|
|
|
}
|
|
|
else {
|
|
|
warn ("> No flat/dark field correction\n");
|
|
@@ -319,9 +361,16 @@ run_simple_reconstruction (Params *params, gchar **argv)
|
|
|
|
|
|
if (with_flat_field_correction (params)) {
|
|
|
g_object_unref (ffc);
|
|
|
- g_object_unref (flat_avg);
|
|
|
- g_object_unref (flat_reader);
|
|
|
+ g_object_unref (flat_before_reader);
|
|
|
+ g_object_unref (flat_before_stack);
|
|
|
+ g_object_unref (flat_before_median);
|
|
|
+ g_object_unref (flat_after_reader);
|
|
|
+ g_object_unref (flat_after_stack);
|
|
|
+ g_object_unref (flat_after_median);
|
|
|
g_object_unref (dark_reader);
|
|
|
+ g_object_unref (copy);
|
|
|
+ g_object_unref (sum);
|
|
|
+ g_object_unref (sum_writer);
|
|
|
}
|
|
|
}
|
|
|
|
|
@@ -402,8 +451,13 @@ run_cached_reconstruction (Params *params, gchar **argv)
|
|
|
UfoBaseScheduler *sched;
|
|
|
GError *error = NULL;
|
|
|
UfoTaskNode *dark_reader = NULL;
|
|
|
- UfoTaskNode *flat_reader = NULL;
|
|
|
- UfoTaskNode *flat_avg = NULL;
|
|
|
+ UfoTaskNode *flat_before_reader = NULL;
|
|
|
+ UfoTaskNode *flat_before_stack = NULL;
|
|
|
+ UfoTaskNode *flat_before_median = NULL;
|
|
|
+ UfoTaskNode *flat_after_reader = NULL;
|
|
|
+ UfoTaskNode *flat_after_stack = NULL;
|
|
|
+ UfoTaskNode *flat_after_median = NULL;
|
|
|
+ UfoTaskNode *flat_interpolate = NULL;
|
|
|
UfoTaskNode *ffc = NULL;
|
|
|
|
|
|
params->cache = g_malloc (((gsize) params->num_radios) * ((gsize) params->width) * ((gsize) params->height) * sizeof (gfloat));
|
|
@@ -416,23 +470,40 @@ run_cached_reconstruction (Params *params, gchar **argv)
|
|
|
data->output = UFO_TASK_NODE (ufo_output_task_new (2));
|
|
|
|
|
|
if (with_flat_field_correction (params)) {
|
|
|
- flat_avg = make_task (data->pm, "averager");
|
|
|
- flat_reader = make_task (data->pm, "reader");
|
|
|
+ flat_before_reader = make_task (data->pm, "reader");
|
|
|
+ flat_before_stack = make_task (data->pm, "stack");
|
|
|
+ flat_before_median = make_task (data->pm, "flatten");
|
|
|
+
|
|
|
+ flat_after_reader = make_task (data->pm, "reader");
|
|
|
+ flat_after_stack = make_task (data->pm, "stack");
|
|
|
+ flat_after_median = make_task (data->pm, "flatten");
|
|
|
+
|
|
|
+ flat_interpolate = make_task (data->pm, "interpolate");
|
|
|
dark_reader = make_task (data->pm, "reader");
|
|
|
ffc = make_task (data->pm, "flat-field-correction");
|
|
|
|
|
|
+ g_object_set (flat_before_stack, "num-items", 21, NULL);
|
|
|
+ g_object_set (flat_after_stack, "num-items", 21, NULL);
|
|
|
+
|
|
|
g_object_set (ffc,
|
|
|
"dark-scale", params->dark_scale,
|
|
|
"absorption-correction", TRUE,
|
|
|
NULL);
|
|
|
|
|
|
- g_object_set (flat_reader, "path", params->flats, NULL);
|
|
|
+ g_object_set (flat_before_reader, "path", params->flats, NULL);
|
|
|
+ g_object_set (flat_after_reader, "path", params->flats_after, NULL);
|
|
|
g_object_set (dark_reader, "path", params->darks, NULL);
|
|
|
|
|
|
- ufo_task_graph_connect_nodes (read_graph, flat_reader, flat_avg);
|
|
|
+ ufo_task_graph_connect_nodes (read_graph, flat_before_reader, flat_before_stack);
|
|
|
+ ufo_task_graph_connect_nodes (read_graph, flat_before_stack, flat_before_median);
|
|
|
+ ufo_task_graph_connect_nodes (read_graph, flat_after_reader, flat_after_stack);
|
|
|
+ ufo_task_graph_connect_nodes (read_graph, flat_after_stack, flat_after_median);
|
|
|
+ ufo_task_graph_connect_nodes_full (read_graph, flat_before_median, flat_interpolate, 0);
|
|
|
+ ufo_task_graph_connect_nodes_full (read_graph, flat_after_median, flat_interpolate, 1);
|
|
|
+
|
|
|
ufo_task_graph_connect_nodes_full (read_graph, radio_reader, ffc, 0);
|
|
|
ufo_task_graph_connect_nodes_full (read_graph, dark_reader, ffc, 1);
|
|
|
- ufo_task_graph_connect_nodes_full (read_graph, flat_avg, ffc, 2);
|
|
|
+ ufo_task_graph_connect_nodes_full (read_graph, flat_interpolate, ffc, 2);
|
|
|
ufo_task_graph_connect_nodes (read_graph, ffc, data->output);
|
|
|
}
|
|
|
else {
|
|
@@ -455,8 +526,12 @@ run_cached_reconstruction (Params *params, gchar **argv)
|
|
|
|
|
|
if (with_flat_field_correction (params)) {
|
|
|
g_object_unref (ffc);
|
|
|
- g_object_unref (flat_avg);
|
|
|
- g_object_unref (flat_reader);
|
|
|
+ g_object_unref (flat_before_reader);
|
|
|
+ g_object_unref (flat_before_stack);
|
|
|
+ g_object_unref (flat_before_median);
|
|
|
+ g_object_unref (flat_after_reader);
|
|
|
+ g_object_unref (flat_after_stack);
|
|
|
+ g_object_unref (flat_after_median);
|
|
|
g_object_unref (dark_reader);
|
|
|
}
|
|
|
}
|