Changes in / [b763f9d:33d7be3] in sasmodels
- Location:
- sasmodels/models
- Files:
-
- 3 deleted
- 53 edited
Legend:
- Unmodified
- Added
- Removed
-
sasmodels/models/barbell.c
rd277229 r71b751d 62 62 } 63 63 64 static double65 radius_from_volume(double radius_bell, double radius, double length)66 {67 const double vol_barbell = form_volume(radius_bell,radius,length);68 return cbrt(0.75*vol_barbell/M_PI);69 }70 71 static double72 radius_from_totallength(double radius_bell, double radius, double length)73 {74 const double hdist = sqrt(square(radius_bell) - square(radius));75 return 0.5*length + hdist + radius_bell;76 }77 78 static double79 effective_radius(int mode, double radius_bell, double radius, double length)80 {81 if (mode == 1) {82 return radius_from_volume(radius_bell, radius , length);83 } else if (mode == 2) {84 return radius;85 } else if (mode == 3) {86 return 0.5*length;87 } else {88 return radius_from_totallength(radius_bell,radius,length);89 }90 }91 92 64 static void 93 65 Fq(double q,double *F1, double *F2, double sld, double solvent_sld, -
sasmodels/models/barbell.py
rd277229 r71b751d 117 117 source = ["lib/polevl.c", "lib/sas_J1.c", "lib/gauss76.c", "barbell.c"] 118 118 have_Fq = True 119 effective_radius_type = ["equivalent sphere","radius","half length","half total length"]120 119 121 120 def random(): -
sasmodels/models/capped_cylinder.c
rd277229 r71b751d 84 84 } 85 85 86 static double87 radius_from_volume(double radius, double radius_cap, double length)88 {89 const double vol_cappedcyl = form_volume(radius,radius_cap,length);90 return cbrt(0.75*vol_cappedcyl/M_PI);91 }92 93 static double94 radius_from_totallength(double radius, double radius_cap, double length)95 {96 const double hc = radius_cap - sqrt(radius_cap*radius_cap - radius*radius);97 return 0.5*length + hc;98 }99 100 static double101 effective_radius(int mode, double radius, double radius_cap, double length)102 {103 if (mode == 1) {104 return radius_from_volume(radius, radius_cap, length);105 } else if (mode == 2) {106 return radius;107 } else if (mode == 3) {108 return 0.5*length;109 } else {110 return radius_from_totallength(radius, radius_cap,length);111 }112 }113 114 86 static void 115 87 Fq(double q,double *F1, double *F2, double sld, double solvent_sld, -
sasmodels/models/capped_cylinder.py
rd277229 r71b751d 137 137 source = ["lib/polevl.c", "lib/sas_J1.c", "lib/gauss76.c", "capped_cylinder.c"] 138 138 have_Fq = True 139 effective_radius_type = ["equivalent sphere","radius","half length","half total length"]140 139 141 140 def random(): -
sasmodels/models/core_multi_shell.c
rd277229 r71b751d 19 19 } 20 20 21 static double22 outer_radius(double core_radius, double fp_n, double thickness[])23 {24 double r = core_radius;25 int n = (int)(fp_n+0.5);26 for (int i=0; i < n; i++) {27 r += thickness[i];28 }29 return r;30 }31 32 static double33 effective_radius(int mode, double core_radius, double fp_n, double thickness[])34 {35 if (mode == 1) {36 double r = core_radius;37 int n = (int)(fp_n+0.5);38 for (int i=0; i < n; i++) {39 r += thickness[i];40 }41 return r;42 //return outer_radius(core_radius,fp_n,thickness);43 } else {44 return core_radius;45 }46 }47 48 21 static void 49 22 Fq(double q, double *F1, double *F2, double core_sld, double core_radius, -
sasmodels/models/core_multi_shell.py
rd277229 r71b751d 100 100 source = ["lib/sas_3j1x_x.c", "core_multi_shell.c"] 101 101 have_Fq = True 102 effective_radius_type = ["outer radius", "core radius"]103 102 104 103 def random(): … … 145 144 return np.asarray(z), np.asarray(rho) 146 145 147 #def ER(radius, n, thickness):148 #"""Effective radius"""149 #n = int(n[0]+0.5) # n is a control parameter and is not polydisperse150 #return np.sum(thickness[:n], axis=0) + radius146 def ER(radius, n, thickness): 147 """Effective radius""" 148 n = int(n[0]+0.5) # n is a control parameter and is not polydisperse 149 return np.sum(thickness[:n], axis=0) + radius 151 150 152 151 demo = dict(sld_core=6.4, -
sasmodels/models/core_shell_bicelle.c
rd277229 r71b751d 34 34 35 35 return t; 36 }37 38 static double39 radius_from_volume(double radius, double thick_rim, double thick_face, double length)40 {41 const double volume_bicelle = form_volume(radius,thick_rim,thick_face,length);42 return cbrt(0.75*volume_bicelle/M_PI);43 }44 45 static double46 radius_from_diagonal(double radius, double thick_rim, double thick_face, double length)47 {48 const double radius_tot = radius + thick_rim;49 const double length_tot = length + 2.0*thick_face;50 return sqrt(radius_tot*radius_tot + 0.25*length_tot*length_tot);51 }52 53 static double54 effective_radius(int mode, double radius, double thick_rim, double thick_face, double length)55 {56 if (mode == 1) {57 return radius_from_volume(radius, thick_rim, thick_face, length);58 } else if (mode == 2) {59 return radius + thick_rim;60 } else if (mode == 3) {61 return 0.5*length + thick_face;62 } else {63 return radius_from_diagonal(radius,thick_rim,thick_face,length);64 }65 36 } 66 37 -
sasmodels/models/core_shell_bicelle.py
rd277229 r71b751d 155 155 "core_shell_bicelle.c"] 156 156 have_Fq = True 157 effective_radius_type = ["equivalent sphere","outer rim radius", "half outer thickness","half diagonal"]158 157 159 158 def random(): -
sasmodels/models/core_shell_bicelle_elliptical.c
rd277229 r71b751d 8 8 { 9 9 return M_PI*(r_minor+thick_rim)*(r_minor*x_core+thick_rim)*(length+2.0*thick_face); 10 }11 12 static double13 radius_from_volume(double r_minor, double x_core, double thick_rim, double thick_face, double length)14 {15 const double volume_bicelle = form_volume(r_minor, x_core, thick_rim,thick_face,length);16 return cbrt(0.75*volume_bicelle/M_PI);17 }18 19 static double20 radius_from_diagonal(double r_minor, double x_core, double thick_rim, double thick_face, double length)21 {22 const double radius_max = (x_core < 1.0 ? r_minor : x_core*r_minor);23 const double radius_max_tot = radius_max + thick_rim;24 const double length_tot = length + 2.0*thick_face;25 return sqrt(radius_max_tot*radius_max_tot + 0.25*length_tot*length_tot);26 }27 28 static double29 effective_radius(int mode, double r_minor, double x_core, double thick_rim, double thick_face, double length)30 {31 if (mode == 1) {32 return radius_from_volume(r_minor, x_core, thick_rim, thick_face, length);33 } else if (mode == 2) {34 return 0.5*r_minor*(1.0 + x_core) + thick_rim;35 } else if (mode == 3) {36 return (x_core < 1.0 ? x_core*r_minor+thick_rim : r_minor+thick_rim);37 } else if (mode == 4) {38 return (x_core > 1.0 ? x_core*r_minor+thick_rim : r_minor+thick_rim);39 } else if (mode ==5) {40 return 0.5*length + thick_face;41 } else {42 return radius_from_diagonal(r_minor,x_core,thick_rim,thick_face,length);43 }44 10 } 45 11 -
sasmodels/models/core_shell_bicelle_elliptical.py
rd277229 r71b751d 147 147 "core_shell_bicelle_elliptical.c"] 148 148 have_Fq = True 149 effective_radius_type = ["equivalent sphere","outer rim average radius","outer rim min radius",150 "outer max radius", "half outer thickness","half diagonal"]151 149 152 150 def random(): -
sasmodels/models/core_shell_bicelle_elliptical_belt_rough.c
rd277229 r71b751d 9 9 return M_PI*( (r_minor + thick_rim)*(r_minor*x_core + thick_rim)* length + 10 10 square(r_minor)*x_core*2.0*thick_face ); 11 }12 13 static double14 radius_from_volume(double r_minor, double x_core, double thick_rim, double thick_face, double length)15 {16 const double volume_bicelle = form_volume(r_minor, x_core, thick_rim,thick_face,length);17 return cbrt(0.75*volume_bicelle/M_PI);18 }19 20 static double21 radius_from_diagonal(double r_minor, double x_core, double thick_rim, double thick_face, double length)22 {23 const double radius_max = (x_core < 1.0 ? r_minor : x_core*r_minor);24 const double radius_max_tot = radius_max + thick_rim;25 const double length_tot = length + 2.0*thick_face;26 return sqrt(radius_max_tot*radius_max_tot + 0.25*length_tot*length_tot);27 }28 29 static double30 effective_radius(int mode, double r_minor, double x_core, double thick_rim, double thick_face, double length)31 {32 if (mode == 1) {33 return radius_from_volume(r_minor, x_core, thick_rim, thick_face, length);34 } else if (mode == 2) {35 return 0.5*r_minor*(1.0 + x_core) + thick_rim;36 } else if (mode == 3) {37 return (x_core < 1.0 ? x_core*r_minor+thick_rim : r_minor+thick_rim);38 } else if (mode == 4) {39 return (x_core > 1.0 ? x_core*r_minor+thick_rim : r_minor+thick_rim);40 } else if (mode ==5) {41 return 0.5*length + thick_face;42 } else {43 return radius_from_diagonal(r_minor,x_core,thick_rim,thick_face,length);44 }45 11 } 46 12 -
sasmodels/models/core_shell_bicelle_elliptical_belt_rough.py
rd277229 r71b751d 160 160 "core_shell_bicelle_elliptical_belt_rough.c"] 161 161 have_Fq = True 162 effective_radius_type = ["equivalent sphere","outer rim average radius","outer rim min radius",163 "outer max radius", "half outer thickness","half diagonal"]164 162 165 163 demo = dict(scale=1, background=0, -
sasmodels/models/core_shell_cylinder.c
rd277229 r71b751d 11 11 { 12 12 return M_PI*square(radius+thickness)*(length+2.0*thickness); 13 }14 15 static double16 radius_from_volume(double radius, double thickness, double length)17 {18 const double volume_outer_cyl = form_volume(radius,thickness,length);19 return cbrt(0.75*volume_outer_cyl/M_PI);20 }21 22 static double23 radius_from_diagonal(double radius, double thickness, double length)24 {25 const double radius_outer = radius + thickness;26 const double length_outer = length + thickness;27 return sqrt(radius_outer*radius_outer + 0.25*length_outer*length_outer);28 }29 30 static double31 effective_radius(int mode, double radius, double thickness, double length)32 {33 if (mode == 1) {34 return radius_from_volume(radius, thickness, length);35 } else if (mode == 2) {36 return radius + thickness;37 } else if (mode == 3) {38 return 0.5*length + thickness;39 } else if (mode == 4) {40 return (radius < 0.5*length ? radius + thickness : 0.5*length + thickness);41 } else if (mode == 5) {42 return (radius > 0.5*length ? radius + thickness : 0.5*length + thickness);43 } else {44 return radius_from_diagonal(radius,thickness,length);45 }46 13 } 47 14 -
sasmodels/models/core_shell_cylinder.py
rd277229 r71b751d 126 126 source = ["lib/polevl.c", "lib/sas_J1.c", "lib/gauss76.c", "core_shell_cylinder.c"] 127 127 have_Fq = True 128 effective_radius_type = ["equivalent sphere","outer radius","half outer length","half min outer dimension",129 "half max outer dimension","half outer diagonal"]130 128 131 #def ER(radius, thickness, length):132 #"""133 #Returns the effective radius used in the S*P calculation134 #"""135 #radius = radius + thickness136 #length = length + 2 * thickness137 #ddd = 0.75 * radius * (2 * radius * length + (length + radius) * (length + pi * radius))138 #return 0.5 * (ddd) ** (1. / 3.)129 def ER(radius, thickness, length): 130 """ 131 Returns the effective radius used in the S*P calculation 132 """ 133 radius = radius + thickness 134 length = length + 2 * thickness 135 ddd = 0.75 * radius * (2 * radius * length + (length + radius) * (length + pi * radius)) 136 return 0.5 * (ddd) ** (1. / 3.) 139 137 140 138 def VR(radius, thickness, length): -
sasmodels/models/core_shell_ellipsoid.c
r3c60146 r71b751d 36 36 double vol = M_4PI_3*equat_shell*equat_shell*polar_shell; 37 37 return vol; 38 }39 40 static double41 radius_from_volume(double radius_equat_core, double x_core, double thick_shell, double x_polar_shell)42 {43 const double volume_ellipsoid = form_volume(radius_equat_core, x_core, thick_shell, x_polar_shell);44 return cbrt(0.75*volume_ellipsoid/M_PI);45 }46 47 static double48 radius_from_curvature(double radius_equat_core, double x_core, double thick_shell, double x_polar_shell)49 {50 // Trivial cases51 if (1.0 == x_core && 1.0 == x_polar_shell) return radius_equat_core + thick_shell;52 if ((radius_equat_core + thick_shell)*(radius_equat_core*x_core + thick_shell*x_polar_shell) == 0.) return 0.;53 54 // see equation (26) in A.Isihara, J.Chem.Phys. 18(1950)1446-144955 const double radius_equat_tot = radius_equat_core + thick_shell;56 const double radius_polar_tot = radius_equat_core*x_core + thick_shell*x_polar_shell;57 const double ratio = (radius_polar_tot < radius_equat_tot58 ? radius_polar_tot / radius_equat_tot59 : radius_equat_tot / radius_polar_tot);60 const double e1 = sqrt(1.0 - ratio*ratio);61 const double b1 = 1.0 + asin(e1) / (e1 * ratio);62 const double bL = (1.0 + e1) / (1.0 - e1);63 const double b2 = 1.0 + 0.5 * ratio * ratio / e1 * log(bL);64 const double delta = 0.75 * b1 * b2;65 const double ddd = 2.0 * (delta + 1.0) * radius_polar_tot * radius_equat_tot * radius_equat_tot;66 return 0.5 * cbrt(ddd);67 }68 69 static double70 effective_radius(int mode, double radius_equat_core, double x_core, double thick_shell, double x_polar_shell)71 {72 const double radius_equat_tot = radius_equat_core + thick_shell;73 const double radius_polar_tot = radius_equat_core*x_core + thick_shell*x_polar_shell;74 75 if (mode == 1) {76 return radius_from_volume(radius_equat_core, x_core, thick_shell, x_polar_shell);77 } else if (mode == 2) {78 return radius_from_curvature(radius_equat_core, x_core, thick_shell, x_polar_shell);79 } else if (mode == 3) {80 return (radius_polar_tot < radius_equat_tot ? radius_polar_tot : radius_equat_tot);81 } else {82 return (radius_polar_tot > radius_equat_tot ? radius_polar_tot : radius_equat_tot);83 }84 38 } 85 39 -
sasmodels/models/core_shell_ellipsoid.py
rd277229 r71b751d 146 146 source = ["lib/sas_3j1x_x.c", "lib/gauss76.c", "core_shell_ellipsoid.c"] 147 147 have_Fq = True 148 effective_radius_type = ["equivalent sphere","average outer curvature", "min outer radius", "max outer radius"] 149 150 #def ER(radius_equat_core, x_core, thick_shell, x_polar_shell): 151 # """ 152 # Returns the effective radius used in the S*P calculation 153 # """ 154 # from .ellipsoid import ER as ellipsoid_ER 155 # polar_outer = radius_equat_core*x_core + thick_shell*x_polar_shell 156 # equat_outer = radius_equat_core + thick_shell 157 # return ellipsoid_ER(polar_outer, equat_outer) 148 149 def ER(radius_equat_core, x_core, thick_shell, x_polar_shell): 150 """ 151 Returns the effective radius used in the S*P calculation 152 """ 153 from .ellipsoid import ER as ellipsoid_ER 154 polar_outer = radius_equat_core*x_core + thick_shell*x_polar_shell 155 equat_outer = radius_equat_core + thick_shell 156 return ellipsoid_ER(polar_outer, equat_outer) 158 157 159 158 def random(): -
sasmodels/models/core_shell_parallelepiped.c
rd277229 r71b751d 25 25 2.0 * length_a * length_b * thick_rim_c; 26 26 #endif 27 }28 29 static double30 radius_from_volume(double length_a, double length_b, double length_c,31 double thick_rim_a, double thick_rim_b, double thick_rim_c)32 {33 const double volume_paral = form_volume(length_a, length_b, length_c, thick_rim_a, thick_rim_b, thick_rim_c);34 return cbrt(0.75*volume_paral/M_PI);35 }36 37 static double38 radius_from_crosssection(double length_a, double length_b, double thick_rim_a, double thick_rim_b)39 {40 const double area_xsec_paral = length_a*length_b + 2.0*thick_rim_a*length_b + 2.0*thick_rim_b*length_a;41 return sqrt(area_xsec_paral/M_PI);42 }43 44 static double45 effective_radius(int mode, double length_a, double length_b, double length_c,46 double thick_rim_a, double thick_rim_b, double thick_rim_c)47 {48 if (mode == 1) {49 return radius_from_volume(length_a, length_b, length_c, thick_rim_a, thick_rim_b, thick_rim_c);50 } else if (mode == 2) {51 return 0.5 * (length_a + thick_rim_a);52 } else if (mode == 3) {53 return 0.5 * (length_b + thick_rim_b);54 } else if (mode == 4) {55 return 0.5 * (length_c + thick_rim_c);56 } else if (mode == 5) {57 return radius_from_crosssection(length_a, length_b, thick_rim_a, thick_rim_b);58 } else if (mode == 6) {59 return 0.5*sqrt(square(length_a+thick_rim_a) + square(length_b+thick_rim_b));60 } else {61 return 0.5*sqrt(square(length_a+thick_rim_a) + square(length_b+thick_rim_b) + square(length_c+thick_rim_c));62 }63 27 } 64 28 -
sasmodels/models/core_shell_parallelepiped.py
rd277229 r71b751d 227 227 source = ["lib/gauss76.c", "core_shell_parallelepiped.c"] 228 228 have_Fq = True 229 effective_radius_type = ["equivalent sphere","half outer length_a", "half outer length_b", "half outer length_c", 230 "equivalent circular cross-section","half outer ab diagonal","half outer diagonal"] 231 232 #def ER(length_a, length_b, length_c, thick_rim_a, thick_rim_b, thick_rim_c): 233 # """ 234 # Return equivalent radius (ER) 235 # """ 236 # from .parallelepiped import ER as ER_p 237 # 238 # a = length_a + 2*thick_rim_a 239 # b = length_b + 2*thick_rim_b 240 # c = length_c + 2*thick_rim_c 241 # return ER_p(a, b, c) 229 230 231 def ER(length_a, length_b, length_c, thick_rim_a, thick_rim_b, thick_rim_c): 232 """ 233 Return equivalent radius (ER) 234 """ 235 from .parallelepiped import ER as ER_p 236 237 a = length_a + 2*thick_rim_a 238 b = length_b + 2*thick_rim_b 239 c = length_c + 2*thick_rim_c 240 return ER_p(a, b, c) 242 241 243 242 # VR defaults to 1.0 -
sasmodels/models/core_shell_sphere.c
rd277229 r71b751d 3 3 { 4 4 return M_4PI_3 * cube(radius + thickness); 5 }6 7 static double8 effective_radius(int mode, double radius, double thickness)9 {10 if (mode == 1) {11 return radius + thickness;12 } else {13 return radius;14 }15 5 } 16 6 -
sasmodels/models/core_shell_sphere.py
rd277229 r71b751d 78 78 source = ["lib/sas_3j1x_x.c", "lib/core_shell.c", "core_shell_sphere.c"] 79 79 have_Fq = True 80 effective_radius_type = ["outer radius", "core radius"]81 80 82 81 demo = dict(scale=1, background=0, radius=60, thickness=10, 83 82 sld_core=1.0, sld_shell=2.0, sld_solvent=0.0) 84 83 85 #def ER(radius, thickness):86 #"""87 #Equivalent radius88 #@param radius: core radius89 #@param thickness: shell thickness90 #"""91 #return radius + thickness84 def ER(radius, thickness): 85 """ 86 Equivalent radius 87 @param radius: core radius 88 @param thickness: shell thickness 89 """ 90 return radius + thickness 92 91 93 92 def VR(radius, thickness): -
sasmodels/models/cylinder.c
rd277229 r71b751d 11 11 { 12 12 return sas_2J1x_x(qab*radius) * sas_sinx_x(qc*0.5*length); 13 }14 15 static double16 radius_from_volume(double radius, double length)17 {18 return cbrt(0.75*radius*radius*length);19 }20 21 static double22 radius_from_diagonal(double radius, double length)23 {24 return sqrt(radius*radius + 0.25*length*length);25 }26 27 static double28 effective_radius(int mode, double radius, double length)29 {30 if (mode == 1) {31 return radius_from_volume(radius, length);32 } else if (mode == 2) {33 return radius;34 } else if (mode == 3) {35 return 0.5*length;36 } else if (mode == 4) {37 return (radius < 0.5*length ? radius : 0.5*length);38 } else if (mode == 5) {39 return (radius > 0.5*length ? radius : 0.5*length);40 } else {41 return radius_from_diagonal(radius,length);42 }43 13 } 44 14 -
sasmodels/models/cylinder.py
rd277229 r71b751d 139 139 source = ["lib/polevl.c", "lib/sas_J1.c", "lib/gauss76.c", "cylinder.c"] 140 140 have_Fq = True 141 effective_radius_type = ["equivalent sphere","radius","half length","half min dimension","half max dimension","half diagonal"]142 141 143 #def ER(radius, length):144 #"""145 #Return equivalent radius (ER)146 #"""147 #ddd = 0.75 * radius * (2 * radius * length + (length + radius) * (length + pi * radius))148 #return 0.5 * (ddd) ** (1. / 3.)142 def ER(radius, length): 143 """ 144 Return equivalent radius (ER) 145 """ 146 ddd = 0.75 * radius * (2 * radius * length + (length + radius) * (length + pi * radius)) 147 return 0.5 * (ddd) ** (1. / 3.) 149 148 150 149 def random(): -
sasmodels/models/ellipsoid.c
rd277229 r6e7ba14 4 4 return M_4PI_3*radius_polar*radius_equatorial*radius_equatorial; 5 5 } 6 6 7 7 8 static double … … 19 20 20 21 // see equation (26) in A.Isihara, J.Chem.Phys. 18(1950)1446-1449 21 const double ratio = (radius_polar < radius_equatorial 22 const double ratio = (radius_polar < radius_equatorial 22 23 ? radius_polar / radius_equatorial 23 24 : radius_equatorial / radius_polar); … … 35 36 { 36 37 if (mode == 1) { 38 return radius_from_curvature(radius_polar, radius_equatorial); 39 } else if (mode == 2) { 37 40 return radius_from_volume(radius_polar, radius_equatorial); 38 } else if (mode == 2) {39 return radius_from_curvature(radius_polar, radius_equatorial);40 41 } else if (mode == 3) { 41 42 return (radius_polar < radius_equatorial ? radius_polar : radius_equatorial); -
sasmodels/models/ellipsoid.py
rd277229 r6e7ba14 164 164 source = ["lib/sas_3j1x_x.c", "lib/gauss76.c", "ellipsoid.c"] 165 165 have_Fq = True 166 effective_radius_type = [" equivalent sphere","average curvature", "min radius", "max radius"]166 effective_radius_type = ["average curvature", "equivalent sphere", "min radius", "max radius"] 167 167 168 168 def random(): -
sasmodels/models/elliptical_cylinder.c
rd277229 r71b751d 3 3 { 4 4 return M_PI * radius_minor * radius_minor * r_ratio * length; 5 }6 7 static double8 radius_from_volume(double radius_minor, double r_ratio, double length)9 {10 const double volume_ellcyl = form_volume(radius_minor,r_ratio,length);11 return cbrt(0.75*volume_ellcyl/M_PI);12 }13 14 static double15 radius_from_min_dimension(double radius_minor, double r_ratio, double length)16 {17 const double rad_min = (r_ratio > 1.0 ? radius_minor : r_ratio*radius_minor);18 return (rad_min < length ? rad_min : length);19 }20 21 static double22 radius_from_max_dimension(double radius_minor, double r_ratio, double length)23 {24 const double rad_max = (r_ratio < 1.0 ? radius_minor : r_ratio*radius_minor);25 return (rad_max > length ? rad_max : length);26 }27 28 static double29 radius_from_diagonal(double radius_minor, double r_ratio, double length)30 {31 const double radius_max = (r_ratio > 1.0 ? radius_minor*r_ratio : radius_minor);32 return sqrt(radius_max*radius_max + 0.25*length*length);33 }34 35 static double36 effective_radius(int mode, double radius_minor, double r_ratio, double length)37 {38 if (mode == 1) {39 return radius_from_volume(radius_minor, r_ratio, length);40 } else if (mode == 2) {41 return 0.5*radius_minor*(1.0 + r_ratio);42 } else if (mode == 3) {43 return (r_ratio > 1.0 ? radius_minor : r_ratio*radius_minor);44 } else if (mode == 4) {45 return (r_ratio < 1.0 ? radius_minor : r_ratio*radius_minor);46 } else if (mode == 5) {47 return sqrt(radius_minor*radius_minor*r_ratio);48 } else if (mode == 6) {49 return 0.5*length;50 } else if (mode == 7) {51 return radius_from_min_dimension(radius_minor,r_ratio,length);52 } else if (mode == 8) {53 return radius_from_max_dimension(radius_minor,r_ratio,length);54 } else {55 return radius_from_diagonal(radius_minor,r_ratio,length);56 }57 5 } 58 6 -
sasmodels/models/elliptical_cylinder.py
rd277229 r71b751d 123 123 source = ["lib/polevl.c", "lib/sas_J1.c", "lib/gauss76.c", "elliptical_cylinder.c"] 124 124 have_Fq = True 125 effective_radius_type = ["equivalent sphere","average radius","min radius","max radius",126 "equivalent circular cross-section","half length","half min dimension","half max dimension","half diagonal"]127 125 128 126 demo = dict(scale=1, background=0, radius_minor=100, axis_ratio=1.5, length=400.0, … … 130 128 theta_pd=10, phi_pd=2, psi_pd=3) 131 129 132 #def ER(radius_minor, axis_ratio, length):133 #"""134 #Equivalent radius135 #@param radius_minor: Ellipse minor radius136 #@param axis_ratio: Ratio of major radius over minor radius137 #@param length: Length of the cylinder138 #"""139 #radius = sqrt(radius_minor * radius_minor * axis_ratio)140 #ddd = 0.75 * radius * (2 * radius * length141 #+ (length + radius) * (length + pi * radius))142 #return 0.5 * (ddd) ** (1. / 3.)130 def ER(radius_minor, axis_ratio, length): 131 """ 132 Equivalent radius 133 @param radius_minor: Ellipse minor radius 134 @param axis_ratio: Ratio of major radius over minor radius 135 @param length: Length of the cylinder 136 """ 137 radius = sqrt(radius_minor * radius_minor * axis_ratio) 138 ddd = 0.75 * radius * (2 * radius * length 139 + (length + radius) * (length + pi * radius)) 140 return 0.5 * (ddd) ** (1. / 3.) 143 141 144 142 def random(): -
sasmodels/models/fuzzy_sphere.py
rd277229 r71b751d 78 78 ["sld_solvent", "1e-6/Ang^2", 3, [-inf, inf], "sld", "Solvent scattering length density"], 79 79 ["radius", "Ang", 60, [0, inf], "volume", "Sphere radius"], 80 ["fuzziness", "Ang", 10, [0, inf], " volume", "std deviation of Gaussian convolution for interface (must be << radius)"],80 ["fuzziness", "Ang", 10, [0, inf], "", "std deviation of Gaussian convolution for interface (must be << radius)"], 81 81 ] 82 82 # pylint: enable=bad-whitespace,line-too-long 83 83 84 source = ["lib/sas_3j1x_x.c" ,"fuzzy_sphere.c"]84 source = ["lib/sas_3j1x_x.c"] 85 85 have_Fq = True 86 effective_radius_type = ["radius","radius + fuzziness"]87 86 88 #def ER(radius): 89 # """ 90 # Return radius 91 # """ 92 # return radius 87 c_code = """ 88 static double form_volume(double radius) 89 { 90 return M_4PI_3*cube(radius); 91 } 92 93 static void Fq(double q, double *F1, double *F2, double sld, double sld_solvent, 94 double radius, double fuzziness) 95 { 96 const double qr = q*radius; 97 const double bes = sas_3j1x_x(qr); 98 const double qf = exp(-0.5*square(q*fuzziness)); 99 const double contrast = (sld - sld_solvent); 100 const double form = contrast * form_volume(radius) * bes * qf; 101 *F1 = 1.0e-2*form; 102 *F2 = 1.0e-4*form*form; 103 } 104 """ 105 106 def ER(radius): 107 """ 108 Return radius 109 """ 110 return radius 93 111 94 112 # VR defaults to 1.0 -
sasmodels/models/hollow_cylinder.c
rd277229 r71b751d 22 22 } 23 23 24 static double25 radius_from_volume(double radius, double thickness, double length)26 {27 const double volume_outer_cyl = M_PI*square(radius + thickness)*length;28 return cbrt(0.75*volume_outer_cyl/M_PI);29 }30 31 static double32 radius_from_diagonal(double radius, double thickness, double length)33 {34 return sqrt(square(radius + thickness) + 0.25*square(length));35 }36 37 static double38 effective_radius(int mode, double radius, double thickness, double length)39 {40 if (mode == 1) {41 return radius_from_volume(radius, thickness, length);42 } else if (mode == 2) {43 return radius + thickness;44 } else if (mode == 3) {45 return 0.5*length;46 } else if (mode == 4) {47 return (radius + thickness < 0.5*length ? radius + thickness : 0.5*length);48 } else if (mode == 5) {49 return (radius + thickness > 0.5*length ? radius + thickness : 0.5*length);50 } else {51 return radius_from_diagonal(radius,thickness,length);52 }53 }54 24 55 25 static void -
sasmodels/models/hollow_cylinder.py
rd277229 r71b751d 90 90 source = ["lib/polevl.c", "lib/sas_J1.c", "lib/gauss76.c", "hollow_cylinder.c"] 91 91 have_Fq = True 92 effective_radius_type = ["equivalent sphere","outer radius","half length",93 "half outer min dimension","half outer max dimension","half outer diagonal"]94 92 95 93 # pylint: disable=W0613 96 #def ER(radius, thickness, length):97 #"""98 #:param radius: Cylinder core radius99 #:param thickness: Cylinder wall thickness100 #:param length: Cylinder length101 #:return: Effective radius102 #"""103 #router = radius + thickness104 #if router == 0 or length == 0:105 #return 0.0106 #len1 = router107 #len2 = length/2.0108 #term1 = len1*len1*2.0*len2/2.0109 #term2 = 1.0 + (len2/len1)*(1.0 + 1/len2/2.0)*(1.0 + pi*len1/len2/2.0)110 #ddd = 3.0*term1*term2111 #diam = pow(ddd, (1.0/3.0))112 #return diam94 def ER(radius, thickness, length): 95 """ 96 :param radius: Cylinder core radius 97 :param thickness: Cylinder wall thickness 98 :param length: Cylinder length 99 :return: Effective radius 100 """ 101 router = radius + thickness 102 if router == 0 or length == 0: 103 return 0.0 104 len1 = router 105 len2 = length/2.0 106 term1 = len1*len1*2.0*len2/2.0 107 term2 = 1.0 + (len2/len1)*(1.0 + 1/len2/2.0)*(1.0 + pi*len1/len2/2.0) 108 ddd = 3.0*term1*term2 109 diam = pow(ddd, (1.0/3.0)) 110 return diam 113 111 114 112 def VR(radius, thickness, length): -
sasmodels/models/hollow_rectangular_prism.c
rd277229 r71b751d 11 11 double vol_shell = vol_total - vol_core; 12 12 return vol_shell; 13 }14 15 static double16 effective_radius(int mode, double length_a, double b2a_ratio, double c2a_ratio, double thickness)17 {18 if (mode == 1) {19 return cbrt(0.75*cube(length_a)*b2a_ratio*c2a_ratio/M_PI);20 } else if (mode == 2) {21 return 0.5 * length_a;22 } else if (mode == 3) {23 return 0.5 * length_a*b2a_ratio;24 } else if (mode == 4) {25 return 0.5 * length_a*c2a_ratio;26 } else if (mode == 5) {27 return length_a*sqrt(b2a_ratio/M_PI);28 } else if (mode == 6) {29 return 0.5*sqrt(square(length_a) * (1.0 + square(b2a_ratio)));30 } else {31 return 0.5*sqrt(square(length_a) * (1.0 + square(b2a_ratio) + square(c2a_ratio)));32 }33 13 } 34 14 -
sasmodels/models/hollow_rectangular_prism.py
rd277229 r71b751d 143 143 source = ["lib/gauss76.c", "hollow_rectangular_prism.c"] 144 144 have_Fq = True 145 effective_radius_type = ["equivalent sphere","half length_a", "half length_b", "half length_c", 146 "equivalent outer circular cross-section","half ab diagonal","half diagonal"] 147 148 #def ER(length_a, b2a_ratio, c2a_ratio, thickness): 149 # """ 150 # Return equivalent radius (ER) 151 # thickness parameter not used 152 # """ 153 # b_side = length_a * b2a_ratio 154 # c_side = length_a * c2a_ratio 155 # 156 # # surface average radius (rough approximation) 157 # surf_rad = sqrt(length_a * b_side / pi) 158 # 159 # ddd = 0.75 * surf_rad * (2 * surf_rad * c_side + (c_side + surf_rad) * (c_side + pi * surf_rad)) 160 # return 0.5 * (ddd) ** (1. / 3.) 145 146 def ER(length_a, b2a_ratio, c2a_ratio, thickness): 147 """ 148 Return equivalent radius (ER) 149 thickness parameter not used 150 """ 151 b_side = length_a * b2a_ratio 152 c_side = length_a * c2a_ratio 153 154 # surface average radius (rough approximation) 155 surf_rad = sqrt(length_a * b_side / pi) 156 157 ddd = 0.75 * surf_rad * (2 * surf_rad * c_side + (c_side + surf_rad) * (c_side + pi * surf_rad)) 158 return 0.5 * (ddd) ** (1. / 3.) 161 159 162 160 def VR(length_a, b2a_ratio, c2a_ratio, thickness): -
sasmodels/models/hollow_rectangular_prism_thin_walls.c
rd277229 r71b751d 6 6 double vol_shell = 2.0 * (length_a*length_b + length_a*length_c + length_b*length_c); 7 7 return vol_shell; 8 }9 10 static double11 effective_radius(int mode, double length_a, double b2a_ratio, double c2a_ratio)12 {13 if (mode == 1) {14 return cbrt(0.75*cube(length_a)*b2a_ratio*c2a_ratio/M_PI);15 } else if (mode == 2) {16 return 0.5 * length_a;17 } else if (mode == 3) {18 return 0.5 * length_a*b2a_ratio;19 } else if (mode == 4) {20 return 0.5 * length_a*c2a_ratio;21 } else if (mode == 5) {22 return length_a*sqrt(b2a_ratio/M_PI);23 } else if (mode == 6) {24 return 0.5*sqrt(square(length_a) * (1.0 + square(b2a_ratio)));25 } else {26 return 0.5*sqrt(square(length_a) * (1.0 + square(b2a_ratio) + square(c2a_ratio)));27 }28 8 } 29 9 -
sasmodels/models/hollow_rectangular_prism_thin_walls.py
rd277229 r71b751d 103 103 source = ["lib/gauss76.c", "hollow_rectangular_prism_thin_walls.c"] 104 104 have_Fq = True 105 effective_radius_type = ["equivalent sphere","half length_a", "half length_b", "half length_c",106 "equivalent outer circular cross-section","half ab diagonal","half diagonal"]107 105 108 #def ER(length_a, b2a_ratio, c2a_ratio):109 #"""110 #Return equivalent radius (ER)111 #"""112 #b_side = length_a * b2a_ratio113 #c_side = length_a * c2a_ratio114 # 115 ## surface average radius (rough approximation)116 #surf_rad = sqrt(length_a * b_side / pi)117 # 118 #ddd = 0.75 * surf_rad * (2 * surf_rad * c_side + (c_side + surf_rad) * (c_side + pi * surf_rad))119 #return 0.5 * (ddd) ** (1. / 3.)106 def ER(length_a, b2a_ratio, c2a_ratio): 107 """ 108 Return equivalent radius (ER) 109 """ 110 b_side = length_a * b2a_ratio 111 c_side = length_a * c2a_ratio 112 113 # surface average radius (rough approximation) 114 surf_rad = sqrt(length_a * b_side / pi) 115 116 ddd = 0.75 * surf_rad * (2 * surf_rad * c_side + (c_side + surf_rad) * (c_side + pi * surf_rad)) 117 return 0.5 * (ddd) ** (1. / 3.) 120 118 121 119 def VR(length_a, b2a_ratio, c2a_ratio): -
sasmodels/models/mono_gauss_coil.py
rd277229 r2d81cfe 54 54 55 55 import numpy as np 56 from numpy import inf 56 from numpy import inf, exp, errstate 57 57 58 58 name = "mono_gauss_coil" … … 69 69 parameters = [ 70 70 ["i_zero", "1/cm", 70.0, [0.0, inf], "", "Intensity at q=0"], 71 ["rg", "Ang", 75.0, [0.0, inf], " volume", "Radius of gyration"],71 ["rg", "Ang", 75.0, [0.0, inf], "", "Radius of gyration"], 72 72 ] 73 74 source = ["mono_gauss_coil.c"]75 have_Fq = False76 effective_radius_type = ["R_g","2R_g","3R_g","(5/3)^0.5*R_g"]77 78 79 73 # pylint: enable=bad-whitespace, line-too-long 80 74 81 # #NB: Scale and Background are implicit parameters on every model82 #def Iq(q, i_zero, rg):83 ## pylint: disable = missing-docstring84 #z = (q * rg)**285 # 86 #with errstate(invalid='ignore'):87 #inten = (i_zero * 2.0) * (exp(-z) + z - 1.0)/z**288 #inten[q == 0] = i_zero89 #return inten90 #Iq.vectorized = True # Iq accepts an array of q values75 # NB: Scale and Background are implicit parameters on every model 76 def Iq(q, i_zero, rg): 77 # pylint: disable = missing-docstring 78 z = (q * rg)**2 79 80 with errstate(invalid='ignore'): 81 inten = (i_zero * 2.0) * (exp(-z) + z - 1.0)/z**2 82 inten[q == 0] = i_zero 83 return inten 84 Iq.vectorized = True # Iq accepts an array of q values 91 85 92 86 def random(): -
sasmodels/models/multilayer_vesicle.c
rd277229 r71b751d 47 47 } 48 48 49 static double50 effective_radius(int mode, double radius, double thick_shell, double thick_solvent, double fp_n_shells)51 {52 return radius + fp_n_shells*thick_shell + (fp_n_shells - 1.0)*thick_solvent;53 }54 55 49 static void 56 50 Fq(double q, -
sasmodels/models/multilayer_vesicle.py
rd277229 r71b751d 146 146 source = ["lib/sas_3j1x_x.c", "multilayer_vesicle.c"] 147 147 have_Fq = True 148 effective_radius_type = ["outer radius"]149 148 150 #def ER(radius, thick_shell, thick_solvent, n_shells):151 #n_shells = int(n_shells+0.5)152 #return radius + n_shells * (thick_shell + thick_solvent) - thick_solvent149 def ER(radius, thick_shell, thick_solvent, n_shells): 150 n_shells = int(n_shells+0.5) 151 return radius + n_shells * (thick_shell + thick_solvent) - thick_solvent 153 152 154 153 def random(): -
sasmodels/models/onion.c
rd277229 r71b751d 40 40 } 41 41 42 static double43 effective_radius(int mode, double radius_core, double n_shells, double thickness[])44 {45 int n = (int)(n_shells+0.5);46 double r = radius_core;47 for (int i=0; i < n; i++) {48 r += thickness[i];49 }50 return r;51 }52 53 42 static void 54 43 Fq(double q, double *F1, double *F2, double sld_core, double radius_core, double sld_solvent, -
sasmodels/models/onion.py
rd277229 r71b751d 316 316 single = False 317 317 have_Fq = True 318 effective_radius_type = ["outer radius"]319 318 320 319 profile_axes = ['Radius (A)', 'SLD (1e-6/A^2)'] … … 367 366 return np.asarray(z), np.asarray(rho) 368 367 369 #def ER(radius_core, n_shells, thickness):370 #"""Effective radius"""371 #n = int(n_shells[0]+0.5)372 #return np.sum(thickness[:n], axis=0) + radius_core368 def ER(radius_core, n_shells, thickness): 369 """Effective radius""" 370 n = int(n_shells[0]+0.5) 371 return np.sum(thickness[:n], axis=0) + radius_core 373 372 374 373 demo = { -
sasmodels/models/parallelepiped.c
rd277229 r71b751d 3 3 { 4 4 return length_a * length_b * length_c; 5 }6 7 static double8 effective_radius(int mode, double length_a, double length_b, double length_c)9 {10 if (mode == 1) {11 return cbrt(0.75*length_a*length_b*length_c/M_PI);12 } else if (mode == 2) {13 return 0.5 * length_a;14 } else if (mode == 3) {15 return 0.5 * length_b;16 } else if (mode == 4) {17 return 0.5 * length_c;18 } else if (mode == 5) {19 return sqrt(length_a*length_b/M_PI);20 } else if (mode == 6) {21 return 0.5*sqrt(length_a*length_a + length_b*length_b);22 } else {23 return 0.5*sqrt(length_a*length_a + length_b*length_b + length_c*length_c);24 }25 5 } 26 6 -
sasmodels/models/parallelepiped.py
rd277229 r71b751d 231 231 source = ["lib/gauss76.c", "parallelepiped.c"] 232 232 have_Fq = True 233 effective_radius_type = ["equivalent sphere","half length_a", "half length_b", "half length_c", 234 "equivalent circular cross-section","half ab diagonal","half diagonal"] 235 236 #def ER(length_a, length_b, length_c): 237 # """ 238 # Return effective radius (ER) for P(q)*S(q) 239 # """ 240 # # now that axes can be in any size order, need to sort a,b,c 241 # # where a~b and c is either much smaller or much larger 242 # abc = np.vstack((length_a, length_b, length_c)) 243 # abc = np.sort(abc, axis=0) 244 # selector = (abc[1] - abc[0]) > (abc[2] - abc[1]) 245 # length = np.where(selector, abc[0], abc[2]) 246 # # surface average radius (rough approximation) 247 # radius = sqrt(np.where(~selector, abc[0]*abc[1], abc[1]*abc[2]) / pi) 248 # 249 # ddd = 0.75 * radius * (2*radius*length + (length + radius)*(length + pi*radius)) 250 # return 0.5 * (ddd) ** (1. / 3.) 233 234 def ER(length_a, length_b, length_c): 235 """ 236 Return effective radius (ER) for P(q)*S(q) 237 """ 238 # now that axes can be in any size order, need to sort a,b,c 239 # where a~b and c is either much smaller or much larger 240 abc = np.vstack((length_a, length_b, length_c)) 241 abc = np.sort(abc, axis=0) 242 selector = (abc[1] - abc[0]) > (abc[2] - abc[1]) 243 length = np.where(selector, abc[0], abc[2]) 244 # surface average radius (rough approximation) 245 radius = sqrt(np.where(~selector, abc[0]*abc[1], abc[1]*abc[2]) / pi) 246 247 ddd = 0.75 * radius * (2*radius*length + (length + radius)*(length + pi*radius)) 248 return 0.5 * (ddd) ** (1. / 3.) 251 249 252 250 # VR defaults to 1.0 -
sasmodels/models/pringle.c
rd277229 r74768cb 104 104 } 105 105 106 static double107 effective_radius(int mode, double radius, double thickness, double alpha, double beta)108 {109 if (mode == 1) {110 return cbrt(0.75*radius*radius*thickness);111 } else {112 return radius;113 }114 }115 116 106 double Iq( 117 107 double q, -
sasmodels/models/pringle.py
rd277229 ref07e95 74 74 source = ["lib/polevl.c", "lib/sas_J0.c", "lib/sas_J1.c", \ 75 75 "lib/sas_JN.c", "lib/gauss76.c", "pringle.c"] 76 effective_radius_type = ["equivalent sphere","radius"]77 76 78 #def ER(radius, thickness, alpha, beta):79 #"""80 #Return equivalent radius (ER)81 #"""82 #ddd = 0.75 * radius * (2 * radius * thickness + (thickness + radius) \83 #* (thickness + pi * radius))84 #return 0.5 * (ddd) ** (1. / 3.)77 def ER(radius, thickness, alpha, beta): 78 """ 79 Return equivalent radius (ER) 80 """ 81 ddd = 0.75 * radius * (2 * radius * thickness + (thickness + radius) \ 82 * (thickness + pi * radius)) 83 return 0.5 * (ddd) ** (1. / 3.) 85 84 86 85 def random(): -
sasmodels/models/raspberry.c
rd277229 r71b751d 1 double form_volume(double radius_lg , double radius_sm, double penetration);1 double form_volume(double radius_lg); 2 2 3 3 double Iq(double q, … … 6 6 double radius_lg, double radius_sm, double penetration); 7 7 8 double form_volume(double radius_lg , double radius_sm, double penetration)8 double form_volume(double radius_lg) 9 9 { 10 10 //Because of the complex structure, volume normalization must … … 12 12 double volume=1.0; 13 13 return volume; 14 }15 16 static double17 effective_radius(int mode, double radius_lg, double radius_sm, double penetration)18 {19 if (mode == 1) {20 return radius_lg;21 } else {22 return radius_lg + 2.0*radius_sm - penetration;23 }24 14 } 25 15 -
sasmodels/models/raspberry.py
rd277229 ref07e95 145 145 ["radius_lg", "Ang", 5000, [0, inf], "volume", 146 146 "radius of large spheres"], 147 ["radius_sm", "Ang", 100, [0, inf], " volume",147 ["radius_sm", "Ang", 100, [0, inf], "", 148 148 "radius of small spheres"], 149 ["penetration", "Ang", 0, [-1, 1], " volume",149 ["penetration", "Ang", 0, [-1, 1], "", 150 150 "fractional penetration depth of small spheres into large sphere"], 151 151 ] 152 152 153 153 source = ["lib/sas_3j1x_x.c", "raspberry.c"] 154 effective_radius_type = ["radius_large","radius_outer"]155 154 156 155 def random(): -
sasmodels/models/rectangular_prism.c
rd277229 r71b751d 3 3 { 4 4 return length_a * (length_a*b2a_ratio) * (length_a*c2a_ratio); 5 }6 7 static double8 effective_radius(int mode, double length_a, double b2a_ratio, double c2a_ratio)9 {10 if (mode == 1) {11 return cbrt(0.75*cube(length_a)*b2a_ratio*c2a_ratio/M_PI);12 } else if (mode == 2) {13 return 0.5 * length_a;14 } else if (mode == 3) {15 return 0.5 * length_a*b2a_ratio;16 } else if (mode == 4) {17 return 0.5 * length_a*c2a_ratio;18 } else if (mode == 5) {19 return length_a*sqrt(b2a_ratio/M_PI);20 } else if (mode == 6) {21 return 0.5*sqrt(square(length_a) * (1.0 + square(b2a_ratio)));22 } else {23 return 0.5*sqrt(square(length_a) * (1.0 + square(b2a_ratio) + square(c2a_ratio)));24 }25 5 } 26 6 -
sasmodels/models/rectangular_prism.py
rd277229 r71b751d 136 136 source = ["lib/gauss76.c", "rectangular_prism.c"] 137 137 have_Fq = True 138 effective_radius_type = ["equivalent sphere","half length_a", "half length_b", "half length_c",139 "equivalent circular cross-section","half ab diagonal","half diagonal"]140 138 141 #def ER(length_a, b2a_ratio, c2a_ratio):142 #"""143 #Return equivalent radius (ER)144 #"""145 #b_side = length_a * b2a_ratio146 #c_side = length_a * c2a_ratio147 # 148 ## surface average radius (rough approximation)149 #surf_rad = sqrt(length_a * b_side / pi)150 # 151 #ddd = 0.75 * surf_rad * (2 * surf_rad * c_side + (c_side + surf_rad) * (c_side + pi * surf_rad))152 #return 0.5 * (ddd) ** (1. / 3.)139 def ER(length_a, b2a_ratio, c2a_ratio): 140 """ 141 Return equivalent radius (ER) 142 """ 143 b_side = length_a * b2a_ratio 144 c_side = length_a * c2a_ratio 145 146 # surface average radius (rough approximation) 147 surf_rad = sqrt(length_a * b_side / pi) 148 149 ddd = 0.75 * surf_rad * (2 * surf_rad * c_side + (c_side + surf_rad) * (c_side + pi * surf_rad)) 150 return 0.5 * (ddd) ** (1. / 3.) 153 151 154 152 def random(): -
sasmodels/models/sphere.py
rd277229 r71b751d 67 67 ] 68 68 69 source = ["lib/sas_3j1x_x.c" ,"sphere.c"]69 source = ["lib/sas_3j1x_x.c"] 70 70 have_Fq = True 71 effective_radius_type = ["radius"]72 71 73 #def ER(radius): 74 # """ 75 # Return equivalent radius (ER) 76 # """ 77 # return radius 72 c_code = """ 73 static double form_volume(double radius) 74 { 75 return M_4PI_3*cube(radius); 76 } 77 78 static void Fq(double q, double *f1, double *f2, double sld, double sld_solvent, double radius) 79 { 80 const double bes = sas_3j1x_x(q*radius); 81 const double contrast = (sld - sld_solvent); 82 const double form = contrast * form_volume(radius) * bes; 83 *f1 = 1.0e-2*form; 84 *f2 = 1.0e-4*form*form; 85 } 86 """ 87 88 def ER(radius): 89 """ 90 Return equivalent radius (ER) 91 """ 92 return radius 78 93 79 94 # VR defaults to 1.0 -
sasmodels/models/spherical_sld.c
rd277229 r71b751d 10 10 } 11 11 return M_4PI_3*cube(r); 12 }13 14 static double15 effective_radius(int mode, double fp_n_shells, double thickness[], double interface[])16 {17 int n_shells= (int)(fp_n_shells + 0.5);18 double r = 0.0;19 for (int i=0; i < n_shells; i++) {20 r += thickness[i] + interface[i];21 }22 return r;23 12 } 24 13 -
sasmodels/models/spherical_sld.py
rd277229 r71b751d 210 210 single = False # TODO: fix low q behaviour 211 211 have_Fq = True 212 effective_radius_type = ["outer radius"]213 212 214 213 profile_axes = ['Radius (A)', 'SLD (1e-6/A^2)'] … … 256 255 257 256 258 #def ER(n_shells, thickness, interface):259 #"""Effective radius"""260 #n_shells = int(n_shells + 0.5)261 #total = (np.sum(thickness[:n_shells], axis=1)262 #+ np.sum(interface[:n_shells], axis=1))263 #return total257 def ER(n_shells, thickness, interface): 258 """Effective radius""" 259 n_shells = int(n_shells + 0.5) 260 total = (np.sum(thickness[:n_shells], axis=1) 261 + np.sum(interface[:n_shells], axis=1)) 262 return total 264 263 265 264 -
sasmodels/models/triaxial_ellipsoid.c
rd277229 r71b751d 7 7 } 8 8 9 static double10 radius_from_volume(double radius_equat_minor, double radius_equat_major, double radius_polar)11 {12 return cbrt(radius_equat_minor*radius_equat_major*radius_polar);13 }14 15 static double16 radius_from_min_dimension(double radius_equat_minor, double radius_equat_major, double radius_polar)17 {18 const double rad_equat_min = (radius_equat_minor < radius_equat_major ? radius_equat_minor : radius_equat_major);19 return (rad_equat_min < radius_polar ? rad_equat_min : radius_polar);20 }21 22 static double23 radius_from_max_dimension(double radius_equat_minor, double radius_equat_major, double radius_polar)24 {25 const double rad_equat_max = (radius_equat_minor < radius_equat_major ? radius_equat_major : radius_equat_minor);26 return (rad_equat_max > radius_polar ? rad_equat_max : radius_polar);27 }28 29 static double30 effective_radius(int mode, double radius_equat_minor, double radius_equat_major, double radius_polar)31 {32 if (mode == 1) {33 return radius_from_volume(radius_equat_minor,radius_equat_major, radius_polar);34 } else if (mode == 2) {35 return radius_from_min_dimension(radius_equat_minor,radius_equat_major, radius_polar);36 } else {37 return radius_from_max_dimension(radius_equat_minor,radius_equat_major, radius_polar);38 }39 }40 9 41 10 static void -
sasmodels/models/triaxial_ellipsoid.py
rd277229 r71b751d 158 158 source = ["lib/sas_3j1x_x.c", "lib/gauss76.c", "triaxial_ellipsoid.c"] 159 159 have_Fq = True 160 effective_radius_type = ["equivalent sphere","min radius", "max radius"]161 160 162 161 def ER(radius_equat_minor, radius_equat_major, radius_polar): -
sasmodels/models/vesicle.c
rd277229 r71b751d 6 6 } 7 7 8 static double9 effective_radius(int mode, double radius, double thickness)10 {11 return radius + thickness;12 }13 8 14 9 static void -
sasmodels/models/vesicle.py
rd277229 r71b751d 95 95 source = ["lib/sas_3j1x_x.c", "vesicle.c"] 96 96 have_Fq = True 97 effective_radius_type = ["outer radius"]98 97 99 #def ER(radius, thickness):100 #'''101 #returns the effective radius used in the S*P calculation102 # 103 #:param radius: core radius104 #:param thickness: shell thickness105 #'''106 #return radius + thickness98 def ER(radius, thickness): 99 ''' 100 returns the effective radius used in the S*P calculation 101 102 :param radius: core radius 103 :param thickness: shell thickness 104 ''' 105 return radius + thickness 107 106 108 107 def VR(radius, thickness):
Note: See TracChangeset
for help on using the changeset viewer.