source: sasmodels/sasmodels/models/lib/wrc_cyl.c @ f94d8a2

core_shell_microgelscostrafo411magnetic_modelrelease_v0.94release_v0.95ticket-1257-vesicle-productticket_1156ticket_1265_superballticket_822_more_unit_tests
Last change on this file since f94d8a2 was f94d8a2, checked in by piotr, 8 years ago

Converted FlexibleCylinderModel?

  • Property mode set to 100644
File size: 11.0 KB
Line 
1/*
2    Functions for WRC implementation of flexible cylinders
3*/
4static double
5AlphaSquare(double x)
6{
7    return pow( (1.0 + (x/3.12)*(x/3.12) +
8         (x/8.67)*(x/8.67)*(x/8.67)),(0.176/3.0) );
9}
10
11//
12static double
13Rgsquarezero(double q, double L, double b)
14{
15    return (L*b/6.0) * (1.0 - 1.5*(b/L) + 1.5*pow((b/L),2) -
16         0.75*pow((b/L),3)*(1.0 - exp(-2.0*(L/b))));
17}
18
19//
20static double
21Rgsquareshort(double q, double L, double b)
22{
23    return AlphaSquare(L/b) * Rgsquarezero(q,L,b);
24}
25
26//
27static double
28Rgsquare(double q, double L, double b)
29{
30    return AlphaSquare(L/b)*L*b/6.0;
31}
32
33static double
34sech_WR(double x)
35{
36    return(1/cosh(x));
37}
38
39static double
40a1long(double q, double L, double b, double p1, double p2, double q0)
41{
42    double yy,C,C1,C2,C3,C4,C5,miu,Rg2;
43    double t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,t11,t12,t13,t14,t15;
44    double E,pi;
45    double b2,b3,b4,q02,q03,q04,q05,Rg22;
46
47    pi = 4.0*atan(1.0);
48    E = 2.718281828459045091;
49
50    if( L/b > 10.0) {
51        C = 3.06/pow((L/b),0.44);
52    } else {
53        C = 1.0;
54    }
55
56    C1 = 1.22;
57    C2 = 0.4288;
58    C3 = -1.651;
59    C4 = 1.523;
60    C5 = 0.1477;
61    miu = 0.585;
62
63    Rg2 = Rgsquare(q,L,b);
64    Rg22 = Rg2*Rg2;
65    b2 = b*b;
66    b3 = b*b*b;
67    b4 = b3*b;
68    q02 = q0*q0;
69    q03 = q0*q0*q0;
70    q04 = q03*q0;
71    q05 = q04*q0;
72
73    t1 = (b*C*((4.0/15.0 - pow(E,(-((q02*Rg2)/b2)))*((11.0/15.0 +
74        (7.0*b2)/(15.0*q02*Rg2))) + (7.0*b2)/(15.0*q02*Rg2))));
75
76    t2 = (2.0*b4*(((-1.0) + pow(E,(-((q02*Rg2)/b2))) +
77        (q02*Rg2)/b2))*((1.0 + 1.0/2.0*(((-1.0) -
78        tanh(((-C4) + (sqrt(Rg2)*q0)/b)/C5))))));
79
80    t3 = ((C3*pow((((sqrt(Rg2)*q0)/b)),((-3.0)/miu)) +
81        C2*pow((((sqrt(Rg2)*q0)/b)),((-2.0)/miu)) +
82        C1*pow((((sqrt(Rg2)*q0)/b)),((-1.0)/miu))));
83
84    t4 = ((1.0 + tanh(((-C4) + (sqrt(Rg2)*q0)/b)/C5)));
85
86    t5 = (1.0/(b*p1*pow(q0,((-1.0) - p1 - p2)) -
87        b*p2*pow(q0,((-1.0) - p1 - p2))));
88
89    t6 = (b*C*(((-((14.0*b3)/(15.0*q03*Rg2))) +
90        (14.0*b3*pow(E,(-((q02*Rg2)/b2))))/(15.0*q03*Rg2) +
91        (2.0*pow(E,(-((q02*Rg2)/b2)))*q0*((11.0/15.0 +
92        (7.0*b2)/(15.0*q02*Rg2)))*Rg2)/b)));
93
94    t7 = (sqrt(Rg2)*((C3*pow((((sqrt(Rg2)*q0)/b)),((-3.0)/miu)) +
95        C2*pow((((sqrt(Rg2)*q0)/b)),((-2.0)/miu)) +
96        C1*pow((((sqrt(Rg2)*q0)/b)),((-1.0)/miu))))*pow(sech_WR(((-C4) +
97        (sqrt(Rg2)*q0)/b)/C5),2));
98
99    t8 = (b4*sqrt(Rg2)*(((-1.0) + pow(E,(-((q02*Rg2)/b2))) +
100        (q02*Rg2)/b2))*pow(sech_WR(((-C4) + (sqrt(Rg2)*q0)/b)/C5),2));
101
102    t9 = (2.0*b4*(((2.0*q0*Rg2)/b -
103        (2.0*pow(E,(-((q02*Rg2)/b2)))*q0*Rg2)/b))*((1.0 + 1.0/2.0*(((-1.0) -
104        tanh(((-C4) + (sqrt(Rg2)*q0)/b)/C5))))));
105
106    t10 = (8.0*b4*b*(((-1.0) + pow(E,(-((q02*Rg2)/b2))) +
107        (q02*Rg2)/b2))*((1.0 + 1.0/2.0*(((-1.0) - tanh(((-C4) +
108        (sqrt(Rg2)*q0)/b)/C5))))));
109
110    t11 = (((-((3.0*C3*sqrt(Rg2)*pow((((sqrt(Rg2)*q0)/b)),((-1.0) -
111        3.0/miu)))/miu)) - (2.0*C2*sqrt(Rg2)*pow((((sqrt(Rg2)*q0)/b)),((-1.0) -
112        2.0/miu)))/miu - (C1*sqrt(Rg2)*pow((((sqrt(Rg2)*q0)/b)),((-1.0) -
113        1.0/miu)))/miu));
114
115    t12 = ((1.0 + tanh(((-C4) + (sqrt(Rg2)*q0)/b)/C5)));
116
117    t13 = (b*C*((4.0/15.0 - pow(E,(-((q02*Rg2)/b2)))*((11.0/15.0 +
118        (7.0*b2)/(15.0*q02* Rg2))) +
119        (7.0*b2)/(15.0*q02*Rg2))));
120
121    t14 = (2.0*b4*(((-1.0) + pow(E,(-((q02*Rg2)/b2))) +
122        (q02*Rg2)/b2))*((1.0 + 1.0/2.0*(((-1.0) - tanh(((-C4) +
123        (sqrt(Rg2)*q0)/b)/C5))))));
124
125    t15 = ((C3*pow((((sqrt(Rg2)*q0)/b)),((-3.0)/miu)) +
126        C2*pow((((sqrt(Rg2)*q0)/b)),((-2.0)/miu)) +
127        C1*pow((((sqrt(Rg2)*q0)/b)),((-1.0)/miu))));
128
129
130    yy = (pow(q0,p1)*(((-((b*pi)/(L*q0))) +t1/L +t2/(q04*Rg22) +
131        1.0/2.0*t3*t4)) + (t5*((pow(q0,(p1 - p2))*
132        (((-pow(q0,(-p1)))*(((b2*pi)/(L*q02) +t6/L +t7/(2.0*C5) -
133        t8/(C5*q04*Rg22) + t9/(q04*Rg22) -t10/(q05*Rg22) + 1.0/2.0*t11*t12)) -
134        b*p1*pow(q0,((-1.0) - p1))*(((-((b*pi)/(L*q0))) + t13/L +
135        t14/(q04*Rg22) + 1.0/2.0*t15*((1.0 + tanh(((-C4) +
136        (sqrt(Rg2)*q0)/b)/C5)))))))))));
137
138    return (yy);
139}
140
141static double
142a2long(double q, double L, double b, double p1, double p2, double q0)
143{
144    double yy,C1,C2,C3,C4,C5,miu,C,Rg2;
145    double t1,t2,t3,t4,t5,t6,t7,t8,t9,t10,pi;
146    double E,b2,b3,b4,q02,q03,q04,q05,Rg22;
147
148    pi = 4.0*atan(1.0);
149    E = 2.718281828459045091;
150    if( L/b > 10.0) {
151        C = 3.06/pow((L/b),0.44);
152    } else {
153        C = 1.0;
154    }
155
156    C1 = 1.22;
157    C2 = 0.4288;
158    C3 = -1.651;
159    C4 = 1.523;
160    C5 = 0.1477;
161    miu = 0.585;
162
163    Rg2 = Rgsquare(q,L,b);
164    Rg22 = Rg2*Rg2;
165    b2 = b*b;
166    b3 = b*b*b;
167    b4 = b3*b;
168    q02 = q0*q0;
169    q03 = q0*q0*q0;
170    q04 = q03*q0;
171    q05 = q04*q0;
172
173    t1 = (1.0/(b* p1*pow(q0,((-1.0) - p1 - p2)) -
174        b*p2*pow(q0,((-1.0) - p1 - p2)) ));
175
176    t2 = (b*C*(((-1.0*((14.0*b3)/(15.0*q03*Rg2))) +
177        (14.0*b3*pow(E,(-((q02*Rg2)/b2))))/(15.0*q03*Rg2) +
178        (2.0*pow(E,(-((q02*Rg2)/b2)))*q0*((11.0/15.0 +
179        (7*b2)/(15.0*q02*Rg2)))*Rg2)/b)))/L;
180
181    t3 = (sqrt(Rg2)*((C3*pow((((sqrt(Rg2)*q0)/b)),((-3.0)/miu)) +
182        C2*pow((((sqrt(Rg2)*q0)/b)),((-2.0)/miu)) +
183        C1*pow((((sqrt(Rg2)*q0)/b)),((-1.0)/miu))))*
184        pow(sech_WR(((-C4) +(sqrt(Rg2)*q0)/b)/C5),2.0))/(2.0*C5);
185
186    t4 = (b4*sqrt(Rg2)*(((-1.0) + pow(E,(-((q02*Rg2)/b2))) +
187        (q02*Rg2)/b2))*pow(sech_WR(((-C4) +
188        (sqrt(Rg2)*q0)/b)/C5),2))/(C5*q04*Rg22);
189
190    t5 = (2.0*b4*(((2.0*q0*Rg2)/b -
191        (2.0*pow(E,(-((q02*Rg2)/b2)))*q0*Rg2)/b))*
192        ((1.0 + 1.0/2.0*(((-1.0) - tanh(((-C4) +
193        (sqrt(Rg2)*q0)/b)/C5))))))/(q04*Rg22);
194
195    t6 = (8.0*b4*b*(((-1.0) + pow(E,(-((q02*Rg2)/b2))) +
196        (q02*Rg2)/b2))*((1.0 + 1.0/2.0*(((-1) - tanh(((-C4) +
197        (sqrt(Rg2)*q0)/b)/C5))))))/(q05*Rg22);
198
199    t7 = (((-((3.0*C3*sqrt(Rg2)*pow((((sqrt(Rg2)*q0)/b)),((-1.0) -
200        3.0/miu)))/miu)) - (2.0*C2*sqrt(Rg2)*pow((((sqrt(Rg2)*q0)/b)),
201        ((-1.0) - 2.0/miu)))/miu - (C1*sqrt(Rg2)*pow((((sqrt(Rg2)*q0)/b)),
202        ((-1.0) - 1.0/miu)))/miu));
203
204    t8 = ((1.0 + tanh(((-C4) + (sqrt(Rg2)*q0)/b)/C5)));
205
206    t9 = (b*C*((4.0/15.0 - pow(E,(-((q02*Rg2)/b2)))*((11.0/15.0 +
207        (7.0    *b2)/(15*q02*Rg2))) + (7.0*b2)/(15.0*q02*Rg2))))/L;
208
209    t10 = (2.0*b4*(((-1) + pow(E,(-((q02*Rg2)/b2))) +
210        (q02*Rg2)/b2))*((1.0 + 1.0/2.0*(((-1) - tanh(((-C4) +
211        (sqrt(Rg2)*q0)/b)/C5))))))/(q04*Rg22);
212
213    yy = ((-1.0*(t1* ((-pow(q0,-p1)*(((b2*pi)/(L*q02) +
214        t2 + t3 - t4 + t5 - t6 + 1.0/2.0*t7*t8)) - b*p1*pow(q0,((-1.0) - p1))*
215        (((-((b*pi)/(L*q0))) + t9 + t10 +
216        1.0/2.0*((C3*pow((((sqrt(Rg2)*q0)/b)),((-3.0)/miu)) +
217        C2*pow((((sqrt(Rg2)*q0)/b)),((-2.0)/miu)) +
218        C1*pow((((sqrt(Rg2)*q0)/b)),((-1.0)/miu))))*
219        ((1.0 + tanh(((-C4) + (sqrt(Rg2)*q0)/b)/C5))))))))));
220
221    return (yy);
222}
223
224//
225static double
226a1short(double q, double L, double b, double p1short, double p2short, double q0)
227{
228    double yy,Rg2_sh;
229    double t1,E,Rg2_sh2,Et1,Emt1,q02,q0p,b3;
230    double pi;
231
232    E = 2.718281828459045091;
233    pi = 4.0*atan(1.0);
234    Rg2_sh = Rgsquareshort(q,L,b);
235    Rg2_sh2 = Rg2_sh*Rg2_sh;
236    b3 = b*b*b;
237    t1 = ((q0*q0*Rg2_sh)/(b*b));
238    Et1 = pow(E,t1);
239    Emt1 =pow(E,-t1);
240    q02 = q0*q0;
241    q0p = pow(q0,(-4.0 + p1short) );
242
243    yy = ((1.0/(L*((p1short - p2short))*Rg2_sh2)*
244        ((b*Emt1*q0p*((8.0*b3*L - 8.0*b3*Et1*L - 2.0*b3*L*p2short +
245        2.0*b3*Et1*L*p2short + 4.0*b*L*q02*Rg2_sh + 4.0*b*Et1*L*q02*Rg2_sh -
246        2.0*b*Et1*L*p2short*q02*Rg2_sh - Et1*pi*q02*q0*Rg2_sh2 +
247        Et1*p2short*pi*q02*q0*Rg2_sh2))))));
248
249    return(yy);
250}
251
252static double
253a2short(double q, double L, double b, double p1short, double p2short, double q0)
254{
255    double yy,Rg2_sh;
256    double t1,E,Rg2_sh2,Et1,Emt1,q02,q0p;
257    double pi;
258
259    E = 2.718281828459045091;
260    pi = 4.0*atan(1.0);
261    Rg2_sh = Rgsquareshort(q,L,b);
262    Rg2_sh2 = Rg2_sh*Rg2_sh;
263    t1 = ((q0*q0*Rg2_sh)/(b*b));
264    Et1 = pow(E,t1);
265    Emt1 =pow(E,-t1);
266    q02 = q0*q0;
267    q0p = pow(q0,(-4.0 + p2short) );
268
269    //E is the number e
270    yy = ((-(1.0/(L*((p1short - p2short))*Rg2_sh2)*
271        ((b*Emt1*q0p*((8.0*b*b*b*L - 8.0*b*b*b*Et1*L - 2.0*b*b*b*L*p1short +
272        2.0*b*b*b*Et1*L*p1short + 4.0*b*L*q02*Rg2_sh + 4.0*b*Et1*L*q02*Rg2_sh -
273        2.0*b*Et1*L*p1short*q02*Rg2_sh - Et1*pi*q02*q0*Rg2_sh2 +
274        Et1*p1short*pi*q02*q0*Rg2_sh2)))))));
275
276    return (yy);
277}
278
279//WR named this w (too generic)
280static double
281w_WR(double x)
282{
283    return 0.5*(1 + tanh((x - 1.523)/0.1477));
284}
285
286//
287static double
288u1(double q, double L, double b)
289{
290    return Rgsquareshort(q,L,b)*q*q;
291}
292
293static double
294u_WR(double q, double L, double b)
295{
296    return Rgsquare(q,L,b)*q*q;
297}
298
299
300static double
301Sdebye(double q, double L, double b)
302{
303    return 2.0*(exp(-u_WR(q,L,b)) + u_WR(q,L,b) -1.0)/(pow((u_WR(q,L,b)),2));
304}
305
306//
307static double
308Sdebye1(double q, double L, double b)
309{
310    return 2.0*(exp(-u1(q,L,b)) + u1(q,L,b) -1.0)/( pow((u1(q,L,b)),2.0) );
311}
312
313//
314static double
315Sexv(double q, double L, double b)
316{
317    double yy,C1,C2,C3,miu,Rg2;
318    C1=1.22;
319    C2=0.4288;
320    C3=-1.651;
321    miu = 0.585;
322
323    Rg2 = Rgsquare(q,L,b);
324
325    yy = (1.0 - w_WR(q*sqrt(Rg2)))*Sdebye(q,L,b) +
326        w_WR(q*sqrt(Rg2))*(C1*pow((q*sqrt(Rg2)),(-1.0/miu)) +
327        C2*pow((q*sqrt(Rg2)),(-2.0/miu)) +
328        C3*pow((q*sqrt(Rg2)),(-3.0/miu)));
329
330    return (yy);
331}
332
333
334static double
335Sexvnew(double q, double L, double b)
336{
337    double yy,C1,C2,C3,miu;
338    double del=1.05,C_star2,Rg2;
339
340    C1=1.22;
341    C2=0.4288;
342    C3=-1.651;
343    miu = 0.585;
344
345    //calculating the derivative to decide on the corection (cutoff) term?
346    // I have modified this from WRs original code
347
348    if( (Sexv(q*del,L,b)-Sexv(q,L,b))/(q*del - q) >= 0.0 ) {
349        C_star2 = 0.0;
350    } else {
351        C_star2 = 1.0;
352    }
353
354    Rg2 = Rgsquare(q,L,b);
355
356    yy = (1.0 - w_WR(q*sqrt(Rg2)))*Sdebye(q,L,b) +
357        C_star2*w_WR(q*sqrt(Rg2))*(C1*pow((q*sqrt(Rg2)),(-1.0/miu)) +
358        C2*pow((q*sqrt(Rg2)),(-2.0/miu)) + C3*pow((q*sqrt(Rg2)),(-3.0/miu)));
359
360    return (yy);
361}
362
363double Sk_WR(double q, double L, double b)
364{
365  //
366  double p1,p2,p1short,p2short,q0;
367  double C,ans,q0short,Sexvmodify,pi;
368
369  pi = 4.0*atan(1.0);
370
371  p1 = 4.12;
372  p2 = 4.42;
373  p1short = 5.36;
374  p2short = 5.62;
375  q0 = 3.1;
376
377  q0short = fmax(1.9/sqrt(Rgsquareshort(q,L,b)),3.0);
378
379
380  if(L/b > 10.0) {
381    C = 3.06/pow((L/b),0.44);
382  } else {
383    C = 1.0;
384  }
385  //
386
387  //
388  if( L > 4*b ) { // Longer Chains
389    if (q*b <= 3.1) {   //Modified by Yun on Oct. 15,
390
391      Sexvmodify = Sexvnew(q, L, b);
392
393      ans = Sexvmodify + C * (4.0/15.0 + 7.0/(15.0*u_WR(q,L,b)) -
394            (11.0/15.0 + 7.0/(15.0*u_WR(q,L,b)))*exp(-u_WR(q,L,b)))*(b/L);
395
396    } else { //q(i)*b > 3.1
397      ans = a1long(q, L, b, p1, p2, q0)/(pow((q*b),p1)) +
398            a2long(q, L, b, p1, p2, q0)/(pow((q*b),p2)) + pi/(q*L);
399    }
400  } else { //L <= 4*b Shorter Chains
401    if (q*b <= fmax(1.9/sqrt(Rgsquareshort(q,L,b)),3.0) ) {
402      if (q*b<=0.01) {
403        ans = 1.0 - Rgsquareshort(q,L,b)*(q*q)/3.0;
404      } else {
405        ans = Sdebye1(q,L,b);
406      }
407    } else {  //q*b > max(1.9/sqrt(Rgsquareshort(q(i),L,b)),3)
408      ans = a1short(q,L,b,p1short,p2short,q0short)/(pow((q*b),p1short)) +
409            a2short(q,L,b,p1short,p2short,q0short)/(pow((q*b),p2short)) +
410            pi/(q*L);
411    }
412  }
413
414  return(ans);
415}
Note: See TracBrowser for help on using the repository browser.