1   
  2   
  3   
  4   
  5   
  6   
  7   
  8   
  9   
 10   
 11   
 12   
 13   
 14   
 15   
 16   
 17   
 18   
 19   
 20   
 21   
 22   
 23  """Analysis specific code for the Lipari-Szabo model-free analysis.""" 
 24   
 25   
 26   
 27  __all__ = [ 'bmrb', 
 28              'macro_base', 
 29              'main', 
 30              'mf_minimise', 
 31              'molmol', 
 32              'multi_processor_commands', 
 33              'pymol', 
 34              'results' 
 35  ] 
 36   
 37   
 38  from generic_fns import diffusion_tensor, relax_data 
 39  from physical_constants import N15_CSA, NH_BOND_LENGTH 
 40  from specific_fns.api_base import API_base 
 41  from specific_fns.api_common import API_common 
 42  from specific_fns.model_free.bmrb import Bmrb 
 43  from specific_fns.model_free.main import Model_free_main 
 44  from specific_fns.model_free.mf_minimise import Mf_minimise 
 45  from specific_fns.model_free.molmol import Molmol 
 46  from specific_fns.model_free.pymol import Pymol 
 47  from specific_fns.model_free.results import Results 
 48   
 49   
 50 -class Model_free(Model_free_main, Mf_minimise, Results, Bmrb, API_base, API_common): 
  51      """Parent class containing all the model-free specific functions.""" 
 52   
 54          """Initialise the class by placing API_common methods into the API.""" 
 55   
 56           
 57          super(Model_free, self).__init__() 
 58   
 59           
 60          self.base_data_loop = self._base_data_loop_spin 
 61          self.return_error = self._return_error_relax_data 
 62          self.return_value = self._return_value_general 
 63          self.sim_pack_data = self._sim_pack_relax_data 
 64          self.test_grid_ops = self._test_grid_ops_general 
 65   
 66           
 67          self._molmol_macros = Molmol() 
 68          self._pymol_macros = Pymol() 
 69   
 70           
 71          self.pymol_macro = self._pymol_macros.create_macro 
 72          self.molmol_macro = self._molmol_macros.create_macro 
 73   
 74           
 75          self.PARAMS.add('tm', scope='global', default=diffusion_tensor.default_value('tm'), conv_factor=1e-9, grace_string='\\xt\\f{}\\sm', units='ns', py_type=float, set='params', err=True, sim=True) 
 76          self.PARAMS.add('Diso', scope='global', default=diffusion_tensor.default_value('Diso'), py_type=float, set='params', err=True, sim=True) 
 77          self.PARAMS.add('Dx', scope='global', default=diffusion_tensor.default_value('Dx'), py_type=float, set='params', err=True, sim=True) 
 78          self.PARAMS.add('Dy', scope='global', default=diffusion_tensor.default_value('Dy'), py_type=float, set='params', err=True, sim=True) 
 79          self.PARAMS.add('Dz', scope='global', default=diffusion_tensor.default_value('Dz'), py_type=float, set='params', err=True, sim=True) 
 80          self.PARAMS.add('Dpar', scope='global', default=diffusion_tensor.default_value('Dpar'), py_type=float, set='params', err=True, sim=True) 
 81          self.PARAMS.add('Dper', scope='global', default=diffusion_tensor.default_value('Dper'), py_type=float, set='params', err=True, sim=True) 
 82          self.PARAMS.add('Da', scope='global', default=diffusion_tensor.default_value('Da'), py_type=float, set='params', err=True, sim=True) 
 83          self.PARAMS.add('Dratio', scope='global', default=diffusion_tensor.default_value('Dratio'), py_type=float, set='params', err=True, sim=True) 
 84          self.PARAMS.add('Dr', scope='global', default=diffusion_tensor.default_value('Dr'), py_type=float, set='params', err=True, sim=True) 
 85          self.PARAMS.add('alpha', scope='global', default=diffusion_tensor.default_value('alpha'), py_type=float, set='params', err=True, sim=True) 
 86          self.PARAMS.add('beta', scope='global', default=diffusion_tensor.default_value('beta'), py_type=float, set='params', err=True, sim=True) 
 87          self.PARAMS.add('gamma', scope='global', default=diffusion_tensor.default_value('gamma'), py_type=float, set='params', err=True, sim=True) 
 88          self.PARAMS.add('theta', scope='global', default=diffusion_tensor.default_value('theta'), py_type=float, set='params', err=True, sim=True) 
 89          self.PARAMS.add('phi', scope='global', default=diffusion_tensor.default_value('phi'), py_type=float, set='params', err=True, sim=True) 
 90   
 91           
 92          self.PARAMS.add('model', scope='spin', desc='The model', py_type=str) 
 93          self.PARAMS.add('equation', scope='spin', desc='The model equation', py_type=str) 
 94          self.PARAMS.add('params', scope='spin', desc='The model parameters', py_type=list) 
 95          self.PARAMS.add('s2', scope='spin', default=0.8, desc='S2, the model-free generalised order parameter (S2 = S2f.S2s)', py_type=float, set='params', grace_string='\\qS\\v{0.4}\\z{0.71}2\\Q', err=True, sim=True) 
 96          self.PARAMS.add('s2f', scope='spin', default=0.8, desc='S2f, the faster motion model-free generalised order parameter', py_type=float, set='params', grace_string='\\qS\\sf\\N\\h{-0.2}\\v{0.4}\\z{0.71}2\\Q', err=True, sim=True) 
 97          self.PARAMS.add('s2s', scope='spin', default=0.8, desc='S2s, the slower motion model-free generalised order parameter', py_type=float, set='params', grace_string='\\qS\\ss\\N\\h{-0.2}\\v{0.4}\\z{0.71}2\\Q', err=True, sim=True) 
 98          self.PARAMS.add('local_tm', scope='spin', default=10.0 * 1e-9, desc='The spin specific global correlation time (seconds)', py_type=float, set='params', grace_string='\\xt\\f{}\\sm', units='ns', err=True, sim=True) 
 99          self.PARAMS.add('te', scope='spin', default=100.0 * 1e-12, desc='Single motion effective internal correlation time (seconds)', py_type=float, set='params', conv_factor=1e-12, grace_string='\\xt\\f{}\\se', units='ps', err=True, sim=True) 
