def exercise_serialization(dials_data, tmp_dir): base_path = pathlib.Path(tmp_dir) template = dials_data("insulin").join("insulin_1_###.img").strpath from xia2.Modules.Indexer.DialsIndexer import DialsIndexer from xia2.Modules.Refiner.DialsRefiner import DialsRefiner from xia2.Modules.Integrater.DialsIntegrater import DialsIntegrater from xia2.Modules.Scaler.CCP4ScalerA import CCP4ScalerA from dxtbx.model.experiment_list import ExperimentListTemplateImporter importer = ExperimentListTemplateImporter([template]) experiments = importer.experiments imageset = experiments.imagesets()[0] from xia2.Schema.XProject import XProject from xia2.Schema.XCrystal import XCrystal from xia2.Schema.XWavelength import XWavelength from xia2.Schema.XSweep import XSweep from xia2.Schema.XSample import XSample proj = XProject(base_path=base_path) proj._name = "PROJ1" cryst = XCrystal("CRYST1", proj) wav = XWavelength("WAVE1", cryst, wavelength=0.98) samp = XSample("X1", cryst) cryst.add_wavelength(wav) cryst.set_ha_info({"atom": "S"}) cryst.add_sample(samp) directory, image = os.path.split(imageset.get_path(1)) sweep = wav.add_sweep(name="SWEEP1", sample=samp, directory=directory, image=image) samp.add_sweep(sweep) from dxtbx.serialize.load import _decode_dict indexer = DialsIndexer() indexer.set_working_directory(tmp_dir) indexer.add_indexer_imageset(imageset) indexer.set_indexer_sweep(sweep) sweep._indexer = indexer refiner = DialsRefiner() refiner.set_working_directory(tmp_dir) refiner.add_refiner_indexer(sweep.get_epoch(1), indexer) refiner.add_refiner_sweep(sweep) sweep._refiner = refiner integrater = DialsIntegrater() integrater.set_output_format("hkl") integrater.set_working_directory(tmp_dir) integrater.setup_from_image(imageset.get_path(1)) integrater.set_integrater_refiner(refiner) # integrater.set_integrater_indexer(indexer) integrater.set_integrater_sweep(sweep) integrater.set_integrater_epoch(sweep.get_epoch(1)) integrater.set_integrater_sweep_name(sweep.get_name()) integrater.set_integrater_project_info( cryst.get_name(), wav.get_name(), sweep.get_name() ) sweep._integrater = integrater scaler = CCP4ScalerA(base_path=base_path) scaler.add_scaler_integrater(integrater) scaler.set_scaler_xcrystal(cryst) scaler.set_scaler_project_info(cryst.get_name(), wav.get_name()) scaler._scalr_xcrystal = cryst cryst._scaler = scaler proj.add_crystal(cryst) s_dict = sweep.to_dict() s_str = json.dumps(s_dict, ensure_ascii=True) s_dict = json.loads(s_str, object_hook=_decode_dict) xsweep = XSweep.from_dict(s_dict) assert xsweep w_dict = wav.to_dict() w_str = json.dumps(w_dict, ensure_ascii=True) w_dict = json.loads(w_str, object_hook=_decode_dict) xwav = XWavelength.from_dict(w_dict) assert xwav.get_sweeps()[0].get_wavelength() is xwav c_dict = cryst.to_dict() c_str = json.dumps(c_dict, ensure_ascii=True) c_dict = json.loads(c_str, object_hook=_decode_dict) xcryst = XCrystal.from_dict(c_dict) assert ( xcryst.get_xwavelength(xcryst.get_wavelength_names()[0]).get_crystal() is xcryst ) p_dict = proj.to_dict() p_str = json.dumps(p_dict, ensure_ascii=True) p_dict = json.loads(p_str, object_hook=_decode_dict) xproj = XProject.from_dict(p_dict) assert xproj.path == base_path assert list(xproj.get_crystals().values())[0].get_project() is xproj assert list(xproj.get_crystals().values())[0]._scaler._base_path == base_path json_str = proj.as_json() xproj = XProject.from_json(string=json_str) assert xproj.path == base_path assert list(xproj.get_crystals().values())[0].get_project() is xproj print(xproj.get_output()) print("\n".join(xproj.summarise())) json_str = xproj.as_json() xproj = XProject.from_json(string=json_str) assert xproj.path == base_path # Test that we can serialize to json and back again xproj = XProject.from_json(string=xproj.as_json()) assert xproj.path == base_path xcryst = list(xproj.get_crystals().values())[0] assert xcryst.get_project() is xproj intgr = xcryst._get_integraters()[0] assert intgr.get_integrater_finish_done() assert ( xcryst._get_scaler() ._sweep_handler.get_sweep_information(intgr.get_integrater_epoch()) .get_integrater() is intgr ) print(xproj.get_output()) print("\n".join(xproj.summarise()))
def _setup_from_xinfo_file(self, xinfo_file): """Set up this object & all subobjects based on the .xinfo file contents.""" settings = PhilIndex.params.xia2.settings sweep_ids = [sweep.id for sweep in settings.sweep] sweep_ranges = [sweep.range for sweep in settings.sweep] if not sweep_ids: sweep_ids = None sweep_ranges = None xinfo = XInfo(xinfo_file, sweep_ids=sweep_ids, sweep_ranges=sweep_ranges) self._name = xinfo.get_project() crystals = xinfo.get_crystals() for crystal in crystals: xc = XCrystal(crystal, self) if "sequence" in crystals[crystal]: xc.set_aa_sequence(crystals[crystal]["sequence"]) if "ha_info" in crystals[crystal]: if crystals[crystal]["ha_info"] != {}: xc.set_ha_info(crystals[crystal]["ha_info"]) if "scaled_merged_reflection_file" in crystals[crystal]: xc.set_scaled_merged_reflections( crystals[crystal]["scaled_merged_reflections"]) if "reference_reflection_file" in crystals[crystal]: xc.set_reference_reflection_file( crystals[crystal]["reference_reflection_file"]) if "freer_file" in crystals[crystal]: xc.set_freer_file(crystals[crystal]["freer_file"]) # user assigned spacegroup if "user_spacegroup" in crystals[crystal]: xc.set_user_spacegroup(crystals[crystal]["user_spacegroup"]) elif settings.space_group is not None: # XXX do we ever actually get here? xc.set_user_spacegroup( settings.space_group.type().lookup_symbol()) # add a default sample if none present in xinfo file if not crystals[crystal]["samples"]: crystals[crystal]["samples"]["X1"] = {} for sample in crystals[crystal]["samples"]: xsample = XSample(sample, xc) xc.add_sample(xsample) if not crystals[crystal]["wavelengths"]: raise RuntimeError("No wavelengths specified in xinfo file") for wavelength, wave_info in crystals[crystal][ "wavelengths"].items(): # FIXME 29/NOV/06 in here need to be able to cope with # no wavelength information - this should default to the # information in the image header (John Cowan pointed # out that this was untidy - requiring that it agrees # with the value in the header makes this almost # useless.) if "wavelength" not in wave_info: logger.debug("No wavelength value given for wavelength %s", wavelength) else: logger.debug( "Overriding value for wavelength %s to %8.6f", wavelength, float(wave_info["wavelength"]), ) # handle case where user writes f" in place of f'' if 'f"' in wave_info and "f''" not in wave_info: wave_info["f''"] = wave_info['f"'] xw = XWavelength( wavelength, xc, wavelength=wave_info.get("wavelength", 0.0), f_pr=wave_info.get("f'", 0.0), f_prpr=wave_info.get("f''", 0.0), dmin=wave_info.get("dmin", 0.0), dmax=wave_info.get("dmax", 0.0), ) # in here I also need to look and see if we have # been given any scaled reflection files... # check to see if we have a user supplied lattice... if "user_spacegroup" in crystals[crystal]: lattice = Syminfo.get_lattice( crystals[crystal]["user_spacegroup"]) elif settings.space_group is not None: # XXX do we ever actually get here? lattice = Syminfo.get_lattice( settings.space_group.type().lookup_symbol()) else: lattice = None # and also user supplied cell constants - from either # the xinfo file (the first port of call) or the # command-line. if "user_cell" in crystals[crystal]: cell = crystals[crystal]["user_cell"] elif settings.unit_cell is not None: # XXX do we ever actually get here? cell = settings.unit_cell.parameters() else: cell = None dmin = wave_info.get("dmin", 0.0) dmax = wave_info.get("dmax", 0.0) if dmin == 0.0 and dmax == 0.0: dmin = PhilIndex.params.xia2.settings.resolution.d_min dmax = PhilIndex.params.xia2.settings.resolution.d_max # want to be able to locally override the resolution limits # for this sweep while leaving the rest for the data set # intact... for sweep_name, sweep_info in crystals[crystal][ "sweeps"].items(): sample_name = sweep_info.get("sample") if sample_name is None: if len(crystals[crystal]["samples"]) == 1: sample_name = list(crystals[crystal]["samples"])[0] else: raise RuntimeError("No sample given for sweep %s" % sweep_name) xsample = xc.get_xsample(sample_name) assert xsample is not None dmin_old = dmin dmax_old = dmax if "RESOLUTION" in sweep_info: values = [ float(x) for x in sweep_info["RESOLUTION"].split() ] if len(values) == 1: dmin = values[0] elif len(values) == 2: dmin = min(values) dmax = max(values) else: raise RuntimeError("bad resolution for sweep %s" % sweep_name) if sweep_info["wavelength"] == wavelength: frames_to_process = sweep_info.get("start_end") xsweep = xw.add_sweep( sweep_name, sample=xsample, directory=sweep_info.get("DIRECTORY"), image=sweep_info.get("IMAGE"), beam=sweep_info.get("beam"), reversephi=sweep_info.get("reversephi", False), distance=sweep_info.get("distance"), gain=float(sweep_info.get("GAIN", 0.0)), dmin=dmin, dmax=dmax, polarization=float( sweep_info.get("POLARIZATION", 0.0)), frames_to_process=frames_to_process, user_lattice=lattice, user_cell=cell, epoch=sweep_info.get("epoch", 0), ice=sweep_info.get("ice", False), excluded_regions=sweep_info.get( "excluded_regions", []), ) xsample.add_sweep(xsweep) dmin = dmin_old dmax = dmax_old xc.add_wavelength(xw) self.add_crystal(xc)
def setup_from_xinfo_file(self, xinfo_file): '''Set up this object & all subobjects based on the .xinfo file contents.''' settings = PhilIndex.params.xia2.settings sweep_ids = [sweep.id for sweep in settings.sweep] sweep_ranges = [sweep.range for sweep in settings.sweep] if not sweep_ids: sweep_ids = None sweep_ranges = None xinfo = XInfo(xinfo_file, sweep_ids=sweep_ids, sweep_ranges=sweep_ranges) self._name = xinfo.get_project() crystals = xinfo.get_crystals() for crystal in crystals.keys(): xc = XCrystal(crystal, self) if 'sequence' in crystals[crystal]: xc.set_aa_sequence(crystals[crystal]['sequence']) if 'ha_info' in crystals[crystal]: if crystals[crystal]['ha_info'] != { }: xc.set_ha_info(crystals[crystal]['ha_info']) if 'scaled_merged_reflection_file' in crystals[crystal]: xc.set_scaled_merged_reflections( crystals[crystal]['scaled_merged_reflections']) if 'reference_reflection_file' in crystals[crystal]: xc.set_reference_reflection_file( crystals[crystal]['reference_reflection_file']) if 'freer_file' in crystals[crystal]: xc.set_freer_file(crystals[crystal]['freer_file']) # user assigned spacegroup if 'user_spacegroup' in crystals[crystal]: xc.set_user_spacegroup(crystals[crystal]['user_spacegroup']) elif settings.space_group is not None: # XXX do we ever actually get here? xc.set_user_spacegroup(settings.space_group.type().lookup_symbol()) # add a default sample if none present in xinfo file if not crystals[crystal]['samples']: crystals[crystal]['samples']['X1'] = {} for sample in crystals[crystal]['samples'].keys(): sample_info = crystals[crystal]['samples'][sample] xsample = XSample(sample, xc) xc.add_sample(xsample) if not crystals[crystal]['wavelengths']: raise RuntimeError('No wavelengths specified in xinfo file') for wavelength in crystals[crystal]['wavelengths'].keys(): # FIXME 29/NOV/06 in here need to be able to cope with # no wavelength information - this should default to the # information in the image header (John Cowan pointed # out that this was untidy - requiring that it agrees # with the value in the header makes this almost # useless.) wave_info = crystals[crystal]['wavelengths'][wavelength] if 'wavelength' not in wave_info: Debug.write( 'No wavelength value given for wavelength %s' % wavelength) else: Debug.write( 'Overriding value for wavelength %s to %8.6f' % \ (wavelength, float(wave_info['wavelength']))) # handle case where user writes f" in place of f'' if 'f"' in wave_info and not \ 'f\'\'' in wave_info: wave_info['f\'\''] = wave_info['f"'] xw = XWavelength(wavelength, xc, wavelength = wave_info.get('wavelength', 0.0), f_pr = wave_info.get('f\'', 0.0), f_prpr = wave_info.get('f\'\'', 0.0), dmin = wave_info.get('dmin', 0.0), dmax = wave_info.get('dmax', 0.0)) # in here I also need to look and see if we have # been given any scaled reflection files... # check to see if we have a user supplied lattice... if 'user_spacegroup' in crystals[crystal]: lattice = Syminfo.get_lattice( crystals[crystal]['user_spacegroup']) elif settings.space_group is not None: # XXX do we ever actually get here? lattice = Syminfo.get_lattice( settings.space_group.type().lookup_symbol()) else: lattice = None # and also user supplied cell constants - from either # the xinfo file (the first port of call) or the # command-line. if 'user_cell' in crystals[crystal]: cell = crystals[crystal]['user_cell'] elif settings.unit_cell is not None: # XXX do we ever actually get here? cell = settings.unit_cell.parameters() else: cell = None dmin = wave_info.get('dmin', 0.0) dmax = wave_info.get('dmax', 0.0) if dmin == 0.0 and dmax == 0.0: dmin = PhilIndex.params.xia2.settings.resolution.d_min dmax = PhilIndex.params.xia2.settings.resolution.d_max # want to be able to locally override the resolution limits # for this sweep while leaving the rest for the data set # intact... for sweep_name in crystals[crystal]['sweeps'].keys(): sweep_info = crystals[crystal]['sweeps'][sweep_name] sample_name = sweep_info.get('sample') if sample_name is None: if len(crystals[crystal]['samples']) == 1: sample_name = crystals[crystal]['samples'].keys()[0] else: raise RuntimeError('No sample given for sweep %s' %sweep_name) xsample = xc.get_xsample(sample_name) assert xsample is not None dmin_old = dmin dmax_old = dmax replace = False if 'RESOLUTION' in sweep_info: values = map(float, sweep_info['RESOLUTION'].split()) if len(values) == 1: dmin = values[0] elif len(values) == 2: dmin = min(values) dmax = max(values) else: raise RuntimeError, \ 'bad resolution for sweep %s' % sweep_name replace = True # FIXME: AJP to implement # FIXME ticket number here please if 'ice' in sweep_info: pass if 'excluded_regions' in sweep_info: pass if sweep_info['wavelength'] == wavelength: frames_to_process = sweep_info.get('start_end') xsweep = xw.add_sweep( sweep_name, sample=xsample, directory = sweep_info.get('DIRECTORY'), image = sweep_info.get('IMAGE'), beam = sweep_info.get('beam'), reversephi = sweep_info.get('reversephi', False), distance = sweep_info.get('distance'), gain = float(sweep_info.get('GAIN', 0.0)), dmin = dmin, dmax = dmax, polarization = float(sweep_info.get( 'POLARIZATION', 0.0)), frames_to_process = frames_to_process, user_lattice = lattice, user_cell = cell, epoch = sweep_info.get('epoch', 0), ice = sweep_info.get('ice', False), excluded_regions = sweep_info.get( 'excluded_regions', []), ) xsample.add_sweep(xsweep) dmin = dmin_old dmax = dmax_old xc.add_wavelength(xw) self.add_crystal(xc) return
def setup_from_xinfo_file(self, xinfo_file): '''Set up this object & all subobjects based on the .xinfo file contents.''' settings = PhilIndex.params.xia2.settings sweep_ids = [sweep.id for sweep in settings.sweep] sweep_ranges = [sweep.range for sweep in settings.sweep] if not sweep_ids: sweep_ids = None sweep_ranges = None xinfo = XInfo(xinfo_file, sweep_ids=sweep_ids, sweep_ranges=sweep_ranges) self._name = xinfo.get_project() crystals = xinfo.get_crystals() for crystal in crystals.keys(): xc = XCrystal(crystal, self) if 'sequence' in crystals[crystal]: xc.set_aa_sequence(crystals[crystal]['sequence']) if 'ha_info' in crystals[crystal]: if crystals[crystal]['ha_info'] != {}: xc.set_ha_info(crystals[crystal]['ha_info']) if 'scaled_merged_reflection_file' in crystals[crystal]: xc.set_scaled_merged_reflections( crystals[crystal]['scaled_merged_reflections']) if 'reference_reflection_file' in crystals[crystal]: xc.set_reference_reflection_file( crystals[crystal]['reference_reflection_file']) if 'freer_file' in crystals[crystal]: xc.set_freer_file(crystals[crystal]['freer_file']) # user assigned spacegroup if 'user_spacegroup' in crystals[crystal]: xc.set_user_spacegroup(crystals[crystal]['user_spacegroup']) elif settings.space_group is not None: # XXX do we ever actually get here? xc.set_user_spacegroup( settings.space_group.type().lookup_symbol()) # add a default sample if none present in xinfo file if not crystals[crystal]['samples']: crystals[crystal]['samples']['X1'] = {} for sample in crystals[crystal]['samples'].keys(): sample_info = crystals[crystal]['samples'][sample] xsample = XSample(sample, xc) xc.add_sample(xsample) if not crystals[crystal]['wavelengths']: raise RuntimeError('No wavelengths specified in xinfo file') for wavelength in crystals[crystal]['wavelengths'].keys(): # FIXME 29/NOV/06 in here need to be able to cope with # no wavelength information - this should default to the # information in the image header (John Cowan pointed # out that this was untidy - requiring that it agrees # with the value in the header makes this almost # useless.) wave_info = crystals[crystal]['wavelengths'][wavelength] if 'wavelength' not in wave_info: Debug.write('No wavelength value given for wavelength %s' % wavelength) else: Debug.write( 'Overriding value for wavelength %s to %8.6f' % \ (wavelength, float(wave_info['wavelength']))) # handle case where user writes f" in place of f'' if 'f"' in wave_info and not \ 'f\'\'' in wave_info: wave_info['f\'\''] = wave_info['f"'] xw = XWavelength(wavelength, xc, wavelength=wave_info.get('wavelength', 0.0), f_pr=wave_info.get('f\'', 0.0), f_prpr=wave_info.get('f\'\'', 0.0), dmin=wave_info.get('dmin', 0.0), dmax=wave_info.get('dmax', 0.0)) # in here I also need to look and see if we have # been given any scaled reflection files... # check to see if we have a user supplied lattice... if 'user_spacegroup' in crystals[crystal]: lattice = Syminfo.get_lattice( crystals[crystal]['user_spacegroup']) elif settings.space_group is not None: # XXX do we ever actually get here? lattice = Syminfo.get_lattice( settings.space_group.type().lookup_symbol()) else: lattice = None # and also user supplied cell constants - from either # the xinfo file (the first port of call) or the # command-line. if 'user_cell' in crystals[crystal]: cell = crystals[crystal]['user_cell'] elif settings.unit_cell is not None: # XXX do we ever actually get here? cell = settings.unit_cell.parameters() else: cell = None dmin = wave_info.get('dmin', 0.0) dmax = wave_info.get('dmax', 0.0) if dmin == 0.0 and dmax == 0.0: dmin = PhilIndex.params.xia2.settings.resolution.d_min dmax = PhilIndex.params.xia2.settings.resolution.d_max # want to be able to locally override the resolution limits # for this sweep while leaving the rest for the data set # intact... for sweep_name in crystals[crystal]['sweeps'].keys(): sweep_info = crystals[crystal]['sweeps'][sweep_name] sample_name = sweep_info.get('sample') if sample_name is None: if len(crystals[crystal]['samples']) == 1: sample_name = crystals[crystal]['samples'].keys( )[0] else: raise RuntimeError('No sample given for sweep %s' % sweep_name) xsample = xc.get_xsample(sample_name) assert xsample is not None dmin_old = dmin dmax_old = dmax replace = False if 'RESOLUTION' in sweep_info: values = map(float, sweep_info['RESOLUTION'].split()) if len(values) == 1: dmin = values[0] elif len(values) == 2: dmin = min(values) dmax = max(values) else: raise RuntimeError('bad resolution for sweep %s' % sweep_name) replace = True if sweep_info['wavelength'] == wavelength: frames_to_process = sweep_info.get('start_end') xsweep = xw.add_sweep( sweep_name, sample=xsample, directory=sweep_info.get('DIRECTORY'), image=sweep_info.get('IMAGE'), beam=sweep_info.get('beam'), reversephi=sweep_info.get('reversephi', False), distance=sweep_info.get('distance'), gain=float(sweep_info.get('GAIN', 0.0)), dmin=dmin, dmax=dmax, polarization=float( sweep_info.get('POLARIZATION', 0.0)), frames_to_process=frames_to_process, user_lattice=lattice, user_cell=cell, epoch=sweep_info.get('epoch', 0), ice=sweep_info.get('ice', False), excluded_regions=sweep_info.get( 'excluded_regions', []), ) xsample.add_sweep(xsweep) dmin = dmin_old dmax = dmax_old xc.add_wavelength(xw) self.add_crystal(xc)