Changes in / [eec5fd6:4554131] in sasmodels


Ignore:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • sasmodels/models/adsorbed_layer.py

    r4f4e0d5 rf10bc52  
    66 
    77r""" 
    8 This model describes the scattering from a layer of surfactant or polymer adsorbed on large, smooth, notionally spherical particles under the conditions that (i) the particles (cores) are contrast-matched to the dispersion medium, (ii) *S(Q)* ~ 1 (ie, the particle volume fraction is dilute), (iii) the particle radius is >> layer thickness (ie, the interface is locally flat), and (iv) scattering from excess unadsorbed adsorbate in the bulk medium is absent or has been corrected for. 
     8This model describes the scattering from a layer of surfactant or polymer adsorbed on spherical particles under the conditions that (i) the particles (cores) are contrast-matched to the dispersion medium, (ii) *S(Q)* ~ 1 (ie, the particle volume fraction is dilute), (iii) the particle radius is >> layer thickness (ie, the interface is locally flat), and (iv) scattering from excess unadsorbed adsorbate in the bulk medium is absent or has been corrected for. 
    99 
    1010Unlike many other core-shell models, this model does not assume any form for the density distribution of the adsorbed species normal to the interface (cf, a core-shell model normally assumes the density distribution to be a homogeneous step-function). For comparison, if the thickness of a (traditional core-shell like) step function distribution is *t*, the second moment about the mean of the density distribution (ie, the distance of the centre-of-mass of the distribution from the interface), |sigma| =  sqrt((*t* :sup:`2` )/12). 
     
    3434 
    3535description =  """ 
    36     Evaluates the scattering from large particles 
     36    Evaluates the scattering from particles 
    3737    with an adsorbed layer of surfactant or 
    3838    polymer, independent of the form of the 
     
    4242 
    4343#             ["name", "units", default, [lower, upper], "type", "description"], 
    44 parameters =  [["second_moment", "Ang", 23.0, [0.0, inf], "", "Second moment of polymer distribution"], 
    45               ["adsorbed_amount", "mg/m2", 1.9, [0.0, inf], "", "Adsorbed amount of polymer"], 
    46               ["density_shell", "g/cm3", 0.7, [0.0, inf], "", "Bulk density of polymer in the shell"], 
    47               ["radius", "Ang", 500.0, [0.0, inf], "", "Core particle radius"], 
    48               ["volfraction", "None", 0.14, [0.0, inf], "", "Core particle volume fraction"], 
    49               ["sld_shell", "1e-6/Ang^2", 1.5, [-inf, inf], "sld", "Polymer shell SLD"], 
    50               ["sld_solvent", "1e-6/Ang^2", 6.3, [-inf, inf], "sld", "Solvent SLD"]] 
     44parameters =  [["second_moment", "Ang", 23.0, [0.0, inf], "", "Second moment"], 
     45              ["adsorbed_amount", "mg/m2", 1.9, [0.0, inf], "", "Adsorbed amount"], 
     46              ["density_poly", "g/cm3", 0.7, [0.0, inf], "", "Polymer density"], 
     47              ["radius", "Ang", 500.0, [0.0, inf], "", "Particle radius"], 
     48              ["volfraction", "None", 0.14, [0.0, inf], "", "Particle vol fraction"], 
     49              ["polymer_sld", "1/Ang^2", 1.5e-06, [-inf, inf], "", "Polymer SLD"], 
     50              ["solvent_sld", "1/Ang^2", 6.3e-06, [-inf, inf], "", "Solvent SLD"]] 
    5151 
    5252# NB: Scale and Background are implicit parameters on every model 
    53 def Iq(q, second_moment, adsorbed_amount, density_shell, radius,  
    54         volfraction, sld_shell, sld_solvent): 
     53def Iq(q, second_moment, adsorbed_amount, density_poly, radius,  
     54        volfraction, polymer_sld, solvent_sld): 
    5555    # pylint: disable = missing-docstring 
    56 #    deltarhosqrd =  (sld_shell - sld_solvent) * (sld_shell - sld_solvent) 
    57 #    numerator =  6.0 * pi * volfraction * (adsorbed_amount * adsorbed_amount) 
    58 #    denominator =  (q * q) * (density_shell * density_shell) * radius 
    59 #    eterm =  exp(-1.0 * (q * q) * (second_moment * second_moment)) 
    60 #    #scale by 10^-2 for units conversion to cm^-1 
    61 #    inten =  1.0e-02 * deltarhosqrd * ((numerator / denominator) * eterm) 
    62     aa =  (sld_shell - sld_solvent) * adsorbed_amount / q / density_shell  
    63     bb = q * second_moment 
    64     #scale by 10^-2 for units conversion to cm^-1 
    65     inten =  6.0e-02 * pi * volfraction * aa * aa * exp(-bb * bb) / radius 
     56    deltarhosqrd =  (polymer_sld - solvent_sld) * (polymer_sld - solvent_sld) 
     57    numerator =  6.0 * pi * volfraction * (adsorbed_amount * adsorbed_amount) 
     58    denominator =  (q * q) * (density_poly * density_poly) * radius 
     59    eterm =  exp(-1.0 * (q * q) * (second_moment * second_moment)) 
     60    #scale by 10^10 for units conversion to cm^-1 
     61    inten =  1.0e+10 * deltarhosqrd * ((numerator / denominator) * eterm) 
    6662    return inten 
    6763Iq.vectorized =  True  # Iq accepts an array of q values 
     
    7571            second_moment = 23.0, 
    7672            adsorbed_amount = 1.9, 
    77             density_shell = 0.7, 
     73            density_poly = 0.7, 
    7874            radius = 500.0, 
    7975            volfraction = 0.14, 
    80             sld_shell = 1.5, 
    81             sld_solvent = 6.3, 
     76            polymer_sld = 1.5e-06, 
     77            solvent_sld = 6.3e-06, 
    8278            background = 0.0) 
    8379 
     
    8682               second_moment = 'second_moment', 
    8783               adsorbed_amount = 'ads_amount', 
    88                density_shell = 'density_poly', 
     84               density_poly = 'density_poly', 
    8985               radius = 'radius_core', 
    9086               volfraction = 'volf_cores', 
    91                sld_shell = 'sld_poly', 
    92                sld_solvent = 'sld_solv', 
     87               polymer_sld = 'sld_poly', 
     88               solvent_sld = 'sld_solv', 
    9389               background = 'background') 
    9490 
     
    9692tests =  [ 
    9793    [{'scale': 1.0, 'second_moment': 23.0, 'adsorbed_amount': 1.9,  
    98      'density_shell': 0.7, 'radius': 500.0, 'volfraction': 0.14,  
    99      'sld_shell': 1.5, 'sld_solvent': 6.3, 'background': 0.0}, 
     94     'density_poly': 0.7, 'radius': 500.0, 'volfraction': 0.14,  
     95     'polymer_sld': 1.5e-06, 'solvent_sld': 6.3e-06, 'background': 0.0}, 
    10096     [0.0106939, 0.469418], [73.741, 9.65391e-53]], 
    10197    ] 
    102 # ADDED by: SMK  ON: 16Mar2016  convert from sasview, check vs SANDRA, 18Mar2016 RKH some edits & renaming 
Note: See TracChangeset for help on using the changeset viewer.