ruby-lapack 1.4.1a → 1.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1638) hide show
  1. data/Rakefile +1 -2
  2. data/ext/cbbcsd.c +34 -34
  3. data/ext/cbdsqr.c +20 -20
  4. data/ext/cgbbrd.c +12 -12
  5. data/ext/cgbcon.c +13 -13
  6. data/ext/cgbequ.c +3 -3
  7. data/ext/cgbequb.c +2 -2
  8. data/ext/cgbrfs.c +22 -22
  9. data/ext/cgbrfsx.c +43 -43
  10. data/ext/cgbsv.c +2 -2
  11. data/ext/cgbsvx.c +25 -25
  12. data/ext/cgbsvxx.c +36 -36
  13. data/ext/cgbtf2.c +3 -3
  14. data/ext/cgbtrf.c +3 -3
  15. data/ext/cgbtrs.c +11 -11
  16. data/ext/cgebak.c +11 -11
  17. data/ext/cgebal.c +1 -1
  18. data/ext/cgebd2.c +1 -1
  19. data/ext/cgebrd.c +1 -1
  20. data/ext/cgecon.c +1 -1
  21. data/ext/cgees.c +3 -3
  22. data/ext/cgeesx.c +4 -4
  23. data/ext/cgeev.c +4 -4
  24. data/ext/cgeevx.c +5 -5
  25. data/ext/cgegs.c +2 -2
  26. data/ext/cgegv.c +3 -3
  27. data/ext/cgehd2.c +1 -1
  28. data/ext/cgehrd.c +2 -2
  29. data/ext/cgelqf.c +6 -6
  30. data/ext/cgels.c +2 -2
  31. data/ext/cgelsd.c +9 -9
  32. data/ext/cgelss.c +2 -2
  33. data/ext/cgelsx.c +12 -12
  34. data/ext/cgelsy.c +12 -12
  35. data/ext/cgeql2.c +1 -1
  36. data/ext/cgeqlf.c +1 -1
  37. data/ext/cgeqp3.c +11 -11
  38. data/ext/cgeqpf.c +11 -11
  39. data/ext/cgeqr2.c +1 -1
  40. data/ext/cgeqr2p.c +1 -1
  41. data/ext/cgeqrf.c +1 -1
  42. data/ext/cgeqrfp.c +1 -1
  43. data/ext/cgerfs.c +31 -31
  44. data/ext/cgerfsx.c +25 -25
  45. data/ext/cgerqf.c +6 -6
  46. data/ext/cgesc2.c +13 -13
  47. data/ext/cgesdd.c +3 -3
  48. data/ext/cgesvd.c +4 -4
  49. data/ext/cgesvx.c +32 -32
  50. data/ext/cgesvxx.c +26 -26
  51. data/ext/cgetf2.c +1 -1
  52. data/ext/cgetrf.c +1 -1
  53. data/ext/cgetri.c +10 -10
  54. data/ext/cgetrs.c +10 -10
  55. data/ext/cggbak.c +11 -11
  56. data/ext/cggbal.c +11 -11
  57. data/ext/cgges.c +15 -15
  58. data/ext/cggesx.c +6 -6
  59. data/ext/cggev.c +3 -3
  60. data/ext/cggevx.c +5 -5
  61. data/ext/cgghrd.c +14 -14
  62. data/ext/cggqrf.c +9 -9
  63. data/ext/cggrqf.c +1 -1
  64. data/ext/cggsvd.c +3 -3
  65. data/ext/cggsvp.c +4 -4
  66. data/ext/cgtcon.c +20 -20
  67. data/ext/cgtrfs.c +48 -48
  68. data/ext/cgtsv.c +8 -8
  69. data/ext/cgtsvx.c +55 -55
  70. data/ext/cgttrs.c +19 -19
  71. data/ext/cgtts2.c +20 -20
  72. data/ext/chbev.c +3 -3
  73. data/ext/chbevd.c +9 -9
  74. data/ext/chbevx.c +7 -7
  75. data/ext/chbgst.c +15 -15
  76. data/ext/chbgv.c +15 -15
  77. data/ext/chbgvd.c +20 -20
  78. data/ext/chbgvx.c +9 -9
  79. data/ext/chbtrd.c +13 -13
  80. data/ext/checon.c +12 -12
  81. data/ext/cheequb.c +1 -1
  82. data/ext/cheev.c +2 -2
  83. data/ext/cheevd.c +7 -7
  84. data/ext/cheevr.c +12 -12
  85. data/ext/cheevx.c +7 -7
  86. data/ext/chegs2.c +2 -2
  87. data/ext/chegst.c +2 -2
  88. data/ext/chegv.c +13 -13
  89. data/ext/chegvd.c +18 -18
  90. data/ext/chegvx.c +19 -19
  91. data/ext/cherfs.c +31 -31
  92. data/ext/cherfsx.c +43 -43
  93. data/ext/chesv.c +10 -10
  94. data/ext/chesvx.c +15 -15
  95. data/ext/chesvxx.c +41 -41
  96. data/ext/chetd2.c +1 -1
  97. data/ext/chetf2.c +1 -1
  98. data/ext/chetrd.c +2 -2
  99. data/ext/chetrf.c +2 -2
  100. data/ext/chetri.c +1 -1
  101. data/ext/chetrs.c +10 -10
  102. data/ext/chetrs2.c +10 -10
  103. data/ext/chfrk.c +6 -6
  104. data/ext/chgeqz.c +27 -27
  105. data/ext/chpcon.c +1 -1
  106. data/ext/chpev.c +2 -2
  107. data/ext/chpevd.c +2 -2
  108. data/ext/chpevx.c +7 -7
  109. data/ext/chpgst.c +10 -10
  110. data/ext/chpgv.c +2 -2
  111. data/ext/chpgvd.c +11 -11
  112. data/ext/chpgvx.c +8 -8
  113. data/ext/chprfs.c +10 -10
  114. data/ext/chpsv.c +1 -1
  115. data/ext/chpsvx.c +20 -20
  116. data/ext/chptrd.c +1 -1
  117. data/ext/chptrf.c +1 -1
  118. data/ext/chptri.c +1 -1
  119. data/ext/chptrs.c +1 -1
  120. data/ext/chsein.c +21 -21
  121. data/ext/chseqr.c +4 -4
  122. data/ext/cla_gbamv.c +14 -14
  123. data/ext/cla_gbrcond_c.c +33 -33
  124. data/ext/cla_gbrcond_x.c +32 -32
  125. data/ext/cla_gbrfsx_extended.c +75 -75
  126. data/ext/cla_gbrpvgrw.c +13 -13
  127. data/ext/cla_geamv.c +6 -6
  128. data/ext/cla_gercond_c.c +31 -31
  129. data/ext/cla_gercond_x.c +30 -30
  130. data/ext/cla_gerfsx_extended.c +81 -81
  131. data/ext/cla_heamv.c +12 -12
  132. data/ext/cla_hercond_c.c +31 -31
  133. data/ext/cla_hercond_x.c +30 -30
  134. data/ext/cla_herfsx_extended.c +82 -82
  135. data/ext/cla_herpvgrw.c +14 -14
  136. data/ext/cla_lin_berr.c +14 -14
  137. data/ext/cla_porcond_c.c +23 -23
  138. data/ext/cla_porcond_x.c +22 -22
  139. data/ext/cla_porfsx_extended.c +74 -74
  140. data/ext/cla_porpvgrw.c +2 -2
  141. data/ext/cla_rpvgrw.c +12 -12
  142. data/ext/cla_syamv.c +13 -13
  143. data/ext/cla_syrcond_c.c +31 -31
  144. data/ext/cla_syrcond_x.c +30 -30
  145. data/ext/cla_syrfsx_extended.c +82 -82
  146. data/ext/cla_syrpvgrw.c +14 -14
  147. data/ext/cla_wwaddw.c +11 -11
  148. data/ext/clabrd.c +2 -2
  149. data/ext/clacn2.c +2 -2
  150. data/ext/clacp2.c +1 -1
  151. data/ext/clacpy.c +1 -1
  152. data/ext/clacrm.c +11 -11
  153. data/ext/clacrt.c +12 -12
  154. data/ext/claed7.c +42 -42
  155. data/ext/claed8.c +27 -27
  156. data/ext/claein.c +14 -14
  157. data/ext/clags2.c +5 -5
  158. data/ext/clagtm.c +21 -21
  159. data/ext/clahef.c +1 -1
  160. data/ext/clahqr.c +6 -6
  161. data/ext/clahr2.c +1 -1
  162. data/ext/clahrd.c +1 -1
  163. data/ext/claic1.c +12 -12
  164. data/ext/clals0.c +37 -37
  165. data/ext/clalsa.c +72 -72
  166. data/ext/clalsd.c +4 -4
  167. data/ext/clangb.c +3 -3
  168. data/ext/clange.c +1 -1
  169. data/ext/clangt.c +10 -10
  170. data/ext/clanhb.c +2 -2
  171. data/ext/clanhe.c +1 -1
  172. data/ext/clanhf.c +3 -3
  173. data/ext/clanhp.c +2 -2
  174. data/ext/clanhs.c +1 -1
  175. data/ext/clanht.c +1 -1
  176. data/ext/clansb.c +2 -2
  177. data/ext/clansp.c +2 -2
  178. data/ext/clansy.c +1 -1
  179. data/ext/clantb.c +3 -3
  180. data/ext/clantp.c +2 -2
  181. data/ext/clantr.c +3 -3
  182. data/ext/clapll.c +10 -10
  183. data/ext/clapmr.c +1 -1
  184. data/ext/clapmt.c +11 -11
  185. data/ext/claqgb.c +2 -2
  186. data/ext/claqge.c +10 -10
  187. data/ext/claqhb.c +2 -2
  188. data/ext/claqhe.c +12 -12
  189. data/ext/claqhp.c +2 -2
  190. data/ext/claqp2.c +10 -10
  191. data/ext/claqps.c +20 -20
  192. data/ext/claqr0.c +3 -3
  193. data/ext/claqr1.c +4 -4
  194. data/ext/claqr2.c +18 -18
  195. data/ext/claqr3.c +18 -18
  196. data/ext/claqr4.c +3 -3
  197. data/ext/claqr5.c +21 -21
  198. data/ext/claqsb.c +13 -13
  199. data/ext/claqsp.c +2 -2
  200. data/ext/claqsy.c +12 -12
  201. data/ext/clar1v.c +15 -15
  202. data/ext/clar2v.c +19 -19
  203. data/ext/clarf.c +2 -2
  204. data/ext/clarfb.c +16 -16
  205. data/ext/clarfg.c +1 -1
  206. data/ext/clarfgp.c +1 -1
  207. data/ext/clarft.c +2 -2
  208. data/ext/clarfx.c +3 -3
  209. data/ext/clargv.c +2 -2
  210. data/ext/clarnv.c +1 -1
  211. data/ext/clarrv.c +40 -40
  212. data/ext/clarscl2.c +8 -8
  213. data/ext/clartv.c +20 -20
  214. data/ext/clarz.c +11 -11
  215. data/ext/clarzb.c +14 -14
  216. data/ext/clarzt.c +2 -2
  217. data/ext/clascl.c +4 -4
  218. data/ext/clascl2.c +8 -8
  219. data/ext/claset.c +4 -4
  220. data/ext/clasr.c +2 -2
  221. data/ext/classq.c +2 -2
  222. data/ext/claswp.c +2 -2
  223. data/ext/clasyf.c +1 -1
  224. data/ext/clatbs.c +14 -14
  225. data/ext/clatdf.c +21 -21
  226. data/ext/clatps.c +12 -12
  227. data/ext/clatrd.c +1 -1
  228. data/ext/clatrs.c +15 -15
  229. data/ext/clatrz.c +1 -1
  230. data/ext/clatzm.c +3 -3
  231. data/ext/clauu2.c +1 -1
  232. data/ext/clauum.c +1 -1
  233. data/ext/cpbcon.c +3 -3
  234. data/ext/cpbequ.c +1 -1
  235. data/ext/cpbrfs.c +12 -12
  236. data/ext/cpbstf.c +1 -1
  237. data/ext/cpbsv.c +1 -1
  238. data/ext/cpbsvx.c +23 -23
  239. data/ext/cpbtf2.c +1 -1
  240. data/ext/cpbtrf.c +1 -1
  241. data/ext/cpbtrs.c +1 -1
  242. data/ext/cpftrf.c +2 -2
  243. data/ext/cpftri.c +2 -2
  244. data/ext/cpftrs.c +2 -2
  245. data/ext/cpocon.c +1 -1
  246. data/ext/cporfs.c +23 -23
  247. data/ext/cporfsx.c +22 -22
  248. data/ext/cposv.c +9 -9
  249. data/ext/cposvx.c +12 -12
  250. data/ext/cposvxx.c +20 -20
  251. data/ext/cpotf2.c +1 -1
  252. data/ext/cpotrf.c +1 -1
  253. data/ext/cpotri.c +1 -1
  254. data/ext/cpotrs.c +9 -9
  255. data/ext/cppcon.c +1 -1
  256. data/ext/cppequ.c +1 -1
  257. data/ext/cpprfs.c +20 -20
  258. data/ext/cppsv.c +1 -1
  259. data/ext/cppsvx.c +12 -12
  260. data/ext/cpptrf.c +1 -1
  261. data/ext/cpptri.c +1 -1
  262. data/ext/cpptrs.c +1 -1
  263. data/ext/cpstf2.c +2 -2
  264. data/ext/cpstrf.c +2 -2
  265. data/ext/cptcon.c +1 -1
  266. data/ext/cpteqr.c +10 -10
  267. data/ext/cptrfs.c +12 -12
  268. data/ext/cptsv.c +8 -8
  269. data/ext/cptsvx.c +19 -19
  270. data/ext/cpttrs.c +1 -1
  271. data/ext/cptts2.c +1 -1
  272. data/ext/crot.c +11 -11
  273. data/ext/cspcon.c +1 -1
  274. data/ext/cspmv.c +3 -3
  275. data/ext/cspr.c +11 -11
  276. data/ext/csprfs.c +10 -10
  277. data/ext/cspsv.c +1 -1
  278. data/ext/cspsvx.c +20 -20
  279. data/ext/csptrf.c +1 -1
  280. data/ext/csptri.c +1 -1
  281. data/ext/csptrs.c +1 -1
  282. data/ext/csrscl.c +2 -2
  283. data/ext/cstedc.c +10 -10
  284. data/ext/cstegr.c +18 -18
  285. data/ext/cstein.c +14 -14
  286. data/ext/cstemr.c +22 -22
  287. data/ext/csteqr.c +10 -10
  288. data/ext/csycon.c +12 -12
  289. data/ext/csyconv.c +12 -12
  290. data/ext/csyequb.c +1 -1
  291. data/ext/csymv.c +13 -13
  292. data/ext/csyr.c +4 -4
  293. data/ext/csyrfs.c +31 -31
  294. data/ext/csyrfsx.c +43 -43
  295. data/ext/csysv.c +10 -10
  296. data/ext/csysvx.c +15 -15
  297. data/ext/csysvxx.c +41 -41
  298. data/ext/csyswapr.c +2 -2
  299. data/ext/csytf2.c +1 -1
  300. data/ext/csytrf.c +2 -2
  301. data/ext/csytri.c +1 -1
  302. data/ext/csytri2.c +3 -3
  303. data/ext/csytri2x.c +2 -2
  304. data/ext/csytrs.c +10 -10
  305. data/ext/csytrs2.c +10 -10
  306. data/ext/ctbcon.c +3 -3
  307. data/ext/ctbrfs.c +14 -14
  308. data/ext/ctbtrs.c +2 -2
  309. data/ext/ctfsm.c +5 -5
  310. data/ext/ctftri.c +1 -1
  311. data/ext/ctfttp.c +1 -1
  312. data/ext/ctfttr.c +1 -1
  313. data/ext/ctgevc.c +32 -32
  314. data/ext/ctgex2.c +14 -14
  315. data/ext/ctgexc.c +25 -25
  316. data/ext/ctgsen.c +37 -37
  317. data/ext/ctgsja.c +26 -26
  318. data/ext/ctgsna.c +24 -24
  319. data/ext/ctgsy2.c +22 -22
  320. data/ext/ctgsyl.c +42 -42
  321. data/ext/ctpcon.c +2 -2
  322. data/ext/ctprfs.c +13 -13
  323. data/ext/ctptri.c +1 -1
  324. data/ext/ctptrs.c +3 -3
  325. data/ext/ctpttf.c +1 -1
  326. data/ext/ctpttr.c +1 -1
  327. data/ext/ctrcon.c +3 -3
  328. data/ext/ctrevc.c +12 -12
  329. data/ext/ctrexc.c +1 -1
  330. data/ext/ctrrfs.c +11 -11
  331. data/ext/ctrsen.c +13 -13
  332. data/ext/ctrsna.c +20 -20
  333. data/ext/ctrsyl.c +11 -11
  334. data/ext/ctrti2.c +1 -1
  335. data/ext/ctrtri.c +1 -1
  336. data/ext/ctrtrs.c +10 -10
  337. data/ext/ctrttf.c +1 -1
  338. data/ext/ctrttp.c +1 -1
  339. data/ext/cunbdb.c +15 -15
  340. data/ext/cuncsd.c +27 -27
  341. data/ext/cung2l.c +9 -9
  342. data/ext/cung2r.c +9 -9
  343. data/ext/cungbr.c +1 -1
  344. data/ext/cunghr.c +7 -7
  345. data/ext/cungl2.c +1 -1
  346. data/ext/cunglq.c +9 -9
  347. data/ext/cungql.c +9 -9
  348. data/ext/cungqr.c +9 -9
  349. data/ext/cungr2.c +1 -1
  350. data/ext/cungrq.c +9 -9
  351. data/ext/cungtr.c +6 -6
  352. data/ext/cunm2l.c +12 -12
  353. data/ext/cunm2r.c +12 -12
  354. data/ext/cunmbr.c +3 -3
  355. data/ext/cunmhr.c +12 -12
  356. data/ext/cunml2.c +1 -1
  357. data/ext/cunmlq.c +7 -7
  358. data/ext/cunmql.c +12 -12
  359. data/ext/cunmqr.c +12 -12
  360. data/ext/cunmr2.c +1 -1
  361. data/ext/cunmr3.c +10 -10
  362. data/ext/cunmrq.c +7 -7
  363. data/ext/cunmrz.c +10 -10
  364. data/ext/cunmtr.c +17 -17
  365. data/ext/cupgtr.c +8 -8
  366. data/ext/cupmtr.c +2 -2
  367. data/ext/dbbcsd.c +29 -29
  368. data/ext/dbdsdc.c +6 -6
  369. data/ext/dbdsqr.c +20 -20
  370. data/ext/ddisna.c +1 -1
  371. data/ext/dgbbrd.c +12 -12
  372. data/ext/dgbcon.c +13 -13
  373. data/ext/dgbequ.c +3 -3
  374. data/ext/dgbequb.c +2 -2
  375. data/ext/dgbrfs.c +22 -22
  376. data/ext/dgbrfsx.c +43 -43
  377. data/ext/dgbsv.c +2 -2
  378. data/ext/dgbsvx.c +25 -25
  379. data/ext/dgbsvxx.c +36 -36
  380. data/ext/dgbtf2.c +3 -3
  381. data/ext/dgbtrf.c +3 -3
  382. data/ext/dgbtrs.c +11 -11
  383. data/ext/dgebak.c +11 -11
  384. data/ext/dgebal.c +1 -1
  385. data/ext/dgebd2.c +1 -1
  386. data/ext/dgebrd.c +1 -1
  387. data/ext/dgecon.c +1 -1
  388. data/ext/dgees.c +3 -3
  389. data/ext/dgeesx.c +4 -4
  390. data/ext/dgeev.c +3 -3
  391. data/ext/dgeevx.c +5 -5
  392. data/ext/dgegs.c +2 -2
  393. data/ext/dgegv.c +3 -3
  394. data/ext/dgehd2.c +1 -1
  395. data/ext/dgehrd.c +2 -2
  396. data/ext/dgejsv.c +16 -16
  397. data/ext/dgelqf.c +6 -6
  398. data/ext/dgels.c +2 -2
  399. data/ext/dgelsd.c +7 -7
  400. data/ext/dgelss.c +2 -2
  401. data/ext/dgelsx.c +12 -12
  402. data/ext/dgelsy.c +12 -12
  403. data/ext/dgeql2.c +1 -1
  404. data/ext/dgeqlf.c +1 -1
  405. data/ext/dgeqp3.c +11 -11
  406. data/ext/dgeqpf.c +11 -11
  407. data/ext/dgeqr2.c +1 -1
  408. data/ext/dgeqr2p.c +1 -1
  409. data/ext/dgeqrf.c +1 -1
  410. data/ext/dgeqrfp.c +1 -1
  411. data/ext/dgerfs.c +31 -31
  412. data/ext/dgerfsx.c +25 -25
  413. data/ext/dgerqf.c +6 -6
  414. data/ext/dgesc2.c +13 -13
  415. data/ext/dgesdd.c +3 -3
  416. data/ext/dgesvd.c +4 -4
  417. data/ext/dgesvj.c +15 -15
  418. data/ext/dgesvx.c +32 -32
  419. data/ext/dgesvxx.c +26 -26
  420. data/ext/dgetf2.c +1 -1
  421. data/ext/dgetrf.c +1 -1
  422. data/ext/dgetri.c +10 -10
  423. data/ext/dgetrs.c +10 -10
  424. data/ext/dggbak.c +11 -11
  425. data/ext/dggbal.c +11 -11
  426. data/ext/dgges.c +15 -15
  427. data/ext/dggesx.c +6 -6
  428. data/ext/dggev.c +3 -3
  429. data/ext/dggevx.c +4 -4
  430. data/ext/dgghrd.c +14 -14
  431. data/ext/dggqrf.c +9 -9
  432. data/ext/dggrqf.c +1 -1
  433. data/ext/dggsvd.c +3 -3
  434. data/ext/dggsvp.c +4 -4
  435. data/ext/dgsvj0.c +20 -20
  436. data/ext/dgsvj1.c +26 -26
  437. data/ext/dgtcon.c +20 -20
  438. data/ext/dgtrfs.c +48 -48
  439. data/ext/dgtsv.c +8 -8
  440. data/ext/dgtsvx.c +55 -55
  441. data/ext/dgttrs.c +19 -19
  442. data/ext/dgtts2.c +20 -20
  443. data/ext/dhgeqz.c +27 -27
  444. data/ext/dhsein.c +42 -42
  445. data/ext/dhseqr.c +4 -4
  446. data/ext/dla_gbamv.c +16 -16
  447. data/ext/dla_gbrcond.c +25 -25
  448. data/ext/dla_gbrfsx_extended.c +56 -56
  449. data/ext/dla_gbrpvgrw.c +13 -13
  450. data/ext/dla_geamv.c +4 -4
  451. data/ext/dla_gercond.c +31 -31
  452. data/ext/dla_gerfsx_extended.c +70 -70
  453. data/ext/dla_lin_berr.c +14 -14
  454. data/ext/dla_porcond.c +15 -15
  455. data/ext/dla_porfsx_extended.c +74 -74
  456. data/ext/dla_porpvgrw.c +2 -2
  457. data/ext/dla_rpvgrw.c +12 -12
  458. data/ext/dla_syamv.c +12 -12
  459. data/ext/dla_syrcond.c +31 -31
  460. data/ext/dla_syrfsx_extended.c +82 -82
  461. data/ext/dla_syrpvgrw.c +14 -14
  462. data/ext/dla_wwaddw.c +11 -11
  463. data/ext/dlabad.c +1 -1
  464. data/ext/dlabrd.c +2 -2
  465. data/ext/dlacn2.c +2 -2
  466. data/ext/dlacpy.c +1 -1
  467. data/ext/dlaebz.c +43 -43
  468. data/ext/dlaed0.c +2 -2
  469. data/ext/dlaed1.c +20 -20
  470. data/ext/dlaed2.c +21 -21
  471. data/ext/dlaed3.c +30 -30
  472. data/ext/dlaed4.c +12 -12
  473. data/ext/dlaed5.c +11 -11
  474. data/ext/dlaed6.c +12 -12
  475. data/ext/dlaed7.c +35 -35
  476. data/ext/dlaed8.c +16 -16
  477. data/ext/dlaed9.c +14 -14
  478. data/ext/dlaeda.c +31 -31
  479. data/ext/dlaein.c +13 -13
  480. data/ext/dlaexc.c +14 -14
  481. data/ext/dlag2s.c +2 -2
  482. data/ext/dlags2.c +4 -4
  483. data/ext/dlagtf.c +10 -10
  484. data/ext/dlagtm.c +21 -21
  485. data/ext/dlagts.c +13 -13
  486. data/ext/dlahqr.c +6 -6
  487. data/ext/dlahr2.c +1 -1
  488. data/ext/dlahrd.c +1 -1
  489. data/ext/dlaic1.c +12 -12
  490. data/ext/dlaln2.c +16 -16
  491. data/ext/dlals0.c +37 -37
  492. data/ext/dlalsa.c +72 -72
  493. data/ext/dlalsd.c +4 -4
  494. data/ext/dlamrg.c +1 -1
  495. data/ext/dlaneg.c +1 -1
  496. data/ext/dlangb.c +3 -3
  497. data/ext/dlange.c +1 -1
  498. data/ext/dlangt.c +10 -10
  499. data/ext/dlanhs.c +1 -1
  500. data/ext/dlansb.c +2 -2
  501. data/ext/dlansf.c +3 -3
  502. data/ext/dlansp.c +3 -3
  503. data/ext/dlanst.c +1 -1
  504. data/ext/dlansy.c +2 -2
  505. data/ext/dlantb.c +2 -2
  506. data/ext/dlantp.c +2 -2
  507. data/ext/dlantr.c +3 -3
  508. data/ext/dlapll.c +10 -10
  509. data/ext/dlapmr.c +1 -1
  510. data/ext/dlapmt.c +11 -11
  511. data/ext/dlaqgb.c +2 -2
  512. data/ext/dlaqge.c +10 -10
  513. data/ext/dlaqp2.c +10 -10
  514. data/ext/dlaqps.c +20 -20
  515. data/ext/dlaqr0.c +3 -3
  516. data/ext/dlaqr1.c +2 -2
  517. data/ext/dlaqr2.c +18 -18
  518. data/ext/dlaqr3.c +18 -18
  519. data/ext/dlaqr4.c +3 -3
  520. data/ext/dlaqr5.c +9 -9
  521. data/ext/dlaqsb.c +13 -13
  522. data/ext/dlaqsp.c +2 -2
  523. data/ext/dlaqsy.c +12 -12
  524. data/ext/dlaqtr.c +12 -12
  525. data/ext/dlar1v.c +15 -15
  526. data/ext/dlar2v.c +19 -19
  527. data/ext/dlarf.c +2 -2
  528. data/ext/dlarfb.c +16 -16
  529. data/ext/dlarfg.c +1 -1
  530. data/ext/dlarfgp.c +1 -1
  531. data/ext/dlarft.c +2 -2
  532. data/ext/dlarfx.c +2 -2
  533. data/ext/dlargv.c +2 -2
  534. data/ext/dlarnv.c +1 -1
  535. data/ext/dlarra.c +20 -20
  536. data/ext/dlarrb.c +22 -22
  537. data/ext/dlarrc.c +13 -13
  538. data/ext/dlarrd.c +25 -25
  539. data/ext/dlarre.c +17 -17
  540. data/ext/dlarrf.c +21 -21
  541. data/ext/dlarrj.c +23 -23
  542. data/ext/dlarrk.c +3 -3
  543. data/ext/dlarrv.c +40 -40
  544. data/ext/dlarscl2.c +8 -8
  545. data/ext/dlartv.c +20 -20
  546. data/ext/dlaruv.c +1 -1
  547. data/ext/dlarz.c +11 -11
  548. data/ext/dlarzb.c +14 -14
  549. data/ext/dlarzt.c +2 -2
  550. data/ext/dlascl.c +4 -4
  551. data/ext/dlascl2.c +8 -8
  552. data/ext/dlasd0.c +3 -3
  553. data/ext/dlasd1.c +13 -13
  554. data/ext/dlasd2.c +18 -18
  555. data/ext/dlasd3.c +15 -15
  556. data/ext/dlasd4.c +12 -12
  557. data/ext/dlasd5.c +11 -11
  558. data/ext/dlasd6.c +14 -14
  559. data/ext/dlasd7.c +25 -25
  560. data/ext/dlasd8.c +27 -27
  561. data/ext/dlasda.c +5 -5
  562. data/ext/dlasdq.c +20 -20
  563. data/ext/dlaset.c +3 -3
  564. data/ext/dlasq3.c +8 -8
  565. data/ext/dlasq4.c +5 -5
  566. data/ext/dlasq5.c +3 -3
  567. data/ext/dlasq6.c +1 -1
  568. data/ext/dlasr.c +2 -2
  569. data/ext/dlasrt.c +1 -1
  570. data/ext/dlassq.c +2 -2
  571. data/ext/dlaswp.c +2 -2
  572. data/ext/dlasy2.c +24 -24
  573. data/ext/dlasyf.c +1 -1
  574. data/ext/dlat2s.c +1 -1
  575. data/ext/dlatbs.c +14 -14
  576. data/ext/dlatdf.c +21 -21
  577. data/ext/dlatps.c +12 -12
  578. data/ext/dlatrd.c +1 -1
  579. data/ext/dlatrs.c +15 -15
  580. data/ext/dlatrz.c +1 -1
  581. data/ext/dlatzm.c +2 -2
  582. data/ext/dlauu2.c +1 -1
  583. data/ext/dlauum.c +1 -1
  584. data/ext/dopgtr.c +8 -8
  585. data/ext/dopmtr.c +2 -2
  586. data/ext/dorbdb.c +15 -15
  587. data/ext/dorcsd.c +13 -13
  588. data/ext/dorg2l.c +9 -9
  589. data/ext/dorg2r.c +9 -9
  590. data/ext/dorgbr.c +1 -1
  591. data/ext/dorghr.c +7 -7
  592. data/ext/dorgl2.c +1 -1
  593. data/ext/dorglq.c +9 -9
  594. data/ext/dorgql.c +9 -9
  595. data/ext/dorgqr.c +9 -9
  596. data/ext/dorgr2.c +1 -1
  597. data/ext/dorgrq.c +9 -9
  598. data/ext/dorgtr.c +6 -6
  599. data/ext/dorm2l.c +12 -12
  600. data/ext/dorm2r.c +12 -12
  601. data/ext/dormbr.c +3 -3
  602. data/ext/dormhr.c +12 -12
  603. data/ext/dorml2.c +1 -1
  604. data/ext/dormlq.c +7 -7
  605. data/ext/dormql.c +12 -12
  606. data/ext/dormqr.c +12 -12
  607. data/ext/dormr2.c +1 -1
  608. data/ext/dormr3.c +10 -10
  609. data/ext/dormrq.c +7 -7
  610. data/ext/dormrz.c +10 -10
  611. data/ext/dormtr.c +17 -17
  612. data/ext/dpbcon.c +3 -3
  613. data/ext/dpbequ.c +1 -1
  614. data/ext/dpbrfs.c +12 -12
  615. data/ext/dpbstf.c +1 -1
  616. data/ext/dpbsv.c +1 -1
  617. data/ext/dpbsvx.c +23 -23
  618. data/ext/dpbtf2.c +1 -1
  619. data/ext/dpbtrf.c +1 -1
  620. data/ext/dpbtrs.c +1 -1
  621. data/ext/dpftrf.c +2 -2
  622. data/ext/dpftri.c +2 -2
  623. data/ext/dpftrs.c +2 -2
  624. data/ext/dpocon.c +1 -1
  625. data/ext/dporfs.c +23 -23
  626. data/ext/dporfsx.c +22 -22
  627. data/ext/dposv.c +9 -9
  628. data/ext/dposvx.c +12 -12
  629. data/ext/dposvxx.c +20 -20
  630. data/ext/dpotf2.c +1 -1
  631. data/ext/dpotrf.c +1 -1
  632. data/ext/dpotri.c +1 -1
  633. data/ext/dpotrs.c +9 -9
  634. data/ext/dppcon.c +1 -1
  635. data/ext/dppequ.c +1 -1
  636. data/ext/dpprfs.c +20 -20
  637. data/ext/dppsv.c +1 -1
  638. data/ext/dppsvx.c +12 -12
  639. data/ext/dpptrf.c +1 -1
  640. data/ext/dpptri.c +1 -1
  641. data/ext/dpptrs.c +1 -1
  642. data/ext/dpstf2.c +2 -2
  643. data/ext/dpstrf.c +2 -2
  644. data/ext/dptcon.c +1 -1
  645. data/ext/dpteqr.c +10 -10
  646. data/ext/dptrfs.c +30 -30
  647. data/ext/dptsv.c +8 -8
  648. data/ext/dptsvx.c +19 -19
  649. data/ext/dpttrs.c +8 -8
  650. data/ext/dptts2.c +8 -8
  651. data/ext/drscl.c +2 -2
  652. data/ext/dsbev.c +3 -3
  653. data/ext/dsbevd.c +9 -9
  654. data/ext/dsbevx.c +7 -7
  655. data/ext/dsbgst.c +15 -15
  656. data/ext/dsbgv.c +15 -15
  657. data/ext/dsbgvd.c +20 -20
  658. data/ext/dsbgvx.c +10 -10
  659. data/ext/dsbtrd.c +13 -13
  660. data/ext/dsfrk.c +5 -5
  661. data/ext/dspcon.c +1 -1
  662. data/ext/dspev.c +2 -2
  663. data/ext/dspevd.c +7 -7
  664. data/ext/dspevx.c +7 -7
  665. data/ext/dspgst.c +10 -10
  666. data/ext/dspgv.c +2 -2
  667. data/ext/dspgvd.c +7 -7
  668. data/ext/dspgvx.c +8 -8
  669. data/ext/dsposv.c +10 -10
  670. data/ext/dsprfs.c +10 -10
  671. data/ext/dspsv.c +1 -1
  672. data/ext/dspsvx.c +20 -20
  673. data/ext/dsptrd.c +1 -1
  674. data/ext/dsptrf.c +1 -1
  675. data/ext/dsptri.c +1 -1
  676. data/ext/dsptrs.c +1 -1
  677. data/ext/dstebz.c +5 -5
  678. data/ext/dstedc.c +5 -5
  679. data/ext/dstegr.c +18 -18
  680. data/ext/dstein.c +14 -14
  681. data/ext/dstemr.c +22 -22
  682. data/ext/dsteqr.c +10 -10
  683. data/ext/dstev.c +1 -1
  684. data/ext/dstevd.c +7 -7
  685. data/ext/dstevr.c +16 -16
  686. data/ext/dstevx.c +6 -6
  687. data/ext/dsycon.c +12 -12
  688. data/ext/dsyconv.c +12 -12
  689. data/ext/dsyequb.c +1 -1
  690. data/ext/dsyev.c +2 -2
  691. data/ext/dsyevd.c +1 -1
  692. data/ext/dsyevr.c +6 -6
  693. data/ext/dsyevx.c +7 -7
  694. data/ext/dsygs2.c +2 -2
  695. data/ext/dsygst.c +2 -2
  696. data/ext/dsygv.c +13 -13
  697. data/ext/dsygvd.c +18 -18
  698. data/ext/dsygvx.c +19 -19
  699. data/ext/dsyrfs.c +31 -31
  700. data/ext/dsyrfsx.c +43 -43
  701. data/ext/dsysv.c +10 -10
  702. data/ext/dsysvx.c +15 -15
  703. data/ext/dsysvxx.c +41 -41
  704. data/ext/dsyswapr.c +2 -2
  705. data/ext/dsytd2.c +1 -1
  706. data/ext/dsytf2.c +1 -1
  707. data/ext/dsytrd.c +2 -2
  708. data/ext/dsytrf.c +2 -2
  709. data/ext/dsytri.c +1 -1
  710. data/ext/dsytri2.c +3 -3
  711. data/ext/dsytri2x.c +2 -2
  712. data/ext/dsytrs.c +10 -10
  713. data/ext/dsytrs2.c +10 -10
  714. data/ext/dtbcon.c +3 -3
  715. data/ext/dtbrfs.c +14 -14
  716. data/ext/dtbtrs.c +2 -2
  717. data/ext/dtfsm.c +13 -13
  718. data/ext/dtftri.c +1 -1
  719. data/ext/dtfttp.c +1 -1
  720. data/ext/dtfttr.c +2 -2
  721. data/ext/dtgevc.c +32 -32
  722. data/ext/dtgex2.c +23 -23
  723. data/ext/dtgexc.c +24 -24
  724. data/ext/dtgsen.c +37 -37
  725. data/ext/dtgsja.c +26 -26
  726. data/ext/dtgsna.c +24 -24
  727. data/ext/dtgsy2.c +22 -22
  728. data/ext/dtgsyl.c +42 -42
  729. data/ext/dtpcon.c +2 -2
  730. data/ext/dtprfs.c +13 -13
  731. data/ext/dtptri.c +1 -1
  732. data/ext/dtptrs.c +3 -3
  733. data/ext/dtpttf.c +1 -1
  734. data/ext/dtpttr.c +1 -1
  735. data/ext/dtrcon.c +3 -3
  736. data/ext/dtrevc.c +12 -12
  737. data/ext/dtrexc.c +1 -1
  738. data/ext/dtrrfs.c +11 -11
  739. data/ext/dtrsen.c +13 -13
  740. data/ext/dtrsna.c +20 -20
  741. data/ext/dtrsyl.c +11 -11
  742. data/ext/dtrti2.c +1 -1
  743. data/ext/dtrtri.c +1 -1
  744. data/ext/dtrtrs.c +10 -10
  745. data/ext/dtrttf.c +1 -1
  746. data/ext/dtrttp.c +1 -1
  747. data/ext/dzsum1.c +1 -1
  748. data/ext/icmax1.c +1 -1
  749. data/ext/ieeeck.c +1 -1
  750. data/ext/ilaclc.c +1 -1
  751. data/ext/ilaclr.c +1 -1
  752. data/ext/iladlc.c +1 -1
  753. data/ext/iladlr.c +1 -1
  754. data/ext/ilaenv.c +4 -4
  755. data/ext/ilaslc.c +1 -1
  756. data/ext/ilaslr.c +1 -1
  757. data/ext/ilazlc.c +1 -1
  758. data/ext/ilazlr.c +1 -1
  759. data/ext/iparmq.c +3 -3
  760. data/ext/izmax1.c +1 -1
  761. data/ext/rb_lapack.c +3146 -3146
  762. data/ext/rb_lapack.h +1 -1
  763. data/ext/sbbcsd.c +29 -29
  764. data/ext/sbdsdc.c +10 -10
  765. data/ext/sbdsqr.c +20 -20
  766. data/ext/scsum1.c +1 -1
  767. data/ext/sdisna.c +1 -1
  768. data/ext/sgbbrd.c +12 -12
  769. data/ext/sgbcon.c +13 -13
  770. data/ext/sgbequ.c +3 -3
  771. data/ext/sgbequb.c +2 -2
  772. data/ext/sgbrfs.c +22 -22
  773. data/ext/sgbrfsx.c +43 -43
  774. data/ext/sgbsv.c +2 -2
  775. data/ext/sgbsvx.c +25 -25
  776. data/ext/sgbsvxx.c +36 -36
  777. data/ext/sgbtf2.c +3 -3
  778. data/ext/sgbtrf.c +3 -3
  779. data/ext/sgbtrs.c +11 -11
  780. data/ext/sgebak.c +11 -11
  781. data/ext/sgebal.c +1 -1
  782. data/ext/sgebd2.c +1 -1
  783. data/ext/sgebrd.c +1 -1
  784. data/ext/sgecon.c +1 -1
  785. data/ext/sgees.c +3 -3
  786. data/ext/sgeesx.c +4 -4
  787. data/ext/sgeev.c +3 -3
  788. data/ext/sgeevx.c +5 -5
  789. data/ext/sgegs.c +2 -2
  790. data/ext/sgegv.c +3 -3
  791. data/ext/sgehd2.c +1 -1
  792. data/ext/sgehrd.c +2 -2
  793. data/ext/sgejsv.c +16 -16
  794. data/ext/sgelqf.c +6 -6
  795. data/ext/sgels.c +2 -2
  796. data/ext/sgelsd.c +7 -7
  797. data/ext/sgelss.c +2 -2
  798. data/ext/sgelsx.c +12 -12
  799. data/ext/sgelsy.c +12 -12
  800. data/ext/sgeql2.c +1 -1
  801. data/ext/sgeqlf.c +1 -1
  802. data/ext/sgeqp3.c +11 -11
  803. data/ext/sgeqpf.c +11 -11
  804. data/ext/sgeqr2.c +1 -1
  805. data/ext/sgeqr2p.c +1 -1
  806. data/ext/sgeqrf.c +1 -1
  807. data/ext/sgeqrfp.c +1 -1
  808. data/ext/sgerfs.c +31 -31
  809. data/ext/sgerfsx.c +25 -25
  810. data/ext/sgerqf.c +6 -6
  811. data/ext/sgesc2.c +13 -13
  812. data/ext/sgesdd.c +3 -3
  813. data/ext/sgesvd.c +4 -4
  814. data/ext/sgesvj.c +15 -15
  815. data/ext/sgesvx.c +32 -32
  816. data/ext/sgesvxx.c +26 -26
  817. data/ext/sgetf2.c +1 -1
  818. data/ext/sgetrf.c +1 -1
  819. data/ext/sgetri.c +10 -10
  820. data/ext/sgetrs.c +10 -10
  821. data/ext/sggbak.c +11 -11
  822. data/ext/sggbal.c +11 -11
  823. data/ext/sgges.c +15 -15
  824. data/ext/sggesx.c +6 -6
  825. data/ext/sggev.c +3 -3
  826. data/ext/sggevx.c +4 -4
  827. data/ext/sgghrd.c +14 -14
  828. data/ext/sggqrf.c +9 -9
  829. data/ext/sggrqf.c +1 -1
  830. data/ext/sggsvd.c +3 -3
  831. data/ext/sggsvp.c +4 -4
  832. data/ext/sgsvj0.c +20 -20
  833. data/ext/sgsvj1.c +26 -26
  834. data/ext/sgtcon.c +20 -20
  835. data/ext/sgtrfs.c +48 -48
  836. data/ext/sgtsv.c +8 -8
  837. data/ext/sgtsvx.c +55 -55
  838. data/ext/sgttrs.c +19 -19
  839. data/ext/sgtts2.c +20 -20
  840. data/ext/shgeqz.c +27 -27
  841. data/ext/shsein.c +42 -42
  842. data/ext/shseqr.c +4 -4
  843. data/ext/sla_gbamv.c +16 -16
  844. data/ext/sla_gbrcond.c +25 -25
  845. data/ext/sla_gbrfsx_extended.c +66 -66
  846. data/ext/sla_gbrpvgrw.c +13 -13
  847. data/ext/sla_geamv.c +4 -4
  848. data/ext/sla_gercond.c +31 -31
  849. data/ext/sla_gerfsx_extended.c +82 -82
  850. data/ext/sla_lin_berr.c +14 -14
  851. data/ext/sla_porcond.c +15 -15
  852. data/ext/sla_porfsx_extended.c +74 -74
  853. data/ext/sla_porpvgrw.c +2 -2
  854. data/ext/sla_rpvgrw.c +12 -12
  855. data/ext/sla_syamv.c +12 -12
  856. data/ext/sla_syrcond.c +31 -31
  857. data/ext/sla_syrfsx_extended.c +82 -82
  858. data/ext/sla_syrpvgrw.c +14 -14
  859. data/ext/sla_wwaddw.c +11 -11
  860. data/ext/slabad.c +1 -1
  861. data/ext/slabrd.c +2 -2
  862. data/ext/slacn2.c +2 -2
  863. data/ext/slacpy.c +1 -1
  864. data/ext/slaebz.c +43 -43
  865. data/ext/slaed0.c +2 -2
  866. data/ext/slaed1.c +20 -20
  867. data/ext/slaed2.c +21 -21
  868. data/ext/slaed3.c +30 -30
  869. data/ext/slaed4.c +12 -12
  870. data/ext/slaed5.c +11 -11
  871. data/ext/slaed6.c +12 -12
  872. data/ext/slaed7.c +35 -35
  873. data/ext/slaed8.c +16 -16
  874. data/ext/slaed9.c +14 -14
  875. data/ext/slaeda.c +31 -31
  876. data/ext/slaein.c +13 -13
  877. data/ext/slaexc.c +14 -14
  878. data/ext/slags2.c +4 -4
  879. data/ext/slagtf.c +10 -10
  880. data/ext/slagtm.c +21 -21
  881. data/ext/slagts.c +13 -13
  882. data/ext/slahqr.c +6 -6
  883. data/ext/slahr2.c +1 -1
  884. data/ext/slahrd.c +3 -3
  885. data/ext/slaic1.c +12 -12
  886. data/ext/slaln2.c +16 -16
  887. data/ext/slals0.c +37 -37
  888. data/ext/slalsa.c +72 -72
  889. data/ext/slalsd.c +4 -4
  890. data/ext/slamrg.c +2 -2
  891. data/ext/slaneg.c +1 -1
  892. data/ext/slangb.c +3 -3
  893. data/ext/slange.c +1 -1
  894. data/ext/slangt.c +10 -10
  895. data/ext/slanhs.c +1 -1
  896. data/ext/slansb.c +2 -2
  897. data/ext/slansf.c +3 -3
  898. data/ext/slansp.c +3 -3
  899. data/ext/slanst.c +1 -1
  900. data/ext/slansy.c +2 -2
  901. data/ext/slantb.c +2 -2
  902. data/ext/slantp.c +2 -2
  903. data/ext/slantr.c +3 -3
  904. data/ext/slapll.c +10 -10
  905. data/ext/slapmr.c +1 -1
  906. data/ext/slapmt.c +11 -11
  907. data/ext/slaqgb.c +2 -2
  908. data/ext/slaqge.c +10 -10
  909. data/ext/slaqp2.c +10 -10
  910. data/ext/slaqps.c +20 -20
  911. data/ext/slaqr0.c +3 -3
  912. data/ext/slaqr1.c +2 -2
  913. data/ext/slaqr2.c +18 -18
  914. data/ext/slaqr3.c +18 -18
  915. data/ext/slaqr4.c +3 -3
  916. data/ext/slaqr5.c +9 -9
  917. data/ext/slaqsb.c +13 -13
  918. data/ext/slaqsp.c +2 -2
  919. data/ext/slaqsy.c +12 -12
  920. data/ext/slaqtr.c +12 -12
  921. data/ext/slar1v.c +15 -15
  922. data/ext/slar2v.c +19 -19
  923. data/ext/slarf.c +2 -2
  924. data/ext/slarfb.c +16 -16
  925. data/ext/slarfg.c +1 -1
  926. data/ext/slarfgp.c +1 -1
  927. data/ext/slarft.c +2 -2
  928. data/ext/slarfx.c +2 -2
  929. data/ext/slargv.c +2 -2
  930. data/ext/slarnv.c +1 -1
  931. data/ext/slarra.c +20 -20
  932. data/ext/slarrb.c +22 -22
  933. data/ext/slarrc.c +13 -13
  934. data/ext/slarrd.c +25 -25
  935. data/ext/slarre.c +17 -17
  936. data/ext/slarrf.c +21 -21
  937. data/ext/slarrj.c +23 -23
  938. data/ext/slarrk.c +3 -3
  939. data/ext/slarrv.c +40 -40
  940. data/ext/slarscl2.c +8 -8
  941. data/ext/slartv.c +20 -20
  942. data/ext/slaruv.c +1 -1
  943. data/ext/slarz.c +11 -11
  944. data/ext/slarzb.c +14 -14
  945. data/ext/slarzt.c +2 -2
  946. data/ext/slascl.c +4 -4
  947. data/ext/slascl2.c +8 -8
  948. data/ext/slasd0.c +3 -3
  949. data/ext/slasd1.c +12 -12
  950. data/ext/slasd2.c +18 -18
  951. data/ext/slasd3.c +15 -15
  952. data/ext/slasd4.c +12 -12
  953. data/ext/slasd5.c +11 -11
  954. data/ext/slasd6.c +14 -14
  955. data/ext/slasd7.c +25 -25
  956. data/ext/slasd8.c +27 -27
  957. data/ext/slasda.c +5 -5
  958. data/ext/slasdq.c +20 -20
  959. data/ext/slaset.c +3 -3
  960. data/ext/slasq3.c +8 -8
  961. data/ext/slasq4.c +5 -5
  962. data/ext/slasq5.c +3 -3
  963. data/ext/slasq6.c +1 -1
  964. data/ext/slasr.c +2 -2
  965. data/ext/slasrt.c +1 -1
  966. data/ext/slassq.c +2 -2
  967. data/ext/slaswp.c +2 -2
  968. data/ext/slasy2.c +24 -24
  969. data/ext/slasyf.c +1 -1
  970. data/ext/slatbs.c +14 -14
  971. data/ext/slatdf.c +21 -21
  972. data/ext/slatps.c +12 -12
  973. data/ext/slatrd.c +1 -1
  974. data/ext/slatrs.c +15 -15
  975. data/ext/slatrz.c +1 -1
  976. data/ext/slatzm.c +2 -2
  977. data/ext/slauu2.c +1 -1
  978. data/ext/slauum.c +1 -1
  979. data/ext/sopgtr.c +8 -8
  980. data/ext/sopmtr.c +2 -2
  981. data/ext/sorbdb.c +15 -15
  982. data/ext/sorcsd.c +13 -13
  983. data/ext/sorg2l.c +9 -9
  984. data/ext/sorg2r.c +9 -9
  985. data/ext/sorgbr.c +1 -1
  986. data/ext/sorghr.c +7 -7
  987. data/ext/sorgl2.c +1 -1
  988. data/ext/sorglq.c +9 -9
  989. data/ext/sorgql.c +9 -9
  990. data/ext/sorgqr.c +9 -9
  991. data/ext/sorgr2.c +1 -1
  992. data/ext/sorgrq.c +9 -9
  993. data/ext/sorgtr.c +6 -6
  994. data/ext/sorm2l.c +12 -12
  995. data/ext/sorm2r.c +12 -12
  996. data/ext/sormbr.c +3 -3
  997. data/ext/sormhr.c +12 -12
  998. data/ext/sorml2.c +1 -1
  999. data/ext/sormlq.c +7 -7
  1000. data/ext/sormql.c +12 -12
  1001. data/ext/sormqr.c +12 -12
  1002. data/ext/sormr2.c +1 -1
  1003. data/ext/sormr3.c +10 -10
  1004. data/ext/sormrq.c +7 -7
  1005. data/ext/sormrz.c +10 -10
  1006. data/ext/sormtr.c +17 -17
  1007. data/ext/spbcon.c +3 -3
  1008. data/ext/spbequ.c +1 -1
  1009. data/ext/spbrfs.c +12 -12
  1010. data/ext/spbstf.c +1 -1
  1011. data/ext/spbsv.c +1 -1
  1012. data/ext/spbsvx.c +23 -23
  1013. data/ext/spbtf2.c +1 -1
  1014. data/ext/spbtrf.c +1 -1
  1015. data/ext/spbtrs.c +1 -1
  1016. data/ext/spftrf.c +2 -2
  1017. data/ext/spftri.c +2 -2
  1018. data/ext/spftrs.c +2 -2
  1019. data/ext/spocon.c +1 -1
  1020. data/ext/sporfs.c +23 -23
  1021. data/ext/sporfsx.c +22 -22
  1022. data/ext/sposv.c +9 -9
  1023. data/ext/sposvx.c +12 -12
  1024. data/ext/sposvxx.c +20 -20
  1025. data/ext/spotf2.c +1 -1
  1026. data/ext/spotrf.c +1 -1
  1027. data/ext/spotri.c +1 -1
  1028. data/ext/spotrs.c +9 -9
  1029. data/ext/sppcon.c +1 -1
  1030. data/ext/sppequ.c +1 -1
  1031. data/ext/spprfs.c +20 -20
  1032. data/ext/sppsv.c +1 -1
  1033. data/ext/sppsvx.c +12 -12
  1034. data/ext/spptrf.c +1 -1
  1035. data/ext/spptri.c +1 -1
  1036. data/ext/spptrs.c +1 -1
  1037. data/ext/spstf2.c +2 -2
  1038. data/ext/spstrf.c +2 -2
  1039. data/ext/sptcon.c +1 -1
  1040. data/ext/spteqr.c +10 -10
  1041. data/ext/sptrfs.c +30 -30
  1042. data/ext/sptsv.c +8 -8
  1043. data/ext/sptsvx.c +19 -19
  1044. data/ext/spttrs.c +8 -8
  1045. data/ext/sptts2.c +8 -8
  1046. data/ext/srscl.c +2 -2
  1047. data/ext/ssbev.c +3 -3
  1048. data/ext/ssbevd.c +9 -9
  1049. data/ext/ssbevx.c +7 -7
  1050. data/ext/ssbgst.c +15 -15
  1051. data/ext/ssbgv.c +15 -15
  1052. data/ext/ssbgvd.c +20 -20
  1053. data/ext/ssbgvx.c +10 -10
  1054. data/ext/ssbtrd.c +13 -13
  1055. data/ext/ssfrk.c +5 -5
  1056. data/ext/sspcon.c +1 -1
  1057. data/ext/sspev.c +2 -2
  1058. data/ext/sspevd.c +7 -7
  1059. data/ext/sspevx.c +7 -7
  1060. data/ext/sspgst.c +10 -10
  1061. data/ext/sspgv.c +2 -2
  1062. data/ext/sspgvd.c +7 -7
  1063. data/ext/sspgvx.c +8 -8
  1064. data/ext/ssprfs.c +10 -10
  1065. data/ext/sspsv.c +1 -1
  1066. data/ext/sspsvx.c +20 -20
  1067. data/ext/ssptrd.c +1 -1
  1068. data/ext/ssptrf.c +1 -1
  1069. data/ext/ssptri.c +1 -1
  1070. data/ext/ssptrs.c +1 -1
  1071. data/ext/sstebz.c +5 -5
  1072. data/ext/sstedc.c +5 -5
  1073. data/ext/sstegr.c +18 -18
  1074. data/ext/sstein.c +14 -14
  1075. data/ext/sstemr.c +22 -22
  1076. data/ext/ssteqr.c +10 -10
  1077. data/ext/sstev.c +1 -1
  1078. data/ext/sstevd.c +7 -7
  1079. data/ext/sstevr.c +16 -16
  1080. data/ext/sstevx.c +6 -6
  1081. data/ext/ssycon.c +12 -12
  1082. data/ext/ssyconv.c +12 -12
  1083. data/ext/ssyequb.c +1 -1
  1084. data/ext/ssyev.c +2 -2
  1085. data/ext/ssyevd.c +1 -1
  1086. data/ext/ssyevr.c +6 -6
  1087. data/ext/ssyevx.c +7 -7
  1088. data/ext/ssygs2.c +2 -2
  1089. data/ext/ssygst.c +2 -2
  1090. data/ext/ssygv.c +13 -13
  1091. data/ext/ssygvd.c +18 -18
  1092. data/ext/ssygvx.c +22 -22
  1093. data/ext/ssyrfs.c +31 -31
  1094. data/ext/ssyrfsx.c +43 -43
  1095. data/ext/ssysv.c +10 -10
  1096. data/ext/ssysvx.c +15 -15
  1097. data/ext/ssysvxx.c +41 -41
  1098. data/ext/ssyswapr.c +2 -2
  1099. data/ext/ssytd2.c +1 -1
  1100. data/ext/ssytf2.c +1 -1
  1101. data/ext/ssytrd.c +2 -2
  1102. data/ext/ssytrf.c +2 -2
  1103. data/ext/ssytri.c +1 -1
  1104. data/ext/ssytri2.c +11 -11
  1105. data/ext/ssytri2x.c +2 -2
  1106. data/ext/ssytrs.c +10 -10
  1107. data/ext/ssytrs2.c +10 -10
  1108. data/ext/stbcon.c +3 -3
  1109. data/ext/stbrfs.c +14 -14
  1110. data/ext/stbtrs.c +2 -2
  1111. data/ext/stfsm.c +13 -13
  1112. data/ext/stftri.c +1 -1
  1113. data/ext/stfttp.c +1 -1
  1114. data/ext/stfttr.c +1 -1
  1115. data/ext/stgevc.c +32 -32
  1116. data/ext/stgex2.c +16 -16
  1117. data/ext/stgexc.c +26 -26
  1118. data/ext/stgsen.c +37 -37
  1119. data/ext/stgsja.c +26 -26
  1120. data/ext/stgsna.c +24 -24
  1121. data/ext/stgsy2.c +22 -22
  1122. data/ext/stgsyl.c +42 -42
  1123. data/ext/stpcon.c +2 -2
  1124. data/ext/stprfs.c +13 -13
  1125. data/ext/stptri.c +1 -1
  1126. data/ext/stptrs.c +3 -3
  1127. data/ext/stpttf.c +1 -1
  1128. data/ext/stpttr.c +1 -1
  1129. data/ext/strcon.c +3 -3
  1130. data/ext/strevc.c +12 -12
  1131. data/ext/strexc.c +1 -1
  1132. data/ext/strrfs.c +11 -11
  1133. data/ext/strsen.c +13 -13
  1134. data/ext/strsna.c +20 -20
  1135. data/ext/strsyl.c +11 -11
  1136. data/ext/strti2.c +1 -1
  1137. data/ext/strtri.c +1 -1
  1138. data/ext/strtrs.c +10 -10
  1139. data/ext/strttf.c +1 -1
  1140. data/ext/strttp.c +1 -1
  1141. data/ext/xerbla_array.c +1 -1
  1142. data/ext/zbbcsd.c +34 -34
  1143. data/ext/zbdsqr.c +20 -20
  1144. data/ext/zcposv.c +10 -10
  1145. data/ext/zdrscl.c +2 -2
  1146. data/ext/zgbbrd.c +12 -12
  1147. data/ext/zgbcon.c +13 -13
  1148. data/ext/zgbequ.c +3 -3
  1149. data/ext/zgbequb.c +2 -2
  1150. data/ext/zgbrfs.c +22 -22
  1151. data/ext/zgbrfsx.c +43 -43
  1152. data/ext/zgbsv.c +2 -2
  1153. data/ext/zgbsvx.c +25 -25
  1154. data/ext/zgbsvxx.c +36 -36
  1155. data/ext/zgbtf2.c +3 -3
  1156. data/ext/zgbtrf.c +3 -3
  1157. data/ext/zgbtrs.c +11 -11
  1158. data/ext/zgebak.c +11 -11
  1159. data/ext/zgebal.c +1 -1
  1160. data/ext/zgebd2.c +1 -1
  1161. data/ext/zgebrd.c +1 -1
  1162. data/ext/zgecon.c +1 -1
  1163. data/ext/zgees.c +3 -3
  1164. data/ext/zgeesx.c +4 -4
  1165. data/ext/zgeev.c +4 -4
  1166. data/ext/zgeevx.c +5 -5
  1167. data/ext/zgegs.c +2 -2
  1168. data/ext/zgegv.c +3 -3
  1169. data/ext/zgehd2.c +1 -1
  1170. data/ext/zgehrd.c +2 -2
  1171. data/ext/zgelqf.c +6 -6
  1172. data/ext/zgels.c +2 -2
  1173. data/ext/zgelsd.c +9 -9
  1174. data/ext/zgelss.c +2 -2
  1175. data/ext/zgelsx.c +12 -12
  1176. data/ext/zgelsy.c +12 -12
  1177. data/ext/zgeql2.c +1 -1
  1178. data/ext/zgeqlf.c +1 -1
  1179. data/ext/zgeqp3.c +11 -11
  1180. data/ext/zgeqpf.c +11 -11
  1181. data/ext/zgeqr2.c +1 -1
  1182. data/ext/zgeqr2p.c +1 -1
  1183. data/ext/zgeqrf.c +1 -1
  1184. data/ext/zgeqrfp.c +1 -1
  1185. data/ext/zgerfs.c +31 -31
  1186. data/ext/zgerfsx.c +25 -25
  1187. data/ext/zgerqf.c +6 -6
  1188. data/ext/zgesc2.c +13 -13
  1189. data/ext/zgesdd.c +3 -3
  1190. data/ext/zgesvd.c +4 -4
  1191. data/ext/zgesvx.c +32 -32
  1192. data/ext/zgesvxx.c +26 -26
  1193. data/ext/zgetf2.c +1 -1
  1194. data/ext/zgetrf.c +1 -1
  1195. data/ext/zgetri.c +10 -10
  1196. data/ext/zgetrs.c +10 -10
  1197. data/ext/zggbak.c +11 -11
  1198. data/ext/zggbal.c +11 -11
  1199. data/ext/zgges.c +15 -15
  1200. data/ext/zggesx.c +6 -6
  1201. data/ext/zggev.c +3 -3
  1202. data/ext/zggevx.c +5 -5
  1203. data/ext/zgghrd.c +14 -14
  1204. data/ext/zggqrf.c +9 -9
  1205. data/ext/zggrqf.c +1 -1
  1206. data/ext/zggsvd.c +3 -3
  1207. data/ext/zggsvp.c +4 -4
  1208. data/ext/zgtcon.c +20 -20
  1209. data/ext/zgtrfs.c +48 -48
  1210. data/ext/zgtsv.c +8 -8
  1211. data/ext/zgtsvx.c +55 -55
  1212. data/ext/zgttrs.c +19 -19
  1213. data/ext/zgtts2.c +20 -20
  1214. data/ext/zhbev.c +3 -3
  1215. data/ext/zhbevd.c +9 -9
  1216. data/ext/zhbevx.c +7 -7
  1217. data/ext/zhbgst.c +15 -15
  1218. data/ext/zhbgv.c +15 -15
  1219. data/ext/zhbgvd.c +20 -20
  1220. data/ext/zhbgvx.c +9 -9
  1221. data/ext/zhbtrd.c +13 -13
  1222. data/ext/zhecon.c +12 -12
  1223. data/ext/zheequb.c +1 -1
  1224. data/ext/zheev.c +2 -2
  1225. data/ext/zheevd.c +7 -7
  1226. data/ext/zheevr.c +12 -12
  1227. data/ext/zheevx.c +7 -7
  1228. data/ext/zhegs2.c +2 -2
  1229. data/ext/zhegst.c +2 -2
  1230. data/ext/zhegv.c +13 -13
  1231. data/ext/zhegvd.c +18 -18
  1232. data/ext/zhegvx.c +19 -19
  1233. data/ext/zherfs.c +31 -31
  1234. data/ext/zherfsx.c +43 -43
  1235. data/ext/zhesv.c +10 -10
  1236. data/ext/zhesvx.c +15 -15
  1237. data/ext/zhesvxx.c +41 -41
  1238. data/ext/zhetd2.c +1 -1
  1239. data/ext/zhetf2.c +1 -1
  1240. data/ext/zhetrd.c +2 -2
  1241. data/ext/zhetrf.c +2 -2
  1242. data/ext/zhetri.c +1 -1
  1243. data/ext/zhetrs.c +10 -10
  1244. data/ext/zhetrs2.c +10 -10
  1245. data/ext/zhfrk.c +6 -6
  1246. data/ext/zhgeqz.c +27 -27
  1247. data/ext/zhpcon.c +1 -1
  1248. data/ext/zhpev.c +2 -2
  1249. data/ext/zhpevd.c +2 -2
  1250. data/ext/zhpevx.c +7 -7
  1251. data/ext/zhpgst.c +10 -10
  1252. data/ext/zhpgv.c +2 -2
  1253. data/ext/zhpgvd.c +11 -11
  1254. data/ext/zhpgvx.c +8 -8
  1255. data/ext/zhprfs.c +10 -10
  1256. data/ext/zhpsv.c +1 -1
  1257. data/ext/zhpsvx.c +20 -20
  1258. data/ext/zhptrd.c +1 -1
  1259. data/ext/zhptrf.c +1 -1
  1260. data/ext/zhptri.c +1 -1
  1261. data/ext/zhptrs.c +1 -1
  1262. data/ext/zhsein.c +21 -21
  1263. data/ext/zhseqr.c +4 -4
  1264. data/ext/zla_gbamv.c +14 -14
  1265. data/ext/zla_gbrcond_c.c +33 -33
  1266. data/ext/zla_gbrcond_x.c +32 -32
  1267. data/ext/zla_gbrfsx_extended.c +78 -78
  1268. data/ext/zla_gbrpvgrw.c +13 -13
  1269. data/ext/zla_geamv.c +4 -4
  1270. data/ext/zla_gercond_c.c +31 -31
  1271. data/ext/zla_gercond_x.c +30 -30
  1272. data/ext/zla_gerfsx_extended.c +70 -70
  1273. data/ext/zla_heamv.c +12 -12
  1274. data/ext/zla_hercond_c.c +31 -31
  1275. data/ext/zla_hercond_x.c +30 -30
  1276. data/ext/zla_herfsx_extended.c +82 -82
  1277. data/ext/zla_herpvgrw.c +14 -14
  1278. data/ext/zla_lin_berr.c +14 -14
  1279. data/ext/zla_porcond_c.c +23 -23
  1280. data/ext/zla_porcond_x.c +22 -22
  1281. data/ext/zla_porfsx_extended.c +74 -74
  1282. data/ext/zla_porpvgrw.c +2 -2
  1283. data/ext/zla_rpvgrw.c +12 -12
  1284. data/ext/zla_syamv.c +12 -12
  1285. data/ext/zla_syrcond_c.c +31 -31
  1286. data/ext/zla_syrcond_x.c +30 -30
  1287. data/ext/zla_syrfsx_extended.c +82 -82
  1288. data/ext/zla_syrpvgrw.c +14 -14
  1289. data/ext/zla_wwaddw.c +11 -11
  1290. data/ext/zlabrd.c +2 -2
  1291. data/ext/zlacn2.c +2 -2
  1292. data/ext/zlacp2.c +1 -1
  1293. data/ext/zlacpy.c +1 -1
  1294. data/ext/zlacrm.c +11 -11
  1295. data/ext/zlacrt.c +12 -12
  1296. data/ext/zlaed7.c +42 -42
  1297. data/ext/zlaed8.c +27 -27
  1298. data/ext/zlaein.c +14 -14
  1299. data/ext/zlag2c.c +2 -2
  1300. data/ext/zlags2.c +5 -5
  1301. data/ext/zlagtm.c +21 -21
  1302. data/ext/zlahef.c +1 -1
  1303. data/ext/zlahqr.c +6 -6
  1304. data/ext/zlahr2.c +1 -1
  1305. data/ext/zlahrd.c +1 -1
  1306. data/ext/zlaic1.c +12 -12
  1307. data/ext/zlals0.c +37 -37
  1308. data/ext/zlalsa.c +72 -72
  1309. data/ext/zlalsd.c +4 -4
  1310. data/ext/zlangb.c +3 -3
  1311. data/ext/zlange.c +1 -1
  1312. data/ext/zlangt.c +10 -10
  1313. data/ext/zlanhb.c +2 -2
  1314. data/ext/zlanhe.c +2 -2
  1315. data/ext/zlanhf.c +3 -3
  1316. data/ext/zlanhp.c +3 -3
  1317. data/ext/zlanhs.c +1 -1
  1318. data/ext/zlanht.c +1 -1
  1319. data/ext/zlansb.c +2 -2
  1320. data/ext/zlansp.c +3 -3
  1321. data/ext/zlansy.c +2 -2
  1322. data/ext/zlantb.c +2 -2
  1323. data/ext/zlantp.c +2 -2
  1324. data/ext/zlantr.c +3 -3
  1325. data/ext/zlapll.c +10 -10
  1326. data/ext/zlapmr.c +1 -1
  1327. data/ext/zlapmt.c +11 -11
  1328. data/ext/zlaqgb.c +2 -2
  1329. data/ext/zlaqge.c +10 -10
  1330. data/ext/zlaqhb.c +2 -2
  1331. data/ext/zlaqhe.c +12 -12
  1332. data/ext/zlaqhp.c +2 -2
  1333. data/ext/zlaqp2.c +10 -10
  1334. data/ext/zlaqps.c +20 -20
  1335. data/ext/zlaqr0.c +17 -17
  1336. data/ext/zlaqr1.c +4 -4
  1337. data/ext/zlaqr2.c +18 -18
  1338. data/ext/zlaqr3.c +18 -18
  1339. data/ext/zlaqr4.c +7 -7
  1340. data/ext/zlaqr5.c +21 -21
  1341. data/ext/zlaqsb.c +13 -13
  1342. data/ext/zlaqsp.c +2 -2
  1343. data/ext/zlaqsy.c +12 -12
  1344. data/ext/zlar1v.c +15 -15
  1345. data/ext/zlar2v.c +19 -19
  1346. data/ext/zlarf.c +2 -2
  1347. data/ext/zlarfb.c +16 -16
  1348. data/ext/zlarfg.c +1 -1
  1349. data/ext/zlarfgp.c +1 -1
  1350. data/ext/zlarft.c +2 -2
  1351. data/ext/zlarfx.c +3 -3
  1352. data/ext/zlargv.c +2 -2
  1353. data/ext/zlarnv.c +1 -1
  1354. data/ext/zlarrv.c +40 -40
  1355. data/ext/zlarscl2.c +8 -8
  1356. data/ext/zlartv.c +20 -20
  1357. data/ext/zlarz.c +11 -11
  1358. data/ext/zlarzb.c +14 -14
  1359. data/ext/zlarzt.c +2 -2
  1360. data/ext/zlascl.c +4 -4
  1361. data/ext/zlascl2.c +8 -8
  1362. data/ext/zlaset.c +4 -4
  1363. data/ext/zlasr.c +2 -2
  1364. data/ext/zlassq.c +2 -2
  1365. data/ext/zlaswp.c +2 -2
  1366. data/ext/zlasyf.c +1 -1
  1367. data/ext/zlat2c.c +1 -1
  1368. data/ext/zlatbs.c +14 -14
  1369. data/ext/zlatdf.c +21 -21
  1370. data/ext/zlatps.c +12 -12
  1371. data/ext/zlatrd.c +1 -1
  1372. data/ext/zlatrs.c +15 -15
  1373. data/ext/zlatrz.c +1 -1
  1374. data/ext/zlatzm.c +3 -3
  1375. data/ext/zlauu2.c +1 -1
  1376. data/ext/zlauum.c +1 -1
  1377. data/ext/zpbcon.c +3 -3
  1378. data/ext/zpbequ.c +1 -1
  1379. data/ext/zpbrfs.c +12 -12
  1380. data/ext/zpbstf.c +1 -1
  1381. data/ext/zpbsv.c +1 -1
  1382. data/ext/zpbsvx.c +23 -23
  1383. data/ext/zpbtf2.c +1 -1
  1384. data/ext/zpbtrf.c +1 -1
  1385. data/ext/zpbtrs.c +1 -1
  1386. data/ext/zpftrf.c +2 -2
  1387. data/ext/zpftri.c +2 -2
  1388. data/ext/zpftrs.c +2 -2
  1389. data/ext/zpocon.c +1 -1
  1390. data/ext/zporfs.c +23 -23
  1391. data/ext/zporfsx.c +22 -22
  1392. data/ext/zposv.c +9 -9
  1393. data/ext/zposvx.c +12 -12
  1394. data/ext/zposvxx.c +20 -20
  1395. data/ext/zpotf2.c +1 -1
  1396. data/ext/zpotrf.c +1 -1
  1397. data/ext/zpotri.c +1 -1
  1398. data/ext/zpotrs.c +9 -9
  1399. data/ext/zppcon.c +1 -1
  1400. data/ext/zppequ.c +1 -1
  1401. data/ext/zpprfs.c +20 -20
  1402. data/ext/zppsv.c +1 -1
  1403. data/ext/zppsvx.c +12 -12
  1404. data/ext/zpptrf.c +1 -1
  1405. data/ext/zpptri.c +1 -1
  1406. data/ext/zpptrs.c +1 -1
  1407. data/ext/zpstf2.c +2 -2
  1408. data/ext/zpstrf.c +2 -2
  1409. data/ext/zptcon.c +1 -1
  1410. data/ext/zpteqr.c +10 -10
  1411. data/ext/zptrfs.c +12 -12
  1412. data/ext/zptsv.c +1 -1
  1413. data/ext/zptsvx.c +19 -19
  1414. data/ext/zpttrs.c +1 -1
  1415. data/ext/zptts2.c +1 -1
  1416. data/ext/zrot.c +11 -11
  1417. data/ext/zspcon.c +1 -1
  1418. data/ext/zspmv.c +15 -15
  1419. data/ext/zspr.c +11 -11
  1420. data/ext/zsprfs.c +10 -10
  1421. data/ext/zspsv.c +1 -1
  1422. data/ext/zspsvx.c +20 -20
  1423. data/ext/zsptrf.c +1 -1
  1424. data/ext/zsptri.c +1 -1
  1425. data/ext/zsptrs.c +1 -1
  1426. data/ext/zstedc.c +10 -10
  1427. data/ext/zstegr.c +18 -18
  1428. data/ext/zstein.c +14 -14
  1429. data/ext/zstemr.c +22 -22
  1430. data/ext/zsteqr.c +10 -10
  1431. data/ext/zsycon.c +12 -12
  1432. data/ext/zsyconv.c +12 -12
  1433. data/ext/zsyequb.c +1 -1
  1434. data/ext/zsymv.c +13 -13
  1435. data/ext/zsyr.c +4 -4
  1436. data/ext/zsyrfs.c +31 -31
  1437. data/ext/zsyrfsx.c +43 -43
  1438. data/ext/zsysv.c +10 -10
  1439. data/ext/zsysvx.c +15 -15
  1440. data/ext/zsysvxx.c +41 -41
  1441. data/ext/zsyswapr.c +2 -2
  1442. data/ext/zsytf2.c +1 -1
  1443. data/ext/zsytrf.c +2 -2
  1444. data/ext/zsytri.c +1 -1
  1445. data/ext/zsytri2.c +3 -3
  1446. data/ext/zsytri2x.c +2 -2
  1447. data/ext/zsytrs.c +10 -10
  1448. data/ext/zsytrs2.c +10 -10
  1449. data/ext/ztbcon.c +3 -3
  1450. data/ext/ztbrfs.c +14 -14
  1451. data/ext/ztbtrs.c +2 -2
  1452. data/ext/ztfsm.c +5 -5
  1453. data/ext/ztftri.c +1 -1
  1454. data/ext/ztfttp.c +1 -1
  1455. data/ext/ztfttr.c +1 -1
  1456. data/ext/ztgevc.c +32 -32
  1457. data/ext/ztgex2.c +14 -14
  1458. data/ext/ztgexc.c +25 -25
  1459. data/ext/ztgsen.c +37 -37
  1460. data/ext/ztgsja.c +26 -26
  1461. data/ext/ztgsna.c +24 -24
  1462. data/ext/ztgsy2.c +22 -22
  1463. data/ext/ztgsyl.c +42 -42
  1464. data/ext/ztpcon.c +2 -2
  1465. data/ext/ztprfs.c +13 -13
  1466. data/ext/ztptri.c +1 -1
  1467. data/ext/ztptrs.c +3 -3
  1468. data/ext/ztpttf.c +1 -1
  1469. data/ext/ztpttr.c +1 -1
  1470. data/ext/ztrcon.c +3 -3
  1471. data/ext/ztrevc.c +12 -12
  1472. data/ext/ztrexc.c +1 -1
  1473. data/ext/ztrrfs.c +11 -11
  1474. data/ext/ztrsen.c +13 -13
  1475. data/ext/ztrsna.c +20 -20
  1476. data/ext/ztrsyl.c +11 -11
  1477. data/ext/ztrti2.c +1 -1
  1478. data/ext/ztrtri.c +1 -1
  1479. data/ext/ztrtrs.c +10 -10
  1480. data/ext/ztrttf.c +1 -1
  1481. data/ext/ztrttp.c +1 -1
  1482. data/ext/zunbdb.c +15 -15
  1483. data/ext/zuncsd.c +27 -27
  1484. data/ext/zung2l.c +9 -9
  1485. data/ext/zung2r.c +9 -9
  1486. data/ext/zungbr.c +1 -1
  1487. data/ext/zunghr.c +7 -7
  1488. data/ext/zungl2.c +1 -1
  1489. data/ext/zunglq.c +9 -9
  1490. data/ext/zungql.c +9 -9
  1491. data/ext/zungqr.c +9 -9
  1492. data/ext/zungr2.c +1 -1
  1493. data/ext/zungrq.c +9 -9
  1494. data/ext/zungtr.c +6 -6
  1495. data/ext/zunm2l.c +12 -12
  1496. data/ext/zunm2r.c +12 -12
  1497. data/ext/zunmbr.c +3 -3
  1498. data/ext/zunmhr.c +12 -12
  1499. data/ext/zunml2.c +1 -1
  1500. data/ext/zunmlq.c +7 -7
  1501. data/ext/zunmql.c +12 -12
  1502. data/ext/zunmqr.c +12 -12
  1503. data/ext/zunmr2.c +1 -1
  1504. data/ext/zunmr3.c +10 -10
  1505. data/ext/zunmrq.c +7 -7
  1506. data/ext/zunmrz.c +10 -10
  1507. data/ext/zunmtr.c +17 -17
  1508. data/ext/zupgtr.c +8 -8
  1509. data/ext/zupmtr.c +2 -2
  1510. metadata +3183 -3329
  1511. data/doc/bd.html +0 -16
  1512. data/doc/c.html +0 -36
  1513. data/doc/cbd.html +0 -161
  1514. data/doc/cgb.html +0 -1865
  1515. data/doc/cge.html +0 -5261
  1516. data/doc/cgg.html +0 -2027
  1517. data/doc/cgt.html +0 -711
  1518. data/doc/chb.html +0 -1031
  1519. data/doc/che.html +0 -3165
  1520. data/doc/chg.html +0 -201
  1521. data/doc/chp.html +0 -1696
  1522. data/doc/chs.html +0 -386
  1523. data/doc/cpb.html +0 -994
  1524. data/doc/cpo.html +0 -1520
  1525. data/doc/cpp.html +0 -770
  1526. data/doc/cpt.html +0 -706
  1527. data/doc/csp.html +0 -905
  1528. data/doc/cst.html +0 -742
  1529. data/doc/csy.html +0 -2194
  1530. data/doc/ctb.html +0 -284
  1531. data/doc/ctg.html +0 -1544
  1532. data/doc/ctp.html +0 -553
  1533. data/doc/ctr.html +0 -1281
  1534. data/doc/ctz.html +0 -211
  1535. data/doc/cun.html +0 -2553
  1536. data/doc/cup.html +0 -166
  1537. data/doc/d.html +0 -35
  1538. data/doc/dbd.html +0 -304
  1539. data/doc/ddi.html +0 -87
  1540. data/doc/dgb.html +0 -1857
  1541. data/doc/dge.html +0 -7267
  1542. data/doc/dgg.html +0 -2102
  1543. data/doc/dgt.html +0 -713
  1544. data/doc/dhg.html +0 -225
  1545. data/doc/dhs.html +0 -414
  1546. data/doc/di.html +0 -14
  1547. data/doc/dop.html +0 -166
  1548. data/doc/dor.html +0 -2540
  1549. data/doc/dpb.html +0 -992
  1550. data/doc/dpo.html +0 -1517
  1551. data/doc/dpp.html +0 -770
  1552. data/doc/dpt.html +0 -675
  1553. data/doc/dsb.html +0 -995
  1554. data/doc/dsp.html +0 -1777
  1555. data/doc/dst.html +0 -1422
  1556. data/doc/dsy.html +0 -3433
  1557. data/doc/dtb.html +0 -284
  1558. data/doc/dtg.html +0 -1730
  1559. data/doc/dtp.html +0 -532
  1560. data/doc/dtr.html +0 -1346
  1561. data/doc/dtz.html +0 -211
  1562. data/doc/gb.html +0 -16
  1563. data/doc/ge.html +0 -16
  1564. data/doc/gg.html +0 -16
  1565. data/doc/gt.html +0 -16
  1566. data/doc/hb.html +0 -14
  1567. data/doc/he.html +0 -14
  1568. data/doc/hg.html +0 -16
  1569. data/doc/hp.html +0 -14
  1570. data/doc/hs.html +0 -16
  1571. data/doc/index.html +0 -53
  1572. data/doc/op.html +0 -14
  1573. data/doc/or.html +0 -14
  1574. data/doc/others.html +0 -1142
  1575. data/doc/pb.html +0 -16
  1576. data/doc/po.html +0 -16
  1577. data/doc/pp.html +0 -16
  1578. data/doc/pt.html +0 -16
  1579. data/doc/s.html +0 -35
  1580. data/doc/sb.html +0 -14
  1581. data/doc/sbd.html +0 -303
  1582. data/doc/sdi.html +0 -87
  1583. data/doc/sgb.html +0 -1863
  1584. data/doc/sge.html +0 -7263
  1585. data/doc/sgg.html +0 -2102
  1586. data/doc/sgt.html +0 -713
  1587. data/doc/shg.html +0 -225
  1588. data/doc/shs.html +0 -414
  1589. data/doc/sop.html +0 -166
  1590. data/doc/sor.html +0 -2540
  1591. data/doc/sp.html +0 -16
  1592. data/doc/spb.html +0 -992
  1593. data/doc/spo.html +0 -1520
  1594. data/doc/spp.html +0 -770
  1595. data/doc/spt.html +0 -675
  1596. data/doc/ssb.html +0 -995
  1597. data/doc/ssp.html +0 -1647
  1598. data/doc/sst.html +0 -1423
  1599. data/doc/ssy.html +0 -3438
  1600. data/doc/st.html +0 -16
  1601. data/doc/stb.html +0 -284
  1602. data/doc/stg.html +0 -1729
  1603. data/doc/stp.html +0 -532
  1604. data/doc/str.html +0 -1346
  1605. data/doc/stz.html +0 -211
  1606. data/doc/sy.html +0 -16
  1607. data/doc/tb.html +0 -16
  1608. data/doc/tg.html +0 -16
  1609. data/doc/tp.html +0 -16
  1610. data/doc/tr.html +0 -16
  1611. data/doc/tz.html +0 -16
  1612. data/doc/un.html +0 -14
  1613. data/doc/up.html +0 -14
  1614. data/doc/z.html +0 -36
  1615. data/doc/zbd.html +0 -161
  1616. data/doc/zgb.html +0 -1862
  1617. data/doc/zge.html +0 -5258
  1618. data/doc/zgg.html +0 -2027
  1619. data/doc/zgt.html +0 -711
  1620. data/doc/zhb.html +0 -1031
  1621. data/doc/zhe.html +0 -3162
  1622. data/doc/zhg.html +0 -201
  1623. data/doc/zhp.html +0 -1697
  1624. data/doc/zhs.html +0 -386
  1625. data/doc/zpb.html +0 -994
  1626. data/doc/zpo.html +0 -1517
  1627. data/doc/zpp.html +0 -770
  1628. data/doc/zpt.html +0 -706
  1629. data/doc/zsp.html +0 -905
  1630. data/doc/zst.html +0 -743
  1631. data/doc/zsy.html +0 -2191
  1632. data/doc/ztb.html +0 -284
  1633. data/doc/ztg.html +0 -1544
  1634. data/doc/ztp.html +0 -553
  1635. data/doc/ztr.html +0 -1281
  1636. data/doc/ztz.html +0 -211
  1637. data/doc/zun.html +0 -2553
  1638. data/doc/zup.html +0 -166
