pk-specf.tex 41 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601
  1. \section{Special Functions}
  2. \begin{Introduction}{Special Function Package}
  3. The REDUCE \name{Special Function Package} supplies extended
  4. algebraic and numeric support for a wide class of objects.
  5. This package was released together with REDUCE 3.5 (October 1993)
  6. for the first time, a major update is released with REDUCE 3.6.\\
  7. \\
  8. The functions included in this package are in most cases (unless otherwise
  9. stated) defined and named like in the book by Abramowitz and Stegun:
  10. Handbook of Mathematical Functions, Dover Publications.\\
  11. \\
  12. The aim is to collect as much information on the special functions
  13. and simplification capabilities as possible,
  14. i.e. algebraic simplifications and numeric (rounded mode) code, limits
  15. of the functions together
  16. with the definitions of the functions, which are in most cases a power
  17. series, a (definite) integral and/or a differential equation.\\
  18. \\
  19. \em{What can be found:} Some famous constants, a variety of Bessel functions,
  20. special polynomials,
  21. the Gamma function, the (Riemann) Zeta function, Elliptic Functions, Elliptic
  22. Integrals, 3J symbols (Clebsch-Gordan coefficients) and integral functions.\\
  23. \\
  24. \em{What is missing:} Mathieu functions, LerchPhi, etc..
  25. The information about the special functions which solve certain
  26. differential equation is very limited.
  27. In several cases numerical approximation is restricted to real
  28. arguments or is missing completely.\\
  29. \\
  30. The implementation of this package uses REDUCE rule sets to a large extent,
  31. which guarantees a high 'readability' of the functions definitions in the
  32. source file directory. It makes extensions to the special
  33. functions code easy in most cases too. To look at these rules
  34. it may be convenient to use the showrules operator e.g.\\
  35. \\
  36. \nameref{showrules} Besseli;\\
  37. .\\
  38. Some evaluations are improved if the special function package is loaded,
  39. e.g. some (infinite) sums and products leading to expressions including
  40. special functions are known in this case.\\
  41. \\
  42. Note: The special function package has to be loaded explicitly by calling
  43. \begin{verbatim}
  44. load_package specfn;
  45. \end{verbatim}
  46. The functions \nameref{MeijerG} and \nameref{hypergeometric} require
  47. additionally
  48. \begin{verbatim}
  49. load_package specfn2;
  50. \end{verbatim}
  51. \end{Introduction}
  52. \begin{Concept}{Constants}
  53. \index{Euler's constant}\index{Catalan's constant}\index{Khinchin's constant}
  54. \index{Golden_Ratio}
  55. There are a few constants known to the special function package, namely\\
  56. \\
  57. \name{Euler's constant} (which can be computed as -\nameref{Psi}(1)) and \\
  58. \name{Khinchin's constant} (which is defined in Khinchin's book \\
  59. ``Continued Fractions'') and \\
  60. \name{Golden_Ratio} (which can be computed as (1 + sqrt 5)/2) and \\
  61. \name{Catalan's constant} (which is known as an infinite sum of reciprocal
  62. powers)
  63. \begin{Examples}
  64. on rounded;
  65. Euler_Gamma; & 0.577215664902 \\
  66. Khinchin; & 2.68545200107 \\
  67. Catalan & 0.915965594177 \\
  68. Golden_Ratio & 1.61803398875
  69. \end{Examples}
  70. \end{Concept}
  71. \subsection{Bernoulli Euler Zeta}
  72. \begin{Operator}{BERNOULLI}
  73. The \name{bernoulli} operator returns the nth Bernoulli number.
  74. \begin{Syntax}
  75. \name{Bernoulli}\(\meta{integer}\)
  76. \end{Syntax}
  77. \begin{Examples}
  78. bernoulli 20; & - 174611 / 330 \\
  79. bernoulli 17; & 0
  80. \end{Examples}
  81. \begin{Comments}
  82. All Bernoulli numbers with odd indices except for 1 are zero.
  83. \end{Comments}
  84. \end{Operator}
  85. \begin{Operator}{BERNOULLIP}
  86. The \name{BernoulliP} operator returns the nth Bernoulli Polynomial
  87. evaluated at x.
  88. \begin{Syntax}
  89. \name{BernoulliP}\(\meta{integer},\meta{expression}\)
  90. \end{Syntax}
  91. \begin{Examples}
  92. BernoulliP(3,z); & z*(2*z^2 - 3*z + 1)/2\\
  93. BernoulliP(10,3); & 338585 / 66
  94. \end{Examples}
  95. \begin{Comments}
  96. The value of the nth Bernoulli Polynomial at 0 is the nth Bernoulli number.
  97. \end{Comments}
  98. \end{Operator}
  99. \begin{Operator}{EULER}
  100. The \name{EULER} operator returns the nth Euler number.
  101. \begin{Syntax}
  102. \name{Euler}\(\meta{integer}\)
  103. \end{Syntax}
  104. \begin{Examples}
  105. Euler 20; & 370371188237525 \\
  106. Euler 0; & 1
  107. \end{Examples}
  108. \begin{Comments}
  109. The \name{Euler} numbers are evaluated by a recursive algorithm which
  110. makes it hard to compute Euler numbers above say 200.
  111. Euler numbers appear in the coefficients of the power series
  112. representation of 1/cos(z).
  113. \end{Comments}
  114. \end{Operator}
  115. \begin{Operator}{EULERP}
  116. The \name{EulerP} operator returns the nth Euler Polynomial.
  117. \begin{Syntax}
  118. \name{EulerP}\(\meta{integer},\meta{expression}\)
  119. \end{Syntax}
  120. \begin{Examples}
  121. EulerP(2,xx); & xx*(xx - 1) \\
  122. EulerP(10,3); & 2046
  123. \end{Examples}
  124. \begin{Comments}
  125. The Euler numbers are the values of the Euler Polynomials at 1/2
  126. multiplied by 2**n.
  127. \end{Comments}
  128. \end{Operator}
  129. \begin{Operator}{ZETA}
  130. The \name{Zeta} operator returns Riemann's Zeta function,
  131. Zeta (z) := sum(1/(k**z),k,1,infinity)
  132. \begin{Syntax}
  133. \name{Zeta}\(\meta{expression}\)
  134. \end{Syntax}
  135. \begin{Examples}
  136. Zeta(2); & pi^2 / 6 \\
  137. on rounded; \\
  138. Zeta 1.01; & 100.577943338
  139. \end{Examples}
  140. \begin{Comments}
  141. Numerical computation for the Zeta function for arguments close to 1 are
  142. tedious, because the series is converging very slowly. In this case a formula
  143. (e.g. found in Bender/Orzag: Advanced Mathematical Methods for
  144. Scientists and Engineers, McGraw-Hill) is used.
  145. No numerical approximation for complex arguments is done.
  146. \end{Comments}
  147. \end{Operator}
  148. \subsection{Bessel Functions}
  149. \begin{Operator}{BESSELJ}
  150. The \name{BesselJ} operator returns the Bessel function of the first kind.
  151. \begin{Syntax}
  152. \name{BesselJ}\(\meta{order},\meta{argument}\)
  153. \end{Syntax}
  154. \begin{Examples}
  155. BesselJ(1/2,pi); & 0 \\
  156. on rounded; \\
  157. BesselJ(0,1); & 0.765197686558 \\
  158. \end{Examples}
  159. \end{Operator}
  160. \begin{Operator}{BESSELY}
  161. \index{Weber's function}
  162. The \name{BesselY} operator returns the Bessel function of the second kind.
  163. \begin{Syntax}
  164. \name{BesselY}\(\meta{order},\meta{argument}\)
  165. \end{Syntax}
  166. \begin{Examples}
  167. BesselY (1/2,pi); & - sqrt(2) / pi \\
  168. on rounded; \\
  169. BesselY (1,3); & 0.324674424792
  170. \end{Examples}
  171. \begin{Comments}
  172. The operator \name{BesselY} is also called Weber's function.
  173. \end{Comments}
  174. \end{Operator}
  175. \begin{Operator}{HANKEL1}
  176. The \name{Hankel1} operator returns the Hankel function of the first kind.
  177. \begin{Syntax}
  178. \name{Hankel1}\(\meta{order},\meta{argument}\)
  179. \end{Syntax}
  180. \begin{Examples}
  181. on complex; \\
  182. Hankel1 (1/2,pi); & - i * sqrt(2) / pi \\
  183. Hankel1 (1,pi); & besselj(1,pi) + i*bessely(1,pi)
  184. \end{Examples}
  185. \begin{Comments}
  186. The operator \name{Hankel1} is also called Bessel function of the third kind.
  187. There is currently no numeric evaluation of Hankel functions.
  188. \end{Comments}
  189. \end{Operator}
  190. \begin{Operator}{HANKEL2}
  191. The \name{Hankel2} operator returns the Hankel function of the second kind.
  192. \begin{Syntax}
  193. \name{Hankel2}\(\meta{order},\meta{argument}\)
  194. \end{Syntax}
  195. \begin{Examples}
  196. on complex; \\
  197. Hankel2 (1/2,pi); & - i * sqrt(2) / pi \\
  198. Hankel2 (1,pi); & besselj(1,pi) - i*bessely(1,pi)
  199. \end{Examples}
  200. \begin{Comments}
  201. The operator \name{Hankel2} is also called Bessel function of the third kind.
  202. There is currently no numeric evaluation of Hankel functions.
  203. \end{Comments}
  204. \end{Operator}
  205. \begin{Operator}{BESSELI}
  206. The \name{BesselI} operator returns the modified Bessel function I.
  207. \begin{Syntax}
  208. \name{BesselI}\(\meta{order},\meta{argument}\)
  209. \end{Syntax}
  210. \begin{Examples}
  211. on rounded; \\
  212. Besseli (1,1); & 0.565159103992
  213. \end{Examples}
  214. \begin{Comments}
  215. The knowledge about the operator \name{BesselI} is currently fairly limited.
  216. \end{Comments}
  217. \end{Operator}
  218. \begin{Operator}{BESSELK}
  219. The \name{BesselK} operator returns the modified Bessel function K.
  220. \begin{Syntax}
  221. \name{BesselK}\(\meta{order},\meta{argument}\)
  222. \end{Syntax}
  223. \begin{Examples}
  224. df(besselk(0,x),x); & - besselk(1,x)
  225. \end{Examples}
  226. \begin{Comments}
  227. There is currently no numeric support for the operator \name{BesselK}.
  228. \end{Comments}
  229. \end{Operator}
  230. \begin{Operator}{StruveH}
  231. The \name{StruveH} operator returns Struve's H function.
  232. \begin{Syntax}
  233. \name{StruveH}\(\meta{order},\meta{argument}\)
  234. \end{Syntax}
  235. \begin{Examples}
  236. struveh(-3/2,x); & - besselj(3/2,x) / i
  237. \end{Examples}
  238. \end{Operator}
  239. \begin{Operator}{StruveL}
  240. The \name{StruveL} operator returns the modified Struve L function .
  241. \begin{Syntax}
  242. \name{StruveL}\(\meta{order},\meta{argument}\)
  243. \end{Syntax}
  244. \begin{Examples}
  245. struvel(-3/2,x); & besseli(3/2,x)
  246. \end{Examples}
  247. \end{Operator}
  248. \begin{Operator}{KummerM}
  249. \index{Confluent Hypergeometric function}
  250. The \name{KummerM} operator returns Kummer's M function.
  251. \begin{Syntax}
  252. \name{KummerM}\(\meta{parameter},\meta{parameter},\meta{argument}\)
  253. \end{Syntax}
  254. \begin{Examples}
  255. kummerm(1,1,x); & e^x \\
  256. on rounded; \\
  257. kummerm(1,3,1.3); & 1.62046942914
  258. \end{Examples}
  259. \begin{Comments}
  260. Kummer's M function is one of the Confluent Hypergeometric functions.
  261. For reference see the \nameref{hypergeometric} operator.
  262. \end{Comments}
  263. \end{Operator}
  264. \begin{Operator}{KummerU}
  265. \index{Confluent Hypergeometric function}
  266. The \name{KummerU} operator returns Kummer's U function.
  267. \begin{Syntax}
  268. \name{KummerU}\(\meta{parameter},\meta{parameter},\meta{argument}\)
  269. \end{Syntax}
  270. \begin{Examples}
  271. df(kummeru(1,1,x),x) & - kummeru(2,2,x)
  272. \end{Examples}
  273. \begin{Comments}
  274. Kummer's U function is one of the Confluent Hypergeometric functions.
  275. For reference see the \nameref{hypergeometric} operator.
  276. \end{Comments}
  277. \end{Operator}
  278. \begin{Operator}{WhittakerW}
  279. \index{Confluent Hypergeometric function}
  280. The \name{WhittakerW} operator returns Whittaker's W function.
  281. \begin{Syntax}
  282. \name{WhittakerW}\(\meta{parameter},\meta{parameter},\meta{argument}\)
  283. \end{Syntax}
  284. \begin{Examples}
  285. WhittakerW(2,2,2); & \rfrac{4*sqrt(2)*kummeru(\rfrac{1}{2},5,2)}{e}
  286. \end{Examples}
  287. \begin{Comments}
  288. Whittaker's W function is one of the Confluent Hypergeometric functions.
  289. For reference see the \nameref{hypergeometric} operator.
  290. \end{Comments}
  291. \end{Operator}
  292. \subsection{Airy Functions}
  293. \begin{Operator}{Airy_Ai}
  294. The \name{Airy\_Ai} operator returns the Airy Ai function for a given argument.
  295. \begin{Syntax}
  296. \name{Airy\_Ai}\(\meta{argument}\)
  297. \end{Syntax}
  298. \begin{Examples}
  299. on complex;
  300. on rounded;
  301. Airy_Ai(0); & 0.355028053888 \\
  302. Airy_Ai(3.45 + 17.97i); & - 5.5561528511e+9 - 8.80397899932e+9*i \\
  303. \end{Examples}
  304. \end{Operator}
  305. \begin{Operator}{Airy_Bi}
  306. The \name{Airy\_Bi} operator returns the Airy Bi function for a given
  307. argument.
  308. \begin{Syntax}
  309. \name{Airy\_Bi}\(\meta{argument}\)
  310. \end{Syntax}
  311. \begin{Examples}
  312. Airy_Bi(0); & 0.614926627446 \\
  313. Airy_Bi(3.45 + 17.97i); & 8.80397899932e+9 - 5.5561528511e+9*i \\
  314. \end{Examples}
  315. \end{Operator}
  316. \begin{Operator}{Airy_Aiprime}
  317. The \name{Airy\_Aiprime} operator returns the Airy Aiprime function for a
  318. given argument.
  319. \begin{Syntax}
  320. \name{Airy\_Aiprime}\(\meta{argument}\)
  321. \end{Syntax}
  322. \begin{Examples}
  323. Airy_Aiprime(0); & - 0.258819403793 \\
  324. Airy_Aiprime(3.45+17.97i);& - 3.83386421824e+19 + 2.16608828136e+19*i \\
  325. \end{Examples}
  326. \end{Operator}
  327. \begin{Operator}{Airy_Biprime}
  328. The \name{Airy\_Biprime} operator returns the Airy Biprime function for a
  329. given argument.
  330. \begin{Syntax}
  331. \name{Airy\_Biprime}\(\meta{argument}\)
  332. \end{Syntax}
  333. \begin{Examples}
  334. Airy_Biprime(0); & \\
  335. Airy_Biprime(3.45 + 17.97i); & 3.84251916792e+19 - 2.18006297399e+19*i\\
  336. \end{Examples}
  337. \end{Operator}
  338. \subsection{Jacobi's Elliptic Functions and Elliptic Integrals}
  339. \begin{Operator}{JacobiSN}
  340. The \name{Jacobisn} operator returns the Jacobi Elliptic function sn.
  341. \begin{Syntax}
  342. \name{Jacobisn}\(\meta{expression},\meta{integer}\)
  343. \end{Syntax}
  344. \begin{Examples}
  345. Jacobisn(0.672, 0.36) & 0.609519691792 \\
  346. Jacobisn(1,0.9) & 0.770085724907881 \\
  347. \end{Examples}
  348. \end{Operator}
  349. \begin{Operator}{JacobiCN}
  350. The \name{Jacobicn} operator returns the Jacobi Elliptic function cn.
  351. \begin{Syntax}
  352. \name{Jacobicn}\(\meta{expression},\meta{integer}\)
  353. \end{Syntax}
  354. \begin{Examples}
  355. Jacobicn(7.2, 0.6) & 0.837288298482018 \\
  356. Jacobicn(0.11, 19) & 0.994403862690043 - 1.6219006985556e-16*i \\
  357. \end{Examples}
  358. \end{Operator}
  359. \begin{Operator}{JacobiDN}
  360. The \name{Jacobidn} operator returns the Jacobi Elliptic function dn.
  361. \begin{Syntax}
  362. \name{Jacobidn}\(\meta{expression},\meta{integer}\)
  363. \end{Syntax}
  364. \begin{Examples}
  365. Jacobidn(15, 0.683) & 0.640574162024592 \\
  366. Jacobidn(0,0) & 1 \\
  367. \end{Examples}
  368. \end{Operator}
  369. \begin{Operator}{JacobiCD}
  370. The \name{Jacobicd} operator returns the Jacobi Elliptic function cd.
  371. \begin{Syntax}
  372. \name{Jacobicd}\(\meta{expression},\meta{integer}\)
  373. \end{Syntax}
  374. \begin{Examples}
  375. Jacobicd(1, 0.34) & 0.657683337805273 \\
  376. Jacobicd(0.8,0.8) & 0.925587311582301 \\
  377. \end{Examples}
  378. \end{Operator}
  379. \begin{Operator}{JacobiSD}
  380. The \name{Jacobisd} operator returns the Jacobi Elliptic function sd.
  381. \begin{Syntax}
  382. \name{Jacobisd}\(\meta{expression},\meta{integer}\)
  383. \end{Syntax}
  384. \begin{Examples}
  385. Jacobisd(12, 0.4) & 0.357189729437272 \\
  386. Jacobisd(0.35,1) & - 1.17713873203043 \\
  387. \end{Examples}
  388. \end{Operator}
  389. \begin{Operator}{JacobiND}
  390. The \name{Jacobind} operator returns the Jacobi Elliptic function nd.
  391. \begin{Syntax}
  392. \name{Jacobind}\(\meta{expression},\meta{integer}\)
  393. \end{Syntax}
  394. \begin{Examples}
  395. Jacobind(0.2, 17) & 1.46553203037507 + 0.0000000000334032759313703*i \\
  396. Jacobind(30, 0.001) & 1.00048958438 \\
  397. \end{Examples}
  398. \end{Operator}
  399. \begin{Operator}{JacobiDC}
  400. The \name{Jacobidc} operator returns the Jacobi Elliptic function dc.
  401. \begin{Syntax}
  402. \name{Jacobidc}\(\meta{expression},\meta{integer}\)
  403. \end{Syntax}
  404. \begin{Examples}
  405. Jacobidc(0.003,1) & 1 \\
  406. Jacobidc(2, 0.75) & 6.43472885111 \\
  407. \end{Examples}
  408. \end{Operator}
  409. \begin{Operator}{JacobiNC}
  410. The \name{Jacobinc} operator returns the Jacobi Elliptic function nc.
  411. \begin{Syntax}
  412. \name{Jacobinc}\(\meta{expression},\meta{integer}\)
  413. \end{Syntax}
  414. \begin{Examples}
  415. Jacobinc(1,0) & 1.85081571768093 \\
  416. Jacobinc(56, 0.4387) & 39.304842663512 \\
  417. \end{Examples}
  418. \end{Operator}
  419. \begin{Operator}{JacobiSC}
  420. The \name{Jacobisc} operator returns the Jacobi Elliptic function sc.
  421. \begin{Syntax}
  422. \name{Jacobisc}\(\meta{expression},\meta{integer}\)
  423. \end{Syntax}
  424. \begin{Examples}
  425. Jacobisc(9, 0.88) & - 1.16417697982095 \\
  426. Jacobisc(0.34, 7) & 0.305851938390775 - 9.8768100944891e-12*i \\
  427. \end{Examples}
  428. \end{Operator}
  429. \begin{Operator}{JacobiNS}
  430. The \name{Jacobins} operator returns the Jacobi Elliptic function ns.
  431. \begin{Syntax}
  432. \name{Jacobins}\(\meta{expression},\meta{integer}\)
  433. \end{Syntax}
  434. \begin{Examples}
  435. Jacobins(3, 0.9) & 1.00945801599785 \\
  436. Jacobins(0.887, 15) & 0.683578280513975 - 0.85023411082469*i \\
  437. \end{Examples}
  438. \end{Operator}
  439. \begin{Operator}{JacobiDS}
  440. The \name{Jacobisn} operator returns the Jacobi Elliptic function ds.
  441. \begin{Syntax}
  442. \name{Jacobids}\(\meta{expression},\meta{integer}\)
  443. \end{Syntax}
  444. \begin{Examples}
  445. Jacobids(98,0.223) & - 1.061253961477 \\
  446. Jacobids(0.36,0.6) & 2.76693172243692 \\
  447. \end{Examples}
  448. \end{Operator}
  449. \begin{Operator}{JacobiCS}
  450. The \name{Jacobics} operator returns the Jacobi Elliptic function cs.
  451. \begin{Syntax}
  452. \name{Jacobics}\(\meta{expression},\meta{integer}\)
  453. \end{Syntax}
  454. \begin{Examples}
  455. Jacobics(0, 0.767) & infinity \\
  456. Jacobics(1.43, 0) & 0.141734127352112 \\
  457. \end{Examples}
  458. \end{Operator}
  459. \begin{Operator}{JacobiAMPLITUDE}
  460. The \name{JacobiAmplitude} operator returns the amplitude of u.
  461. \begin{Syntax}
  462. \name{JacobiAmplitude}\(\meta{expression},\meta{integer}\)
  463. \end{Syntax}
  464. \begin{Examples}
  465. JacobiAmplitude(7.239, 0.427) & 0.0520978301448978 \\
  466. JacobiAmplitude(0,0.1) & 0 \\
  467. \end{Examples}
  468. \begin{Comments}
  469. Amplitude u = asin(\name{Jacobisn(u,m)})
  470. \end{Comments}
  471. \end{Operator}
  472. \begin{Operator}{AGM_FUNCTION}
  473. The \name{AGM_function} operator returns a list of (N, AGM,
  474. list of aNtoa0, list of bNtob0, list of cNtoc0) where a0, b0 and c0
  475. are the initial values; N is the index number of the last term
  476. used to generate the AGM. AGM is the Arithmetic Geometric Mean.
  477. \begin{Syntax}
  478. \name{AGM_function}\(\meta{integer},\meta{integer},\meta{integer}\)
  479. \end{Syntax}
  480. \begin{Examples}
  481. AGM_function(1,1,1) & {1,1,{1,1},{1,1},{0,1}} \\
  482. AGM_function(1, 0.1, 1.3) &
  483. \begin{multilineoutput}{6cm}
  484. \{6,
  485. 2.27985615996629,
  486. \{2.27985615996629, 2.27985615996629,
  487. 2.2798561599706, 2.2798624278857,
  488. 2.28742283656583, 2.55, 1\},
  489. \{2.27985615996629, 2.27985615996629,
  490. 2.27985615996198, 2.2798498920555,
  491. 2.27230201920557, 2.02484567313166, 4.1\},
  492. \{0, 4.30803136219904e-12, 0.0000062679151007581,
  493. 0.00756040868012758, 0.262577163434171, - 1.55, 5.9\}\}
  494. \end{multilineoutput} \\
  495. \end{Examples}
  496. \begin{Comments}
  497. The other Jacobi functions use this function with initial values
  498. a0=1, b0=sqrt(1-m), c0=sqrt(m).
  499. \end{Comments}
  500. \end{Operator}
  501. \begin{Operator}{LANDENTRANS}
  502. The \name{landentrans} operator generates the descending landen
  503. transformation of the given imput values, returning a list of these
  504. values; initial to final in each case.
  505. \begin{Syntax}
  506. \name{landentrans}\(\meta{expression},\meta{integer}\)
  507. \end{Syntax}
  508. \begin{Examples}
  509. landentrans(0,0.1) & \{\{0,0,0,0,0\},\{0.1,0.0025041751943776, \\
  510. & 0.00000156772498954046,6.1444078 9914461e-13,0\}\} \\
  511. \end{Examples}
  512. \begin{Comments}
  513. The first list ascends in value, and the second descends in value.
  514. \end{Comments}
  515. \end{Operator}
  516. \begin{Operator}{EllipticF}
  517. The \name{EllipticF} operator returns the Elliptic Integral of the
  518. First Kind.
  519. \begin{Syntax}
  520. \name{EllitpicF}\(\meta{expression},\meta{integer}\)
  521. \end{Syntax}
  522. \begin{Examples}
  523. EllipticF(0.3, 8.222) & 0.3 \\
  524. EllipticF(7.396, 0.1) & 7.58123216114307 \\
  525. \end{Examples}
  526. \begin{Comments}
  527. The Complete Elliptic Integral of the First Kind can be found by
  528. putting the first argument to pi/2 or by using \name{EllipticK}
  529. and the second argument.
  530. \end{Comments}
  531. \end{Operator}
  532. \begin{Operator}{EllipticK}
  533. The \name{EllipticK} operator returns the Elliptic value K.
  534. \begin{Syntax}
  535. \name{EllipticK}\(\meta{integer}\)
  536. \end{Syntax}
  537. \begin{Examples}
  538. EllipticK(0.2) & 1.65962359861053 \\
  539. EllipticK(4.3) & 0.808442364282734 - 1.05562492399206*i \\
  540. EllipticK(0.000481) & 1.57098526617635 \\
  541. \end{Examples}
  542. \begin{Comments}
  543. The \name{EllipticK} function is the Complete Elliptic Integral of
  544. the First Kind.
  545. \end{Comments}
  546. \end{Operator}
  547. \begin{Operator}{EllipticKprime}
  548. The \name{EllipticK'} operator returns the Elliptic value K(m).
  549. \begin{Syntax}
  550. \name{EllipticKprime}\(\meta{integer}\)
  551. \end{Syntax}
  552. \begin{Examples}
  553. EllipticKprime(0.2) & 2.25720532682085 \\
  554. EllipticKprime(4.3) & 1.05562492399206 \\
  555. EllipticKprime(0.000481) & 5.206621921966 \\
  556. \end{Examples}
  557. \begin{Comments}
  558. The \name{EllipticKprime} function is the Complete Elliptic Integral of
  559. the First Kind of (1-m).
  560. \end{Comments}
  561. \end{Operator}
  562. \begin{Operator}{EllipticE}
  563. The \name{EllipticE} operator used with two arguments
  564. returns the Elliptic Integral of the Second Kind.
  565. \begin{Syntax}
  566. \name{EllipticE}\(\meta{expression},\meta{integer}\)
  567. \end{Syntax}
  568. \begin{Examples}
  569. EllipticE(1.2,0.22) & 1.15094019180949 \\
  570. EllipticE(0,4.35) & 0 \\
  571. EllipticE(9,0.00719) & 8.98312465929145 \\
  572. \end{Examples}
  573. \begin{Comments}
  574. The Complete Elliptic Integral of the Second Kind can be obtained by
  575. using just the second argument, or by using pi/2 as the first argument.
  576. \end{Comments}
  577. The \name{EllipticE} operator used with one argument
  578. returns the Elliptic value E.
  579. \begin{Syntax}
  580. \name{EllipticE}\(\meta{integer}\)
  581. \end{Syntax}
  582. \begin{Examples}
  583. EllipticE(0.22) & 1.48046637439519 \\
  584. EllipticE(pi/2, 0.22) & 1.48046637439519 \\
  585. \end{Examples}
  586. \end{Operator}
  587. \begin{Operator}{EllipticTHETA}
  588. The \name{EllipticTheta} operator returns one of the four Theta
  589. functions. It cannot except any number other than 1,2,3 or 4 as
  590. its first argument.
  591. \begin{Syntax}
  592. \name{EllipticTheta}\(\meta{integer},\meta{expression},\meta{integer}\)
  593. \end{Syntax}
  594. \begin{Examples}
  595. EllipticTheta(1, 1.4, 0.72) & 0.91634775373 \\
  596. EllipticTheta(2, 3.9, 6.1 ) & -48.0202736969 + 20.9881034377 i \\
  597. EllipticTheta(3, 0.67, 0.2) & 1.0083077448 \\
  598. EllipticTheta(4, 8, 0.75) & 0.894963369304 \\
  599. EllipticTheta(5, 1, 0.1) & ***** In EllipticTheta(a,u,m); a = 1,2,3 or 4.
  600. \\
  601. \end{Examples}
  602. \begin{Comments}
  603. Theta functions are important because every one of the Jacobian
  604. Elliptic functions can be expressed as the ratio of two theta functions.
  605. \end{Comments}
  606. \end{Operator}
  607. \begin{Operator}{JacobiZETA}
  608. The \name{JacobiZeta} operator returns the Jacobian function Zeta.
  609. \begin{Syntax}
  610. \name{JacobiZeta}\(\meta{expression},\meta{integer}\)
  611. \end{Syntax}
  612. \begin{Examples}
  613. JacobiZeta(3.2, 0.8) & - 0.254536403439 \\
  614. JacobiZeta(0.2, 1.6) & 0.171766095970451 - 0.0717028569800147*i \\
  615. \end{Examples}
  616. \begin{Comments}
  617. The Jacobian function Zeta is related to the Jacobian function Theta.
  618. But it is significantly different from Riemann's Zeta Function \nameref{Zeta}.
  619. \end{Comments}
  620. \end{Operator}
  621. \subsection{Gamma and Related Functions}
  622. \begin{Operator}{POCHHAMMER}
  623. The \name{Pochhammer} operator implements the Pochhammer notation
  624. (shifted factorial).
  625. \begin{Syntax}
  626. \name{Pochhammer}\(\meta{expression},\meta{expression}\)
  627. \end{Syntax}
  628. \begin{Examples}
  629. pochhammer(17,4); & 116280 \\
  630. pochhammer(1/2,z); &
  631. \rfrac{factorial(2*z)}{(2^{2*z}*factorial(z))}
  632. \end{Examples}
  633. \begin{Comments}
  634. A number of complex rules for \name{Pochhammer} are inactive, because they
  635. cause a huge system load in algebraic mode. If one wants to use more rules
  636. for the simplification of Pochhammer's notation, one can do:
  637. \\
  638. let special!*pochhammer!*rules;
  639. \end{Comments}
  640. \end{Operator}
  641. \begin{Operator}{GAMMA}
  642. The \name{Gamma} operator returns the Gamma function.
  643. \begin{Syntax}
  644. \name{Gamma}\(\meta{expression}\)
  645. \end{Syntax}
  646. \begin{Examples}
  647. gamma(10); & 362880 \\
  648. gamma(1/2); & sqrt(pi)
  649. \end{Examples}
  650. \end{Operator}
  651. \begin{Operator}{BETA}
  652. The \name{Beta} operator returns the Beta function defined by
  653. Beta (z,w) := defint(t**(z-1)* (1 - t)**(w-1),t,0,1) .
  654. \begin{Syntax}
  655. \name{Beta}\(\meta{expression},\meta{expression}\)
  656. \end{Syntax}
  657. \begin{Examples}
  658. Beta(2,2); & 1 / 6 \\
  659. Beta(x,y); & gamma(x)*gamma(y) / gamma(x + y)
  660. \end{Examples}
  661. \begin{Comments}
  662. The operator \name{Beta} is simplified towards the \nameref{GAMMA} operator.
  663. \end{Comments}
  664. \end{Operator}
  665. \begin{Operator}{PSI}
  666. \index{Euler's constant}
  667. The \name{Psi} operator returns the Psi (or DiGamma) function.
  668. Psi(x) := df(Gamma(z),z)/ Gamma (z)
  669. \begin{Syntax}
  670. \name{Gamma}\(\meta{expression}\)
  671. \end{Syntax}
  672. \begin{Examples}
  673. Psi(3); & (2*log(2) + psi(1/2) + psi(1) + 3)/2 \\
  674. on rounded; \\
  675. - Psi(1); & 0.577215664902
  676. \end{Examples}
  677. \begin{Comments}
  678. Euler's constant can be found as - Psi(1).
  679. \end{Comments}
  680. \end{Operator}
  681. \begin{Operator}{POLYGAMMA}
  682. The \name{Polygamma} operator returns the Polygamma function.
  683. Polygamma(n,x) := df(Psi(z),z,n);
  684. \begin{Syntax}
  685. \name{Polygamma}\(\meta{integer},\meta{expression}\)
  686. \end{Syntax}
  687. \begin{Examples}
  688. Polygamma(1,2); & (pi^2 - 6) / 6\\
  689. on rounded; \\
  690. Polygamma(1,2.35); & 0.52849689109
  691. \end{Examples}
  692. \begin{Comments}
  693. The Polygamma function is used for simplification of the \nameref{ZETA}
  694. function for some arguments.
  695. \end{Comments}
  696. \end{Operator}
  697. \subsection{Miscellaneous Functions}
  698. \begin{Operator}{DILOG extended}
  699. \index{Spence's Integral}
  700. The package \name{specfn} supplies an extended support for the
  701. \nameref{dilog} operator which implements the \nameindex{dilogarithm function}.
  702. dilog(x) := - defint(log(t)/(t - 1),t,1,x);
  703. \begin{Syntax}
  704. \name{Dilog}\(\meta{order},\meta{expression}\)
  705. \end{Syntax}
  706. \begin{Examples}
  707. defint(log(t)/(t - 1),t,1,x); & - dilog (x) \\
  708. dilog 2; & - pi^2 /12 \\
  709. on rounded; \\
  710. Dilog 20; & - 5.92783972438
  711. \end{Examples}
  712. \begin{Comments}
  713. The operator \name{Dilog} is sometimes called Spence's Integral for n = 2.
  714. \end{Comments}
  715. \end{Operator}
  716. \begin{Operator}{Lambert_W function}
  717. Lambert's W function is the inverse of the function w * e^w.
  718. It is used in the \nameref{solve} package for equations containing
  719. exponentials and logarithms.
  720. \begin{Syntax}
  721. \name{Lambert\_W}\(\meta{z}\)
  722. \end{Syntax}
  723. \begin{Examples}
  724. Lambert_W(-1/e); & -1 \\
  725. solve(w + log(w),w); & {w=lambert\_w(1)}\\
  726. on rounded; \\
  727. Lambert_W(-0.05); & - 0.0527059835515
  728. \end{Examples}
  729. \begin{Comments}
  730. The current implementation will compute the principal branch in
  731. rounded mode only.
  732. \end{Comments}
  733. \end{Operator}
  734. \subsection{Orthogonal Polynomials}
  735. \begin{Operator}{ChebyshevT}
  736. The \name{ChebyshevT} operator computes the nth Chebyshev T Polynomial (of the
  737. first kind).
  738. \begin{Syntax}
  739. \name{ChebyshevT}\(\meta{integer},\meta{expression}\)
  740. \end{Syntax}
  741. \begin{Examples}
  742. ChebyshevT(3,xx); & xx*(4*xx^2 - 3) \\
  743. ChebyshevT(3,4); & 244
  744. \end{Examples}
  745. \begin{Comments}
  746. Chebyshev's T polynomials are computed using the recurrence relation:
  747. ChebyshevT(n,x) := 2x*ChebyshevT(n-1,x) - ChebyshevT(n-2,x) with \\
  748. ChebyshevT(0,x) := 0 and ChebyshevT(1,x) := x
  749. \end{Comments}
  750. \end{Operator}
  751. \begin{Operator}{ChebyshevU}
  752. The \name{ChebyshevU} operator returns the nth Chebyshev U Polynomial (of the
  753. second kind).
  754. \begin{Syntax}
  755. \name{ChebyshevU}\(\meta{integer},\meta{expression}\)
  756. \end{Syntax}
  757. \begin{Examples}
  758. ChebyshevU(3,xx); & 4*x*(2*x^2 - 1) \\
  759. ChebyshevU(3,4); & 496
  760. \end{Examples}
  761. \begin{Comments}
  762. Chebyshev's U polynomials are computed using the recurrence relation:
  763. ChebyshevU(n,x) := 2x*ChebyshevU(n-1,x) - ChebyshevU(n-2,x) with \\
  764. ChebyshevU(0,x) := 0 and ChebyshevU(1,x) := 2x
  765. \end{Comments}
  766. \end{Operator}
  767. \begin{Operator}{HermiteP}
  768. The \name{HermiteP} operator returns the nth Hermite Polynomial.
  769. \begin{Syntax}
  770. \name{HermiteP}\(\meta{integer},\meta{expression}\)
  771. \end{Syntax}
  772. \begin{Examples}
  773. HermiteP(3,xx); & 4*xx*(2*xx^2 - 3) \\
  774. HermiteP(3,4); & 464
  775. \end{Examples}
  776. \begin{Comments}
  777. Hermite polynomials are computed using the recurrence relation:
  778. \\
  779. HermiteP(n,x) := 2x*HermiteP(n-1,x) - 2*(n-1)*HermiteP(n-2,x) with \\
  780. HermiteP(0,x) := 1 and HermiteP(1,x) := 2x
  781. \end{Comments}
  782. \end{Operator}
  783. \begin{Operator}{LaguerreP}
  784. The \name{LaguerreP} operator computes the nth Laguerre Polynomial.
  785. The two argument call of LaguerreP is a (common) abbreviation of
  786. LaguerreP(n,0,x).
  787. \begin{Syntax}
  788. \name{LaguerreP}\(\meta{integer},\meta{expression}\) or\\
  789. \name{LaguerreP}\(\meta{integer},\meta{expression},\meta{expression}\)
  790. \end{Syntax}
  791. \begin{Examples}
  792. LaguerreP(3,xx); & (- xx^3 + 9*xx^2 - 18*xx + 6)/6\\
  793. LaguerreP(2,3,4); & -2
  794. \end{Examples}
  795. \begin{Comments}
  796. Laguerre polynomials are computed using the recurrence relation:
  797. LaguerreP(n,a,x) := (2n+a-1-x)/n*LaguerreP(n-1,a,x) -
  798. (n+a-1) * LaguerreP(n-2,a,x) with \\
  799. \\
  800. LaguerreP(0,a,x) := 1 and LaguerreP(2,a,x) := -x+1+a
  801. \end{Comments}
  802. \end{Operator}
  803. \begin{Operator}{LegendreP}
  804. The binary \name{LegendreP} operator computes the nth Legendre
  805. Polynomial which is
  806. a special case of the nth Jacobi Polynomial with \\
  807. \\
  808. LegendreP(n,x) := JacobiP(n,0,0,x)\\
  809. \\
  810. The ternary form returns the associated Legendre Polynomial (see below).
  811. \begin{Syntax}
  812. \name{LegendreP}\(\meta{integer},\meta{expression}\) or\\
  813. \name{LegendreP}\(\meta{integer},\meta{expression},\meta{expression}\)
  814. \end{Syntax}
  815. \begin{Examples}
  816. LegendreP(3,xx); &\rfrac{xx*(5*xx^2 - 3)}{2}\\
  817. LegendreP(3,2,xx); &15*xx*( - xx^2 + 1)
  818. \end{Examples}
  819. \begin{Comments}
  820. The ternary form of the operator \name{LegendreP} is the associated
  821. Legendre Polynomial defined as \\
  822. \\
  823. P(n,m,x) = (-1)**m * (1-x**2)**(m/2) * df(LegendreP(n,x),x,m)
  824. \end{Comments}
  825. \end{Operator}
  826. \begin{Operator}{JacobiP}
  827. The \name{JacobiP} operator computes the nth Jacobi Polynomial.
  828. \begin{Syntax}
  829. \name{JacobiP}\(\meta{integer},\meta{expression},\meta{expression},
  830. \meta{expression}\)
  831. \end{Syntax}
  832. \begin{Examples}
  833. JacobiP(3,4,5,xx); & \rfrac{7*(65*xx^3 - 13*xx^2 - 13*xx + 1)}{8}\\
  834. JacobiP(3,4,5,6); & 94465/8
  835. \end{Examples}
  836. \end{Operator}
  837. \begin{Operator}{GegenbauerP}
  838. \index{ultraspherical polynomials}
  839. The \name{GegenbauerP} operator computes Gegenbauer's (ultraspherical)
  840. polynomials.
  841. \begin{Syntax}
  842. \name{GegenbauerP}\(\meta{integer},\meta{expression},\meta{expression}\)
  843. \end{Syntax}
  844. \begin{Examples}
  845. GegenbauerP(3,2,xx); & 4*xx*(8*xx^2 - 3)\\
  846. GegenbauerP(3,2,4); & 2000
  847. \end{Examples}
  848. \end{Operator}
  849. \begin{Operator}{SolidHarmonicY}
  850. \index{Solid harmonic polynomials}
  851. The \name{SolidHarmonicY} operator computes Solid harmonic (Laplace)
  852. polynomials.
  853. \begin{Syntax}
  854. \name{SolidHarmonicY}\(\meta{integer},\meta{integer},
  855. \meta{expression},\meta{expression},\meta{expression},\meta{expression}\)
  856. \end{Syntax}
  857. \begin{Examples}
  858. SolidHarmonicY(3,-2,x,y,z,r2); &
  859. \rfrac{sqrt(105)*z*(-2*i*x*y + x^2 - y^2)}{4*sqrt(pi)*sqrt(2)}\\
  860. \end{Examples}
  861. \end{Operator}
  862. \begin{Operator}{SphericalHarmonicY}
  863. \index{Spherical harmonic polynomials}
  864. The \name{SphericalHarmonicY} operator computes Spherical harmonic (Laplace)
  865. polynomials. These are special cases of the
  866. solid harmonic polynomials, \nameref{SolidHarmonicY}.
  867. \begin{Syntax}
  868. \name{SphericalHarmonicY}\(\meta{integer},\meta{integer},
  869. \meta{expression},\meta{expression}\)
  870. \end{Syntax}
  871. \begin{Examples}
  872. SphericalHarmonicY(3,2,theta,phi); &
  873. \rfrac{sqrt(105)*cos(theta)*sin(theta)^2*(cos(phi)^2+2*cos(phi)*sin(phi)*i-
  874. sin(phi)^2)}{4*sqrt(pi)*sqrt(2)}\\
  875. \end{Examples}
  876. \end{Operator}
  877. \subsection{Integral Functions}
  878. \index{sine integral function}
  879. \begin{Operator}{Si}
  880. \index{Sine integral function}\index{integral function}
  881. The \name{Si} operator returns the Sine Integral function.
  882. \begin{Syntax}
  883. \name{Si}\(\meta{expression}\)
  884. \end{Syntax}
  885. \begin{Examples}
  886. limit(Si(x),x,infinity); & pi / 2 \\
  887. on rounded; \\
  888. Si(0.35); & 0.347626790989
  889. \end{Examples}
  890. \begin{Comments}
  891. The numeric values for the operator \name{Si} are computed via the
  892. power series representation, which limits the argument range.
  893. \end{Comments}
  894. \end{Operator}
  895. \begin{Operator}{Shi}
  896. \index{hyperbolic sine integral function}\index{integral function}
  897. The \name{Shi} operator returns the hyperbolic Sine Integral function.
  898. \begin{Syntax}
  899. \name{Shi}\(\meta{expression}\)
  900. \end{Syntax}
  901. \begin{Examples}
  902. df(shi(x),x); & sinh(x) / x \\
  903. on rounded; \\
  904. Shi(0.35); & 0.352390716351
  905. \end{Examples}
  906. \begin{Comments}
  907. The numeric values for the operator \name{Shi} are computed via the
  908. power series representation, which limits the argument range.
  909. \end{Comments}
  910. \end{Operator}
  911. \begin{Operator}{s_i}
  912. \index{sine integral function}\index{integral function}
  913. The \name{s_i} operator returns the Sine Integral function si.
  914. \begin{Syntax}
  915. \name{s_i}\(\meta{expression}\)
  916. \end{Syntax}
  917. \begin{Examples}
  918. s_i(xx); & (2*Si(xx) - pi) / 2 \\
  919. df(s_i(x),x); & sin(x) / x
  920. \end{Examples}
  921. \begin{Comments}
  922. The operator name \name{s_i} is simplified towards \nameref{SI}.
  923. Since REDUCE is not case sensitive by default the name ``si'' can't be
  924. used.
  925. \end{Comments}
  926. \end{Operator}
  927. \begin{Operator}{Ci}
  928. \index{cosine integral function}
  929. The \name{Ci} operator returns the Cosine Integral function.
  930. \begin{Syntax}
  931. \name{Ci}\(\meta{expression}\)
  932. \end{Syntax}
  933. \begin{Examples}
  934. defint(cos(t)/t,t,x,infinity); & - ci (x) \\
  935. on rounded; \\
  936. Ci(0.35); & - 0.50307556932
  937. \end{Examples}
  938. \begin{Comments}
  939. The numeric values for the operator \name{Ci} are computed via the
  940. power series representation, which limits the argument range.
  941. \end{Comments}
  942. \end{Operator}
  943. \begin{Operator}{Chi}
  944. \index{hyperbolic cosine integral function}\index{integral function}
  945. The \name{Chi} operator returns the Hyperbolic Cosine Integral function.
  946. \begin{Syntax}
  947. \name{Chi}\(\meta{expression}\)
  948. \end{Syntax}
  949. \begin{Examples}
  950. defint((cosh(t)-1)/t,t,0,x); & - log(x) + psi(1) + chi(x)\\
  951. on rounded; \\
  952. Chi(0.35); & - 0.44182471827
  953. \end{Examples}
  954. \begin{Comments}
  955. The numeric values for the operator \name{Chi} are computed via the
  956. power series representation, which limits the argument range.
  957. \end{Comments}
  958. \end{Operator}
  959. \begin{Operator}{ERF extended}
  960. \index{error function}
  961. The special function package supplies an extended support for the
  962. \nameref{erf} operator which implements the \nameindex{error function} \\
  963. \\
  964. defint(e**(-x**2),x,0,infinity) * 2/sqrt(pi) \\
  965. .\\
  966. \begin{Syntax}
  967. \name{erf}\(\meta{expression}\)
  968. \end{Syntax}
  969. \begin{Examples}
  970. erf(-x); & - erf(x)\\
  971. on rounded; \\
  972. erf(0.35); & 0.379382053562
  973. \end{Examples}
  974. \begin{Comments}
  975. The numeric values for the operator \name{erf} are computed via the
  976. power series representation, which limits the argument range.
  977. \end{Comments}
  978. \end{Operator}
  979. \begin{Operator}{erfc}
  980. \index{error function}\index{complementary error function}
  981. The \name{erfc} operator returns the complementary Error function\\
  982. \\
  983. 1 - defint(e**(-x**2),x,0,infinity) * 2/sqrt(pi) \\
  984. .\\
  985. \begin{Syntax}
  986. \name{erfc}\(\meta{expression}\)
  987. \end{Syntax}
  988. \begin{Examples}
  989. erfc(xx); & - erf(xx) + 1
  990. \end{Examples}
  991. \begin{Comments}
  992. The operator \name{erfc} is simplified towards the \nameref{erf} operator.
  993. \end{Comments}
  994. \end{Operator}
  995. \begin{Operator}{Ei}
  996. \index{exponential integral function}
  997. The \name{Ei} operator returns the Exponential Integral function.
  998. \begin{Syntax}
  999. \name{Ei}\(\meta{expression}\)
  1000. \end{Syntax}
  1001. \begin{Examples}
  1002. df(ei(x),x); & \rfrac{e^x}{x}\\
  1003. on rounded; \\
  1004. Ei(0.35); & - 0.0894340019184
  1005. \end{Examples}
  1006. \begin{Comments}
  1007. The numeric values for the operator \name{Ei} are computed via the
  1008. power series representation, which limits the argument range.
  1009. \end{Comments}
  1010. \end{Operator}
  1011. \begin{Operator}{Fresnel_C}
  1012. The \name{Fresnel_C} operator represents Fresnel's Cosine function.
  1013. \begin{Syntax}
  1014. \name{Fresnel_C}\(\meta{expression}\)
  1015. \end{Syntax}
  1016. \begin{Examples}
  1017. int(cos(t^2*pi/2),t,0,x); & fresnel\_c(x) \\
  1018. on rounded; \\
  1019. fresnel_c(2.1); & 0.581564135061
  1020. \end{Examples}
  1021. \begin{Comments}
  1022. The operator \name{Fresnel_C} has a limited numeric evaluation of
  1023. large values of its argument.
  1024. \end{Comments}
  1025. \end{Operator}
  1026. \begin{Operator}{Fresnel_S}
  1027. The \name{Fresnel_S} operator represents Fresnel's Sine Integral function.
  1028. \begin{Syntax}
  1029. \name{Fresnel_S}\(\meta{expression}\)
  1030. \end{Syntax}
  1031. \begin{Examples}
  1032. int(sin(t^2*pi/2),t,0,x); & fresnel\_s(x) \\
  1033. on rounded; \\
  1034. fresnel_s(2.1); & 0.374273359378
  1035. \end{Examples}
  1036. \begin{Comments}
  1037. The operator \name{Fresnel_S} has a limited numeric evaluation of
  1038. large values of its argument.
  1039. \end{Comments}
  1040. \end{Operator}
  1041. \subsection{Combinatorial Operators}
  1042. \begin{Operator}{BINOMIAL}
  1043. The \name{Binomial} operator returns the Binomial coefficient if both
  1044. parameter are integer and expressions involving the Gamma function otherwise.
  1045. \begin{Syntax}
  1046. \name{Binomial}\(\meta{integer},\meta{integer}\)
  1047. \end{Syntax}
  1048. \begin{Examples}
  1049. Binomial(49,6); & 13983816 \\
  1050. Binomial(n,3); & \rfrac{gamma(n + 1)}{6*gamma(n - 2)}
  1051. \end{Examples}
  1052. \begin{Comments}
  1053. The operator \name{Binomial} evaluates the Binomial coefficients from
  1054. the explicit form and therefore it is not the best algorithm if you
  1055. want to compute many binomial coefficients with big indices in which
  1056. case a recursive algorithm is preferable.
  1057. \end{Comments}
  1058. \end{Operator}
  1059. \begin{Operator}{STIRLING1}
  1060. The \name{Stirling1} operator returns the Stirling Numbers S(n,m) of the first
  1061. kind, i.e. the number of permutations of n symbols which have exactly m cycles
  1062. (divided by (-1)**(n-m)).
  1063. \begin{Syntax}
  1064. \name{Stirling1}\(\meta{integer},\meta{integer}\)
  1065. \end{Syntax}
  1066. \begin{Examples}
  1067. Stirling1 (17,4); & -87077748875904 \\
  1068. Stirling1 (n,n-1); & \rfrac{-gamma(n+1)}{2*gamma(n-1)}
  1069. \end{Examples}
  1070. \begin{Comments}
  1071. The operator \name{Stirling1} evaluates the Stirling numbers of the
  1072. first kind by rulesets for special cases or by a computing the closed
  1073. form, which is a series involving the operators \nameref{BINOMIAL}
  1074. and \nameref{STIRLING2}.
  1075. \end{Comments}
  1076. \end{Operator}
  1077. \begin{Operator}{STIRLING2}
  1078. The \name{Stirling1} operator returns the Stirling Numbers S(n,m) of the
  1079. second kind, i.e. the number of ways of partitioning a set of n elements
  1080. into m non-empty subsets.
  1081. \begin{Syntax}
  1082. \name{Stirling2}\(\meta{integer},\meta{integer}\)
  1083. \end{Syntax}
  1084. \begin{Examples}
  1085. Stirling2 (17,4); & 694337290 \\
  1086. Stirling2 (n,n-1); & \rfrac{gamma(n+1)}{2*gamma(n-1)}
  1087. \end{Examples}
  1088. \begin{Comments}
  1089. The operator \name{Stirling2} evaluates the Stirling numbers of the
  1090. second kind by rulesets for special cases or by a computing the closed
  1091. form.
  1092. \end{Comments}
  1093. \end{Operator}
  1094. \subsection{3j and 6j symbols}
  1095. \begin{Operator}{ThreejSymbol}
  1096. The \name{ThreejSymbol} operator implements the 3j symbol.
  1097. \begin{Syntax}
  1098. \name{ThreejSymbol}\(\meta{list of j1,m1},\meta{list of j2,m2},
  1099. \meta{list of j3,m3}\)
  1100. \end{Syntax}
  1101. \begin{Examples}
  1102. ThreejSymbol({j+1,m},{j+1,-m},{1,0}); &
  1103. \rfrac{( - 1)^j *(abs(j - m + 1) - abs(j + m + 1))}
  1104. { 2*sqrt(2*j^3 + 9*j^2 + 13*j + 6)*( - 1)^m}\\
  1105. \end{Examples}
  1106. \end{Operator}
  1107. \begin{Operator}{Clebsch_Gordan}
  1108. The \name{Clebsch\_Gordan} operator implements the Clebsch\_Gordan
  1109. coefficients. This is closely related to the \nameref{Threejsymbol}.
  1110. \begin{Syntax}
  1111. \name{Clebsch\_Gordan}\(\meta{list of j1,m1},\meta{list of j2,m2},
  1112. \meta{list of j3,m3}\)
  1113. \end{Syntax}
  1114. \begin{Examples}
  1115. Clebsch_Gordan({2,0},{2,0},{2,0}); & \rfrac{-2}{sqrt(14)}\\
  1116. \end{Examples}
  1117. \end{Operator}
  1118. \begin{Operator}{SixjSymbol}
  1119. The \name{SixjSymbol} operator implements the 6j symbol.
  1120. \begin{Syntax}
  1121. \name{SixjSymbol}\(\meta{list of j1,j2,j3},\meta{list of l1,l2,l3}\)
  1122. \end{Syntax}
  1123. \begin{Examples}
  1124. SixjSymbol({7,6,3},{2,4,6}); & \rfrac{1}{14*sqrt(858)}\\
  1125. \end{Examples}
  1126. \begin{Comments}
  1127. The operator \name{SixjSymbol} uses the \nameref{ineq} package in order
  1128. to find minima and maxima for the summation index.
  1129. \end{Comments}
  1130. \end{Operator}
  1131. \subsection{Miscellaneous}
  1132. \begin{Operator}{HYPERGEOMETRIC}
  1133. \index{hypergeometric function}
  1134. \index{generalized hypergeometric function}
  1135. The \name{Hypergeometric} operator provides simplifications for the
  1136. generalized hypergeometric functions.
  1137. The \name{Hypergeometric} operator is included in the package specfn2.
  1138. \begin{Syntax}
  1139. \name{hypergeometric}\(\meta{list of parameters},\meta{list of parameters},
  1140. \meta{argument}\)
  1141. \end{Syntax}
  1142. \begin{Examples}
  1143. load specfn2;\\
  1144. hypergeometric ({1/2,1},{3/2},-x^2); & \rfrac{atan(x)}{x}\\
  1145. hypergeometric ({},{},z); & e^z
  1146. \end{Examples}
  1147. \begin{Comments}
  1148. The special case where the length of the first list is equal to 2 and
  1149. the length of the second list is equal to 1 is often called
  1150. ``the hypergeometric function'' (notated as 2F1(a1,a2,b;x)).
  1151. \end{Comments}
  1152. \end{Operator}
  1153. \begin{Operator}{MeijerG}
  1154. The \name{MeijerG} operator provides simplifications for Meijer's G
  1155. function. The simplifications are performed towards polynomials,
  1156. elementary or
  1157. special functions or (generalized) \nameref{hypergeometric} functions.
  1158. The \name{MeijerG} operator is included in the package specfn2.
  1159. \begin{Syntax}
  1160. \name{MeijerG}\(\meta{list of parameters},\meta{list of parameters},
  1161. \meta{argument}\)
  1162. \end{Syntax}
  1163. The first element of the lists has to be the list containing the
  1164. first group (mostly called ``m'' and ``n'') of parameters. This passes
  1165. the four parameters of a Meijer's G function implicitly via the
  1166. length of the lists.
  1167. \begin{Examples}
  1168. load specfn2;\\
  1169. MeijerG({{},1},{{0}},x); & heaviside(-x+1)\\
  1170. MeijerG({{}},{{1+1/4},1-1/4},(x^2)/4) * sqrt pi;
  1171. & \rfrac{sqrt(2)*sin(x)*x^2}{4*sqrt(x)}
  1172. \end{Examples}
  1173. \begin{Comments}
  1174. Many well-known functions can be written as G functions,
  1175. e.g. exponentials, logarithms, trigonometric functions, Bessel functions
  1176. and hypergeometric functions.
  1177. The formulae can be found e.g. in \\
  1178. A.P.Prudnikov, Yu.A.Brychkov, O.I.Marichev:
  1179. Integrals and Series, Volume 3: More special functions,
  1180. Gordon and Breach Science Publishers (1990).
  1181. \end{Comments}
  1182. \end{Operator}
  1183. \begin{Operator}{Heaviside}
  1184. The \name{Heaviside} operator returns the Heaviside function. \\
  1185. Heaviside(~w) => if (w < 0) then 0 else 1 \\
  1186. when numberp w;
  1187. \begin{Syntax}
  1188. \name{Heaviside}\(\meta{argument}\)
  1189. \end{Syntax}
  1190. \begin{Comments}
  1191. This operator is often included in the result of the simplification
  1192. of a generalized \nameref{hypergeometric} function or a
  1193. \nameref{MeijerG} function.
  1194. No simplification is done for this function.
  1195. \end{Comments}
  1196. \end{Operator}
  1197. \begin{Operator}{erfi}
  1198. The \name{erfi} operator returns the error function of an imaginary argument.
  1199. erfi(~x) => 2/sqrt(pi) * defint(e**(t**2),t,0,x);
  1200. \begin{Syntax}
  1201. \name{erfi}\(\meta{argument}\)
  1202. \end{Syntax}
  1203. \begin{Comments}
  1204. This operator is sometimes included in the result of the simplification
  1205. of a generalized \nameref{hypergeometric} function or a
  1206. \nameref{MeijerG} function.
  1207. No simplification is done for this function.
  1208. \end{Comments}
  1209. \end{Operator}