mirror of
https://github.com/eddyem/BTA_utils.git
synced 2025-12-06 18:55:18 +03:00
151 lines
4.5 KiB
C
151 lines
4.5 KiB
C
/*
|
|
* main.c
|
|
*
|
|
* Copyright 2016 Edward V. Emelianov <eddy@sao.ru, edward.emelianoff@gmail.com>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
|
* MA 02110-1301, USA.
|
|
*/
|
|
#include <math.h>
|
|
#include "usefull_macros.h"
|
|
#include "cmdlnopts.h"
|
|
#include "readwfs.h"
|
|
#include "readdat.h"
|
|
#include "zernike.h"
|
|
|
|
|
|
glob_pars *GP = NULL;
|
|
|
|
/**
|
|
* Read and dump WFS file
|
|
*/
|
|
void proc_WFS(){
|
|
int fd = open(GP->inwfs, O_RDONLY);
|
|
if(fd < 0){
|
|
WARN(_("open %s"), GP->inwfs);
|
|
return;
|
|
}
|
|
if(!test_wfs_file(fd)){
|
|
WARNX(_("Bad WFS file %s"), GP->inwfs);
|
|
return;
|
|
}
|
|
Zhistory *hist = show_zhistry(fd);
|
|
print_table(hist, fd);
|
|
hist = show_zhistry(fd);
|
|
print_table(hist, fd);
|
|
close(fd);
|
|
}
|
|
|
|
void proc_DAT(){
|
|
int i, j, Zn;
|
|
if(fabs(GP->step - DEFAULT_CRD_STEP) > DBL_EPSILON){ // user change default step
|
|
if((i = z_set_step(GP->step))){
|
|
WARNX(_("Can't change step to %g, value is too %s"), GP->step, i < 0 ? "small" : "big");
|
|
return;
|
|
}
|
|
}
|
|
if(fabs(GP->rotangle) > DBL_EPSILON) z_set_rotangle(GP->rotangle);
|
|
if(fabs(GP->wavelength - DEFAULT_WAVELENGTH) > DBL_EPSILON){ // user want to change wavelength
|
|
// WARNING! This option test should be before changing unit because units depends on wavelength
|
|
if(z_set_wavelength(GP->wavelength)){
|
|
WARNX(_("Bad wavelength: %g, should be from 100 to 10000um (1e-7 to 1e-5 or 0.1 to 10)"), GP->wavelength);
|
|
return;
|
|
}
|
|
}
|
|
if(GP->tozero) z_set_tozero(GP->tozero);
|
|
if(GP->addcoef) z_set_addcoef(GP->addcoef);
|
|
|
|
if(strcmp(GP->wfunits, DEFAULT_WF_UNIT)){ // user ask to change default unit
|
|
if(z_set_wfunit(GP->wfunits)){
|
|
WARNX(_("Bad wavefront unit: %s. Should be one of"), GP->wfunits);
|
|
z_print_wfunits();
|
|
return;
|
|
}
|
|
}
|
|
if(GP->zzero) z_set_Nzero(GP->zzero);
|
|
datfile *dat = open_dat_file(GP->indat);
|
|
char *fprefix = NULL;
|
|
if(!GP->outname){ // default filename
|
|
fprefix = strdup(GP->indat);
|
|
char *pt = strrchr(fprefix, '.');
|
|
if(pt && pt != fprefix) *pt = 0;
|
|
}else fprefix = strdup(GP->outname);
|
|
if(!dat){
|
|
WARNX(_("Bad DAT file %s"), GP->indat);
|
|
return;
|
|
}
|
|
polcrds *crds = gen_coords();
|
|
if(!crds){
|
|
WARNX("malloc()");
|
|
return;
|
|
}
|
|
int Sz = crds->Sz;
|
|
printf("%d points\n", Sz);
|
|
double *surf = MALLOC(double, Sz), *surf2 = MALLOC(double, Sz);
|
|
for(i = 0; ; ++i){
|
|
printf("image %d \r",i); fflush(stdout);
|
|
double *zerncoeffs = dat_read_next_line(dat, &Zn);
|
|
if(!zerncoeffs) break; // EOF
|
|
#ifdef EBUG
|
|
//printf("Read coefficients:\n");
|
|
//for(j = 0; j < Zn; ++j) printf("%4d\t%g\n", j, zerncoeffs[j]);
|
|
#endif
|
|
double *cur = Zcompose(Zn, zerncoeffs, crds);
|
|
for(j = 0; j < Sz; ++j){
|
|
double c = cur[j];
|
|
surf[j] += c;
|
|
surf2[j] += c*c;
|
|
}
|
|
free(zerncoeffs);
|
|
free(cur);
|
|
}
|
|
green(_("Got %d iterations, now save file\n"), i);
|
|
if(i > 0){
|
|
for(j = 0; j < Sz; ++j){
|
|
surf[j] /= i; // mean
|
|
surf2[j] = surf2[j]/i - surf[j]*surf[j]; // std
|
|
}
|
|
if(z_save_wavefront(crds, surf, surf2, fprefix))
|
|
WARN(_("Can't save files %s"), fprefix);
|
|
else
|
|
green(_("Saved to %s\n"), fprefix);
|
|
}else{
|
|
WARNX(_("Couldn't read any data"));
|
|
}
|
|
FREE(fprefix);
|
|
FREE(crds);
|
|
FREE(surf);
|
|
FREE(surf2);
|
|
close_dat_file(dat);
|
|
}
|
|
|
|
/**
|
|
* Read DAT file and build table with wavefront coordinates
|
|
*/
|
|
int main(int argc, char** argv){
|
|
initial_setup();
|
|
GP = parse_args(argc, argv);
|
|
if(!GP->inwfs && !GP->indat) ERRX(_("You should give input file name"));
|
|
z_set_scale(GP->scale);
|
|
if(GP->inwfs){
|
|
proc_WFS();
|
|
}
|
|
if(GP->indat){
|
|
proc_DAT();
|
|
}
|
|
return 0;
|
|
}
|
|
|