100          self.PARAMS.add('tf', scope='spin', default=10.0 * 1e-12, desc='Faster motion effective internal correlation time (seconds)', py_type=float, set='params', conv_factor=1e-12, grace_string='\\xt\\f{}\\sf', units='ps', err=True, sim=True) 
101          self.PARAMS.add('ts', scope='spin', default=1000.0 * 1e-12, desc='Slower motion effective internal correlation time (seconds)', py_type=float, set='params', conv_factor=1e-12, grace_string='\\xt\\f{}\\ss', units='ps', err=True, sim=True) 
102          self.PARAMS.add('rex', scope='spin', default=0.0, desc='Chemical exchange relaxation (sigma_ex = Rex / omega**2)', py_type=float, set='params', conv_factor=self._conv_factor_rex, units=self._units_rex, grace_string='\\qR\\sex\\Q', err=True, sim=True) 
103          self.PARAMS.add('csa', scope='spin', default=N15_CSA, units='ppm', desc='Chemical shift anisotropy (unitless)', py_type=float, set='params', conv_factor=1e-6, grace_string='\\qCSA\\Q', err=True, sim=True) 
104   
105           
106          self.PARAMS.add_min_data(min_stats_global=True, min_stats_spin=True) 
107   
108           
109          self.PARAMS.add('ri_data', scope='spin', desc=relax_data.return_data_desc('ri_data'), py_type=dict, err=False, sim=True) 
110          self.PARAMS.add('ri_data_err', scope='spin', desc=relax_data.return_data_desc('ri_data_err'), py_type=dict, err=False, sim=False) 
  111