/* * prof2d_check.c * * Check 2D profile fitting * * Copyright © 2013-2020 Deutsches Elektronen-Synchrotron DESY, * a research centre of the Helmholtz Association. * * Authors: * 2013-2014,2016 Thomas White * * This file is part of CrystFEL. * * CrystFEL 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 3 of the License, or * (at your option) any later version. * * CrystFEL 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 CrystFEL. If not, see . * */ #ifdef HAVE_CONFIG_H #include #endif #include #include #include #include #include "histogram.h" #include "../libcrystfel/src/integration.c" #define ADD_PX(fs, ss, val) \ if ( ((fs)>0) && ((ss)>0) && ((fs)n_panels = 1; image.det->panels = calloc(1, sizeof(struct panel)); image.dp = calloc(1, sizeof(float *)); image.bad = calloc(1, sizeof(int *)); image.det->panels[0].w = w; image.det->panels[0].h = h; image.det->panels[0].fsx = 1.0; image.det->panels[0].fsy = 0.0; image.det->panels[0].ssx = 0.0; image.det->panels[0].ssy = 1.0; image.det->panels[0].xfs = 1.0; image.det->panels[0].yfs = 0.0; image.det->panels[0].xss = 0.0; image.det->panels[0].yss = 1.0; image.det->panels[0].cnx = -w/2; image.det->panels[0].cny = -h/2; image.det->panels[0].clen = 60.0e-3; image.det->panels[0].res = 100000; /* 10 px per mm */ image.det->panels[0].adu_per_eV = 10.0/9000.0; /* 10 adu/ph */ image.det->panels[0].max_adu = +INFINITY; /* No cutoff */ image.det->furthest_out_panel = &image.det->panels[0]; image.det->furthest_out_fs = 0; image.det->furthest_out_ss = 0; image.dp[0] = malloc(w*h*sizeof(float)); memset(image.dp[0], 0, w*h*sizeof(float)); image.bad[0] = malloc(w*h*sizeof(int)); memset(image.bad[0], 0, w*h*sizeof(int)); image.sat = NULL; cell = cell_new(); cell_set_lattice_type(cell, L_CUBIC); cell_set_centering(cell, 'P'); cell_set_parameters(cell, 800.0e-10, 800.0e-10, 800.0e-10, deg2rad(90.0), deg2rad(90.0), deg2rad(90.0)); cell = cell_rotate(cell, random_quaternion(rng)); cr = crystal_new(); crystal_set_profile_radius(cr, 0.001e9); crystal_set_mosaicity(cr, 0.0); /* radians */ crystal_set_image(cr, &image); crystal_set_cell(cr, cell); image.n_crystals = 1; image.crystals = &cr; list = predict_to_res(cr, largest_q(&image)); crystal_set_reflections(cr, list); for ( fs=0; fspanels); free(image.det); free(image.dp[0]); free(image.dp); gsl_rng_free(rng); if ( fail ) return 1; return 0; }