data/doc/bd.html DELETED
@@ -1,16 +0,0 @@
1
- <HTML>
2
- <HEAD>
3
- <TITLE>bidiagonal routines</TITLE>
4
- </HEAD>
5
- <BODY>
6
- <H1>bidiagonal routines</H1>
7
- <UL>
8
- <LI><A HREF="sbd.html">S: REAL</A></LI>
9
- <LI><A HREF="dbd.html">D: DOUBLE PRECISION</A></LI>
10
- <LI><A HREF="cbd.html">C: COMPLEX</A></LI>
11
- <LI><A HREF="zbd.html">Z: COMPLEX*16 or DOUBLE COMPLEX</A></LI>
12
- </UL>
13
- <HR />
14
- <A HREF="index.html">back to index.html</A>
15
- </BODY>
16
- </HTML>
data/doc/c.html DELETED
@@ -1,36 +0,0 @@
1
- <HTML>
2
- <HEAD>
3
- <TITLE>COMPLEX routines</TITLE>
4
- </HEAD>
5
- <BODY>
6
- <H1>COMPLEX routines</H1>
7
- <UL>
8
- <LI><A HREF="cbd.html">BD: bidiagonal</A></LI>
9
- <LI><A HREF="cgb.html">GB: general band</A></LI>
10
- <LI><A HREF="cge.html">GE: general (i.e., unsymmetric, in some cases rectangular)</A></LI>
11
- <LI><A HREF="cgg.html">GG: general matrices, generalized problem (i.e., a pair of general matrices)</A></LI>
12
- <LI><A HREF="cgt.html">GT: general tridiagonal</A></LI>
13
- <LI><A HREF="chb.html">HB: (complex) Hermitian band</A></LI>
14
- <LI><A HREF="che.html">HE: (complex) Hermitian</A></LI>
15
- <LI><A HREF="chg.html">HG: upper Hessenberg matrix, generalized problem (i.e a Hessenberg and a triangular matrix)</A></LI>
16
- <LI><A HREF="chp.html">HP: (complex) Hermitian, packed storage</A></LI>
17
- <LI><A HREF="chs.html">HS: upper Hessenberg</A></LI>
18
- <LI><A HREF="cpb.html">PB: symmetric or Hermitian positive definite band</A></LI>
19
- <LI><A HREF="cpo.html">PO: symmetric or Hermitian positive definite</A></LI>
20
- <LI><A HREF="cpp.html">PP: symmetric or Hermitian positive definite, packed storage</A></LI>
21
- <LI><A HREF="cpt.html">PT: symmetric or Hermitian positive definite tridiagonal</A></LI>
22
- <LI><A HREF="csp.html">SP: symmetric, packed storage</A></LI>
23
- <LI><A HREF="cst.html">ST: (real) symmetric tridiagonal</A></LI>
24
- <LI><A HREF="csy.html">SY: symmetric</A></LI>
25
- <LI><A HREF="ctb.html">TB: triangular band</A></LI>
26
- <LI><A HREF="ctg.html">TG: triangular matrices, generalized problem (i.e., a pair of triangular matrices)</A></LI>
27
- <LI><A HREF="ctp.html">TP: triangular, packed storage</A></LI>
28
- <LI><A HREF="ctr.html">TR: triangular (or in some cases quasi-triangular)</A></LI>
29
- <LI><A HREF="ctz.html">TZ: trapezoidal</A></LI>
30
- <LI><A HREF="cun.html">UN: (complex) unitary</A></LI>
31
- <LI><A HREF="cup.html">UP: (complex) unitary, packed storageBDbidiagonal</A></LI>
32
- </UL>
33
- <HR />
34
- <A HREF="index.html">back to index.html</A>
35
- </BODY>
36
- </HTML>
data/doc/cbd.html DELETED
@@ -1,161 +0,0 @@
1
- <HTML>
2
- <HEAD>
3
- <TITLE>COMPLEX routines for bidiagonal matrix</TITLE>
4
- </HEAD>
5
- <BODY>
6
- <A NAME="top"></A>
7
- <H1>COMPLEX routines for bidiagonal matrix</H1>
8
- <UL>
9
- <LI><A HREF="#cbdsqr">cbdsqr</A></LI>
10
- </UL>
11
-
12
- <A NAME="cbdsqr"></A>
13
- <H2>cbdsqr</H2>
14
- <PRE>
15
- USAGE:
16
- info, d, e, vt, u, c = NumRu::Lapack.cbdsqr( uplo, nru, d, e, vt, u, c, [:usage => usage, :help => help])
17
-
18
-
19
- FORTRAN MANUAL
20
- SUBROUTINE CBDSQR( UPLO, N, NCVT, NRU, NCC, D, E, VT, LDVT, U, LDU, C, LDC, RWORK, INFO )
21
-
22
- * Purpose
23
- * =======
24
- *
25
- * CBDSQR computes the singular values and, optionally, the right and/or
26
- * left singular vectors from the singular value decomposition (SVD) of
27
- * a real N-by-N (upper or lower) bidiagonal matrix B using the implicit
28
- * zero-shift QR algorithm. The SVD of B has the form
29
- *
30
- * B = Q * S * P**H
31
- *
32
- * where S is the diagonal matrix of singular values, Q is an orthogonal
33
- * matrix of left singular vectors, and P is an orthogonal matrix of
34
- * right singular vectors. If left singular vectors are requested, this
35
- * subroutine actually returns U*Q instead of Q, and, if right singular
36
- * vectors are requested, this subroutine returns P**H*VT instead of
37
- * P**H, for given complex input matrices U and VT. When U and VT are
38
- * the unitary matrices that reduce a general matrix A to bidiagonal
39
- * form: A = U*B*VT, as computed by CGEBRD, then
40
- *
41
- * A = (U*Q) * S * (P**H*VT)
42
- *
43
- * is the SVD of A. Optionally, the subroutine may also compute Q**H*C
44
- * for a given complex input matrix C.
45
- *
46
- * See "Computing Small Singular Values of Bidiagonal Matrices With
47
- * Guaranteed High Relative Accuracy," by J. Demmel and W. Kahan,
48
- * LAPACK Working Note #3 (or SIAM J. Sci. Statist. Comput. vol. 11,
49
- * no. 5, pp. 873-912, Sept 1990) and
50
- * "Accurate singular values and differential qd algorithms," by
51
- * B. Parlett and V. Fernando, Technical Report CPAM-554, Mathematics
52
- * Department, University of California at Berkeley, July 1992
53
- * for a detailed description of the algorithm.
54
- *
55
-
56
- * Arguments
57
- * =========
58
- *
59
- * UPLO (input) CHARACTER*1
60
- * = 'U': B is upper bidiagonal;
61
- * = 'L': B is lower bidiagonal.
62
- *
63
- * N (input) INTEGER
64
- * The order of the matrix B. N >= 0.
65
- *
66
- * NCVT (input) INTEGER
67
- * The number of columns of the matrix VT. NCVT >= 0.
68
- *
69
- * NRU (input) INTEGER
70
- * The number of rows of the matrix U. NRU >= 0.
71
- *
72
- * NCC (input) INTEGER
73
- * The number of columns of the matrix C. NCC >= 0.
74
- *
75
- * D (input/output) REAL array, dimension (N)
76
- * On entry, the n diagonal elements of the bidiagonal matrix B.
77
- * On exit, if INFO=0, the singular values of B in decreasing
78
- * order.
79
- *
80
- * E (input/output) REAL array, dimension (N-1)
81
- * On entry, the N-1 offdiagonal elements of the bidiagonal
82
- * matrix B.
83
- * On exit, if INFO = 0, E is destroyed; if INFO > 0, D and E
84
- * will contain the diagonal and superdiagonal elements of a
85
- * bidiagonal matrix orthogonally equivalent to the one given
86
- * as input.
87
- *
88
- * VT (input/output) COMPLEX array, dimension (LDVT, NCVT)
89
- * On entry, an N-by-NCVT matrix VT.
90
- * On exit, VT is overwritten by P**H * VT.
91
- * Not referenced if NCVT = 0.
92
- *
93
- * LDVT (input) INTEGER
94
- * The leading dimension of the array VT.
95
- * LDVT >= max(1,N) if NCVT > 0; LDVT >= 1 if NCVT = 0.
96
- *
97
- * U (input/output) COMPLEX array, dimension (LDU, N)
98
- * On entry, an NRU-by-N matrix U.
99
- * On exit, U is overwritten by U * Q.
100
- * Not referenced if NRU = 0.
101
- *
102
- * LDU (input) INTEGER
103
- * The leading dimension of the array U. LDU >= max(1,NRU).
104
- *
105
- * C (input/output) COMPLEX array, dimension (LDC, NCC)
106
- * On entry, an N-by-NCC matrix C.
107
- * On exit, C is overwritten by Q**H * C.
108
- * Not referenced if NCC = 0.
109
- *
110
- * LDC (input) INTEGER
111
- * The leading dimension of the array C.
112
- * LDC >= max(1,N) if NCC > 0; LDC >=1 if NCC = 0.
113
- *
114
- * RWORK (workspace) REAL array, dimension (2*N)
115
- * if NCVT = NRU = NCC = 0, (max(1, 4*N-4)) otherwise
116
- *
117
- * INFO (output) INTEGER
118
- * = 0: successful exit
119
- * < 0: If INFO = -i, the i-th argument had an illegal value
120
- * > 0: the algorithm did not converge; D and E contain the
121
- * elements of a bidiagonal matrix which is orthogonally
122
- * similar to the input matrix B; if INFO = i, i
123
- * elements of E have not converged to zero.
124
- *
125
- * Internal Parameters
126
- * ===================
127
- *
128
- * TOLMUL REAL, default = max(10,min(100,EPS**(-1/8)))
129
- * TOLMUL controls the convergence criterion of the QR loop.
130
- * If it is positive, TOLMUL*EPS is the desired relative
131
- * precision in the computed singular values.
132
- * If it is negative, abs(TOLMUL*EPS*sigma_max) is the
133
- * desired absolute accuracy in the computed singular
134
- * values (corresponds to relative accuracy
135
- * abs(TOLMUL*EPS) in the largest singular value.
136
- * abs(TOLMUL) should be between 1 and 1/EPS, and preferably
137
- * between 10 (for fast convergence) and .1/EPS
138
- * (for there to be some accuracy in the results).
139
- * Default is to lose at either one eighth or 2 of the
140
- * available decimal digits in each computed singular value
141
- * (whichever is smaller).
142
- *
143
- * MAXITR INTEGER, default = 6
144
- * MAXITR controls the maximum number of passes of the
145
- * algorithm through its inner loop. The algorithms stops
146
- * (and so fails to converge) if the number of passes
147
- * through the inner loop exceeds MAXITR*N**2.
148
- *
149
-
150
- * =====================================================================
151
- *
152
-
153
-
154
- </PRE>
155
- <A HREF="#top">go to the page top</A>
156
-
157
- <HR />
158
- <A HREF="c.html">back to matrix types</A><BR>
159
- <A HREF="c.html">back to data types</A>
160
- </BODY>
161
- </HTML>
data/doc/cgb.html DELETED
@@ -1,1865 +0,0 @@
1
- <HTML>
2
- <HEAD>
3
- <TITLE>COMPLEX routines for general band matrix</TITLE>
4
- </HEAD>
5
- <BODY>
6
- <A NAME="top"></A>
7
- <H1>COMPLEX routines for general band matrix</H1>
8
- <UL>
9
- <LI><A HREF="#cgbbrd">cgbbrd</A></LI>
10
- <LI><A HREF="#cgbcon">cgbcon</A></LI>
11
- <LI><A HREF="#cgbequ">cgbequ</A></LI>
12
- <LI><A HREF="#cgbequb">cgbequb</A></LI>
13
- <LI><A HREF="#cgbrfs">cgbrfs</A></LI>
14
- <LI><A HREF="#cgbrfsx">cgbrfsx</A></LI>
15
- <LI><A HREF="#cgbsv">cgbsv</A></LI>
16
- <LI><A HREF="#cgbsvx">cgbsvx</A></LI>
17
- <LI><A HREF="#cgbsvxx">cgbsvxx</A></LI>
18
- <LI><A HREF="#cgbtf2">cgbtf2</A></LI>
19
- <LI><A HREF="#cgbtrf">cgbtrf</A></LI>
20
- <LI><A HREF="#cgbtrs">cgbtrs</A></LI>
21
- </UL>
22
-
23
- <A NAME="cgbbrd"></A>
24
- <H2>cgbbrd</H2>
25
- <PRE>
26
- USAGE:
27
- d, e, q, pt, info, ab, c = NumRu::Lapack.cgbbrd( vect, kl, ku, ab, c, [:usage => usage, :help => help])
28
-
29
-
30
- FORTRAN MANUAL
31
- SUBROUTINE CGBBRD( VECT, M, N, NCC, KL, KU, AB, LDAB, D, E, Q, LDQ, PT, LDPT, C, LDC, WORK, RWORK, INFO )
32
-
33
- * Purpose
34
- * =======
35
- *
36
- * CGBBRD reduces a complex general m-by-n band matrix A to real upper
37
- * bidiagonal form B by a unitary transformation: Q' * A * P = B.
38
- *
39
- * The routine computes B, and optionally forms Q or P', or computes
40
- * Q'*C for a given matrix C.
41
- *
42
-
43
- * Arguments
44
- * =========
45
- *
46
- * VECT (input) CHARACTER*1
47
- * Specifies whether or not the matrices Q and P' are to be
48
- * formed.
49
- * = 'N': do not form Q or P';
50
- * = 'Q': form Q only;
51
- * = 'P': form P' only;
52
- * = 'B': form both.
53
- *
54
- * M (input) INTEGER
55
- * The number of rows of the matrix A. M >= 0.
56
- *
57
- * N (input) INTEGER
58
- * The number of columns of the matrix A. N >= 0.
59
- *
60
- * NCC (input) INTEGER
61
- * The number of columns of the matrix C. NCC >= 0.
62
- *
63
- * KL (input) INTEGER
64
- * The number of subdiagonals of the matrix A. KL >= 0.
65
- *
66
- * KU (input) INTEGER
67
- * The number of superdiagonals of the matrix A. KU >= 0.
68
- *
69
- * AB (input/output) COMPLEX array, dimension (LDAB,N)
70
- * On entry, the m-by-n band matrix A, stored in rows 1 to
71
- * KL+KU+1. The j-th column of A is stored in the j-th column of
72
- * the array AB as follows:
73
- * AB(ku+1+i-j,j) = A(i,j) for max(1,j-ku)<=i<=min(m,j+kl).
74
- * On exit, A is overwritten by values generated during the
75
- * reduction.
76
- *
77
- * LDAB (input) INTEGER
78
- * The leading dimension of the array A. LDAB >= KL+KU+1.
79
- *
80
- * D (output) REAL array, dimension (min(M,N))
81
- * The diagonal elements of the bidiagonal matrix B.
82
- *
83
- * E (output) REAL array, dimension (min(M,N)-1)
84
- * The superdiagonal elements of the bidiagonal matrix B.
85
- *
86
- * Q (output) COMPLEX array, dimension (LDQ,M)
87
- * If VECT = 'Q' or 'B', the m-by-m unitary matrix Q.
88
- * If VECT = 'N' or 'P', the array Q is not referenced.
89
- *
90
- * LDQ (input) INTEGER
91
- * The leading dimension of the array Q.
92
- * LDQ >= max(1,M) if VECT = 'Q' or 'B'; LDQ >= 1 otherwise.
93
- *
94
- * PT (output) COMPLEX array, dimension (LDPT,N)
95
- * If VECT = 'P' or 'B', the n-by-n unitary matrix P'.
96
- * If VECT = 'N' or 'Q', the array PT is not referenced.
97
- *
98
- * LDPT (input) INTEGER
99
- * The leading dimension of the array PT.
100
- * LDPT >= max(1,N) if VECT = 'P' or 'B'; LDPT >= 1 otherwise.
101
- *
102
- * C (input/output) COMPLEX array, dimension (LDC,NCC)
103
- * On entry, an m-by-ncc matrix C.
104
- * On exit, C is overwritten by Q'*C.
105
- * C is not referenced if NCC = 0.
106
- *
107
- * LDC (input) INTEGER
108
- * The leading dimension of the array C.
109
- * LDC >= max(1,M) if NCC > 0; LDC >= 1 if NCC = 0.
110
- *
111
- * WORK (workspace) COMPLEX array, dimension (max(M,N))
112
- *
113
- * RWORK (workspace) REAL array, dimension (max(M,N))
114
- *
115
- * INFO (output) INTEGER
116
- * = 0: successful exit.
117
- * < 0: if INFO = -i, the i-th argument had an illegal value.
118
- *
119
-
120
- * =====================================================================
121
- *
122
-
123
-
124
- </PRE>
125
- <A HREF="#top">go to the page top</A>
126
-
127
- <A NAME="cgbcon"></A>
128
- <H2>cgbcon</H2>
129
- <PRE>
130
- USAGE:
131
- rcond, info = NumRu::Lapack.cgbcon( norm, kl, ku, ab, ipiv, anorm, [:usage => usage, :help => help])
132
-
133
-
134
- FORTRAN MANUAL
135
- SUBROUTINE CGBCON( NORM, N, KL, KU, AB, LDAB, IPIV, ANORM, RCOND, WORK, RWORK, INFO )
136
-
137
- * Purpose
138
- * =======
139
- *
140
- * CGBCON estimates the reciprocal of the condition number of a complex
141
- * general band matrix A, in either the 1-norm or the infinity-norm,
142
- * using the LU factorization computed by CGBTRF.
143
- *
144
- * An estimate is obtained for norm(inv(A)), and the reciprocal of the
145
- * condition number is computed as
146
- * RCOND = 1 / ( norm(A) * norm(inv(A)) ).
147
- *
148
-
149
- * Arguments
150
- * =========
151
- *
152
- * NORM (input) CHARACTER*1
153
- * Specifies whether the 1-norm condition number or the
154
- * infinity-norm condition number is required:
155
- * = '1' or 'O': 1-norm;
156
- * = 'I': Infinity-norm.
157
- *
158
- * N (input) INTEGER
159
- * The order of the matrix A. N >= 0.
160
- *
161
- * KL (input) INTEGER
162
- * The number of subdiagonals within the band of A. KL >= 0.
163
- *
164
- * KU (input) INTEGER
165
- * The number of superdiagonals within the band of A. KU >= 0.
166
- *
167
- * AB (input) COMPLEX array, dimension (LDAB,N)
168
- * Details of the LU factorization of the band matrix A, as
169
- * computed by CGBTRF. U is stored as an upper triangular band
170
- * matrix with KL+KU superdiagonals in rows 1 to KL+KU+1, and
171
- * the multipliers used during the factorization are stored in
172
- * rows KL+KU+2 to 2*KL+KU+1.
173
- *
174
- * LDAB (input) INTEGER
175
- * The leading dimension of the array AB. LDAB >= 2*KL+KU+1.
176
- *
177
- * IPIV (input) INTEGER array, dimension (N)
178
- * The pivot indices; for 1 <= i <= N, row i of the matrix was
179
- * interchanged with row IPIV(i).
180
- *
181
- * ANORM (input) REAL
182
- * If NORM = '1' or 'O', the 1-norm of the original matrix A.
183
- * If NORM = 'I', the infinity-norm of the original matrix A.
184
- *
185
- * RCOND (output) REAL
186
- * The reciprocal of the condition number of the matrix A,
187
- * computed as RCOND = 1/(norm(A) * norm(inv(A))).
188
- *
189
- * WORK (workspace) COMPLEX array, dimension (2*N)
190
- *
191
- * RWORK (workspace) REAL array, dimension (N)
192
- *
193
- * INFO (output) INTEGER
194
- * = 0: successful exit
195
- * < 0: if INFO = -i, the i-th argument had an illegal value
196
- *
197
-
198
- * =====================================================================
199
- *
200
-
201
-
202
- </PRE>
203
- <A HREF="#top">go to the page top</A>
204
-
205
- <A NAME="cgbequ"></A>
206
- <H2>cgbequ</H2>
207
- <PRE>
208
- USAGE:
209
- r, c, rowcnd, colcnd, amax, info = NumRu::Lapack.cgbequ( m, kl, ku, ab, [:usage => usage, :help => help])
210
-
211
-
212
- FORTRAN MANUAL
213
- SUBROUTINE CGBEQU( M, N, KL, KU, AB, LDAB, R, C, ROWCND, COLCND, AMAX, INFO )
214
-
215
- * Purpose
216
- * =======
217
- *
218
- * CGBEQU computes row and column scalings intended to equilibrate an
219
- * M-by-N band matrix A and reduce its condition number. R returns the
220
- * row scale factors and C the column scale factors, chosen to try to
221
- * make the largest element in each row and column of the matrix B with
222
- * elements B(i,j)=R(i)*A(i,j)*C(j) have absolute value 1.
223
- *
224
- * R(i) and C(j) are restricted to be between SMLNUM = smallest safe
225
- * number and BIGNUM = largest safe number. Use of these scaling
226
- * factors is not guaranteed to reduce the condition number of A but
227
- * works well in practice.
228
- *
229
-
230
- * Arguments
231
- * =========
232
- *
233
- * M (input) INTEGER
234
- * The number of rows of the matrix A. M >= 0.
235
- *
236
- * N (input) INTEGER
237
- * The number of columns of the matrix A. N >= 0.
238
- *
239
- * KL (input) INTEGER
240
- * The number of subdiagonals within the band of A. KL >= 0.
241
- *
242
- * KU (input) INTEGER
243
- * The number of superdiagonals within the band of A. KU >= 0.
244
- *
245
- * AB (input) COMPLEX array, dimension (LDAB,N)
246
- * The band matrix A, stored in rows 1 to KL+KU+1. The j-th
247
- * column of A is stored in the j-th column of the array AB as
248
- * follows:
249
- * AB(ku+1+i-j,j) = A(i,j) for max(1,j-ku)<=i<=min(m,j+kl).
250
- *
251
- * LDAB (input) INTEGER
252
- * The leading dimension of the array AB. LDAB >= KL+KU+1.
253
- *
254
- * R (output) REAL array, dimension (M)
255
- * If INFO = 0, or INFO > M, R contains the row scale factors
256
- * for A.
257
- *
258
- * C (output) REAL array, dimension (N)
259
- * If INFO = 0, C contains the column scale factors for A.
260
- *
261
- * ROWCND (output) REAL
262
- * If INFO = 0 or INFO > M, ROWCND contains the ratio of the
263
- * smallest R(i) to the largest R(i). If ROWCND >= 0.1 and
264
- * AMAX is neither too large nor too small, it is not worth
265
- * scaling by R.
266
- *
267
- * COLCND (output) REAL
268
- * If INFO = 0, COLCND contains the ratio of the smallest
269
- * C(i) to the largest C(i). If COLCND >= 0.1, it is not
270
- * worth scaling by C.
271
- *
272
- * AMAX (output) REAL
273
- * Absolute value of largest matrix element. If AMAX is very
274
- * close to overflow or very close to underflow, the matrix
275
- * should be scaled.
276
- *
277
- * INFO (output) INTEGER
278
- * = 0: successful exit
279
- * < 0: if INFO = -i, the i-th argument had an illegal value
280
- * > 0: if INFO = i, and i is
281
- * <= M: the i-th row of A is exactly zero
282
- * > M: the (i-M)-th column of A is exactly zero
283
- *
284
-
285
- * =====================================================================
286
- *
287
-
288
-
289
- </PRE>
290
- <A HREF="#top">go to the page top</A>
291
-
292
- <A NAME="cgbequb"></A>
293
- <H2>cgbequb</H2>
294
- <PRE>
295
- USAGE:
296
- r, c, rowcnd, colcnd, amax, info = NumRu::Lapack.cgbequb( kl, ku, ab, [:usage => usage, :help => help])
297
-
298
-
299
- FORTRAN MANUAL
300
- SUBROUTINE CGBEQUB( M, N, KL, KU, AB, LDAB, R, C, ROWCND, COLCND, AMAX, INFO )
301
-
302
- * Purpose
303
- * =======
304
- *
305
- * CGBEQUB computes row and column scalings intended to equilibrate an
306
- * M-by-N matrix A and reduce its condition number. R returns the row
307
- * scale factors and C the column scale factors, chosen to try to make
308
- * the largest element in each row and column of the matrix B with
309
- * elements B(i,j)=R(i)*A(i,j)*C(j) have an absolute value of at most
310
- * the radix.
311
- *
312
- * R(i) and C(j) are restricted to be a power of the radix between
313
- * SMLNUM = smallest safe number and BIGNUM = largest safe number. Use
314
- * of these scaling factors is not guaranteed to reduce the condition
315
- * number of A but works well in practice.
316
- *
317
- * This routine differs from CGEEQU by restricting the scaling factors
318
- * to a power of the radix. Baring over- and underflow, scaling by
319
- * these factors introduces no additional rounding errors. However, the
320
- * scaled entries' magnitured are no longer approximately 1 but lie
321
- * between sqrt(radix) and 1/sqrt(radix).
322
- *
323
-
324
- * Arguments
325
- * =========
326
- *
327
- * M (input) INTEGER
328
- * The number of rows of the matrix A. M >= 0.
329
- *
330
- * N (input) INTEGER
331
- * The number of columns of the matrix A. N >= 0.
332
- *
333
- * KL (input) INTEGER
334
- * The number of subdiagonals within the band of A. KL >= 0.
335
- *
336
- * KU (input) INTEGER
337
- * The number of superdiagonals within the band of A. KU >= 0.
338
- *
339
- * AB (input) DOUBLE PRECISION array, dimension (LDAB,N)
340
- * On entry, the matrix A in band storage, in rows 1 to KL+KU+1.
341
- * The j-th column of A is stored in the j-th column of the
342
- * array AB as follows:
343
- * AB(KU+1+i-j,j) = A(i,j) for max(1,j-KU)<=i<=min(N,j+kl)
344
- *
345
- * LDAB (input) INTEGER
346
- * The leading dimension of the array A. LDAB >= max(1,M).
347
- *
348
- * R (output) REAL array, dimension (M)
349
- * If INFO = 0 or INFO > M, R contains the row scale factors
350
- * for A.
351
- *
352
- * C (output) REAL array, dimension (N)
353
- * If INFO = 0, C contains the column scale factors for A.
354
- *
355
- * ROWCND (output) REAL
356
- * If INFO = 0 or INFO > M, ROWCND contains the ratio of the
357
- * smallest R(i) to the largest R(i). If ROWCND >= 0.1 and
358
- * AMAX is neither too large nor too small, it is not worth
359
- * scaling by R.
360
- *
361
- * COLCND (output) REAL
362
- * If INFO = 0, COLCND contains the ratio of the smallest
363
- * C(i) to the largest C(i). If COLCND >= 0.1, it is not
364
- * worth scaling by C.
365
- *
366
- * AMAX (output) REAL
367
- * Absolute value of largest matrix element. If AMAX is very
368
- * close to overflow or very close to underflow, the matrix
369
- * should be scaled.
370
- *
371
- * INFO (output) INTEGER
372
- * = 0: successful exit
373
- * < 0: if INFO = -i, the i-th argument had an illegal value
374
- * > 0: if INFO = i, and i is
375
- * <= M: the i-th row of A is exactly zero
376
- * > M: the (i-M)-th column of A is exactly zero
377
- *
378
-
379
- * =====================================================================
380
- *
381
-
382
-
383
- </PRE>
384
- <A HREF="#top">go to the page top</A>
385
-
386
- <A NAME="cgbrfs"></A>
387
- <H2>cgbrfs</H2>
388
- <PRE>
389
- USAGE:
390
- ferr, berr, info, x = NumRu::Lapack.cgbrfs( trans, kl, ku, ab, afb, ipiv, b, x, [:usage => usage, :help => help])
391
-
392
-
393
- FORTRAN MANUAL
394
- SUBROUTINE CGBRFS( TRANS, N, KL, KU, NRHS, AB, LDAB, AFB, LDAFB, IPIV, B, LDB, X, LDX, FERR, BERR, WORK, RWORK, INFO )
395
-
396
- * Purpose
397
- * =======
398
- *
399
- * CGBRFS improves the computed solution to a system of linear
400
- * equations when the coefficient matrix is banded, and provides
401
- * error bounds and backward error estimates for the solution.
402
- *
403
-
404
- * Arguments
405
- * =========
406
- *
407
- * TRANS (input) CHARACTER*1
408
- * Specifies the form of the system of equations:
409
- * = 'N': A * X = B (No transpose)
410
- * = 'T': A**T * X = B (Transpose)
411
- * = 'C': A**H * X = B (Conjugate transpose)
412
- *
413
- * N (input) INTEGER
414
- * The order of the matrix A. N >= 0.
415
- *
416
- * KL (input) INTEGER
417
- * The number of subdiagonals within the band of A. KL >= 0.
418
- *
419
- * KU (input) INTEGER
420
- * The number of superdiagonals within the band of A. KU >= 0.
421
- *
422
- * NRHS (input) INTEGER
423
- * The number of right hand sides, i.e., the number of columns
424
- * of the matrices B and X. NRHS >= 0.
425
- *
426
- * AB (input) COMPLEX array, dimension (LDAB,N)
427
- * The original band matrix A, stored in rows 1 to KL+KU+1.
428
- * The j-th column of A is stored in the j-th column of the
429
- * array AB as follows:
430
- * AB(ku+1+i-j,j) = A(i,j) for max(1,j-ku)<=i<=min(n,j+kl).
431
- *
432
- * LDAB (input) INTEGER
433
- * The leading dimension of the array AB. LDAB >= KL+KU+1.
434
- *
435
- * AFB (input) COMPLEX array, dimension (LDAFB,N)
436
- * Details of the LU factorization of the band matrix A, as
437
- * computed by CGBTRF. U is stored as an upper triangular band
438
- * matrix with KL+KU superdiagonals in rows 1 to KL+KU+1, and
439
- * the multipliers used during the factorization are stored in
440
- * rows KL+KU+2 to 2*KL+KU+1.
441
- *
442
- * LDAFB (input) INTEGER
443
- * The leading dimension of the array AFB. LDAFB >= 2*KL*KU+1.
444
- *
445
- * IPIV (input) INTEGER array, dimension (N)
446
- * The pivot indices from CGBTRF; for 1<=i<=N, row i of the
447
- * matrix was interchanged with row IPIV(i).
448
- *
449
- * B (input) COMPLEX array, dimension (LDB,NRHS)
450
- * The right hand side matrix B.
451
- *
452
- * LDB (input) INTEGER
453
- * The leading dimension of the array B. LDB >= max(1,N).
454
- *
455
- * X (input/output) COMPLEX array, dimension (LDX,NRHS)
456
- * On entry, the solution matrix X, as computed by CGBTRS.
457
- * On exit, the improved solution matrix X.
458
- *
459
- * LDX (input) INTEGER
460
- * The leading dimension of the array X. LDX >= max(1,N).
461
- *
462
- * FERR (output) REAL array, dimension (NRHS)
463
- * The estimated forward error bound for each solution vector
464
- * X(j) (the j-th column of the solution matrix X).
465
- * If XTRUE is the true solution corresponding to X(j), FERR(j)
466
- * is an estimated upper bound for the magnitude of the largest
467
- * element in (X(j) - XTRUE) divided by the magnitude of the
468
- * largest element in X(j). The estimate is as reliable as
469
- * the estimate for RCOND, and is almost always a slight
470
- * overestimate of the true error.
471
- *
472
- * BERR (output) REAL array, dimension (NRHS)
473
- * The componentwise relative backward error of each solution
474
- * vector X(j) (i.e., the smallest relative change in
475
- * any element of A or B that makes X(j) an exact solution).
476
- *
477
- * WORK (workspace) COMPLEX array, dimension (2*N)
478
- *
479
- * RWORK (workspace) REAL array, dimension (N)
480
- *
481
- * INFO (output) INTEGER
482
- * = 0: successful exit
483
- * < 0: if INFO = -i, the i-th argument had an illegal value
484
- *
485
- * Internal Parameters
486
- * ===================
487
- *
488
- * ITMAX is the maximum number of steps of iterative refinement.
489
- *
490
-
491
- * =====================================================================
492
- *
493
-
494
-
495
- </PRE>
496
- <A HREF="#top">go to the page top</A>
497
-
498
- <A NAME="cgbrfsx"></A>
499
- <H2>cgbrfsx</H2>
500
- <PRE>
501
- USAGE:
502
- rcond, berr, err_bnds_norm, err_bnds_comp, info, r, c, x, params = NumRu::Lapack.cgbrfsx( trans, equed, kl, ku, ab, afb, ipiv, r, c, b, x, params, [:usage => usage, :help => help])
503
-
504
-
505
- FORTRAN MANUAL
506
- SUBROUTINE CGBRFSX( TRANS, EQUED, N, KL, KU, NRHS, AB, LDAB, AFB, LDAFB, IPIV, R, C, B, LDB, X, LDX, RCOND, BERR, N_ERR_BNDS, ERR_BNDS_NORM, ERR_BNDS_COMP, NPARAMS, PARAMS, WORK, RWORK, INFO )
507
-
508
- * Purpose
509
- * =======
510
- *
511
- * CGBRFSX improves the computed solution to a system of linear
512
- * equations and provides error bounds and backward error estimates
513
- * for the solution. In addition to normwise error bound, the code
514
- * provides maximum componentwise error bound if possible. See
515
- * comments for ERR_BNDS_NORM and ERR_BNDS_COMP for details of the
516
- * error bounds.
517
- *
518
- * The original system of linear equations may have been equilibrated
519
- * before calling this routine, as described by arguments EQUED, R
520
- * and C below. In this case, the solution and error bounds returned
521
- * are for the original unequilibrated system.
522
- *
523
-
524
- * Arguments
525
- * =========
526
- *
527
- * Some optional parameters are bundled in the PARAMS array. These
528
- * settings determine how refinement is performed, but often the
529
- * defaults are acceptable. If the defaults are acceptable, users
530
- * can pass NPARAMS = 0 which prevents the source code from accessing
531
- * the PARAMS argument.
532
- *
533
- * TRANS (input) CHARACTER*1
534
- * Specifies the form of the system of equations:
535
- * = 'N': A * X = B (No transpose)
536
- * = 'T': A**T * X = B (Transpose)
537
- * = 'C': A**H * X = B (Conjugate transpose = Transpose)
538
- *
539
- * EQUED (input) CHARACTER*1
540
- * Specifies the form of equilibration that was done to A
541
- * before calling this routine. This is needed to compute
542
- * the solution and error bounds correctly.
543
- * = 'N': No equilibration
544
- * = 'R': Row equilibration, i.e., A has been premultiplied by
545
- * diag(R).
546
- * = 'C': Column equilibration, i.e., A has been postmultiplied
547
- * by diag(C).
548
- * = 'B': Both row and column equilibration, i.e., A has been
549
- * replaced by diag(R) * A * diag(C).
550
- * The right hand side B has been changed accordingly.
551
- *
552
- * N (input) INTEGER
553
- * The order of the matrix A. N >= 0.
554
- *
555
- * KL (input) INTEGER
556
- * The number of subdiagonals within the band of A. KL >= 0.
557
- *
558
- * KU (input) INTEGER
559
- * The number of superdiagonals within the band of A. KU >= 0.
560
- *
561
- * NRHS (input) INTEGER
562
- * The number of right hand sides, i.e., the number of columns
563
- * of the matrices B and X. NRHS >= 0.
564
- *
565
- * AB (input) DOUBLE PRECISION array, dimension (LDAB,N)
566
- * The original band matrix A, stored in rows 1 to KL+KU+1.
567
- * The j-th column of A is stored in the j-th column of the
568
- * array AB as follows:
569
- * AB(ku+1+i-j,j) = A(i,j) for max(1,j-ku)<=i<=min(n,j+kl).
570
- *
571
- * LDAB (input) INTEGER
572
- * The leading dimension of the array AB. LDAB >= KL+KU+1.
573
- *
574
- * AFB (input) DOUBLE PRECISION array, dimension (LDAFB,N)
575
- * Details of the LU factorization of the band matrix A, as
576
- * computed by DGBTRF. U is stored as an upper triangular band
577
- * matrix with KL+KU superdiagonals in rows 1 to KL+KU+1, and
578
- * the multipliers used during the factorization are stored in
579
- * rows KL+KU+2 to 2*KL+KU+1.
580
- *
581
- * LDAFB (input) INTEGER
582
- * The leading dimension of the array AFB. LDAFB >= 2*KL*KU+1.
583
- *
584
- * IPIV (input) INTEGER array, dimension (N)
585
- * The pivot indices from SGETRF; for 1<=i<=N, row i of the
586
- * matrix was interchanged with row IPIV(i).
587
- *
588
- * R (input or output) REAL array, dimension (N)
589
- * The row scale factors for A. If EQUED = 'R' or 'B', A is
590
- * multiplied on the left by diag(R); if EQUED = 'N' or 'C', R
591
- * is not accessed. R is an input argument if FACT = 'F';
592
- * otherwise, R is an output argument. If FACT = 'F' and
593
- * EQUED = 'R' or 'B', each element of R must be positive.
594
- * If R is output, each element of R is a power of the radix.
595
- * If R is input, each element of R should be a power of the radix
596
- * to ensure a reliable solution and error estimates. Scaling by
597
- * powers of the radix does not cause rounding errors unless the
598
- * result underflows or overflows. Rounding errors during scaling
599
- * lead to refining with a matrix that is not equivalent to the
600
- * input matrix, producing error estimates that may not be
601
- * reliable.
602
- *
603
- * C (input or output) REAL array, dimension (N)
604
- * The column scale factors for A. If EQUED = 'C' or 'B', A is
605
- * multiplied on the right by diag(C); if EQUED = 'N' or 'R', C
606
- * is not accessed. C is an input argument if FACT = 'F';
607
- * otherwise, C is an output argument. If FACT = 'F' and
608
- * EQUED = 'C' or 'B', each element of C must be positive.
609
- * If C is output, each element of C is a power of the radix.
610
- * If C is input, each element of C should be a power of the radix
611
- * to ensure a reliable solution and error estimates. Scaling by
612
- * powers of the radix does not cause rounding errors unless the
613
- * result underflows or overflows. Rounding errors during scaling
614
- * lead to refining with a matrix that is not equivalent to the
615
- * input matrix, producing error estimates that may not be
616
- * reliable.
617
- *
618
- * B (input) REAL array, dimension (LDB,NRHS)
619
- * The right hand side matrix B.
620
- *
621
- * LDB (input) INTEGER
622
- * The leading dimension of the array B. LDB >= max(1,N).
623
- *
624
- * X (input/output) REAL array, dimension (LDX,NRHS)
625
- * On entry, the solution matrix X, as computed by SGETRS.
626
- * On exit, the improved solution matrix X.
627
- *
628
- * LDX (input) INTEGER
629
- * The leading dimension of the array X. LDX >= max(1,N).
630
- *
631
- * RCOND (output) REAL
632
- * Reciprocal scaled condition number. This is an estimate of the
633
- * reciprocal Skeel condition number of the matrix A after
634
- * equilibration (if done). If this is less than the machine
635
- * precision (in particular, if it is zero), the matrix is singular
636
- * to working precision. Note that the error may still be small even
637
- * if this number is very small and the matrix appears ill-
638
- * conditioned.
639
- *
640
- * BERR (output) REAL array, dimension (NRHS)
641
- * Componentwise relative backward error. This is the
642
- * componentwise relative backward error of each solution vector X(j)
643
- * (i.e., the smallest relative change in any element of A or B that
644
- * makes X(j) an exact solution).
645
- *
646
- * N_ERR_BNDS (input) INTEGER
647
- * Number of error bounds to return for each right hand side
648
- * and each type (normwise or componentwise). See ERR_BNDS_NORM and
649
- * ERR_BNDS_COMP below.
650
- *
651
- * ERR_BNDS_NORM (output) REAL array, dimension (NRHS, N_ERR_BNDS)
652
- * For each right-hand side, this array contains information about
653
- * various error bounds and condition numbers corresponding to the
654
- * normwise relative error, which is defined as follows:
655
- *
656
- * Normwise relative error in the ith solution vector:
657
- * max_j (abs(XTRUE(j,i) - X(j,i)))
658
- * ------------------------------
659
- * max_j abs(X(j,i))
660
- *
661
- * The array is indexed by the type of error information as described
662
- * below. There currently are up to three pieces of information
663
- * returned.
664
- *
665
- * The first index in ERR_BNDS_NORM(i,:) corresponds to the ith
666
- * right-hand side.
667
- *
668
- * The second index in ERR_BNDS_NORM(:,err) contains the following
669
- * three fields:
670
- * err = 1 "Trust/don't trust" boolean. Trust the answer if the
671
- * reciprocal condition number is less than the threshold
672
- * sqrt(n) * slamch('Epsilon').
673
- *
674
- * err = 2 "Guaranteed" error bound: The estimated forward error,
675
- * almost certainly within a factor of 10 of the true error
676
- * so long as the next entry is greater than the threshold
677
- * sqrt(n) * slamch('Epsilon'). This error bound should only
678
- * be trusted if the previous boolean is true.
679
- *
680
- * err = 3 Reciprocal condition number: Estimated normwise
681
- * reciprocal condition number. Compared with the threshold
682
- * sqrt(n) * slamch('Epsilon') to determine if the error
683
- * estimate is "guaranteed". These reciprocal condition
684
- * numbers are 1 / (norm(Z^{-1},inf) * norm(Z,inf)) for some
685
- * appropriately scaled matrix Z.
686
- * Let Z = S*A, where S scales each row by a power of the
687
- * radix so all absolute row sums of Z are approximately 1.
688
- *
689
- * See Lapack Working Note 165 for further details and extra
690
- * cautions.
691
- *
692
- * ERR_BNDS_COMP (output) REAL array, dimension (NRHS, N_ERR_BNDS)
693
- * For each right-hand side, this array contains information about
694
- * various error bounds and condition numbers corresponding to the
695
- * componentwise relative error, which is defined as follows:
696
- *
697
- * Componentwise relative error in the ith solution vector:
698
- * abs(XTRUE(j,i) - X(j,i))
699
- * max_j ----------------------
700
- * abs(X(j,i))
701
- *
702
- * The array is indexed by the right-hand side i (on which the
703
- * componentwise relative error depends), and the type of error
704
- * information as described below. There currently are up to three
705
- * pieces of information returned for each right-hand side. If
706
- * componentwise accuracy is not requested (PARAMS(3) = 0.0), then
707
- * ERR_BNDS_COMP is not accessed. If N_ERR_BNDS .LT. 3, then at most
708
- * the first (:,N_ERR_BNDS) entries are returned.
709
- *
710
- * The first index in ERR_BNDS_COMP(i,:) corresponds to the ith
711
- * right-hand side.
712
- *
713
- * The second index in ERR_BNDS_COMP(:,err) contains the following
714
- * three fields:
715
- * err = 1 "Trust/don't trust" boolean. Trust the answer if the
716
- * reciprocal condition number is less than the threshold
717
- * sqrt(n) * slamch('Epsilon').
718
- *
719
- * err = 2 "Guaranteed" error bound: The estimated forward error,
720
- * almost certainly within a factor of 10 of the true error
721
- * so long as the next entry is greater than the threshold
722
- * sqrt(n) * slamch('Epsilon'). This error bound should only
723
- * be trusted if the previous boolean is true.
724
- *
725
- * err = 3 Reciprocal condition number: Estimated componentwise
726
- * reciprocal condition number. Compared with the threshold
727
- * sqrt(n) * slamch('Epsilon') to determine if the error
728
- * estimate is "guaranteed". These reciprocal condition
729
- * numbers are 1 / (norm(Z^{-1},inf) * norm(Z,inf)) for some
730
- * appropriately scaled matrix Z.
731
- * Let Z = S*(A*diag(x)), where x is the solution for the
732
- * current right-hand side and S scales each row of
733
- * A*diag(x) by a power of the radix so all absolute row
734
- * sums of Z are approximately 1.
735
- *
736
- * See Lapack Working Note 165 for further details and extra
737
- * cautions.
738
- *
739
- * NPARAMS (input) INTEGER
740
- * Specifies the number of parameters set in PARAMS. If .LE. 0, the
741
- * PARAMS array is never referenced and default values are used.
742
- *
743
- * PARAMS (input / output) REAL array, dimension NPARAMS
744
- * Specifies algorithm parameters. If an entry is .LT. 0.0, then
745
- * that entry will be filled with default value used for that
746
- * parameter. Only positions up to NPARAMS are accessed; defaults
747
- * are used for higher-numbered parameters.
748
- *
749
- * PARAMS(LA_LINRX_ITREF_I = 1) : Whether to perform iterative
750
- * refinement or not.
751
- * Default: 1.0
752
- * = 0.0 : No refinement is performed, and no error bounds are
753
- * computed.
754
- * = 1.0 : Use the double-precision refinement algorithm,
755
- * possibly with doubled-single computations if the
756
- * compilation environment does not support DOUBLE
757
- * PRECISION.
758
- * (other values are reserved for future use)
759
- *
760
- * PARAMS(LA_LINRX_ITHRESH_I = 2) : Maximum number of residual
761
- * computations allowed for refinement.
762
- * Default: 10
763
- * Aggressive: Set to 100 to permit convergence using approximate
764
- * factorizations or factorizations other than LU. If
765
- * the factorization uses a technique other than
766
- * Gaussian elimination, the guarantees in
767
- * err_bnds_norm and err_bnds_comp may no longer be
768
- * trustworthy.
769
- *
770
- * PARAMS(LA_LINRX_CWISE_I = 3) : Flag determining if the code
771
- * will attempt to find a solution with small componentwise
772
- * relative error in the double-precision algorithm. Positive
773
- * is true, 0.0 is false.
774
- * Default: 1.0 (attempt componentwise convergence)
775
- *
776
- * WORK (workspace) COMPLEX array, dimension (2*N)
777
- *
778
- * RWORK (workspace) REAL array, dimension (2*N)
779
- *
780
- * INFO (output) INTEGER
781
- * = 0: Successful exit. The solution to every right-hand side is
782
- * guaranteed.
783
- * < 0: If INFO = -i, the i-th argument had an illegal value
784
- * > 0 and <= N: U(INFO,INFO) is exactly zero. The factorization
785
- * has been completed, but the factor U is exactly singular, so
786
- * the solution and error bounds could not be computed. RCOND = 0
787
- * is returned.
788
- * = N+J: The solution corresponding to the Jth right-hand side is
789
- * not guaranteed. The solutions corresponding to other right-
790
- * hand sides K with K > J may not be guaranteed as well, but
791
- * only the first such right-hand side is reported. If a small
792
- * componentwise error is not requested (PARAMS(3) = 0.0) then
793
- * the Jth right-hand side is the first with a normwise error
794
- * bound that is not guaranteed (the smallest J such
795
- * that ERR_BNDS_NORM(J,1) = 0.0). By default (PARAMS(3) = 1.0)
796
- * the Jth right-hand side is the first with either a normwise or
797
- * componentwise error bound that is not guaranteed (the smallest
798
- * J such that either ERR_BNDS_NORM(J,1) = 0.0 or
799
- * ERR_BNDS_COMP(J,1) = 0.0). See the definition of
800
- * ERR_BNDS_NORM(:,1) and ERR_BNDS_COMP(:,1). To get information
801
- * about all of the right-hand sides check ERR_BNDS_NORM or
802
- * ERR_BNDS_COMP.
803
- *
804
-
805
- * ==================================================================
806
- *
807
-
808
-
809
- </PRE>
810
- <A HREF="#top">go to the page top</A>
811
-
812
- <A NAME="cgbsv"></A>
813
- <H2>cgbsv</H2>
814
- <PRE>
815
- USAGE:
816
- ipiv, info, ab, b = NumRu::Lapack.cgbsv( kl, ku, ab, b, [:usage => usage, :help => help])
817
-
818
-
819
- FORTRAN MANUAL
820
- SUBROUTINE CGBSV( N, KL, KU, NRHS, AB, LDAB, IPIV, B, LDB, INFO )
821
-
822
- * Purpose
823
- * =======
824
- *
825
- * CGBSV computes the solution to a complex system of linear equations
826
- * A * X = B, where A is a band matrix of order N with KL subdiagonals
827
- * and KU superdiagonals, and X and B are N-by-NRHS matrices.
828
- *
829
- * The LU decomposition with partial pivoting and row interchanges is
830
- * used to factor A as A = L * U, where L is a product of permutation
831
- * and unit lower triangular matrices with KL subdiagonals, and U is
832
- * upper triangular with KL+KU superdiagonals. The factored form of A
833
- * is then used to solve the system of equations A * X = B.
834
- *
835
-
836
- * Arguments
837
- * =========
838
- *
839
- * N (input) INTEGER
840
- * The number of linear equations, i.e., the order of the
841
- * matrix A. N >= 0.
842
- *
843
- * KL (input) INTEGER
844
- * The number of subdiagonals within the band of A. KL >= 0.
845
- *
846
- * KU (input) INTEGER
847
- * The number of superdiagonals within the band of A. KU >= 0.
848
- *
849
- * NRHS (input) INTEGER
850
- * The number of right hand sides, i.e., the number of columns
851
- * of the matrix B. NRHS >= 0.
852
- *
853
- * AB (input/output) COMPLEX array, dimension (LDAB,N)
854
- * On entry, the matrix A in band storage, in rows KL+1 to
855
- * 2*KL+KU+1; rows 1 to KL of the array need not be set.
856
- * The j-th column of A is stored in the j-th column of the
857
- * array AB as follows:
858
- * AB(KL+KU+1+i-j,j) = A(i,j) for max(1,j-KU)<=i<=min(N,j+KL)
859
- * On exit, details of the factorization: U is stored as an
860
- * upper triangular band matrix with KL+KU superdiagonals in
861
- * rows 1 to KL+KU+1, and the multipliers used during the
862
- * factorization are stored in rows KL+KU+2 to 2*KL+KU+1.
863
- * See below for further details.
864
- *
865
- * LDAB (input) INTEGER
866
- * The leading dimension of the array AB. LDAB >= 2*KL+KU+1.
867
- *
868
- * IPIV (output) INTEGER array, dimension (N)
869
- * The pivot indices that define the permutation matrix P;
870
- * row i of the matrix was interchanged with row IPIV(i).
871
- *
872
- * B (input/output) COMPLEX array, dimension (LDB,NRHS)
873
- * On entry, the N-by-NRHS right hand side matrix B.
874
- * On exit, if INFO = 0, the N-by-NRHS solution matrix X.
875
- *
876
- * LDB (input) INTEGER
877
- * The leading dimension of the array B. LDB >= max(1,N).
878
- *
879
- * INFO (output) INTEGER
880
- * = 0: successful exit
881
- * < 0: if INFO = -i, the i-th argument had an illegal value
882
- * > 0: if INFO = i, U(i,i) is exactly zero. The factorization
883
- * has been completed, but the factor U is exactly
884
- * singular, and the solution has not been computed.
885
- *
886
-
887
- * Further Details
888
- * ===============
889
- *
890
- * The band storage scheme is illustrated by the following example, when
891
- * M = N = 6, KL = 2, KU = 1:
892
- *
893
- * On entry: On exit:
894
- *
895
- * * * * + + + * * * u14 u25 u36
896
- * * * + + + + * * u13 u24 u35 u46
897
- * * a12 a23 a34 a45 a56 * u12 u23 u34 u45 u56
898
- * a11 a22 a33 a44 a55 a66 u11 u22 u33 u44 u55 u66
899
- * a21 a32 a43 a54 a65 * m21 m32 m43 m54 m65 *
900
- * a31 a42 a53 a64 * * m31 m42 m53 m64 * *
901
- *
902
- * Array elements marked * are not used by the routine; elements marked
903
- * + need not be set on entry, but are required by the routine to store
904
- * elements of U because of fill-in resulting from the row interchanges.
905
- *
906
- * =====================================================================
907
- *
908
- * .. External Subroutines ..
909
- EXTERNAL CGBTRF, CGBTRS, XERBLA
910
- * ..
911
- * .. Intrinsic Functions ..
912
- INTRINSIC MAX
913
- * ..
914
-
915
-
916
- </PRE>
917
- <A HREF="#top">go to the page top</A>
918
-
919
- <A NAME="cgbsvx"></A>
920
- <H2>cgbsvx</H2>
921
- <PRE>
922
- USAGE:
923
- x, rcond, ferr, berr, rwork, info, ab, afb, ipiv, equed, r, c, b = NumRu::Lapack.cgbsvx( fact, trans, kl, ku, ab, b, [:afb => afb, :ipiv => ipiv, :equed => equed, :r => r, :c => c, :usage => usage, :help => help])
924
-
925
-
926
- FORTRAN MANUAL
927
- SUBROUTINE CGBSVX( FACT, TRANS, N, KL, KU, NRHS, AB, LDAB, AFB, LDAFB, IPIV, EQUED, R, C, B, LDB, X, LDX, RCOND, FERR, BERR, WORK, RWORK, INFO )
928
-
929
- * Purpose
930
- * =======
931
- *
932
- * CGBSVX uses the LU factorization to compute the solution to a complex
933
- * system of linear equations A * X = B, A**T * X = B, or A**H * X = B,
934
- * where A is a band matrix of order N with KL subdiagonals and KU
935
- * superdiagonals, and X and B are N-by-NRHS matrices.
936
- *
937
- * Error bounds on the solution and a condition estimate are also
938
- * provided.
939
- *
940
- * Description
941
- * ===========
942
- *
943
- * The following steps are performed by this subroutine:
944
- *
945
- * 1. If FACT = 'E', real scaling factors are computed to equilibrate
946
- * the system:
947
- * TRANS = 'N': diag(R)*A*diag(C) *inv(diag(C))*X = diag(R)*B
948
- * TRANS = 'T': (diag(R)*A*diag(C))**T *inv(diag(R))*X = diag(C)*B
949
- * TRANS = 'C': (diag(R)*A*diag(C))**H *inv(diag(R))*X = diag(C)*B
950
- * Whether or not the system will be equilibrated depends on the
951
- * scaling of the matrix A, but if equilibration is used, A is
952
- * overwritten by diag(R)*A*diag(C) and B by diag(R)*B (if TRANS='N')
953
- * or diag(C)*B (if TRANS = 'T' or 'C').
954
- *
955
- * 2. If FACT = 'N' or 'E', the LU decomposition is used to factor the
956
- * matrix A (after equilibration if FACT = 'E') as
957
- * A = L * U,
958
- * where L is a product of permutation and unit lower triangular
959
- * matrices with KL subdiagonals, and U is upper triangular with
960
- * KL+KU superdiagonals.
961
- *
962
- * 3. If some U(i,i)=0, so that U is exactly singular, then the routine
963
- * returns with INFO = i. Otherwise, the factored form of A is used
964
- * to estimate the condition number of the matrix A. If the
965
- * reciprocal of the condition number is less than machine precision,
966
- * INFO = N+1 is returned as a warning, but the routine still goes on
967
- * to solve for X and compute error bounds as described below.
968
- *
969
- * 4. The system of equations is solved for X using the factored form
970
- * of A.
971
- *
972
- * 5. Iterative refinement is applied to improve the computed solution
973
- * matrix and calculate error bounds and backward error estimates
974
- * for it.
975
- *
976
- * 6. If equilibration was used, the matrix X is premultiplied by
977
- * diag(C) (if TRANS = 'N') or diag(R) (if TRANS = 'T' or 'C') so
978
- * that it solves the original system before equilibration.
979
- *
980
-
981
- * Arguments
982
- * =========
983
- *
984
- * FACT (input) CHARACTER*1
985
- * Specifies whether or not the factored form of the matrix A is
986
- * supplied on entry, and if not, whether the matrix A should be
987
- * equilibrated before it is factored.
988
- * = 'F': On entry, AFB and IPIV contain the factored form of
989
- * A. If EQUED is not 'N', the matrix A has been
990
- * equilibrated with scaling factors given by R and C.
991
- * AB, AFB, and IPIV are not modified.
992
- * = 'N': The matrix A will be copied to AFB and factored.
993
- * = 'E': The matrix A will be equilibrated if necessary, then
994
- * copied to AFB and factored.
995
- *
996
- * TRANS (input) CHARACTER*1
997
- * Specifies the form of the system of equations.
998
- * = 'N': A * X = B (No transpose)
999
- * = 'T': A**T * X = B (Transpose)
1000
- * = 'C': A**H * X = B (Conjugate transpose)
1001
- *
1002
- * N (input) INTEGER
1003
- * The number of linear equations, i.e., the order of the
1004
- * matrix A. N >= 0.
1005
- *
1006
- * KL (input) INTEGER
1007
- * The number of subdiagonals within the band of A. KL >= 0.
1008
- *
1009
- * KU (input) INTEGER
1010
- * The number of superdiagonals within the band of A. KU >= 0.
1011
- *
1012
- * NRHS (input) INTEGER
1013
- * The number of right hand sides, i.e., the number of columns
1014
- * of the matrices B and X. NRHS >= 0.
1015
- *
1016
- * AB (input/output) COMPLEX array, dimension (LDAB,N)
1017
- * On entry, the matrix A in band storage, in rows 1 to KL+KU+1.
1018
- * The j-th column of A is stored in the j-th column of the
1019
- * array AB as follows:
1020
- * AB(KU+1+i-j,j) = A(i,j) for max(1,j-KU)<=i<=min(N,j+kl)
1021
- *
1022
- * If FACT = 'F' and EQUED is not 'N', then A must have been
1023
- * equilibrated by the scaling factors in R and/or C. AB is not
1024
- * modified if FACT = 'F' or 'N', or if FACT = 'E' and
1025
- * EQUED = 'N' on exit.
1026
- *
1027
- * On exit, if EQUED .ne. 'N', A is scaled as follows:
1028
- * EQUED = 'R': A := diag(R) * A
1029
- * EQUED = 'C': A := A * diag(C)
1030
- * EQUED = 'B': A := diag(R) * A * diag(C).
1031
- *
1032
- * LDAB (input) INTEGER
1033
- * The leading dimension of the array AB. LDAB >= KL+KU+1.
1034
- *
1035
- * AFB (input or output) COMPLEX array, dimension (LDAFB,N)
1036
- * If FACT = 'F', then AFB is an input argument and on entry
1037
- * contains details of the LU factorization of the band matrix
1038
- * A, as computed by CGBTRF. U is stored as an upper triangular
1039
- * band matrix with KL+KU superdiagonals in rows 1 to KL+KU+1,
1040
- * and the multipliers used during the factorization are stored
1041
- * in rows KL+KU+2 to 2*KL+KU+1. If EQUED .ne. 'N', then AFB is
1042
- * the factored form of the equilibrated matrix A.
1043
- *
1044
- * If FACT = 'N', then AFB is an output argument and on exit
1045
- * returns details of the LU factorization of A.
1046
- *
1047
- * If FACT = 'E', then AFB is an output argument and on exit
1048
- * returns details of the LU factorization of the equilibrated
1049
- * matrix A (see the description of AB for the form of the
1050
- * equilibrated matrix).
1051
- *
1052
- * LDAFB (input) INTEGER
1053
- * The leading dimension of the array AFB. LDAFB >= 2*KL+KU+1.
1054
- *
1055
- * IPIV (input or output) INTEGER array, dimension (N)
1056
- * If FACT = 'F', then IPIV is an input argument and on entry
1057
- * contains the pivot indices from the factorization A = L*U
1058
- * as computed by CGBTRF; row i of the matrix was interchanged
1059
- * with row IPIV(i).
1060
- *
1061
- * If FACT = 'N', then IPIV is an output argument and on exit
1062
- * contains the pivot indices from the factorization A = L*U
1063
- * of the original matrix A.
1064
- *
1065
- * If FACT = 'E', then IPIV is an output argument and on exit
1066
- * contains the pivot indices from the factorization A = L*U
1067
- * of the equilibrated matrix A.
1068
- *
1069
- * EQUED (input or output) CHARACTER*1
1070
- * Specifies the form of equilibration that was done.
1071
- * = 'N': No equilibration (always true if FACT = 'N').
1072
- * = 'R': Row equilibration, i.e., A has been premultiplied by
1073
- * diag(R).
1074
- * = 'C': Column equilibration, i.e., A has been postmultiplied
1075
- * by diag(C).
1076
- * = 'B': Both row and column equilibration, i.e., A has been
1077
- * replaced by diag(R) * A * diag(C).
1078
- * EQUED is an input argument if FACT = 'F'; otherwise, it is an
1079
- * output argument.
1080
- *
1081
- * R (input or output) REAL array, dimension (N)
1082
- * The row scale factors for A. If EQUED = 'R' or 'B', A is
1083
- * multiplied on the left by diag(R); if EQUED = 'N' or 'C', R
1084
- * is not accessed. R is an input argument if FACT = 'F';
1085
- * otherwise, R is an output argument. If FACT = 'F' and
1086
- * EQUED = 'R' or 'B', each element of R must be positive.
1087
- *
1088
- * C (input or output) REAL array, dimension (N)
1089
- * The column scale factors for A. If EQUED = 'C' or 'B', A is
1090
- * multiplied on the right by diag(C); if EQUED = 'N' or 'R', C
1091
- * is not accessed. C is an input argument if FACT = 'F';
1092
- * otherwise, C is an output argument. If FACT = 'F' and
1093
- * EQUED = 'C' or 'B', each element of C must be positive.
1094
- *
1095
- * B (input/output) COMPLEX array, dimension (LDB,NRHS)
1096
- * On entry, the right hand side matrix B.
1097
- * On exit,
1098
- * if EQUED = 'N', B is not modified;
1099
- * if TRANS = 'N' and EQUED = 'R' or 'B', B is overwritten by
1100
- * diag(R)*B;
1101
- * if TRANS = 'T' or 'C' and EQUED = 'C' or 'B', B is
1102
- * overwritten by diag(C)*B.
1103
- *
1104
- * LDB (input) INTEGER
1105
- * The leading dimension of the array B. LDB >= max(1,N).
1106
- *
1107
- * X (output) COMPLEX array, dimension (LDX,NRHS)
1108
- * If INFO = 0 or INFO = N+1, the N-by-NRHS solution matrix X
1109
- * to the original system of equations. Note that A and B are
1110
- * modified on exit if EQUED .ne. 'N', and the solution to the
1111
- * equilibrated system is inv(diag(C))*X if TRANS = 'N' and
1112
- * EQUED = 'C' or 'B', or inv(diag(R))*X if TRANS = 'T' or 'C'
1113
- * and EQUED = 'R' or 'B'.
1114
- *
1115
- * LDX (input) INTEGER
1116
- * The leading dimension of the array X. LDX >= max(1,N).
1117
- *
1118
- * RCOND (output) REAL
1119
- * The estimate of the reciprocal condition number of the matrix
1120
- * A after equilibration (if done). If RCOND is less than the
1121
- * machine precision (in particular, if RCOND = 0), the matrix
1122
- * is singular to working precision. This condition is
1123
- * indicated by a return code of INFO > 0.
1124
- *
1125
- * FERR (output) REAL array, dimension (NRHS)
1126
- * The estimated forward error bound for each solution vector
1127
- * X(j) (the j-th column of the solution matrix X).
1128
- * If XTRUE is the true solution corresponding to X(j), FERR(j)
1129
- * is an estimated upper bound for the magnitude of the largest
1130
- * element in (X(j) - XTRUE) divided by the magnitude of the
1131
- * largest element in X(j). The estimate is as reliable as
1132
- * the estimate for RCOND, and is almost always a slight
1133
- * overestimate of the true error.
1134
- *
1135
- * BERR (output) REAL array, dimension (NRHS)
1136
- * The componentwise relative backward error of each solution
1137
- * vector X(j) (i.e., the smallest relative change in
1138
- * any element of A or B that makes X(j) an exact solution).
1139
- *
1140
- * WORK (workspace) COMPLEX array, dimension (2*N)
1141
- *
1142
- * RWORK (workspace/output) REAL array, dimension (N)
1143
- * On exit, RWORK(1) contains the reciprocal pivot growth
1144
- * factor norm(A)/norm(U). The "max absolute element" norm is
1145
- * used. If RWORK(1) is much less than 1, then the stability
1146
- * of the LU factorization of the (equilibrated) matrix A
1147
- * could be poor. This also means that the solution X, condition
1148
- * estimator RCOND, and forward error bound FERR could be
1149
- * unreliable. If factorization fails with 0<INFO<=N, then
1150
- * RWORK(1) contains the reciprocal pivot growth factor for the
1151
- * leading INFO columns of A.
1152
- *
1153
- * INFO (output) INTEGER
1154
- * = 0: successful exit
1155
- * < 0: if INFO = -i, the i-th argument had an illegal value
1156
- * > 0: if INFO = i, and i is
1157
- * <= N: U(i,i) is exactly zero. The factorization
1158
- * has been completed, but the factor U is exactly
1159
- * singular, so the solution and error bounds
1160
- * could not be computed. RCOND = 0 is returned.
1161
- * = N+1: U is nonsingular, but RCOND is less than machine
1162
- * precision, meaning that the matrix is singular
1163
- * to working precision. Nevertheless, the
1164
- * solution and error bounds are computed because
1165
- * there are a number of situations where the
1166
- * computed solution can be more accurate than the
1167
- * value of RCOND would suggest.
1168
- *
1169
-
1170
- * =====================================================================
1171
- * Moved setting of INFO = N+1 so INFO does not subsequently get
1172
- * overwritten. Sven, 17 Mar 05.
1173
- * =====================================================================
1174
- *
1175
-
1176
-
1177
- </PRE>
1178
- <A HREF="#top">go to the page top</A>
1179
-
1180
- <A NAME="cgbsvxx"></A>
1181
- <H2>cgbsvxx</H2>
1182
- <PRE>
1183
- USAGE:
1184
- x, rcond, rpvgrw, berr, err_bnds_norm, err_bnds_comp, info, ab, afb, ipiv, equed, r, c, b, params = NumRu::Lapack.cgbsvxx( fact, trans, kl, ku, ab, afb, ipiv, equed, r, c, b, params, [:usage => usage, :help => help])
1185
-
1186
-
1187
- FORTRAN MANUAL
1188
- SUBROUTINE CGBSVXX( FACT, TRANS, N, KL, KU, NRHS, AB, LDAB, AFB, LDAFB, IPIV, EQUED, R, C, B, LDB, X, LDX, RCOND, RPVGRW, BERR, N_ERR_BNDS, ERR_BNDS_NORM, ERR_BNDS_COMP, NPARAMS, PARAMS, WORK, RWORK, INFO )
1189
-
1190
- * Purpose
1191
- * =======
1192
- *
1193
- * CGBSVXX uses the LU factorization to compute the solution to a
1194
- * complex system of linear equations A * X = B, where A is an
1195
- * N-by-N matrix and X and B are N-by-NRHS matrices.
1196
- *
1197
- * If requested, both normwise and maximum componentwise error bounds
1198
- * are returned. CGBSVXX will return a solution with a tiny
1199
- * guaranteed error (O(eps) where eps is the working machine
1200
- * precision) unless the matrix is very ill-conditioned, in which
1201
- * case a warning is returned. Relevant condition numbers also are
1202
- * calculated and returned.
1203
- *
1204
- * CGBSVXX accepts user-provided factorizations and equilibration
1205
- * factors; see the definitions of the FACT and EQUED options.
1206
- * Solving with refinement and using a factorization from a previous
1207
- * CGBSVXX call will also produce a solution with either O(eps)
1208
- * errors or warnings, but we cannot make that claim for general
1209
- * user-provided factorizations and equilibration factors if they
1210
- * differ from what CGBSVXX would itself produce.
1211
- *
1212
- * Description
1213
- * ===========
1214
- *
1215
- * The following steps are performed:
1216
- *
1217
- * 1. If FACT = 'E', real scaling factors are computed to equilibrate
1218
- * the system:
1219
- *
1220
- * TRANS = 'N': diag(R)*A*diag(C) *inv(diag(C))*X = diag(R)*B
1221
- * TRANS = 'T': (diag(R)*A*diag(C))**T *inv(diag(R))*X = diag(C)*B
1222
- * TRANS = 'C': (diag(R)*A*diag(C))**H *inv(diag(R))*X = diag(C)*B
1223
- *
1224
- * Whether or not the system will be equilibrated depends on the
1225
- * scaling of the matrix A, but if equilibration is used, A is
1226
- * overwritten by diag(R)*A*diag(C) and B by diag(R)*B (if TRANS='N')
1227
- * or diag(C)*B (if TRANS = 'T' or 'C').
1228
- *
1229
- * 2. If FACT = 'N' or 'E', the LU decomposition is used to factor
1230
- * the matrix A (after equilibration if FACT = 'E') as
1231
- *
1232
- * A = P * L * U,
1233
- *
1234
- * where P is a permutation matrix, L is a unit lower triangular
1235
- * matrix, and U is upper triangular.
1236
- *
1237
- * 3. If some U(i,i)=0, so that U is exactly singular, then the
1238
- * routine returns with INFO = i. Otherwise, the factored form of A
1239
- * is used to estimate the condition number of the matrix A (see
1240
- * argument RCOND). If the reciprocal of the condition number is less
1241
- * than machine precision, the routine still goes on to solve for X
1242
- * and compute error bounds as described below.
1243
- *
1244
- * 4. The system of equations is solved for X using the factored form
1245
- * of A.
1246
- *
1247
- * 5. By default (unless PARAMS(LA_LINRX_ITREF_I) is set to zero),
1248
- * the routine will use iterative refinement to try to get a small
1249
- * error and error bounds. Refinement calculates the residual to at
1250
- * least twice the working precision.
1251
- *
1252
- * 6. If equilibration was used, the matrix X is premultiplied by
1253
- * diag(C) (if TRANS = 'N') or diag(R) (if TRANS = 'T' or 'C') so
1254
- * that it solves the original system before equilibration.
1255
- *
1256
-
1257
- * Arguments
1258
- * =========
1259
- *
1260
- * Some optional parameters are bundled in the PARAMS array. These
1261
- * settings determine how refinement is performed, but often the
1262
- * defaults are acceptable. If the defaults are acceptable, users
1263
- * can pass NPARAMS = 0 which prevents the source code from accessing
1264
- * the PARAMS argument.
1265
- *
1266
- * FACT (input) CHARACTER*1
1267
- * Specifies whether or not the factored form of the matrix A is
1268
- * supplied on entry, and if not, whether the matrix A should be
1269
- * equilibrated before it is factored.
1270
- * = 'F': On entry, AF and IPIV contain the factored form of A.
1271
- * If EQUED is not 'N', the matrix A has been
1272
- * equilibrated with scaling factors given by R and C.
1273
- * A, AF, and IPIV are not modified.
1274
- * = 'N': The matrix A will be copied to AF and factored.
1275
- * = 'E': The matrix A will be equilibrated if necessary, then
1276
- * copied to AF and factored.
1277
- *
1278
- * TRANS (input) CHARACTER*1
1279
- * Specifies the form of the system of equations:
1280
- * = 'N': A * X = B (No transpose)
1281
- * = 'T': A**T * X = B (Transpose)
1282
- * = 'C': A**H * X = B (Conjugate Transpose = Transpose)
1283
- *
1284
- * N (input) INTEGER
1285
- * The number of linear equations, i.e., the order of the
1286
- * matrix A. N >= 0.
1287
- *
1288
- * KL (input) INTEGER
1289
- * The number of subdiagonals within the band of A. KL >= 0.
1290
- *
1291
- * KU (input) INTEGER
1292
- * The number of superdiagonals within the band of A. KU >= 0.
1293
- *
1294
- * NRHS (input) INTEGER
1295
- * The number of right hand sides, i.e., the number of columns
1296
- * of the matrices B and X. NRHS >= 0.
1297
- *
1298
- * AB (input/output) REAL array, dimension (LDAB,N)
1299
- * On entry, the matrix A in band storage, in rows 1 to KL+KU+1.
1300
- * The j-th column of A is stored in the j-th column of the
1301
- * array AB as follows:
1302
- * AB(KU+1+i-j,j) = A(i,j) for max(1,j-KU)<=i<=min(N,j+kl)
1303
- *
1304
- * If FACT = 'F' and EQUED is not 'N', then AB must have been
1305
- * equilibrated by the scaling factors in R and/or C. AB is not
1306
- * modified if FACT = 'F' or 'N', or if FACT = 'E' and
1307
- * EQUED = 'N' on exit.
1308
- *
1309
- * On exit, if EQUED .ne. 'N', A is scaled as follows:
1310
- * EQUED = 'R': A := diag(R) * A
1311
- * EQUED = 'C': A := A * diag(C)
1312
- * EQUED = 'B': A := diag(R) * A * diag(C).
1313
- *
1314
- * LDAB (input) INTEGER
1315
- * The leading dimension of the array AB. LDAB >= KL+KU+1.
1316
- *
1317
- * AFB (input or output) REAL array, dimension (LDAFB,N)
1318
- * If FACT = 'F', then AFB is an input argument and on entry
1319
- * contains details of the LU factorization of the band matrix
1320
- * A, as computed by CGBTRF. U is stored as an upper triangular
1321
- * band matrix with KL+KU superdiagonals in rows 1 to KL+KU+1,
1322
- * and the multipliers used during the factorization are stored
1323
- * in rows KL+KU+2 to 2*KL+KU+1. If EQUED .ne. 'N', then AFB is
1324
- * the factored form of the equilibrated matrix A.
1325
- *
1326
- * If FACT = 'N', then AF is an output argument and on exit
1327
- * returns the factors L and U from the factorization A = P*L*U
1328
- * of the original matrix A.
1329
- *
1330
- * If FACT = 'E', then AF is an output argument and on exit
1331
- * returns the factors L and U from the factorization A = P*L*U
1332
- * of the equilibrated matrix A (see the description of A for
1333
- * the form of the equilibrated matrix).
1334
- *
1335
- * LDAFB (input) INTEGER
1336
- * The leading dimension of the array AFB. LDAFB >= 2*KL+KU+1.
1337
- *
1338
- * IPIV (input or output) INTEGER array, dimension (N)
1339
- * If FACT = 'F', then IPIV is an input argument and on entry
1340
- * contains the pivot indices from the factorization A = P*L*U
1341
- * as computed by SGETRF; row i of the matrix was interchanged
1342
- * with row IPIV(i).
1343
- *
1344
- * If FACT = 'N', then IPIV is an output argument and on exit
1345
- * contains the pivot indices from the factorization A = P*L*U
1346
- * of the original matrix A.
1347
- *
1348
- * If FACT = 'E', then IPIV is an output argument and on exit
1349
- * contains the pivot indices from the factorization A = P*L*U
1350
- * of the equilibrated matrix A.
1351
- *
1352
- * EQUED (input or output) CHARACTER*1
1353
- * Specifies the form of equilibration that was done.
1354
- * = 'N': No equilibration (always true if FACT = 'N').
1355
- * = 'R': Row equilibration, i.e., A has been premultiplied by
1356
- * diag(R).
1357
- * = 'C': Column equilibration, i.e., A has been postmultiplied
1358
- * by diag(C).
1359
- * = 'B': Both row and column equilibration, i.e., A has been
1360
- * replaced by diag(R) * A * diag(C).
1361
- * EQUED is an input argument if FACT = 'F'; otherwise, it is an
1362
- * output argument.
1363
- *
1364
- * R (input or output) REAL array, dimension (N)
1365
- * The row scale factors for A. If EQUED = 'R' or 'B', A is
1366
- * multiplied on the left by diag(R); if EQUED = 'N' or 'C', R
1367
- * is not accessed. R is an input argument if FACT = 'F';
1368
- * otherwise, R is an output argument. If FACT = 'F' and
1369
- * EQUED = 'R' or 'B', each element of R must be positive.
1370
- * If R is output, each element of R is a power of the radix.
1371
- * If R is input, each element of R should be a power of the radix
1372
- * to ensure a reliable solution and error estimates. Scaling by
1373
- * powers of the radix does not cause rounding errors unless the
1374
- * result underflows or overflows. Rounding errors during scaling
1375
- * lead to refining with a matrix that is not equivalent to the
1376
- * input matrix, producing error estimates that may not be
1377
- * reliable.
1378
- *
1379
- * C (input or output) REAL array, dimension (N)
1380
- * The column scale factors for A. If EQUED = 'C' or 'B', A is
1381
- * multiplied on the right by diag(C); if EQUED = 'N' or 'R', C
1382
- * is not accessed. C is an input argument if FACT = 'F';
1383
- * otherwise, C is an output argument. If FACT = 'F' and
1384
- * EQUED = 'C' or 'B', each element of C must be positive.
1385
- * If C is output, each element of C is a power of the radix.
1386
- * If C is input, each element of C should be a power of the radix
1387
- * to ensure a reliable solution and error estimates. Scaling by
1388
- * powers of the radix does not cause rounding errors unless the
1389
- * result underflows or overflows. Rounding errors during scaling
1390
- * lead to refining with a matrix that is not equivalent to the
1391
- * input matrix, producing error estimates that may not be
1392
- * reliable.
1393
- *
1394
- * B (input/output) REAL array, dimension (LDB,NRHS)
1395
- * On entry, the N-by-NRHS right hand side matrix B.
1396
- * On exit,
1397
- * if EQUED = 'N', B is not modified;
1398
- * if TRANS = 'N' and EQUED = 'R' or 'B', B is overwritten by
1399
- * diag(R)*B;
1400
- * if TRANS = 'T' or 'C' and EQUED = 'C' or 'B', B is
1401
- * overwritten by diag(C)*B.
1402
- *
1403
- * LDB (input) INTEGER
1404
- * The leading dimension of the array B. LDB >= max(1,N).
1405
- *
1406
- * X (output) REAL array, dimension (LDX,NRHS)
1407
- * If INFO = 0, the N-by-NRHS solution matrix X to the original
1408
- * system of equations. Note that A and B are modified on exit
1409
- * if EQUED .ne. 'N', and the solution to the equilibrated system is
1410
- * inv(diag(C))*X if TRANS = 'N' and EQUED = 'C' or 'B', or
1411
- * inv(diag(R))*X if TRANS = 'T' or 'C' and EQUED = 'R' or 'B'.
1412
- *
1413
- * LDX (input) INTEGER
1414
- * The leading dimension of the array X. LDX >= max(1,N).
1415
- *
1416
- * RCOND (output) REAL
1417
- * Reciprocal scaled condition number. This is an estimate of the
1418
- * reciprocal Skeel condition number of the matrix A after
1419
- * equilibration (if done). If this is less than the machine
1420
- * precision (in particular, if it is zero), the matrix is singular
1421
- * to working precision. Note that the error may still be small even
1422
- * if this number is very small and the matrix appears ill-
1423
- * conditioned.
1424
- *
1425
- * RPVGRW (output) REAL
1426
- * Reciprocal pivot growth. On exit, this contains the reciprocal
1427
- * pivot growth factor norm(A)/norm(U). The "max absolute element"
1428
- * norm is used. If this is much less than 1, then the stability of
1429
- * the LU factorization of the (equilibrated) matrix A could be poor.
1430
- * This also means that the solution X, estimated condition numbers,
1431
- * and error bounds could be unreliable. If factorization fails with
1432
- * 0<INFO<=N, then this contains the reciprocal pivot growth factor
1433
- * for the leading INFO columns of A. In SGESVX, this quantity is
1434
- * returned in WORK(1).
1435
- *
1436
- * BERR (output) REAL array, dimension (NRHS)
1437
- * Componentwise relative backward error. This is the
1438
- * componentwise relative backward error of each solution vector X(j)
1439
- * (i.e., the smallest relative change in any element of A or B that
1440
- * makes X(j) an exact solution).
1441
- *
1442
- * N_ERR_BNDS (input) INTEGER
1443
- * Number of error bounds to return for each right hand side
1444
- * and each type (normwise or componentwise). See ERR_BNDS_NORM and
1445
- * ERR_BNDS_COMP below.
1446
- *
1447
- * ERR_BNDS_NORM (output) REAL array, dimension (NRHS, N_ERR_BNDS)
1448
- * For each right-hand side, this array contains information about
1449
- * various error bounds and condition numbers corresponding to the
1450
- * normwise relative error, which is defined as follows:
1451
- *
1452
- * Normwise relative error in the ith solution vector:
1453
- * max_j (abs(XTRUE(j,i) - X(j,i)))
1454
- * ------------------------------
1455
- * max_j abs(X(j,i))
1456
- *
1457
- * The array is indexed by the type of error information as described
1458
- * below. There currently are up to three pieces of information
1459
- * returned.
1460
- *
1461
- * The first index in ERR_BNDS_NORM(i,:) corresponds to the ith
1462
- * right-hand side.
1463
- *
1464
- * The second index in ERR_BNDS_NORM(:,err) contains the following
1465
- * three fields:
1466
- * err = 1 "Trust/don't trust" boolean. Trust the answer if the
1467
- * reciprocal condition number is less than the threshold
1468
- * sqrt(n) * slamch('Epsilon').
1469
- *
1470
- * err = 2 "Guaranteed" error bound: The estimated forward error,
1471
- * almost certainly within a factor of 10 of the true error
1472
- * so long as the next entry is greater than the threshold
1473
- * sqrt(n) * slamch('Epsilon'). This error bound should only
1474
- * be trusted if the previous boolean is true.
1475
- *
1476
- * err = 3 Reciprocal condition number: Estimated normwise
1477
- * reciprocal condition number. Compared with the threshold
1478
- * sqrt(n) * slamch('Epsilon') to determine if the error
1479
- * estimate is "guaranteed". These reciprocal condition
1480
- * numbers are 1 / (norm(Z^{-1},inf) * norm(Z,inf)) for some
1481
- * appropriately scaled matrix Z.
1482
- * Let Z = S*A, where S scales each row by a power of the
1483
- * radix so all absolute row sums of Z are approximately 1.
1484
- *
1485
- * See Lapack Working Note 165 for further details and extra
1486
- * cautions.
1487
- *
1488
- * ERR_BNDS_COMP (output) REAL array, dimension (NRHS, N_ERR_BNDS)
1489
- * For each right-hand side, this array contains information about
1490
- * various error bounds and condition numbers corresponding to the
1491
- * componentwise relative error, which is defined as follows:
1492
- *
1493
- * Componentwise relative error in the ith solution vector:
1494
- * abs(XTRUE(j,i) - X(j,i))
1495
- * max_j ----------------------
1496
- * abs(X(j,i))
1497
- *
1498
- * The array is indexed by the right-hand side i (on which the
1499
- * componentwise relative error depends), and the type of error
1500
- * information as described below. There currently are up to three
1501
- * pieces of information returned for each right-hand side. If
1502
- * componentwise accuracy is not requested (PARAMS(3) = 0.0), then
1503
- * ERR_BNDS_COMP is not accessed. If N_ERR_BNDS .LT. 3, then at most
1504
- * the first (:,N_ERR_BNDS) entries are returned.
1505
- *
1506
- * The first index in ERR_BNDS_COMP(i,:) corresponds to the ith
1507
- * right-hand side.
1508
- *
1509
- * The second index in ERR_BNDS_COMP(:,err) contains the following
1510
- * three fields:
1511
- * err = 1 "Trust/don't trust" boolean. Trust the answer if the
1512
- * reciprocal condition number is less than the threshold
1513
- * sqrt(n) * slamch('Epsilon').
1514
- *
1515
- * err = 2 "Guaranteed" error bound: The estimated forward error,
1516
- * almost certainly within a factor of 10 of the true error
1517
- * so long as the next entry is greater than the threshold
1518
- * sqrt(n) * slamch('Epsilon'). This error bound should only
1519
- * be trusted if the previous boolean is true.
1520
- *
1521
- * err = 3 Reciprocal condition number: Estimated componentwise
1522
- * reciprocal condition number. Compared with the threshold
1523
- * sqrt(n) * slamch('Epsilon') to determine if the error
1524
- * estimate is "guaranteed". These reciprocal condition
1525
- * numbers are 1 / (norm(Z^{-1},inf) * norm(Z,inf)) for some
1526
- * appropriately scaled matrix Z.
1527
- * Let Z = S*(A*diag(x)), where x is the solution for the
1528
- * current right-hand side and S scales each row of
1529
- * A*diag(x) by a power of the radix so all absolute row
1530
- * sums of Z are approximately 1.
1531
- *
1532
- * See Lapack Working Note 165 for further details and extra
1533
- * cautions.
1534
- *
1535
- * NPARAMS (input) INTEGER
1536
- * Specifies the number of parameters set in PARAMS. If .LE. 0, the
1537
- * PARAMS array is never referenced and default values are used.
1538
- *
1539
- * PARAMS (input / output) REAL array, dimension NPARAMS
1540
- * Specifies algorithm parameters. If an entry is .LT. 0.0, then
1541
- * that entry will be filled with default value used for that
1542
- * parameter. Only positions up to NPARAMS are accessed; defaults
1543
- * are used for higher-numbered parameters.
1544
- *
1545
- * PARAMS(LA_LINRX_ITREF_I = 1) : Whether to perform iterative
1546
- * refinement or not.
1547
- * Default: 1.0
1548
- * = 0.0 : No refinement is performed, and no error bounds are
1549
- * computed.
1550
- * = 1.0 : Use the double-precision refinement algorithm,
1551
- * possibly with doubled-single computations if the
1552
- * compilation environment does not support DOUBLE
1553
- * PRECISION.
1554
- * (other values are reserved for future use)
1555
- *
1556
- * PARAMS(LA_LINRX_ITHRESH_I = 2) : Maximum number of residual
1557
- * computations allowed for refinement.
1558
- * Default: 10
1559
- * Aggressive: Set to 100 to permit convergence using approximate
1560
- * factorizations or factorizations other than LU. If
1561
- * the factorization uses a technique other than
1562
- * Gaussian elimination, the guarantees in
1563
- * err_bnds_norm and err_bnds_comp may no longer be
1564
- * trustworthy.
1565
- *
1566
- * PARAMS(LA_LINRX_CWISE_I = 3) : Flag determining if the code
1567
- * will attempt to find a solution with small componentwise
1568
- * relative error in the double-precision algorithm. Positive
1569
- * is true, 0.0 is false.
1570
- * Default: 1.0 (attempt componentwise convergence)
1571
- *
1572
- * WORK (workspace) COMPLEX array, dimension (2*N)
1573
- *
1574
- * RWORK (workspace) REAL array, dimension (2*N)
1575
- *
1576
- * INFO (output) INTEGER
1577
- * = 0: Successful exit. The solution to every right-hand side is
1578
- * guaranteed.
1579
- * < 0: If INFO = -i, the i-th argument had an illegal value
1580
- * > 0 and <= N: U(INFO,INFO) is exactly zero. The factorization
1581
- * has been completed, but the factor U is exactly singular, so
1582
- * the solution and error bounds could not be computed. RCOND = 0
1583
- * is returned.
1584
- * = N+J: The solution corresponding to the Jth right-hand side is
1585
- * not guaranteed. The solutions corresponding to other right-
1586
- * hand sides K with K > J may not be guaranteed as well, but
1587
- * only the first such right-hand side is reported. If a small
1588
- * componentwise error is not requested (PARAMS(3) = 0.0) then
1589
- * the Jth right-hand side is the first with a normwise error
1590
- * bound that is not guaranteed (the smallest J such
1591
- * that ERR_BNDS_NORM(J,1) = 0.0). By default (PARAMS(3) = 1.0)
1592
- * the Jth right-hand side is the first with either a normwise or
1593
- * componentwise error bound that is not guaranteed (the smallest
1594
- * J such that either ERR_BNDS_NORM(J,1) = 0.0 or
1595
- * ERR_BNDS_COMP(J,1) = 0.0). See the definition of
1596
- * ERR_BNDS_NORM(:,1) and ERR_BNDS_COMP(:,1). To get information
1597
- * about all of the right-hand sides check ERR_BNDS_NORM or
1598
- * ERR_BNDS_COMP.
1599
- *
1600
-
1601
- * ==================================================================
1602
- *
1603
-
1604
-
1605
- </PRE>
1606
- <A HREF="#top">go to the page top</A>
1607
-
1608
- <A NAME="cgbtf2"></A>
1609
- <H2>cgbtf2</H2>
1610
- <PRE>
1611
- USAGE:
1612
- ipiv, info, ab = NumRu::Lapack.cgbtf2( m, kl, ku, ab, [:usage => usage, :help => help])
1613
-
1614
-
1615
- FORTRAN MANUAL
1616
- SUBROUTINE CGBTF2( M, N, KL, KU, AB, LDAB, IPIV, INFO )
1617
-
1618
- * Purpose
1619
- * =======
1620
- *
1621
- * CGBTF2 computes an LU factorization of a complex m-by-n band matrix
1622
- * A using partial pivoting with row interchanges.
1623
- *
1624
- * This is the unblocked version of the algorithm, calling Level 2 BLAS.
1625
- *
1626
-
1627
- * Arguments
1628
- * =========
1629
- *
1630
- * M (input) INTEGER
1631
- * The number of rows of the matrix A. M >= 0.
1632
- *
1633
- * N (input) INTEGER
1634
- * The number of columns of the matrix A. N >= 0.
1635
- *
1636
- * KL (input) INTEGER
1637
- * The number of subdiagonals within the band of A. KL >= 0.
1638
- *
1639
- * KU (input) INTEGER
1640
- * The number of superdiagonals within the band of A. KU >= 0.
1641
- *
1642
- * AB (input/output) COMPLEX array, dimension (LDAB,N)
1643
- * On entry, the matrix A in band storage, in rows KL+1 to
1644
- * 2*KL+KU+1; rows 1 to KL of the array need not be set.
1645
- * The j-th column of A is stored in the j-th column of the
1646
- * array AB as follows:
1647
- * AB(kl+ku+1+i-j,j) = A(i,j) for max(1,j-ku)<=i<=min(m,j+kl)
1648
- *
1649
- * On exit, details of the factorization: U is stored as an
1650
- * upper triangular band matrix with KL+KU superdiagonals in
1651
- * rows 1 to KL+KU+1, and the multipliers used during the
1652
- * factorization are stored in rows KL+KU+2 to 2*KL+KU+1.
1653
- * See below for further details.
1654
- *
1655
- * LDAB (input) INTEGER
1656
- * The leading dimension of the array AB. LDAB >= 2*KL+KU+1.
1657
- *
1658
- * IPIV (output) INTEGER array, dimension (min(M,N))
1659
- * The pivot indices; for 1 <= i <= min(M,N), row i of the
1660
- * matrix was interchanged with row IPIV(i).
1661
- *
1662
- * INFO (output) INTEGER
1663
- * = 0: successful exit
1664
- * < 0: if INFO = -i, the i-th argument had an illegal value
1665
- * > 0: if INFO = +i, U(i,i) is exactly zero. The factorization
1666
- * has been completed, but the factor U is exactly
1667
- * singular, and division by zero will occur if it is used
1668
- * to solve a system of equations.
1669
- *
1670
-
1671
- * Further Details
1672
- * ===============
1673
- *
1674
- * The band storage scheme is illustrated by the following example, when
1675
- * M = N = 6, KL = 2, KU = 1:
1676
- *
1677
- * On entry: On exit:
1678
- *
1679
- * * * * + + + * * * u14 u25 u36
1680
- * * * + + + + * * u13 u24 u35 u46
1681
- * * a12 a23 a34 a45 a56 * u12 u23 u34 u45 u56
1682
- * a11 a22 a33 a44 a55 a66 u11 u22 u33 u44 u55 u66
1683
- * a21 a32 a43 a54 a65 * m21 m32 m43 m54 m65 *
1684
- * a31 a42 a53 a64 * * m31 m42 m53 m64 * *
1685
- *
1686
- * Array elements marked * are not used by the routine; elements marked
1687
- * + need not be set on entry, but are required by the routine to store
1688
- * elements of U, because of fill-in resulting from the row
1689
- * interchanges.
1690
- *
1691
- * =====================================================================
1692
- *
1693
-
1694
-
1695
- </PRE>
1696
- <A HREF="#top">go to the page top</A>
1697
-
1698
- <A NAME="cgbtrf"></A>
1699
- <H2>cgbtrf</H2>
1700
- <PRE>
1701
- USAGE:
1702
- ipiv, info, ab = NumRu::Lapack.cgbtrf( m, kl, ku, ab, [:usage => usage, :help => help])
1703
-
1704
-
1705
- FORTRAN MANUAL
1706
- SUBROUTINE CGBTRF( M, N, KL, KU, AB, LDAB, IPIV, INFO )
1707
-
1708
- * Purpose
1709
- * =======
1710
- *
1711
- * CGBTRF computes an LU factorization of a complex m-by-n band matrix A
1712
- * using partial pivoting with row interchanges.
1713
- *
1714
- * This is the blocked version of the algorithm, calling Level 3 BLAS.
1715
- *
1716
-
1717
- * Arguments
1718
- * =========
1719
- *
1720
- * M (input) INTEGER
1721
- * The number of rows of the matrix A. M >= 0.
1722
- *
1723
- * N (input) INTEGER
1724
- * The number of columns of the matrix A. N >= 0.
1725
- *
1726
- * KL (input) INTEGER
1727
- * The number of subdiagonals within the band of A. KL >= 0.
1728
- *
1729
- * KU (input) INTEGER
1730
- * The number of superdiagonals within the band of A. KU >= 0.
1731
- *
1732
- * AB (input/output) COMPLEX array, dimension (LDAB,N)
1733
- * On entry, the matrix A in band storage, in rows KL+1 to
1734
- * 2*KL+KU+1; rows 1 to KL of the array need not be set.
1735
- * The j-th column of A is stored in the j-th column of the
1736
- * array AB as follows:
1737
- * AB(kl+ku+1+i-j,j) = A(i,j) for max(1,j-ku)<=i<=min(m,j+kl)
1738
- *
1739
- * On exit, details of the factorization: U is stored as an
1740
- * upper triangular band matrix with KL+KU superdiagonals in
1741
- * rows 1 to KL+KU+1, and the multipliers used during the
1742
- * factorization are stored in rows KL+KU+2 to 2*KL+KU+1.
1743
- * See below for further details.
1744
- *
1745
- * LDAB (input) INTEGER
1746
- * The leading dimension of the array AB. LDAB >= 2*KL+KU+1.
1747
- *
1748
- * IPIV (output) INTEGER array, dimension (min(M,N))
1749
- * The pivot indices; for 1 <= i <= min(M,N), row i of the
1750
- * matrix was interchanged with row IPIV(i).
1751
- *
1752
- * INFO (output) INTEGER
1753
- * = 0: successful exit
1754
- * < 0: if INFO = -i, the i-th argument had an illegal value
1755
- * > 0: if INFO = +i, U(i,i) is exactly zero. The factorization
1756
- * has been completed, but the factor U is exactly
1757
- * singular, and division by zero will occur if it is used
1758
- * to solve a system of equations.
1759
- *
1760
-
1761
- * Further Details
1762
- * ===============
1763
- *
1764
- * The band storage scheme is illustrated by the following example, when
1765
- * M = N = 6, KL = 2, KU = 1:
1766
- *
1767
- * On entry: On exit:
1768
- *
1769
- * * * * + + + * * * u14 u25 u36
1770
- * * * + + + + * * u13 u24 u35 u46
1771
- * * a12 a23 a34 a45 a56 * u12 u23 u34 u45 u56
1772
- * a11 a22 a33 a44 a55 a66 u11 u22 u33 u44 u55 u66
1773
- * a21 a32 a43 a54 a65 * m21 m32 m43 m54 m65 *
1774
- * a31 a42 a53 a64 * * m31 m42 m53 m64 * *
1775
- *
1776
- * Array elements marked * are not used by the routine; elements marked
1777
- * + need not be set on entry, but are required by the routine to store
1778
- * elements of U because of fill-in resulting from the row interchanges.
1779
- *
1780
- * =====================================================================
1781
- *
1782
-
1783
-
1784
- </PRE>
1785
- <A HREF="#top">go to the page top</A>
1786
-
1787
- <A NAME="cgbtrs"></A>
1788
- <H2>cgbtrs</H2>
1789
- <PRE>
1790
- USAGE:
1791
- info, b = NumRu::Lapack.cgbtrs( trans, kl, ku, ab, ipiv, b, [:usage => usage, :help => help])
1792
-
1793
-
1794
- FORTRAN MANUAL
1795
- SUBROUTINE CGBTRS( TRANS, N, KL, KU, NRHS, AB, LDAB, IPIV, B, LDB, INFO )
1796
-
1797
- * Purpose
1798
- * =======
1799
- *
1800
- * CGBTRS solves a system of linear equations
1801
- * A * X = B, A**T * X = B, or A**H * X = B
1802
- * with a general band matrix A using the LU factorization computed
1803
- * by CGBTRF.
1804
- *
1805
-
1806
- * Arguments
1807
- * =========
1808
- *
1809
- * TRANS (input) CHARACTER*1
1810
- * Specifies the form of the system of equations.
1811
- * = 'N': A * X = B (No transpose)
1812
- * = 'T': A**T * X = B (Transpose)
1813
- * = 'C': A**H * X = B (Conjugate transpose)
1814
- *
1815
- * N (input) INTEGER
1816
- * The order of the matrix A. N >= 0.
1817
- *
1818
- * KL (input) INTEGER
1819
- * The number of subdiagonals within the band of A. KL >= 0.
1820
- *
1821
- * KU (input) INTEGER
1822
- * The number of superdiagonals within the band of A. KU >= 0.
1823
- *
1824
- * NRHS (input) INTEGER
1825
- * The number of right hand sides, i.e., the number of columns
1826
- * of the matrix B. NRHS >= 0.
1827
- *
1828
- * AB (input) COMPLEX array, dimension (LDAB,N)
1829
- * Details of the LU factorization of the band matrix A, as
1830
- * computed by CGBTRF. U is stored as an upper triangular band
1831
- * matrix with KL+KU superdiagonals in rows 1 to KL+KU+1, and
1832
- * the multipliers used during the factorization are stored in
1833
- * rows KL+KU+2 to 2*KL+KU+1.
1834
- *
1835
- * LDAB (input) INTEGER
1836
- * The leading dimension of the array AB. LDAB >= 2*KL+KU+1.
1837
- *
1838
- * IPIV (input) INTEGER array, dimension (N)
1839
- * The pivot indices; for 1 <= i <= N, row i of the matrix was
1840
- * interchanged with row IPIV(i).
1841
- *
1842
- * B (input/output) COMPLEX array, dimension (LDB,NRHS)
1843
- * On entry, the right hand side matrix B.
1844
- * On exit, the solution matrix X.
1845
- *
1846
- * LDB (input) INTEGER
1847
- * The leading dimension of the array B. LDB >= max(1,N).
1848
- *
1849
- * INFO (output) INTEGER
1850
- * = 0: successful exit
1851
- * < 0: if INFO = -i, the i-th argument had an illegal value
1852
- *
1853
-
1854
- * =====================================================================
1855
- *
1856
-
1857
-
1858
- </PRE>
1859
- <A HREF="#top">go to the page top</A>
1860
-
1861
- <HR />
1862
- <A HREF="c.html">back to matrix types</A><BR>
1863
- <A HREF="c.html">back to data types</A>
1864
- </BODY>
1865
- </HTML>