1 
   2 
   3 
   4 
   5 
   6 
   7 
   8 
   9 
  10 
  11 
  12 
  13 
  14 
  15 
  16 
  17 
  18 
  19 
  20 
  21 
  22 
  23 
  24 
  25 
  26 
  27 
  28 
  29 
  30 
  31 
  32 
  33 
  34 
  35 
  36 
  37 
  38 
  39 
  40 
  41 
  42 
  43 
  44 
  45 
  46 
  47 
  48 
  49 
  50 
  51 
  52 
  53 
  54 
  55 
  56 
  57 
  58 
  59 
  60 
  61 
  62 
  63 
  64 
  65 
  66 
  67 
  68 
  69 
  70 
  71 
  72 
  73 
  74 
  75 
  76 
  77 
  78 
  79 
  80 
  81 
  82 
  83 
  84 
  85 
  86 
  87 
  88 
  89 
  90 
  91 
  92 
  93 
  94 
  95 
  96 
  97 
  98 
  99 
 100 
 101 
 102 
 103 
 104 
 105 
 106 
 107 
 108 
 109 
 110 
 111 
 112 
 113 
 114 
 115 
 116 
 117 
 118 
 119 
 120 
 121 
 122 
 123 
 124 
 125 
 126 
 127 
 128 
 129 
 130 
 131 
 132 
 133 
 134 
 135 
 136 
 137 
 138 
 139 
 140 
 141 
 142 
 143 
 144 
 145 
 146 
 147 
 148 
 149 
 150 
 151 
 152 
 153 
 154 
 155 
 156 
 157 
 158 
 159 
 160 
 161 
 162 
 163 
 164 
 165 
 166 
 167 
 168 
 169 
 170 
 171 
 172 
 173 
 174 
 175 
 176 
 177 
 178 
 179 
 180 
 181 
 182 
 183 
 184 
 185 
 186 
 187 
 188 
 189 
 190 
 191 
 192 
 193 
 194 
 195 
 196 
 197 
 198 
 199 
 200 
 201 
 202 
 203 
 204 
 205 
 206 
 207 
 208 
 209 
 210 
 211 
 212 
 213 
 214 
 215 
 216 
 217 
 218 
 219 
 220 
 221 
 222 
 223 
 224 
 225 
 226 
 227 
 228 
 229 
 230 
 231 
 232 
 233 
 234 
 235 
 236 
 237 
 238 
 239 
 240 
 241 
 242 
 243 
 244 
 245 
 246 
 247 
 248 
 249 
 250 
 251 
 252 
 253 
 254 
 255 
 256 
 257 
 258 
 259 
 260 
 261 
 262 
 263 
 264 
 265 
 266 
 267 
 268 
 269 
 270 
 271 
 272 
 273 
 274 
 275 
 276 
 277 
 278 
 279 
 280 
 281 
 282 
 283 
 284 
 285 
 286 
 287 
 288 
 289 
 290 
 291 
 292 
 293 
 294 
 295 
 296 
 297 
 298 
 299 
 300 
 301 
 302 
 303 
 304 
 305 
 306 
 307 
 308 
 309 
 310 
 311 
 312 
 313 
 314 
 315 
 316 
 317 
 318 
 319 
 320 
 321 
 322 
 323 
 324 
 325 
 326 
 327 
 328 
 329 
 330 
 331 
 332 
 333 
 334 
 335 
 336 
 337 
 338 
 339 
 340 
 341 
 342 
 343 
 344 
 345 
 346 
 347 
 348 
 349 
 350 
 351 
 352 
 353 
 354 
 355 
 356 
 357 
 358 
 359 
 360 
 361 
 362 
 363 
 364 
 365 
 366 
 367 
 368 
 369 
 370 
 371 
 372 
 373 
 374 
 375 
 376 
 377 
 378 
 379 
 380 
 381 
 382 
 383 
 384 
 385 
 386 
 387 
 388 
 389 
 390 
 391 
 392 
 393 
 394 
 395 
 396 
 397 
 398 
 399 
 400 
 401 
 402 
 403 
 404 
 405 
 406 
 407 
 408 
 409 
 410 
 411 
 412 
 413 
 414 
 415 
 416 
 417 
 418 
 419 
 420 
 421 
 422 
 423 
 424 
 425 
 426 
 427 
 428 
 429 
 430 
 431 
 432 
 433 
 434 
 435 
 436 
 437 
 438 
 439 
 440 
 441 
 442 
 443 
 444 
 445 
 446 
 447 
 448 
 449 
 450 
 451 
 452 
 453 
 454 
 455 
 456 
 457 
 458 
 459 
 460 
 461 
 462 
 463 
 464 
 465 
 466 
 467 
 468 
 469 
 470 
 471 
 472 
 473 
 474 
 475 
 476 
 477 
 478 
 479 
 480 
 481 
 482 
 483 
 484 
 485 
 486 
 487 
 488 
 489 
 490 
 491 
 492 
 493 
 494 
 495 
 496 
 497 
 498 
 499 
 500 
 501 
 502 
 503 
 504 
 505 
 506 
 507 
 508 
 509 
 510 
 511 
 512 
 513 
 514 
 515 
 516 
 517 
 518 
 519 
 520 
 521 
 522 
 523 
 524 
 525 
 526 
 527 
 528 
 529 
 530 
 531 
 532 
 533 
 534 
 535 
 536 
 537 
 538 
 539 
 540 
 541 
 542 
 543 
 544 
 545 
 546 
 547 
 548 
 549 
 550 
 551 
 552 
 553 
 554 
 555 
 556 
 557 
 558 
 559 
 560 
 561 
 562 
 563 
 564 
 565 
 566 
 567 
 568 
 569 
 570 
 571 
 572 
 573 
 574 
 575 
 576 
 577 
 578 
 579 
 580 
 581 
 582 
 583 
 584 
 585 
 586 
 587 
 588 
 589 
 590 
 591 
 592 
 593 
 594 
 595 
 596 
 597 
 598 
 599 
 600 
 601 
 602 
 603 
 604 
 605 
 606 
 607 
 608 
 609 
 610 
 611 
 612 
 613 
 614 
 615 
 616 
 617 
 618 
 619 
 620 
 621 
 622 
 623 
 624 
 625 
 626 
 627 
 628 
 629 
 630 
 631 
 632 
 633 
 634 
 635 
 636 
 637 
 638 
 639 
 640 
 641 
 642 
 643 
 644 
 645 
 646 
 647 
 648 
 649 
 650 
 651 
 652 
 653 
 654 
 655 
 656 
 657 
 658 
 659 
 660 
 661 
 662 
 663 
 664 
 665 
 666 
 667 
 668 
 669 
 670 
 671 
 672 
 673 
 674 
 675 
 676 
 677 
 678 
 679 
 680 
 681 
 682 
 683 
 684 
 685 
 686 
 687 
 688 
 689 
 690 
 691 
 692 
 693 
 694 
 695 
 696 
 697 
 698 
 699 
 700 
 701 
 702 
 703 
 704 
 705 
 706 
 707 
 708 
 709 
 710 
 711 
 712 
 713 
 714 
 715 
 716 
 717 
 718 
 719 
 720 
 721 
 722 
 723 
 724 
 725 
 726 
 727 
 728 
 729 
 730 
 731 
 732 
 733 
 734 
 735 
 736 
 737 
 738 
 739 
 740 
 741 
 742 
 743 
 744 
 745 
 746 
 747 
 748 
 749 
 750 
 751 
 752 
 753 
 754 
 755 
 756 
 757 
 758 
 759 
 760 
 761 
 762 
 763 
 764 
 765 
 766 
 767 
 768 
 769 
 770 
 771 
 772 
 773 
 774 
 775 
 776 
 777 
 778 
 779 
 780 
 781 
 782 
 783 
 784 
 785 
 786 
 787 
 788 
 789 
 790 
 791 
 792 
 793 
 794 
 795 
 796 
 797 
 798 
 799 
 800 
 801 
 802 
 803 
 804 
 805 
 806 
 807 
 808 
 809 
 810 
 811 
 812 
 813 
 814 
 815 
 816 
 817 
 818 
 819 
 820 
 821 
 822 
 823 
 824 
 825 
 826 
 827 
 828 
 829 
 830 
 831 
 832 
 833 
 834 
 835 
 836 
 837 
 838 
 839 
 840 
 841 
 842 
 843 
 844 
 845 
 846 
 847 
 848 
 849 
 850 
 851 
 852 
 853 
 854 
 855 
 856 
 857 
 858 
 859 
 860 
 861 
 862 
 863 
 864 
 865 
 866 
 867 
 868 
 869 
 870 
 871 
 872 
 873 
 874 
 875 
 876 
 877 
 878 
 879 
 880 
 881 
 882 
 883 
 884 
 885 
 886 
 887 
 888 
 889 
 890 
 891 
 892 
 893 
 894 
 895 
 896 
 897 
 898 
 899 
 900 
 901 
 902 
 903 
 904 
 905 
 906 
 907 
 908 
 909 
 910 
 911 
 912 
 913 
 914 
 915 
 916 
 917 
 918 
 919 
 920 
 921 
 922 
 923 
 924 
 925 
 926 
 927 
 928 
 929 
 930 
 931 
 932 
 933 
 934 
 935 
 936 
 937 
 938 
 939 
 940 
 941 
 942 
 943 
 944 
 945 
 946 
 947 
 948 
 949 
 950 
 951 
 952 
 953 
 954 
 955 
 956 
 957 
 958 
 959 
 960 
 961 
 962 
 963 
 964 
 965 
 966 
 967 
 968 
 969 
 970 
 971 
 972 
 973 
 974 
 975 
 976 
 977 
 978 
 979 
 980 
 981 
 982 
 983 
 984 
 985 
 986 
 987 
 988 
 989 
 990 
 991 
 992 
 993 
 994 
 995 
 996 
 997 
 998 
 999 
1000 
1001 
1002 
1003 
1004 
1005 
1006 
1007 
1008 
1009 
1010 
1011 
1012 
1013 
1014 
1015 
1016 
1017 
1018 
1019 
1020 
1021 
1022 
1023 
1024 
1025 
1026 
1027 
1028 
1029 
1030 
1031 
1032 
1033 
1034 
1035 
1036 
1037 
1038 
1039 
1040 
1041 
1042 
1043 
1044 
1045 
1046 
1047 
1048 
1049 
1050 
1051 
1052 
1053 
1054 
1055 
1056 
1057 
1058 
1059 
1060 
1061 
1062 
1063 
1064 
1065 
1066 
1067 
1068 
1069 
1070 
1071 
1072 
1073 
1074 
1075 
1076 
1077 
1078 
1079 
1080 
1081 
1082 
1083 
1084 
1085 
1086 
1087 
1088 
1089 
1090 
1091 
1092 
1093 
1094 
1095 
1096 
1097 
1098 
1099 
1100 
1101 
1102 
1103 
1104 
1105 
1106 
1107 
1108 
1109 
1110 
1111 
1112 
1113 
1114 
1115 
1116 
1117 
1118 
1119 
1120 
1121 
1122 
1123 
1124 
1125 
1126 
1127 
1128 
1129 
1130 
1131 
1132 
1133 
1134 
1135 
1136 
1137 
1138 
1139 
1140 
1141 
1142 
1143 
1144 
1145 
1146 
1147 
1148 
1149 
1150 
1151 
1152 
1153 
1154 
1155 
1156 
1157 
1158 
1159 
1160 
1161 
1162 
1163 
1164 
1165 
1166 
1167 
1168 
1169 
1170 
1171 
1172 
1173 
1174 
1175 
1176 
1177 
1178 
1179 
1180 
1181 
1182 
1183 
1184 
1185 
1186 
1187 
1188 
1189 
1190 
1191 
1192 
1193 
1194 
1195 
1196 
1197 
1198 
1199 
1200 
1201 
1202 
1203 
1204 
1205 
1206 
1207 
1208 
1209 
1210 
1211 
1212 
1213 
1214 
1215 
1216 
1217 
1218 
1219 
1220 
1221 
1222 
1223 
1224 
1225 
1226 
1227 
1228 
1229 
1230 
1231 
1232 
1233 
1234 
1235 
1236 
1237 
1238 
1239 
1240 
1241 
1242 
1243 
1244 
1245 
1246 
1247 
1248 
1249 
1250 
1251 
1252 
1253 
1254 
1255 
1256 
1257 
1258 
1259 
1260 
1261 
1262 
1263 
1264 
1265 
1266 
1267 
1268 
1269 
1270 
1271 
1272 
1273 
1274 
1275 
1276 
1277 
1278 
1279 
1280 
1281 
1282 
1283 
1284 
1285 
1286 
1287 
1288 
1289 
1290 
1291 
1292 
1293 
1294 
1295 
1296 
1297 
1298 
1299 
1300 
1301 
1302 
1303 
1304 
1305 
1306 
1307 
1308 
1309 
1310 
1311 
1312 
1313 
1314 
1315 
1316 
1317 
1318 
1319 
1320 
1321 
1322 
1323 
1324 
1325 
1326 
1327 
1328 
1329 
1330 
1331 
1332 
1333 
1334 
1335 
1336 
1337 
1338 
1339 
1340 
1341 
1342 
1343 
1344 
1345 
1346 
1347 
1348 
1349 
1350 
1351 
1352 
1353 
1354 
1355 
1356 
1357 
1358 
1359 
1360 
1361 
1362 
1363 
1364 
1365 
1366 
1367 
1368 
1369 
1370 
1371 
1372 
1373 
1374 
1375 
1376 
1377 
1378 
1379 
1380 
1381 
1382 
1383 
1384 
1385 
1386 
1387 
1388 
1389 
1390 
1391 
1392 
1393 
1394 
1395 
1396 
1397 
1398 
1399 
1400 
1401 
1402 
1403 
1404 
1405 
1406 
1407 
1408 
1409 
1410 
1411 
1412 
1413 
1414 
1415 
1416 
1417 
1418 
1419 
1420 
1421 
1422 
1423 
1424 
1425 
1426 
1427 
1428 
1429 
1430 
1431 
1432 
1433 
1434 
1435 
1436 
1437 
1438 
1439 
1440 
1441 
1442 
1443 
1444 
1445 
1446 
1447 
1448 
1449 
1450 
1451 
1452 
1453 
1454 
1455 
1456 
1457 
1458 
1459 
1460 
1461 
1462 
1463 
1464 
1465 
1466 
1467 
1468 
1469 
1470 
1471 
1472 
1473 
1474 
1475 
1476 
1477 
1478 
1479 
1480 
1481 
1482 
1483 
1484 
1485 
1486 
1487 
1488 
1489 
1490 
1491 
1492 
1493 
1494 
1495 
1496 
1497 
1498 
1499 
1500 
1501 
1502 
1503 
1504 
1505 
1506 
1507 
1508 
1509 
1510 
1511 
1512 
1513 
1514 
1515 
1516 
1517 
1518 
1519 
1520 
1521 
1522 
1523 
1524 
1525 
1526 
1527 
1528 
1529 
1530 
1531 
1532 
1533 
1534 
1535 
1536 
1537 
1538 
1539 
1540 
1541 
1542 
1543 
1544 
1545 
1546 
1547 
1548 
1549 
1550 
1551 
1552 
1553 
1554 
1555 
1556 
1557 
1558 
1559 
1560 
1561 
1562 
1563 
1564 
1565 
1566 
1567 
1568 
1569 
1570 
1571 
1572 
1573 
1574 
1575 
1576 
1577 
1578 
1579 
1580 
1581 
1582 
1583 
1584 
1585 
1586 
1587 
1588 
1589 
1590 
1591 
1592 
1593 
1594 
1595 
1596 
1597 
1598 
1599 
1600 
1601 
1602 
1603 
1604 
1605 
1606 
1607 
1608 
1609 
1610 
1611 
1612 
1613 
1614 
1615 
1616 
1617 
1618 
1619 
1620 
1621 
1622 
1623 
1624 
1625 
1626 
1627 
1628 
1629 
1630 
1631 
1632 
1633 
1634 
1635 
1636 
1637 
1638 
1639 
1640 
1641 
1642 
1643 
1644 
1645 
1646 
1647 
1648 
1649 
1650 
1651 
1652 
1653 
1654 
1655 
1656 
1657 
1658 
1659 
1660 
1661 
1662 
1663 
1664 
1665 
1666 
1667 
1668 
1669 
1670 
1671 
1672 
1673 
1674 
1675 
1676 
1677 
1678 
1679 
1680 
1681 
1682 
1683 
1684 
1685 
1686 
1687 
1688 
1689 
1690 
1691 
1692 
1693 
1694 
1695 
1696 
1697 
1698 
1699 
1700 
1701 
1702 
1703 
1704 
1705 
1706 
1707 
1708 
1709 
1710 
1711 
1712 
1713 
1714 
1715 
1716 
1717 
1718 
1719 
1720 
1721 
1722 
1723 
1724 
1725 
1726 
1727 
1728 
1729 
1730 
1731 
1732 
1733 
1734 
1735 
1736 
1737 
1738 
1739 
1740 
1741 
1742 
1743 
1744 
1745 
1746 
1747 
1748 
1749 
1750 
1751 
1752 
1753 
1754 
1755 
1756 
1757 
1758 
1759 
1760 
1761 
1762 
1763 
1764 
1765 
1766 
1767 
1768 
1769 
1770 
1771 
1772 
1773 
1774 
1775 
1776 
1777 
1778 
1779 
1780 
1781 
1782 
1783 
1784 
1785 
1786 
1787 
1788 
1789 
1790 
1791 
1792 
1793 
1794 
1795 
1796 
1797 
1798 
1799 
1800 
1801 
1802 
1803 
1804 
1805 
1806 
1807 
1808 
1809 
1810 
1811 
1812 
1813 
1814 
1815 
1816 
1817 
1818 
1819 
1820 
1821 
1822 
1823 
1824 
1825 
1826 
1827 
1828 
1829 
1830 
1831 
1832 
1833 
1834 
1835 
1836 
1837 
1838 
1839 
1840 
1841 
1842 
1843 
1844 
1845 
1846 
1847 
1848 
1849 
1850 
1851 
1852 
1853 
1854 
1855 
1856 
1857 
1858 
1859 
1860 
1861 
1862 
1863 
1864 
1865 
1866 
1867 
1868 
1869 
1870 
1871 
1872 
1873 
1874 
1875 
1876 
1877 
1878 
1879 
1880 
1881 
1882 
1883 
1884 
1885 
1886 
1887 
1888 
1889 
1890 
1891 
1892 
1893 
1894 
1895 
1896 
1897 
1898 
1899 
1900 
1901 
1902 
1903 
1904 
1905 
1906 
1907 
1908 
1909 
1910 
1911 
1912 
1913 
1914 
1915 
1916 
1917 
1918 
1919 
1920 
1921 
1922 
1923 
1924 
1925 
1926 
1927 
1928 
1929 
1930 
1931 
1932 
1933 
1934 
1935 
1936 
1937 
1938 
1939 
1940 
1941 
1942 
1943 
1944 
1945 
1946 
1947 
1948 
1949 
1950 
1951 
1952 
1953 
1954 
1955 
1956 
1957 
1958 
1959 
1960 
1961 
1962 
1963 
1964 
1965 
1966 
1967 
1968 
1969 
1970 
1971 
1972 
1973 
1974 
1975 
1976 
1977 
1978 
1979 
1980 
1981 
1982 
1983 
1984 
1985 
1986 
1987 
1988 
1989 
1990 
1991 
1992 
1993 
1994 
1995 
1996 
1997 
1998 
1999 
2000 
2001 
2002 
2003 
2004 
2005 
2006 
2007 
2008 
2009 
2010 
2011 
2012 
2013 
2014 
2015 
2016 
2017 
2018 
2019 
2020 
2021 
2022 
2023 
2024 
2025 
2026 
2027 
2028 
2029 
2030 
2031 
2032 
2033 
2034 
2035 
2036 
2037 
2038 
2039 
2040 
2041 
2042 
2043 
2044 
2045 
2046 
2047 
2048 
2049 
2050 
2051 
2052 
2053 
2054 
2055 
2056 
2057 
2058 
2059 
2060 
2061 
2062 
2063 
2064 
2065 
2066 
2067 
2068 
2069 
2070 
2071 
2072 
2073 
2074 
2075 
2076 
2077 
2078 
2079 
2080 
2081 
2082 
2083 
2084 
2085 
2086 
2087 
2088 
2089 
2090 
2091 
2092 
2093 
2094 
2095 
2096 
2097 
2098 
2099 
2100 
2101 
2102 
2103 
2104 
2105 
2106 
2107 
2108 
2109 
2110 
2111 
2112 
2113 
2114 
2115 
2116 
2117 
2118 
2119 
2120 
2121 
2122 
2123 
2124 
2125 
2126 
2127 
2128 
2129 
2130 
2131 
2132 
2133 
2134 
2135 
2136 
2137 
2138 
2139 
2140 
2141 
2142 
2143 
2144 
2145 
2146 
2147 
2148 
2149 
2150 
2151 
2152 
2153 
2154 
2155 
2156 
2157 
2158 
2159 
2160 
2161 
2162 
2163 
2164 
2165 
2166 
2167 
2168 
2169 
2170 
2171 
2172 
2173 
2174 
2175 
2176 
2177 
2178 
2179 
2180 
2181 
2182 
2183 
2184 
2185 
2186 
2187 
2188 
2189 
2190 
2191 
2192 
2193 
2194 
2195 
2196 
2197 
2198 
2199 
2200 
2201 
2202 
2203 
2204 
2205 
2206 
2207 
2208 
2209 
2210 
2211 
2212 
2213 
2214 
2215 
2216 
2217 
2218 
2219 
2220 
2221 
2222 
2223 
2224 
2225 
2226 
2227 
2228 
2229 
2230 
2231 
2232 
2233 
2234 
2235 
2236 
2237 
2238 
2239 
2240 
2241 
2242 
2243 
2244 
2245 
2246 
2247 
2248 
2249 
2250 
2251 
2252 
2253 
2254 
2255 
2256 
2257 
2258 
2259 
2260 
2261 
2262 
2263 
2264 
2265 
2266 
2267 
2268 
2269 
2270 
2271 
2272 
2273 
2274 
2275 
2276 
2277 
2278 
2279 
2280 
2281 
2282 
2283 
2284 
2285 
2286 
2287 
2288 
2289 
2290 
2291 
2292 
2293 
2294 
2295 
2296 
2297 
2298 
2299 
2300 
2301 
2302 
2303 
2304 
2305 
2306 
2307 
2308 
2309 
2310 
2311 
2312 
2313 
2314 
2315 
2316 
2317 
2318 
2319 
2320 
2321 
2322 
2323 
2324 
2325 
2326 
2327 
2328 
2329 
2330 
2331 
2332 
2333 
2334 
2335 
2336 
2337 
2338 
2339 
2340 
2341 
2342 
2343 
2344 
2345 
2346 
2347 
2348 
2349 
2350 
2351 
2352 
2353 
2354 
2355 
2356 
2357 
2358 
2359 
2360 
2361 
2362 
2363 
2364 
2365 
2366 
2367 
2368 
2369 
2370 
2371 
2372 
2373 
2374 
2375 
2376 
2377 
2378 
2379 
2380 
2381 
2382 
2383 
2384 
2385 
2386 
2387 
2388 
2389 
2390 
2391 
2392 
2393 
2394 
2395 
2396 
2397 
2398 
2399 
2400 
2401 
2402 
2403 
2404 
2405 
2406 
2407 
2408 
2409 
2410 
2411 
2412 
2413 
2414 
2415 
2416 
2417 
2418 
2419 
2420 
2421 
2422 
2423 
2424 
2425 
2426 
2427 
2428 
2429 
2430 
2431 
2432 
2433 
2434 
2435 
2436 
2437 
2438 
2439 
2440 
2441 
2442 
2443 
2444 
2445 
2446 
2447 
2448 
2449 
2450 
2451 
2452 
2453 
2454 
2455 
2456 
2457 
2458 
2459 
2460 
2461 
2462 
2463 
2464 
2465 
2466 
2467 
2468 
2469 
2470 
2471 
2472 
2473 
2474 
2475 
2476 
2477 
2478 
2479 
2480 
2481 
2482 
2483 
2484 
2485 
2486 
2487 
2488 
2489 
2490 
2491 
2492 
2493 
2494 
2495 
2496 
2497 
2498 
2499 
2500 
2501 
2502 
2503 
2504 
2505 
2506 
2507 
2508 
2509 
2510 
2511 
2512 
2513 
2514 
2515 
2516 
2517 
2518 
2519 
2520 
2521 
2522 
2523 
2524 
2525 
2526 
2527 
2528 
2529 
2530 
2531 
2532 
2533 
2534 
2535 
2536 
2537 
2538 
2539 
2540 
2541 
2542 
2543 
2544 
2545 
2546 
2547 
2548 
2549 
2550 
2551 
2552 
2553 
2554 
2555 
2556 
2557 
2558 
2559 
2560 
2561 
2562 
2563 
2564 
2565 
2566 
2567 
2568 
2569 
2570 
2571 
2572 
2573 
2574 
2575 
2576 
2577 
2578 
2579 
2580 
2581 
2582 
2583 
2584 
2585 
2586 
2587 
2588 
2589 
2590 
2591 
2592 
2593 
2594 
2595 
2596 
2597 
2598 
2599 
2600 
2601 
2602 
2603 
2604 
2605 
2606 
2607 
2608 
2609 
2610 
2611 
2612 
2613 
2614 
2615 
2616 
2617 
2618 
2619 
2620 
2621 
2622 
2623 
2624 
2625 
2626 
2627 
2628 
2629 
2630 
2631 
2632 
2633 
2634 
2635 
2636 
2637 
2638 
2639 
2640 
2641 
2642 
2643 
2644 
2645 
2646 
2647 
2648 
2649 
2650 
2651 
2652 
2653 
2654 
2655 
2656 
2657 
2658 
2659 
2660 
2661 
2662 
2663 
2664 
2665 
2666 
2667 
2668 
2669 
2670 
2671 
2672 
2673 
2674 
2675 
2676 
2677 
2678 
2679 
2680 
2681 
2682 
2683 
2684 
2685 
2686 
2687 
2688 
2689 
2690 
2691 
2692 
2693 
2694 
2695 
2696 
2697 
2698 
2699 
2700 
2701 
2702 
2703 
2704 
2705 
2706 
2707 
2708 
2709 
2710 
2711 
2712 
2713 
2714 
2715 
2716 
2717 
2718 
2719 
2720 
2721 
2722 
2723 
2724 
2725 
2726 
2727 
2728 
2729 
2730 
2731 
2732 
2733 
2734 
2735 
2736 
2737 
2738 
2739 
2740 
2741 
2742 
2743 
2744 
2745 
2746 
2747 
2748 
2749 
2750 
2751 
2752 
2753 
2754 
2755 
2756 
2757 
2758 
2759 
2760 
2761 
2762 
2763 
2764 
2765 
2766 
2767 
2768 
2769 
2770 
2771 
2772 
2773 
2774 
2775 
2776 
2777 
2778 
2779 
2780 
2781 
2782 
2783 
2784 
2785 
2786 
2787 
2788 
2789 
2790 
2791 
2792 
2793 
2794 
2795 
2796 
2797 
2798 
2799 
2800 
2801 
2802 
2803 
2804 
2805 
2806 
2807 
2808 
2809 
2810 
2811 
2812 
2813 
2814 
2815 
2816 
2817 
2818 
2819 
2820 
2821 
2822 
2823 
 
 | 
 
      PROGRAM DBLAT3 
* 
*  Test program for the DOUBLE PRECISION Level 3 Blas. 
* 
*  The program must be driven by a short data file. The first 14 records 
*  of the file are read using list-directed input, the last 6 records 
*  are read using the format ( A6, L2 ). An annotated example of a data 
*  file can be obtained by deleting the first 3 characters from the 
*  following 20 lines: 
*  'DBLAT3.SUMM'     NAME OF SUMMARY OUTPUT FILE 
*  6                 UNIT NUMBER OF SUMMARY FILE 
*  'DBLAT3.SNAP'     NAME OF SNAPSHOT OUTPUT FILE 
*  -1                UNIT NUMBER OF SNAPSHOT FILE (NOT USED IF .LT. 0) 
*  F        LOGICAL FLAG, T TO REWIND SNAPSHOT FILE AFTER EACH RECORD. 
*  F        LOGICAL FLAG, T TO STOP ON FAILURES. 
*  T        LOGICAL FLAG, T TO TEST ERROR EXITS. 
*  16.0     THRESHOLD VALUE OF TEST RATIO 
*  6                 NUMBER OF VALUES OF N 
*  0 1 2 3 5 9       VALUES OF N 
*  3                 NUMBER OF VALUES OF ALPHA 
*  0.0 1.0 0.7       VALUES OF ALPHA 
*  3                 NUMBER OF VALUES OF BETA 
*  0.0 1.0 1.3       VALUES OF BETA 
*  DGEMM  T PUT F FOR NO TEST. SAME COLUMNS. 
*  DSYMM  T PUT F FOR NO TEST. SAME COLUMNS. 
*  DTRMM  T PUT F FOR NO TEST. SAME COLUMNS. 
*  DTRSM  T PUT F FOR NO TEST. SAME COLUMNS. 
*  DSYRK  T PUT F FOR NO TEST. SAME COLUMNS. 
*  DSYR2K T PUT F FOR NO TEST. SAME COLUMNS. 
* 
*  See: 
* 
*     Dongarra J. J., Du Croz J. J., Duff I. S. and Hammarling S. 
*     A Set of Level 3 Basic Linear Algebra Subprograms. 
* 
*     Technical Memorandum No.88 (Revision 1), Mathematics and 
*     Computer Science Division, Argonne National Laboratory, 9700 
*     South Cass Avenue, Argonne, Illinois 60439, US. 
* 
*  -- Written on 8-February-1989. 
*     Jack Dongarra, Argonne National Laboratory. 
*     Iain Duff, AERE Harwell. 
*     Jeremy Du Croz, Numerical Algorithms Group Ltd. 
*     Sven Hammarling, Numerical Algorithms Group Ltd. 
* 
*     .. Parameters .. 
      INTEGER            NIN 
      PARAMETER          ( NIN = 5 ) 
      INTEGER            NSUBS 
      PARAMETER          ( NSUBS = 6 ) 
      DOUBLE PRECISION   ZERO, HALF, ONE 
      PARAMETER          ( ZERO = 0.0D0, HALF = 0.5D0, ONE = 1.0D0 ) 
      INTEGER            NMAX 
      PARAMETER          ( NMAX = 65 ) 
      INTEGER            NIDMAX, NALMAX, NBEMAX 
      PARAMETER          ( NIDMAX = 9, NALMAX = 7, NBEMAX = 7 ) 
*     .. Local Scalars .. 
      DOUBLE PRECISION   EPS, ERR, THRESH 
      INTEGER            I, ISNUM, J, N, NALF, NBET, NIDIM, NOUT, NTRA 
      LOGICAL            FATAL, LTESTT, REWI, SAME, SFATAL, TRACE, 
     $                   TSTERR 
      CHARACTER*1        TRANSA, TRANSB 
      CHARACTER*6        SNAMET 
      CHARACTER*32       SNAPS, SUMMRY 
*     .. Local Arrays .. 
      DOUBLE PRECISION   AA( NMAX*NMAX ), AB( NMAX, 2*NMAX ), 
     $                   ALF( NALMAX ), AS( NMAX*NMAX ), 
     $                   BB( NMAX*NMAX ), BET( NBEMAX ), 
     $                   BS( NMAX*NMAX ), C( NMAX, NMAX ), 
     $                   CC( NMAX*NMAX ), CS( NMAX*NMAX ), CT( NMAX ), 
     $                   G( NMAX ), W( 2*NMAX ) 
      INTEGER            IDIM( NIDMAX ) 
      LOGICAL            LTEST( NSUBS ) 
      CHARACTER*6        SNAMES( NSUBS ) 
*     .. External Functions .. 
      DOUBLE PRECISION   DDIFF 
      LOGICAL            LDE 
      EXTERNAL           DDIFF, LDE 
*     .. External Subroutines .. 
      EXTERNAL           DCHK1, DCHK2, DCHK3, DCHK4, DCHK5, DCHKE, DMMCH 
*     .. Intrinsic Functions .. 
      INTRINSIC          MAX, MIN 
*     .. Scalars in Common .. 
      INTEGER            INFOT, NOUTC 
      LOGICAL            LERR, OK 
      CHARACTER*6        SRNAMT 
*     .. Common blocks .. 
      COMMON             /INFOC/INFOT, NOUTC, OK, LERR 
      COMMON             /SRNAMC/SRNAMT 
*     .. Data statements .. 
      DATA               SNAMES/'DGEMM ', 'DSYMM ', 'DTRMM ', 'DTRSM ', 
     $                   'DSYRK ', 'DSYR2K'/ 
*     .. Executable Statements .. 
* 
*     Read name and unit number for summary output file and open file. 
* 
      READ( NIN, FMT = * )SUMMRY 
      READ( NIN, FMT = * )NOUT 
      OPEN( NOUT, FILE = SUMMRY, STATUS = 'NEW' ) 
      NOUTC = NOUT 
* 
*     Read name and unit number for snapshot output file and open file. 
* 
      READ( NIN, FMT = * )SNAPS 
      READ( NIN, FMT = * )NTRA 
      TRACE = NTRA.GE.0 
      IF( TRACE )THEN 
         OPEN( NTRA, FILE = SNAPS, STATUS = 'NEW' ) 
      END IF 
*     Read the flag that directs rewinding of the snapshot file. 
      READ( NIN, FMT = * )REWI 
      REWI = REWI.AND.TRACE 
*     Read the flag that directs stopping on any failure. 
      READ( NIN, FMT = * )SFATAL 
*     Read the flag that indicates whether error exits are to be tested. 
      READ( NIN, FMT = * )TSTERR 
*     Read the threshold value of the test ratio 
      READ( NIN, FMT = * )THRESH 
* 
*     Read and check the parameter values for the tests. 
* 
*     Values of N 
      READ( NIN, FMT = * )NIDIM 
      IF( NIDIM.LT.1.OR.NIDIM.GT.NIDMAX )THEN 
         WRITE( NOUT, FMT = 9997 )'N', NIDMAX 
         GO TO 220 
      END IF 
      READ( NIN, FMT = * )( IDIM( I ), I = 1, NIDIM ) 
      DO 10 I = 1, NIDIM 
         IF( IDIM( I ).LT.0.OR.IDIM( I ).GT.NMAX )THEN 
            WRITE( NOUT, FMT = 9996 )NMAX 
            GO TO 220 
         END IF 
   10 CONTINUE 
*     Values of ALPHA 
      READ( NIN, FMT = * )NALF 
      IF( NALF.LT.1.OR.NALF.GT.NALMAX )THEN 
         WRITE( NOUT, FMT = 9997 )'ALPHA', NALMAX 
         GO TO 220 
      END IF 
      READ( NIN, FMT = * )( ALF( I ), I = 1, NALF ) 
*     Values of BETA 
      READ( NIN, FMT = * )NBET 
      IF( NBET.LT.1.OR.NBET.GT.NBEMAX )THEN 
         WRITE( NOUT, FMT = 9997 )'BETA', NBEMAX 
         GO TO 220 
      END IF 
      READ( NIN, FMT = * )( BET( I ), I = 1, NBET ) 
* 
*     Report values of parameters. 
* 
      WRITE( NOUT, FMT = 9995 ) 
      WRITE( NOUT, FMT = 9994 )( IDIM( I ), I = 1, NIDIM ) 
      WRITE( NOUT, FMT = 9993 )( ALF( I ), I = 1, NALF ) 
      WRITE( NOUT, FMT = 9992 )( BET( I ), I = 1, NBET ) 
      IF( .NOT.TSTERR )THEN 
         WRITE( NOUT, FMT = * ) 
         WRITE( NOUT, FMT = 9984 ) 
      END IF 
      WRITE( NOUT, FMT = * ) 
      WRITE( NOUT, FMT = 9999 )THRESH 
      WRITE( NOUT, FMT = * ) 
* 
*     Read names of subroutines and flags which indicate 
*     whether they are to be tested. 
* 
      DO 20 I = 1, NSUBS 
         LTEST( I ) = .FALSE. 
   20 CONTINUE 
   30 READ( NIN, FMT = 9988, END = 60 )SNAMET, LTESTT 
      DO 40 I = 1, NSUBS 
         IF( SNAMET.EQ.SNAMES( I ) ) 
     $      GO TO 50 
   40 CONTINUE 
      WRITE( NOUT, FMT = 9990 )SNAMET 
      STOP 
   50 LTEST( I ) = LTESTT 
      GO TO 30 
* 
   60 CONTINUE 
      CLOSE ( NIN ) 
* 
*     Compute EPS (the machine precision). 
* 
      EPS = ONE 
   70 CONTINUE 
      IF( DDIFF( ONE + EPS, ONE ).EQ.ZERO ) 
     $   GO TO 80 
      EPS = HALF*EPS 
      GO TO 70 
   80 CONTINUE 
      EPS = EPS + EPS 
      WRITE( NOUT, FMT = 9998 )EPS 
* 
*     Check the reliability of DMMCH using exact data. 
* 
      N = MIN( 32, NMAX ) 
      DO 100 J = 1, N 
         DO 90 I = 1, N 
            AB( I, J ) = MAX( I - J + 1, 0 ) 
   90    CONTINUE 
         AB( J, NMAX + 1 ) = J 
         AB( 1, NMAX + J ) = J 
         C( J, 1 ) = ZERO 
  100 CONTINUE 
      DO 110 J = 1, N 
         CC( J ) = J*( ( J + 1 )*J )/2 - ( ( J + 1 )*J*( J - 1 ) )/3 
  110 CONTINUE 
*     CC holds the exact result. On exit from DMMCH CT holds 
*     the result computed by DMMCH. 
      TRANSA = 'N' 
      TRANSB = 'N' 
      CALL DMMCH( TRANSA, TRANSB, N, 1, N, ONE, AB, NMAX, 
     $            AB( 1, NMAX + 1 ), NMAX, ZERO, C, NMAX, CT, G, CC, 
     $            NMAX, EPS, ERR, FATAL, NOUT, .TRUE. ) 
      SAME = LDE( CC, CT, N ) 
      IF( .NOT.SAME.OR.ERR.NE.ZERO )THEN 
         WRITE( NOUT, FMT = 9989 )TRANSA, TRANSB, SAME, ERR 
         STOP 
      END IF 
      TRANSB = 'T' 
      CALL DMMCH( TRANSA, TRANSB, N, 1, N, ONE, AB, NMAX, 
     $            AB( 1, NMAX + 1 ), NMAX, ZERO, C, NMAX, CT, G, CC, 
     $            NMAX, EPS, ERR, FATAL, NOUT, .TRUE. ) 
      SAME = LDE( CC, CT, N ) 
      IF( .NOT.SAME.OR.ERR.NE.ZERO )THEN 
         WRITE( NOUT, FMT = 9989 )TRANSA, TRANSB, SAME, ERR 
         STOP 
      END IF 
      DO 120 J = 1, N 
         AB( J, NMAX + 1 ) = N - J + 1 
         AB( 1, NMAX + J ) = N - J + 1 
  120 CONTINUE 
      DO 130 J = 1, N 
         CC( N - J + 1 ) = J*( ( J + 1 )*J )/2 - 
     $                     ( ( J + 1 )*J*( J - 1 ) )/3 
  130 CONTINUE 
      TRANSA = 'T' 
      TRANSB = 'N' 
      CALL DMMCH( TRANSA, TRANSB, N, 1, N, ONE, AB, NMAX, 
     $            AB( 1, NMAX + 1 ), NMAX, ZERO, C, NMAX, CT, G, CC, 
     $            NMAX, EPS, ERR, FATAL, NOUT, .TRUE. ) 
      SAME = LDE( CC, CT, N ) 
      IF( .NOT.SAME.OR.ERR.NE.ZERO )THEN 
         WRITE( NOUT, FMT = 9989 )TRANSA, TRANSB, SAME, ERR 
         STOP 
      END IF 
      TRANSB = 'T' 
      CALL DMMCH( TRANSA, TRANSB, N, 1, N, ONE, AB, NMAX, 
     $            AB( 1, NMAX + 1 ), NMAX, ZERO, C, NMAX, CT, G, CC, 
     $            NMAX, EPS, ERR, FATAL, NOUT, .TRUE. ) 
      SAME = LDE( CC, CT, N ) 
      IF( .NOT.SAME.OR.ERR.NE.ZERO )THEN 
         WRITE( NOUT, FMT = 9989 )TRANSA, TRANSB, SAME, ERR 
         STOP 
      END IF 
* 
*     Test each subroutine in turn. 
* 
      DO 200 ISNUM = 1, NSUBS 
         WRITE( NOUT, FMT = * ) 
         IF( .NOT.LTEST( ISNUM ) )THEN 
*           Subprogram is not to be tested. 
            WRITE( NOUT, FMT = 9987 )SNAMES( ISNUM ) 
         ELSE 
            SRNAMT = SNAMES( ISNUM ) 
*           Test error exits. 
            IF( TSTERR )THEN 
               CALL DCHKE( ISNUM, SNAMES( ISNUM ), NOUT ) 
               WRITE( NOUT, FMT = * ) 
            END IF 
*           Test computations. 
            INFOT = 0 
            OK = .TRUE. 
            FATAL = .FALSE. 
            GO TO ( 140, 150, 160, 160, 170, 180 )ISNUM 
*           Test DGEMM, 01. 
  140       CALL DCHK1( SNAMES( ISNUM ), EPS, THRESH, NOUT, NTRA, TRACE, 
     $                  REWI, FATAL, NIDIM, IDIM, NALF, ALF, NBET, BET, 
     $                  NMAX, AB, AA, AS, AB( 1, NMAX + 1 ), BB, BS, C, 
     $                  CC, CS, CT, G ) 
            GO TO 190 
*           Test DSYMM, 02. 
  150       CALL DCHK2( SNAMES( ISNUM ), EPS, THRESH, NOUT, NTRA, TRACE, 
     $                  REWI, FATAL, NIDIM, IDIM, NALF, ALF, NBET, BET, 
     $                  NMAX, AB, AA, AS, AB( 1, NMAX + 1 ), BB, BS, C, 
     $                  CC, CS, CT, G ) 
            GO TO 190 
*           Test DTRMM, 03, DTRSM, 04. 
  160       CALL DCHK3( SNAMES( ISNUM ), EPS, THRESH, NOUT, NTRA, TRACE, 
     $                  REWI, FATAL, NIDIM, IDIM, NALF, ALF, NMAX, AB, 
     $                  AA, AS, AB( 1, NMAX + 1 ), BB, BS, CT, G, C ) 
            GO TO 190 
*           Test DSYRK, 05. 
  170       CALL DCHK4( SNAMES( ISNUM ), EPS, THRESH, NOUT, NTRA, TRACE, 
     $                  REWI, FATAL, NIDIM, IDIM, NALF, ALF, NBET, BET, 
     $                  NMAX, AB, AA, AS, AB( 1, NMAX + 1 ), BB, BS, C, 
     $                  CC, CS, CT, G ) 
            GO TO 190 
*           Test DSYR2K, 06. 
  180       CALL DCHK5( SNAMES( ISNUM ), EPS, THRESH, NOUT, NTRA, TRACE, 
     $                  REWI, FATAL, NIDIM, IDIM, NALF, ALF, NBET, BET, 
     $                  NMAX, AB, AA, AS, BB, BS, C, CC, CS, CT, G, W ) 
            GO TO 190 
* 
  190       IF( FATAL.AND.SFATAL ) 
     $         GO TO 210 
         END IF 
  200 CONTINUE 
      WRITE( NOUT, FMT = 9986 ) 
      GO TO 230 
* 
  210 CONTINUE 
      WRITE( NOUT, FMT = 9985 ) 
      GO TO 230 
* 
  220 CONTINUE 
      WRITE( NOUT, FMT = 9991 ) 
* 
  230 CONTINUE 
      IF( TRACE ) 
     $   CLOSE ( NTRA ) 
      CLOSE ( NOUT ) 
      STOP 
* 
 9999 FORMAT( ' ROUTINES PASS COMPUTATIONAL TESTS IF TEST RATIO IS LES', 
     $      'S THAN', F8.2 ) 
 9998 FORMAT( ' RELATIVE MACHINE PRECISION IS TAKEN TO BE', 1P, D9.1 ) 
 9997 FORMAT( ' NUMBER OF VALUES OF ', A, ' IS LESS THAN 1 OR GREATER ', 
     $      'THAN ', I2 ) 
 9996 FORMAT( ' VALUE OF N IS LESS THAN 0 OR GREATER THAN ', I2 ) 
 9995 FORMAT( ' TESTS OF THE DOUBLE PRECISION LEVEL 3 BLAS', //' THE F', 
     $      'OLLOWING PARAMETER VALUES WILL BE USED:' ) 
 9994 FORMAT( '   FOR N              ', 9I6 ) 
 9993 FORMAT( '   FOR ALPHA          ', 7F6.1 ) 
 9992 FORMAT( '   FOR BETA           ', 7F6.1 ) 
 9991 FORMAT( ' AMEND DATA FILE OR INCREASE ARRAY SIZES IN PROGRAM', 
     $      /' ******* TESTS ABANDONED *******' ) 
 9990 FORMAT( ' SUBPROGRAM NAME ', A6, ' NOT RECOGNIZED', /' ******* T', 
     $      'ESTS ABANDONED *******' ) 
 9989 FORMAT( ' ERROR IN DMMCH -  IN-LINE DOT PRODUCTS ARE BEING EVALU', 
     $      'ATED WRONGLY.', /' DMMCH WAS CALLED WITH TRANSA = ', A1, 
     $      ' AND TRANSB = ', A1, /' AND RETURNED SAME = ', L1, ' AND ', 
     $      'ERR = ', F12.3, '.', /' THIS MAY BE DUE TO FAULTS IN THE ', 
     $      'ARITHMETIC OR THE COMPILER.', /' ******* TESTS ABANDONED ', 
     $      '*******' ) 
 9988 FORMAT( A6, L2 ) 
 9987 FORMAT( 1X, A6, ' WAS NOT TESTED' ) 
 9986 FORMAT( /' END OF TESTS' ) 
 9985 FORMAT( /' ******* FATAL ERROR - TESTS ABANDONED *******' ) 
 9984 FORMAT( ' ERROR-EXITS WILL NOT BE TESTED' ) 
* 
*     End of DBLAT3. 
* 
      END 
      SUBROUTINE DCHK1( SNAME, EPS, THRESH, NOUT, NTRA, TRACE, REWI, 
     $                  FATAL, NIDIM, IDIM, NALF, ALF, NBET, BET, NMAX, 
     $                  A, AA, AS, B, BB, BS, C, CC, CS, CT, G ) 
* 
*  Tests DGEMM. 
* 
*  Auxiliary routine for test program for Level 3 Blas. 
* 
*  -- Written on 8-February-1989. 
*     Jack Dongarra, Argonne National Laboratory. 
*     Iain Duff, AERE Harwell. 
*     Jeremy Du Croz, Numerical Algorithms Group Ltd. 
*     Sven Hammarling, Numerical Algorithms Group Ltd. 
* 
*     .. Parameters .. 
      DOUBLE PRECISION   ZERO 
      PARAMETER          ( ZERO = 0.0D0 ) 
*     .. Scalar Arguments .. 
      DOUBLE PRECISION   EPS, THRESH 
      INTEGER            NALF, NBET, NIDIM, NMAX, NOUT, NTRA 
      LOGICAL            FATAL, REWI, TRACE 
      CHARACTER*6        SNAME 
*     .. Array Arguments .. 
      DOUBLE PRECISION   A( NMAX, NMAX ), AA( NMAX*NMAX ), ALF( NALF ), 
     $                   AS( NMAX*NMAX ), B( NMAX, NMAX ), 
     $                   BB( NMAX*NMAX ), BET( NBET ), BS( NMAX*NMAX ), 
     $                   C( NMAX, NMAX ), CC( NMAX*NMAX ), 
     $                   CS( NMAX*NMAX ), CT( NMAX ), G( NMAX ) 
      INTEGER            IDIM( NIDIM ) 
*     .. Local Scalars .. 
      DOUBLE PRECISION   ALPHA, ALS, BETA, BLS, ERR, ERRMAX 
      INTEGER            I, IA, IB, ICA, ICB, IK, IM, IN, K, KS, LAA, 
     $                   LBB, LCC, LDA, LDAS, LDB, LDBS, LDC, LDCS, M, 
     $                   MA, MB, MS, N, NA, NARGS, NB, NC, NS 
      LOGICAL            NULL, RESET, SAME, TRANA, TRANB 
      CHARACTER*1        TRANAS, TRANBS, TRANSA, TRANSB 
      CHARACTER*3        ICH 
*     .. Local Arrays .. 
      LOGICAL            ISAME( 13 ) 
*     .. External Functions .. 
      LOGICAL            LDE, LDERES 
      EXTERNAL           LDE, LDERES 
*     .. External Subroutines .. 
      EXTERNAL           DGEMM, DMAKE, DMMCH 
*     .. Intrinsic Functions .. 
      INTRINSIC          MAX 
*     .. Scalars in Common .. 
      INTEGER            INFOT, NOUTC 
      LOGICAL            LERR, OK 
*     .. Common blocks .. 
      COMMON             /INFOC/INFOT, NOUTC, OK, LERR 
*     .. Data statements .. 
      DATA               ICH/'NTC'/ 
*     .. Executable Statements .. 
* 
      NARGS = 13 
      NC = 0 
      RESET = .TRUE. 
      ERRMAX = ZERO 
* 
      DO 110 IM = 1, NIDIM 
         M = IDIM( IM ) 
* 
         DO 100 IN = 1, NIDIM 
            N = IDIM( IN ) 
*           Set LDC to 1 more than minimum value if room. 
            LDC = M 
            IF( LDC.LT.NMAX ) 
     $         LDC = LDC + 1 
*           Skip tests if not enough room. 
            IF( LDC.GT.NMAX ) 
     $         GO TO 100 
            LCC = LDC*N 
            NULL = N.LE.0.OR.M.LE.0 
* 
            DO 90 IK = 1, NIDIM 
               K = IDIM( IK ) 
* 
               DO 80 ICA = 1, 3 
                  TRANSA = ICH( ICA: ICA ) 
                  TRANA = TRANSA.EQ.'T'.OR.TRANSA.EQ.'C' 
* 
                  IF( TRANA )THEN 
                     MA = K 
                     NA = M 
                  ELSE 
                     MA = M 
                     NA = K 
                  END IF 
*                 Set LDA to 1 more than minimum value if room. 
                  LDA = MA 
                  IF( LDA.LT.NMAX ) 
     $               LDA = LDA + 1 
*                 Skip tests if not enough room. 
                  IF( LDA.GT.NMAX ) 
     $               GO TO 80 
                  LAA = LDA*NA 
* 
*                 Generate the matrix A. 
* 
                  CALL DMAKE( 'GE', ' ', ' ', MA, NA, A, NMAX, AA, LDA, 
     $                        RESET, ZERO ) 
* 
                  DO 70 ICB = 1, 3 
                     TRANSB = ICH( ICB: ICB ) 
                     TRANB = TRANSB.EQ.'T'.OR.TRANSB.EQ.'C' 
* 
                     IF( TRANB )THEN 
                        MB = N 
                        NB = K 
                     ELSE 
                        MB = K 
                        NB = N 
                     END IF 
*                    Set LDB to 1 more than minimum value if room. 
                     LDB = MB 
                     IF( LDB.LT.NMAX ) 
     $                  LDB = LDB + 1 
*                    Skip tests if not enough room. 
                     IF( LDB.GT.NMAX ) 
     $                  GO TO 70 
                     LBB = LDB*NB 
* 
*                    Generate the matrix B. 
* 
                     CALL DMAKE( 'GE', ' ', ' ', MB, NB, B, NMAX, BB, 
     $                           LDB, RESET, ZERO ) 
* 
                     DO 60 IA = 1, NALF 
                        ALPHA = ALF( IA ) 
* 
                        DO 50 IB = 1, NBET 
                           BETA = BET( IB ) 
* 
*                          Generate the matrix C. 
* 
                           CALL DMAKE( 'GE', ' ', ' ', M, N, C, NMAX, 
     $                                 CC, LDC, RESET, ZERO ) 
* 
                           NC = NC + 1 
* 
*                          Save every datum before calling the 
*                          subroutine. 
* 
                           TRANAS = TRANSA 
                           TRANBS = TRANSB 
                           MS = M 
                           NS = N 
                           KS = K 
                           ALS = ALPHA 
                           DO 10 I = 1, LAA 
                              AS( I ) = AA( I ) 
   10                      CONTINUE 
                           LDAS = LDA 
                           DO 20 I = 1, LBB 
                              BS( I ) = BB( I ) 
   20                      CONTINUE 
                           LDBS = LDB 
                           BLS = BETA 
                           DO 30 I = 1, LCC 
                              CS( I ) = CC( I ) 
   30                      CONTINUE 
                           LDCS = LDC 
* 
*                          Call the subroutine. 
* 
                           IF( TRACE ) 
     $                        WRITE( NTRA, FMT = 9995 )NC, SNAME, 
     $                        TRANSA, TRANSB, M, N, K, ALPHA, LDA, LDB, 
     $                        BETA, LDC 
                           IF( REWI ) 
     $                        REWIND NTRA 
                           CALL DGEMM( TRANSA, TRANSB, M, N, K, ALPHA, 
     $                                 AA, LDA, BB, LDB, BETA, CC, LDC ) 
* 
*                          Check if error-exit was taken incorrectly. 
* 
                           IF( .NOT.OK )THEN 
                              WRITE( NOUT, FMT = 9994 ) 
                              FATAL = .TRUE. 
                              GO TO 120 
                           END IF 
* 
*                          See what data changed inside subroutines. 
* 
                           ISAME( 1 ) = TRANSA.EQ.TRANAS 
                           ISAME( 2 ) = TRANSB.EQ.TRANBS 
                           ISAME( 3 ) = MS.EQ.M 
                           ISAME( 4 ) = NS.EQ.N 
                           ISAME( 5 ) = KS.EQ.K 
                           ISAME( 6 ) = ALS.EQ.ALPHA 
                           ISAME( 7 ) = LDE( AS, AA, LAA ) 
                           ISAME( 8 ) = LDAS.EQ.LDA 
                           ISAME( 9 ) = LDE( BS, BB, LBB ) 
                           ISAME( 10 ) = LDBS.EQ.LDB 
                           ISAME( 11 ) = BLS.EQ.BETA 
                           IF( NULL )THEN 
                              ISAME( 12 ) = LDE( CS, CC, LCC ) 
                           ELSE 
                              ISAME( 12 ) = LDERES( 'GE', ' ', M, N, CS, 
     $                                      CC, LDC ) 
                           END IF 
                           ISAME( 13 ) = LDCS.EQ.LDC 
* 
*                          If data was incorrectly changed, report 
*                          and return. 
* 
                           SAME = .TRUE. 
                           DO 40 I = 1, NARGS 
                              SAME = SAME.AND.ISAME( I ) 
                              IF( .NOT.ISAME( I ) ) 
     $                           WRITE( NOUT, FMT = 9998 )I 
   40                      CONTINUE 
                           IF( .NOT.SAME )THEN 
                              FATAL = .TRUE. 
                              GO TO 120 
                           END IF 
* 
                           IF( .NOT.NULL )THEN 
* 
*                             Check the result. 
* 
                              CALL DMMCH( TRANSA, TRANSB, M, N, K, 
     $                                    ALPHA, A, NMAX, B, NMAX, BETA, 
     $                                    C, NMAX, CT, G, CC, LDC, EPS, 
     $                                    ERR, FATAL, NOUT, .TRUE. ) 
                              ERRMAX = MAX( ERRMAX, ERR ) 
*                             If got really bad answer, report and 
*                             return. 
                              IF( FATAL ) 
     $                           GO TO 120 
                           END IF 
* 
   50                   CONTINUE 
* 
   60                CONTINUE 
* 
   70             CONTINUE 
* 
   80          CONTINUE 
* 
   90       CONTINUE 
* 
  100    CONTINUE 
* 
  110 CONTINUE 
* 
*     Report result. 
* 
      IF( ERRMAX.LT.THRESH )THEN 
         WRITE( NOUT, FMT = 9999 )SNAME, NC 
      ELSE 
         WRITE( NOUT, FMT = 9997 )SNAME, NC, ERRMAX 
      END IF 
      GO TO 130 
* 
  120 CONTINUE 
      WRITE( NOUT, FMT = 9996 )SNAME 
      WRITE( NOUT, FMT = 9995 )NC, SNAME, TRANSA, TRANSB, M, N, K, 
     $   ALPHA, LDA, LDB, BETA, LDC 
* 
  130 CONTINUE 
      RETURN 
* 
 9999 FORMAT( ' ', A6, ' PASSED THE COMPUTATIONAL TESTS (', I6, ' CALL', 
     $      'S)' ) 
 9998 FORMAT( ' ******* FATAL ERROR - PARAMETER NUMBER ', I2, ' WAS CH', 
     $      'ANGED INCORRECTLY *******' ) 
 9997 FORMAT( ' ', A6, ' COMPLETED THE COMPUTATIONAL TESTS (', I6, ' C', 
     $      'ALLS)', /' ******* BUT WITH MAXIMUM TEST RATIO', F8.2, 
     $      ' - SUSPECT *******' ) 
 9996 FORMAT( ' ******* ', A6, ' FAILED ON CALL NUMBER:' ) 
 9995 FORMAT( 1X, I6, ': ', A6, '(''', A1, ''',''', A1, ''',', 
     $      3( I3, ',' ), F4.1, ', A,', I3, ', B,', I3, ',', F4.1, ', ', 
     $      'C,', I3, ').' ) 
 9994 FORMAT( ' ******* FATAL ERROR - ERROR-EXIT TAKEN ON VALID CALL *', 
     $      '******' ) 
* 
*     End of DCHK1. 
* 
      END 
      SUBROUTINE DCHK2( SNAME, EPS, THRESH, NOUT, NTRA, TRACE, REWI, 
     $                  FATAL, NIDIM, IDIM, NALF, ALF, NBET, BET, NMAX, 
     $                  A, AA, AS, B, BB, BS, C, CC, CS, CT, G ) 
* 
*  Tests DSYMM. 
* 
*  Auxiliary routine for test program for Level 3 Blas. 
* 
*  -- Written on 8-February-1989. 
*     Jack Dongarra, Argonne National Laboratory. 
*     Iain Duff, AERE Harwell. 
*     Jeremy Du Croz, Numerical Algorithms Group Ltd. 
*     Sven Hammarling, Numerical Algorithms Group Ltd. 
* 
*     .. Parameters .. 
      DOUBLE PRECISION   ZERO 
      PARAMETER          ( ZERO = 0.0D0 ) 
*     .. Scalar Arguments .. 
      DOUBLE PRECISION   EPS, THRESH 
      INTEGER            NALF, NBET, NIDIM, NMAX, NOUT, NTRA 
      LOGICAL            FATAL, REWI, TRACE 
      CHARACTER*6        SNAME 
*     .. Array Arguments .. 
      DOUBLE PRECISION   A( NMAX, NMAX ), AA( NMAX*NMAX ), ALF( NALF ), 
     $                   AS( NMAX*NMAX ), B( NMAX, NMAX ), 
     $                   BB( NMAX*NMAX ), BET( NBET ), BS( NMAX*NMAX ), 
     $                   C( NMAX, NMAX ), CC( NMAX*NMAX ), 
     $                   CS( NMAX*NMAX ), CT( NMAX ), G( NMAX ) 
      INTEGER            IDIM( NIDIM ) 
*     .. Local Scalars .. 
      DOUBLE PRECISION   ALPHA, ALS, BETA, BLS, ERR, ERRMAX 
      INTEGER            I, IA, IB, ICS, ICU, IM, IN, LAA, LBB, LCC, 
     $                   LDA, LDAS, LDB, LDBS, LDC, LDCS, M, MS, N, NA, 
     $                   NARGS, NC, NS 
      LOGICAL            LEFT, NULL, RESET, SAME 
      CHARACTER*1        SIDE, SIDES, UPLO, UPLOS 
      CHARACTER*2        ICHS, ICHU 
*     .. Local Arrays .. 
      LOGICAL            ISAME( 13 ) 
*     .. External Functions .. 
      LOGICAL            LDE, LDERES 
      EXTERNAL           LDE, LDERES 
*     .. External Subroutines .. 
      EXTERNAL           DMAKE, DMMCH, DSYMM 
*     .. Intrinsic Functions .. 
      INTRINSIC          MAX 
*     .. Scalars in Common .. 
      INTEGER            INFOT, NOUTC 
      LOGICAL            LERR, OK 
*     .. Common blocks .. 
      COMMON             /INFOC/INFOT, NOUTC, OK, LERR 
*     .. Data statements .. 
      DATA               ICHS/'LR'/, ICHU/'UL'/ 
*     .. Executable Statements .. 
* 
      NARGS = 12 
      NC = 0 
      RESET = .TRUE. 
      ERRMAX = ZERO 
* 
      DO 100 IM = 1, NIDIM 
         M = IDIM( IM ) 
* 
         DO 90 IN = 1, NIDIM 
            N = IDIM( IN ) 
*           Set LDC to 1 more than minimum value if room. 
            LDC = M 
            IF( LDC.LT.NMAX ) 
     $         LDC = LDC + 1 
*           Skip tests if not enough room. 
            IF( LDC.GT.NMAX ) 
     $         GO TO 90 
            LCC = LDC*N 
            NULL = N.LE.0.OR.M.LE.0 
* 
*           Set LDB to 1 more than minimum value if room. 
            LDB = M 
            IF( LDB.LT.NMAX ) 
     $         LDB = LDB + 1 
*           Skip tests if not enough room. 
            IF( LDB.GT.NMAX ) 
     $         GO TO 90 
            LBB = LDB*N 
* 
*           Generate the matrix B. 
* 
            CALL DMAKE( 'GE', ' ', ' ', M, N, B, NMAX, BB, LDB, RESET, 
     $                  ZERO ) 
* 
            DO 80 ICS = 1, 2 
               SIDE = ICHS( ICS: ICS ) 
               LEFT = SIDE.EQ.'L' 
* 
               IF( LEFT )THEN 
                  NA = M 
               ELSE 
                  NA = N 
               END IF 
*              Set LDA to 1 more than minimum value if room. 
               LDA = NA 
               IF( LDA.LT.NMAX ) 
     $            LDA = LDA + 1 
*              Skip tests if not enough room. 
               IF( LDA.GT.NMAX ) 
     $            GO TO 80 
               LAA = LDA*NA 
* 
               DO 70 ICU = 1, 2 
                  UPLO = ICHU( ICU: ICU ) 
* 
*                 Generate the symmetric matrix A. 
* 
                  CALL DMAKE( 'SY', UPLO, ' ', NA, NA, A, NMAX, AA, LDA, 
     $                        RESET, ZERO ) 
* 
                  DO 60 IA = 1, NALF 
                     ALPHA = ALF( IA ) 
* 
                     DO 50 IB = 1, NBET 
                        BETA = BET( IB ) 
* 
*                       Generate the matrix C. 
* 
                        CALL DMAKE( 'GE', ' ', ' ', M, N, C, NMAX, CC, 
     $                              LDC, RESET, ZERO ) 
* 
                        NC = NC + 1 
* 
*                       Save every datum before calling the 
*                       subroutine. 
* 
                        SIDES = SIDE 
                        UPLOS = UPLO 
                        MS = M 
                        NS = N 
                        ALS = ALPHA 
                        DO 10 I = 1, LAA 
                           AS( I ) = AA( I ) 
   10                   CONTINUE 
                        LDAS = LDA 
                        DO 20 I = 1, LBB 
                           BS( I ) = BB( I ) 
   20                   CONTINUE 
                        LDBS = LDB 
                        BLS = BETA 
                        DO 30 I = 1, LCC 
                           CS( I ) = CC( I ) 
   30                   CONTINUE 
                        LDCS = LDC 
* 
*                       Call the subroutine. 
* 
                        IF( TRACE ) 
     $                     WRITE( NTRA, FMT = 9995 )NC, SNAME, SIDE, 
     $                     UPLO, M, N, ALPHA, LDA, LDB, BETA, LDC 
                        IF( REWI ) 
     $                     REWIND NTRA 
                        CALL DSYMM( SIDE, UPLO, M, N, ALPHA, AA, LDA, 
     $                              BB, LDB, BETA, CC, LDC ) 
* 
*                       Check if error-exit was taken incorrectly. 
* 
                        IF( .NOT.OK )THEN 
                           WRITE( NOUT, FMT = 9994 ) 
                           FATAL = .TRUE. 
                           GO TO 110 
                        END IF 
* 
*                       See what data changed inside subroutines. 
* 
                        ISAME( 1 ) = SIDES.EQ.SIDE 
                        ISAME( 2 ) = UPLOS.EQ.UPLO 
                        ISAME( 3 ) = MS.EQ.M 
                        ISAME( 4 ) = NS.EQ.N 
                        ISAME( 5 ) = ALS.EQ.ALPHA 
                        ISAME( 6 ) = LDE( AS, AA, LAA ) 
                        ISAME( 7 ) = LDAS.EQ.LDA 
                        ISAME( 8 ) = LDE( BS, BB, LBB ) 
                        ISAME( 9 ) = LDBS.EQ.LDB 
                        ISAME( 10 ) = BLS.EQ.BETA 
                        IF( NULL )THEN 
                           ISAME( 11 ) = LDE( CS, CC, LCC ) 
                        ELSE 
                           ISAME( 11 ) = LDERES( 'GE', ' ', M, N, CS, 
     $                                   CC, LDC ) 
                        END IF 
                        ISAME( 12 ) = LDCS.EQ.LDC 
* 
*                       If data was incorrectly changed, report and 
*                       return. 
* 
                        SAME = .TRUE. 
                        DO 40 I = 1, NARGS 
                           SAME = SAME.AND.ISAME( I ) 
                           IF( .NOT.ISAME( I ) ) 
     $                        WRITE( NOUT, FMT = 9998 )I 
   40                   CONTINUE 
                        IF( .NOT.SAME )THEN 
                           FATAL = .TRUE. 
                           GO TO 110 
                        END IF 
* 
                        IF( .NOT.NULL )THEN 
* 
*                          Check the result. 
* 
                           IF( LEFT )THEN 
                              CALL DMMCH( 'N', 'N', M, N, M, ALPHA, A, 
     $                                    NMAX, B, NMAX, BETA, C, NMAX, 
     $                                    CT, G, CC, LDC, EPS, ERR, 
     $                                    FATAL, NOUT, .TRUE. ) 
                           ELSE 
                              CALL DMMCH( 'N', 'N', M, N, N, ALPHA, B, 
     $                                    NMAX, A, NMAX, BETA, C, NMAX, 
     $                                    CT, G, CC, LDC, EPS, ERR, 
     $                                    FATAL, NOUT, .TRUE. ) 
                           END IF 
                           ERRMAX = MAX( ERRMAX, ERR ) 
*                          If got really bad answer, report and 
*                          return. 
                           IF( FATAL ) 
     $                        GO TO 110 
                        END IF 
* 
   50                CONTINUE 
* 
   60             CONTINUE 
* 
   70          CONTINUE 
* 
   80       CONTINUE 
* 
   90    CONTINUE 
* 
  100 CONTINUE 
* 
*     Report result. 
* 
      IF( ERRMAX.LT.THRESH )THEN 
         WRITE( NOUT, FMT = 9999 )SNAME, NC 
      ELSE 
         WRITE( NOUT, FMT = 9997 )SNAME, NC, ERRMAX 
      END IF 
      GO TO 120 
* 
  110 CONTINUE 
      WRITE( NOUT, FMT = 9996 )SNAME 
      WRITE( NOUT, FMT = 9995 )NC, SNAME, SIDE, UPLO, M, N, ALPHA, LDA, 
     $   LDB, BETA, LDC 
* 
  120 CONTINUE 
      RETURN 
* 
 9999 FORMAT( ' ', A6, ' PASSED THE COMPUTATIONAL TESTS (', I6, ' CALL', 
     $      'S)' ) 
 9998 FORMAT( ' ******* FATAL ERROR - PARAMETER NUMBER ', I2, ' WAS CH', 
     $      'ANGED INCORRECTLY *******' ) 
 9997 FORMAT( ' ', A6, ' COMPLETED THE COMPUTATIONAL TESTS (', I6, ' C', 
     $      'ALLS)', /' ******* BUT WITH MAXIMUM TEST RATIO', F8.2, 
     $      ' - SUSPECT *******' ) 
 9996 FORMAT( ' ******* ', A6, ' FAILED ON CALL NUMBER:' ) 
 9995 FORMAT( 1X, I6, ': ', A6, '(', 2( '''', A1, ''',' ), 2( I3, ',' ), 
     $      F4.1, ', A,', I3, ', B,', I3, ',', F4.1, ', C,', I3, ')   ', 
     $      ' .' ) 
 9994 FORMAT( ' ******* FATAL ERROR - ERROR-EXIT TAKEN ON VALID CALL *', 
     $      '******' ) 
* 
*     End of DCHK2. 
* 
      END 
      SUBROUTINE DCHK3( SNAME, EPS, THRESH, NOUT, NTRA, TRACE, REWI, 
     $                  FATAL, NIDIM, IDIM, NALF, ALF, NMAX, A, AA, AS, 
     $                  B, BB, BS, CT, G, C ) 
* 
*  Tests DTRMM and DTRSM. 
* 
*  Auxiliary routine for test program for Level 3 Blas. 
* 
*  -- Written on 8-February-1989. 
*     Jack Dongarra, Argonne National Laboratory. 
*     Iain Duff, AERE Harwell. 
*     Jeremy Du Croz, Numerical Algorithms Group Ltd. 
*     Sven Hammarling, Numerical Algorithms Group Ltd. 
* 
*     .. Parameters .. 
      DOUBLE PRECISION   ZERO, ONE 
      PARAMETER          ( ZERO = 0.0D0, ONE = 1.0D0 ) 
*     .. Scalar Arguments .. 
      DOUBLE PRECISION   EPS, THRESH 
      INTEGER            NALF, NIDIM, NMAX, NOUT, NTRA 
      LOGICAL            FATAL, REWI, TRACE 
      CHARACTER*6        SNAME 
*     .. Array Arguments .. 
      DOUBLE PRECISION   A( NMAX, NMAX ), AA( NMAX*NMAX ), ALF( NALF ), 
     $                   AS( NMAX*NMAX ), B( NMAX, NMAX ), 
     $                   BB( NMAX*NMAX ), BS( NMAX*NMAX ), 
     $                   C( NMAX, NMAX ), CT( NMAX ), G( NMAX ) 
      INTEGER            IDIM( NIDIM ) 
*     .. Local Scalars .. 
      DOUBLE PRECISION   ALPHA, ALS, ERR, ERRMAX 
      INTEGER            I, IA, ICD, ICS, ICT, ICU, IM, IN, J, LAA, LBB, 
     $                   LDA, LDAS, LDB, LDBS, M, MS, N, NA, NARGS, NC, 
     $                   NS 
      LOGICAL            LEFT, NULL, RESET, SAME 
      CHARACTER*1        DIAG, DIAGS, SIDE, SIDES, TRANAS, TRANSA, UPLO, 
     $                   UPLOS 
      CHARACTER*2        ICHD, ICHS, ICHU 
      CHARACTER*3        ICHT 
*     .. Local Arrays .. 
      LOGICAL            ISAME( 13 ) 
*     .. External Functions .. 
      LOGICAL            LDE, LDERES 
      EXTERNAL           LDE, LDERES 
*     .. External Subroutines .. 
      EXTERNAL           DMAKE, DMMCH, DTRMM, DTRSM 
*     .. Intrinsic Functions .. 
      INTRINSIC          MAX 
*     .. Scalars in Common .. 
      INTEGER            INFOT, NOUTC 
      LOGICAL            LERR, OK 
*     .. Common blocks .. 
      COMMON             /INFOC/INFOT, NOUTC, OK, LERR 
*     .. Data statements .. 
      DATA               ICHU/'UL'/, ICHT/'NTC'/, ICHD/'UN'/, ICHS/'LR'/ 
*     .. Executable Statements .. 
* 
      NARGS = 11 
      NC = 0 
      RESET = .TRUE. 
      ERRMAX = ZERO 
*     Set up zero matrix for DMMCH. 
      DO 20 J = 1, NMAX 
         DO 10 I = 1, NMAX 
            C( I, J ) = ZERO 
   10    CONTINUE 
   20 CONTINUE 
* 
      DO 140 IM = 1, NIDIM 
         M = IDIM( IM ) 
* 
         DO 130 IN = 1, NIDIM 
            N = IDIM( IN ) 
*           Set LDB to 1 more than minimum value if room. 
            LDB = M 
            IF( LDB.LT.NMAX ) 
     $         LDB = LDB + 1 
*           Skip tests if not enough room. 
            IF( LDB.GT.NMAX ) 
     $         GO TO 130 
            LBB = LDB*N 
            NULL = M.LE.0.OR.N.LE.0 
* 
            DO 120 ICS = 1, 2 
               SIDE = ICHS( ICS: ICS ) 
               LEFT = SIDE.EQ.'L' 
               IF( LEFT )THEN 
                  NA = M 
               ELSE 
                  NA = N 
               END IF 
*              Set LDA to 1 more than minimum value if room. 
               LDA = NA 
               IF( LDA.LT.NMAX ) 
     $            LDA = LDA + 1 
*              Skip tests if not enough room. 
               IF( LDA.GT.NMAX ) 
     $            GO TO 130 
               LAA = LDA*NA 
* 
               DO 110 ICU = 1, 2 
                  UPLO = ICHU( ICU: ICU ) 
* 
                  DO 100 ICT = 1, 3 
                     TRANSA = ICHT( ICT: ICT ) 
* 
                     DO 90 ICD = 1, 2 
                        DIAG = ICHD( ICD: ICD ) 
* 
                        DO 80 IA = 1, NALF 
                           ALPHA = ALF( IA ) 
* 
*                          Generate the matrix A. 
* 
                           CALL DMAKE( 'TR', UPLO, DIAG, NA, NA, A, 
     $                                 NMAX, AA, LDA, RESET, ZERO ) 
* 
*                          Generate the matrix B. 
* 
                           CALL DMAKE( 'GE', ' ', ' ', M, N, B, NMAX, 
     $                                 BB, LDB, RESET, ZERO ) 
* 
                           NC = NC + 1 
* 
*                          Save every datum before calling the 
*                          subroutine. 
* 
                           SIDES = SIDE 
                           UPLOS = UPLO 
                           TRANAS = TRANSA 
                           DIAGS = DIAG 
                           MS = M 
                           NS = N 
                           ALS = ALPHA 
                           DO 30 I = 1, LAA 
                              AS( I ) = AA( I ) 
   30                      CONTINUE 
                           LDAS = LDA 
                           DO 40 I = 1, LBB 
                              BS( I ) = BB( I ) 
   40                      CONTINUE 
                           LDBS = LDB 
* 
*                          Call the subroutine. 
* 
                           IF( SNAME( 4: 5 ).EQ.'MM' )THEN 
                              IF( TRACE ) 
     $                           WRITE( NTRA, FMT = 9995 )NC, SNAME, 
     $                           SIDE, UPLO, TRANSA, DIAG, M, N, ALPHA, 
     $                           LDA, LDB 
                              IF( REWI ) 
     $                           REWIND NTRA 
                              CALL DTRMM( SIDE, UPLO, TRANSA, DIAG, M, 
     $                                    N, ALPHA, AA, LDA, BB, LDB ) 
                           ELSE IF( SNAME( 4: 5 ).EQ.'SM' )THEN 
                              IF( TRACE ) 
     $                           WRITE( NTRA, FMT = 9995 )NC, SNAME, 
     $                           SIDE, UPLO, TRANSA, DIAG, M, N, ALPHA, 
     $                           LDA, LDB 
                              IF( REWI ) 
     $                           REWIND NTRA 
                              CALL DTRSM( SIDE, UPLO, TRANSA, DIAG, M, 
     $                                    N, ALPHA, AA, LDA, BB, LDB ) 
                           END IF 
* 
*                          Check if error-exit was taken incorrectly. 
* 
                           IF( .NOT.OK )THEN 
                              WRITE( NOUT, FMT = 9994 ) 
                              FATAL = .TRUE. 
                              GO TO 150 
                           END IF 
* 
*                          See what data changed inside subroutines. 
* 
                           ISAME( 1 ) = SIDES.EQ.SIDE 
                           ISAME( 2 ) = UPLOS.EQ.UPLO 
                           ISAME( 3 ) = TRANAS.EQ.TRANSA 
                           ISAME( 4 ) = DIAGS.EQ.DIAG 
                           ISAME( 5 ) = MS.EQ.M 
                           ISAME( 6 ) = NS.EQ.N 
                           ISAME( 7 ) = ALS.EQ.ALPHA 
                           ISAME( 8 ) = LDE( AS, AA, LAA ) 
                           ISAME( 9 ) = LDAS.EQ.LDA 
                           IF( NULL )THEN 
                              ISAME( 10 ) = LDE( BS, BB, LBB ) 
                           ELSE 
                              ISAME( 10 ) = LDERES( 'GE', ' ', M, N, BS, 
     $                                      BB, LDB ) 
                           END IF 
                           ISAME( 11 ) = LDBS.EQ.LDB 
* 
*                          If data was incorrectly changed, report and 
*                          return. 
* 
                           SAME = .TRUE. 
                           DO 50 I = 1, NARGS 
                              SAME = SAME.AND.ISAME( I ) 
                              IF( .NOT.ISAME( I ) ) 
     $                           WRITE( NOUT, FMT = 9998 )I 
   50                      CONTINUE 
                           IF( .NOT.SAME )THEN 
                              FATAL = .TRUE. 
                              GO TO 150 
                           END IF 
* 
                           IF( .NOT.NULL )THEN 
                              IF( SNAME( 4: 5 ).EQ.'MM' )THEN 
* 
*                                Check the result. 
* 
                                 IF( LEFT )THEN 
                                    CALL DMMCH( TRANSA, 'N', M, N, M, 
     $                                          ALPHA, A, NMAX, B, NMAX, 
     $                                          ZERO, C, NMAX, CT, G, 
     $                                          BB, LDB, EPS, ERR, 
     $                                          FATAL, NOUT, .TRUE. ) 
                                 ELSE 
                                    CALL DMMCH( 'N', TRANSA, M, N, N, 
     $                                          ALPHA, B, NMAX, A, NMAX, 
     $                                          ZERO, C, NMAX, CT, G, 
     $                                          BB, LDB, EPS, ERR, 
     $                                          FATAL, NOUT, .TRUE. ) 
                                 END IF 
                              ELSE IF( SNAME( 4: 5 ).EQ.'SM' )THEN 
* 
*                                Compute approximation to original 
*                                matrix. 
* 
                                 DO 70 J = 1, N 
                                    DO 60 I = 1, M 
                                       C( I, J ) = BB( I + ( J - 1 )* 
     $                                             LDB ) 
                                       BB( I + ( J - 1 )*LDB ) = ALPHA* 
     $                                    B( I, J ) 
   60                               CONTINUE 
   70                            CONTINUE 
* 
                                 IF( LEFT )THEN 
                                    CALL DMMCH( TRANSA, 'N', M, N, M, 
     $                                          ONE, A, NMAX, C, NMAX, 
     $                                          ZERO, B, NMAX, CT, G, 
     $                                          BB, LDB, EPS, ERR, 
     $                                          FATAL, NOUT, .FALSE. ) 
                                 ELSE 
                                    CALL DMMCH( 'N', TRANSA, M, N, N, 
     $                                          ONE, C, NMAX, A, NMAX, 
     $                                          ZERO, B, NMAX, CT, G, 
     $                                          BB, LDB, EPS, ERR, 
     $                                          FATAL, NOUT, .FALSE. ) 
                                 END IF 
                              END IF 
                              ERRMAX = MAX( ERRMAX, ERR ) 
*                             If got really bad answer, report and 
*                             return. 
                              IF( FATAL ) 
     $                           GO TO 150 
                           END IF 
* 
   80                   CONTINUE 
* 
   90                CONTINUE 
* 
  100             CONTINUE 
* 
  110          CONTINUE 
* 
  120       CONTINUE 
* 
  130    CONTINUE 
* 
  140 CONTINUE 
* 
*     Report result. 
* 
      IF( ERRMAX.LT.THRESH )THEN 
         WRITE( NOUT, FMT = 9999 )SNAME, NC 
      ELSE 
         WRITE( NOUT, FMT = 9997 )SNAME, NC, ERRMAX 
      END IF 
      GO TO 160 
* 
  150 CONTINUE 
      WRITE( NOUT, FMT = 9996 )SNAME 
      WRITE( NOUT, FMT = 9995 )NC, SNAME, SIDE, UPLO, TRANSA, DIAG, M, 
     $   N, ALPHA, LDA, LDB 
* 
  160 CONTINUE 
      RETURN 
* 
 9999 FORMAT( ' ', A6, ' PASSED THE COMPUTATIONAL TESTS (', I6, ' CALL', 
     $      'S)' ) 
 9998 FORMAT( ' ******* FATAL ERROR - PARAMETER NUMBER ', I2, ' WAS CH', 
     $      'ANGED INCORRECTLY *******' ) 
 9997 FORMAT( ' ', A6, ' COMPLETED THE COMPUTATIONAL TESTS (', I6, ' C', 
     $      'ALLS)', /' ******* BUT WITH MAXIMUM TEST RATIO', F8.2, 
     $      ' - SUSPECT *******' ) 
 9996 FORMAT( ' ******* ', A6, ' FAILED ON CALL NUMBER:' ) 
 9995 FORMAT( 1X, I6, ': ', A6, '(', 4( '''', A1, ''',' ), 2( I3, ',' ), 
     $      F4.1, ', A,', I3, ', B,', I3, ')        .' ) 
 9994 FORMAT( ' ******* FATAL ERROR - ERROR-EXIT TAKEN ON VALID CALL *', 
     $      '******' ) 
* 
*     End of DCHK3. 
* 
      END 
      SUBROUTINE DCHK4( SNAME, EPS, THRESH, NOUT, NTRA, TRACE, REWI, 
     $                  FATAL, NIDIM, IDIM, NALF, ALF, NBET, BET, NMAX, 
     $                  A, AA, AS, B, BB, BS, C, CC, CS, CT, G ) 
* 
*  Tests DSYRK. 
* 
*  Auxiliary routine for test program for Level 3 Blas. 
* 
*  -- Written on 8-February-1989. 
*     Jack Dongarra, Argonne National Laboratory. 
*     Iain Duff, AERE Harwell. 
*     Jeremy Du Croz, Numerical Algorithms Group Ltd. 
*     Sven Hammarling, Numerical Algorithms Group Ltd. 
* 
*     .. Parameters .. 
      DOUBLE PRECISION   ZERO 
      PARAMETER          ( ZERO = 0.0D0 ) 
*     .. Scalar Arguments .. 
      DOUBLE PRECISION   EPS, THRESH 
      INTEGER            NALF, NBET, NIDIM, NMAX, NOUT, NTRA 
      LOGICAL            FATAL, REWI, TRACE 
      CHARACTER*6        SNAME 
*     .. Array Arguments .. 
      DOUBLE PRECISION   A( NMAX, NMAX ), AA( NMAX*NMAX ), ALF( NALF ), 
     $                   AS( NMAX*NMAX ), B( NMAX, NMAX ), 
     $                   BB( NMAX*NMAX ), BET( NBET ), BS( NMAX*NMAX ), 
     $                   C( NMAX, NMAX ), CC( NMAX*NMAX ), 
     $                   CS( NMAX*NMAX ), CT( NMAX ), G( NMAX ) 
      INTEGER            IDIM( NIDIM ) 
*     .. Local Scalars .. 
      DOUBLE PRECISION   ALPHA, ALS, BETA, BETS, ERR, ERRMAX 
      INTEGER            I, IA, IB, ICT, ICU, IK, IN, J, JC, JJ, K, KS, 
     $                   LAA, LCC, LDA, LDAS, LDC, LDCS, LJ, MA, N, NA, 
     $                   NARGS, NC, NS 
      LOGICAL            NULL, RESET, SAME, TRAN, UPPER 
      CHARACTER*1        TRANS, TRANSS, UPLO, UPLOS 
      CHARACTER*2        ICHU 
      CHARACTER*3        ICHT 
*     .. Local Arrays .. 
      LOGICAL            ISAME( 13 ) 
*     .. External Functions .. 
      LOGICAL            LDE, LDERES 
      EXTERNAL           LDE, LDERES 
*     .. External Subroutines .. 
      EXTERNAL           DMAKE, DMMCH, DSYRK 
*     .. Intrinsic Functions .. 
      INTRINSIC          MAX 
*     .. Scalars in Common .. 
      INTEGER            INFOT, NOUTC 
      LOGICAL            LERR, OK 
*     .. Common blocks .. 
      COMMON             /INFOC/INFOT, NOUTC, OK, LERR 
*     .. Data statements .. 
      DATA               ICHT/'NTC'/, ICHU/'UL'/ 
*     .. Executable Statements .. 
* 
      NARGS = 10 
      NC = 0 
      RESET = .TRUE. 
      ERRMAX = ZERO 
* 
      DO 100 IN = 1, NIDIM 
         N = IDIM( IN ) 
*        Set LDC to 1 more than minimum value if room. 
         LDC = N 
         IF( LDC.LT.NMAX ) 
     $      LDC = LDC + 1 
*        Skip tests if not enough room. 
         IF( LDC.GT.NMAX ) 
     $      GO TO 100 
         LCC = LDC*N 
         NULL = N.LE.0 
* 
         DO 90 IK = 1, NIDIM 
            K = IDIM( IK ) 
* 
            DO 80 ICT = 1, 3 
               TRANS = ICHT( ICT: ICT ) 
               TRAN = TRANS.EQ.'T'.OR.TRANS.EQ.'C' 
               IF( TRAN )THEN 
                  MA = K 
                  NA = N 
               ELSE 
                  MA = N 
                  NA = K 
               END IF 
*              Set LDA to 1 more than minimum value if room. 
               LDA = MA 
               IF( LDA.LT.NMAX ) 
     $            LDA = LDA + 1 
*              Skip tests if not enough room. 
               IF( LDA.GT.NMAX ) 
     $            GO TO 80 
               LAA = LDA*NA 
* 
*              Generate the matrix A. 
* 
               CALL DMAKE( 'GE', ' ', ' ', MA, NA, A, NMAX, AA, LDA, 
     $                     RESET, ZERO ) 
* 
               DO 70 ICU = 1, 2 
                  UPLO = ICHU( ICU: ICU ) 
                  UPPER = UPLO.EQ.'U' 
* 
                  DO 60 IA = 1, NALF 
                     ALPHA = ALF( IA ) 
* 
                     DO 50 IB = 1, NBET 
                        BETA = BET( IB ) 
* 
*                       Generate the matrix C. 
* 
                        CALL DMAKE( 'SY', UPLO, ' ', N, N, C, NMAX, CC, 
     $                              LDC, RESET, ZERO ) 
* 
                        NC = NC + 1 
* 
*                       Save every datum before calling the subroutine. 
* 
                        UPLOS = UPLO 
                        TRANSS = TRANS 
                        NS = N 
                        KS = K 
                        ALS = ALPHA 
                        DO 10 I = 1, LAA 
                           AS( I ) = AA( I ) 
   10                   CONTINUE 
                        LDAS = LDA 
                        BETS = BETA 
                        DO 20 I = 1, LCC 
                           CS( I ) = CC( I ) 
   20                   CONTINUE 
                        LDCS = LDC 
* 
*                       Call the subroutine. 
* 
                        IF( TRACE ) 
     $                     WRITE( NTRA, FMT = 9994 )NC, SNAME, UPLO, 
     $                     TRANS, N, K, ALPHA, LDA, BETA, LDC 
                        IF( REWI ) 
     $                     REWIND NTRA 
                        CALL DSYRK( UPLO, TRANS, N, K, ALPHA, AA, LDA, 
     $                              BETA, CC, LDC ) 
* 
*                       Check if error-exit was taken incorrectly. 
* 
                        IF( .NOT.OK )THEN 
                           WRITE( NOUT, FMT = 9993 ) 
                           FATAL = .TRUE. 
                           GO TO 120 
                        END IF 
* 
*                       See what data changed inside subroutines. 
* 
                        ISAME( 1 ) = UPLOS.EQ.UPLO 
                        ISAME( 2 ) = TRANSS.EQ.TRANS 
                        ISAME( 3 ) = NS.EQ.N 
                        ISAME( 4 ) = KS.EQ.K 
                        ISAME( 5 ) = ALS.EQ.ALPHA 
                        ISAME( 6 ) = LDE( AS, AA, LAA ) 
                        ISAME( 7 ) = LDAS.EQ.LDA 
                        ISAME( 8 ) = BETS.EQ.BETA 
                        IF( NULL )THEN 
                           ISAME( 9 ) = LDE( CS, CC, LCC ) 
                        ELSE 
                           ISAME( 9 ) = LDERES( 'SY', UPLO, N, N, CS, 
     $                                  CC, LDC ) 
                        END IF 
                        ISAME( 10 ) = LDCS.EQ.LDC 
* 
*                       If data was incorrectly changed, report and 
*                       return. 
* 
                        SAME = .TRUE. 
                        DO 30 I = 1, NARGS 
                           SAME = SAME.AND.ISAME( I ) 
                           IF( .NOT.ISAME( I ) ) 
     $                        WRITE( NOUT, FMT = 9998 )I 
   30                   CONTINUE 
                        IF( .NOT.SAME )THEN 
                           FATAL = .TRUE. 
                           GO TO 120 
                        END IF 
* 
                        IF( .NOT.NULL )THEN 
* 
*                          Check the result column by column. 
* 
                           JC = 1 
                           DO 40 J = 1, N 
                              IF( UPPER )THEN 
                                 JJ = 1 
                                 LJ = J 
                              ELSE 
                                 JJ = J 
                                 LJ = N - J + 1 
                              END IF 
                              IF( TRAN )THEN 
                                 CALL DMMCH( 'T', 'N', LJ, 1, K, ALPHA, 
     $                                       A( 1, JJ ), NMAX, 
     $                                       A( 1, J ), NMAX, BETA, 
     $                                       C( JJ, J ), NMAX, CT, G, 
     $                                       CC( JC ), LDC, EPS, ERR, 
     $                                       FATAL, NOUT, .TRUE. ) 
                              ELSE 
                                 CALL DMMCH( 'N', 'T', LJ, 1, K, ALPHA, 
     $                                       A( JJ, 1 ), NMAX, 
     $                                       A( J, 1 ), NMAX, BETA, 
     $                                       C( JJ, J ), NMAX, CT, G, 
     $                                       CC( JC ), LDC, EPS, ERR, 
     $                                       FATAL, NOUT, .TRUE. ) 
                              END IF 
                              IF( UPPER )THEN 
                                 JC = JC + LDC 
                              ELSE 
                                 JC = JC + LDC + 1 
                              END IF 
                              ERRMAX = MAX( ERRMAX, ERR ) 
*                             If got really bad answer, report and 
*                             return. 
                              IF( FATAL ) 
     $                           GO TO 110 
   40                      CONTINUE 
                        END IF 
* 
   50                CONTINUE 
* 
   60             CONTINUE 
* 
   70          CONTINUE 
* 
   80       CONTINUE 
* 
   90    CONTINUE 
* 
  100 CONTINUE 
* 
*     Report result. 
* 
      IF( ERRMAX.LT.THRESH )THEN 
         WRITE( NOUT, FMT = 9999 )SNAME, NC 
      ELSE 
         WRITE( NOUT, FMT = 9997 )SNAME, NC, ERRMAX 
      END IF 
      GO TO 130 
* 
  110 CONTINUE 
      IF( N.GT.1 ) 
     $   WRITE( NOUT, FMT = 9995 )J 
* 
  120 CONTINUE 
      WRITE( NOUT, FMT = 9996 )SNAME 
      WRITE( NOUT, FMT = 9994 )NC, SNAME, UPLO, TRANS, N, K, ALPHA, 
     $   LDA, BETA, LDC 
* 
  130 CONTINUE 
      RETURN 
* 
 9999 FORMAT( ' ', A6, ' PASSED THE COMPUTATIONAL TESTS (', I6, ' CALL', 
     $      'S)' ) 
 9998 FORMAT( ' ******* FATAL ERROR - PARAMETER NUMBER ', I2, ' WAS CH', 
     $      'ANGED INCORRECTLY *******' ) 
 9997 FORMAT( ' ', A6, ' COMPLETED THE COMPUTATIONAL TESTS (', I6, ' C', 
     $      'ALLS)', /' ******* BUT WITH MAXIMUM TEST RATIO', F8.2, 
     $      ' - SUSPECT *******' ) 
 9996 FORMAT( ' ******* ', A6, ' FAILED ON CALL NUMBER:' ) 
 9995 FORMAT( '      THESE ARE THE RESULTS FOR COLUMN ', I3 ) 
 9994 FORMAT( 1X, I6, ': ', A6, '(', 2( '''', A1, ''',' ), 2( I3, ',' ), 
     $      F4.1, ', A,', I3, ',', F4.1, ', C,', I3, ')           .' ) 
 9993 FORMAT( ' ******* FATAL ERROR - ERROR-EXIT TAKEN ON VALID CALL *', 
     $      '******' ) 
* 
*     End of DCHK4. 
* 
      END 
      SUBROUTINE DCHK5( SNAME, EPS, THRESH, NOUT, NTRA, TRACE, REWI, 
     $                  FATAL, NIDIM, IDIM, NALF, ALF, NBET, BET, NMAX, 
     $                  AB, AA, AS, BB, BS, C, CC, CS, CT, G, W ) 
* 
*  Tests DSYR2K. 
* 
*  Auxiliary routine for test program for Level 3 Blas. 
* 
*  -- Written on 8-February-1989. 
*     Jack Dongarra, Argonne National Laboratory. 
*     Iain Duff, AERE Harwell. 
*     Jeremy Du Croz, Numerical Algorithms Group Ltd. 
*     Sven Hammarling, Numerical Algorithms Group Ltd. 
* 
*     .. Parameters .. 
      DOUBLE PRECISION   ZERO 
      PARAMETER          ( ZERO = 0.0D0 ) 
*     .. Scalar Arguments .. 
      DOUBLE PRECISION   EPS, THRESH 
      INTEGER            NALF, NBET, NIDIM, NMAX, NOUT, NTRA 
      LOGICAL            FATAL, REWI, TRACE 
      CHARACTER*6        SNAME 
*     .. Array Arguments .. 
      DOUBLE PRECISION   AA( NMAX*NMAX ), AB( 2*NMAX*NMAX ), 
     $                   ALF( NALF ), AS( NMAX*NMAX ), BB( NMAX*NMAX ), 
     $                   BET( NBET ), BS( NMAX*NMAX ), C( NMAX, NMAX ), 
     $                   CC( NMAX*NMAX ), CS( NMAX*NMAX ), CT( NMAX ), 
     $                   G( NMAX ), W( 2*NMAX ) 
      INTEGER            IDIM( NIDIM ) 
*     .. Local Scalars .. 
      DOUBLE PRECISION   ALPHA, ALS, BETA, BETS, ERR, ERRMAX 
      INTEGER            I, IA, IB, ICT, ICU, IK, IN, J, JC, JJ, JJAB, 
     $                   K, KS, LAA, LBB, LCC, LDA, LDAS, LDB, LDBS, 
     $                   LDC, LDCS, LJ, MA, N, NA, NARGS, NC, NS 
      LOGICAL            NULL, RESET, SAME, TRAN, UPPER 
      CHARACTER*1        TRANS, TRANSS, UPLO, UPLOS 
      CHARACTER*2        ICHU 
      CHARACTER*3        ICHT 
*     .. Local Arrays .. 
      LOGICAL            ISAME( 13 ) 
*     .. External Functions .. 
      LOGICAL            LDE, LDERES 
      EXTERNAL           LDE, LDERES 
*     .. External Subroutines .. 
      EXTERNAL           DMAKE, DMMCH, DSYR2K 
*     .. Intrinsic Functions .. 
      INTRINSIC          MAX 
*     .. Scalars in Common .. 
      INTEGER            INFOT, NOUTC 
      LOGICAL            LERR, OK 
*     .. Common blocks .. 
      COMMON             /INFOC/INFOT, NOUTC, OK, LERR 
*     .. Data statements .. 
      DATA               ICHT/'NTC'/, ICHU/'UL'/ 
*     .. Executable Statements .. 
* 
      NARGS = 12 
      NC = 0 
      RESET = .TRUE. 
      ERRMAX = ZERO 
* 
      DO 130 IN = 1, NIDIM 
         N = IDIM( IN ) 
*        Set LDC to 1 more than minimum value if room. 
         LDC = N 
         IF( LDC.LT.NMAX ) 
     $      LDC = LDC + 1 
*        Skip tests if not enough room. 
         IF( LDC.GT.NMAX ) 
     $      GO TO 130 
         LCC = LDC*N 
         NULL = N.LE.0 
* 
         DO 120 IK = 1, NIDIM 
            K = IDIM( IK ) 
* 
            DO 110 ICT = 1, 3 
               TRANS = ICHT( ICT: ICT ) 
               TRAN = TRANS.EQ.'T'.OR.TRANS.EQ.'C' 
               IF( TRAN )THEN 
                  MA = K 
                  NA = N 
               ELSE 
                  MA = N 
                  NA = K 
               END IF 
*              Set LDA to 1 more than minimum value if room. 
               LDA = MA 
               IF( LDA.LT.NMAX ) 
     $            LDA = LDA + 1 
*              Skip tests if not enough room. 
               IF( LDA.GT.NMAX ) 
     $            GO TO 110 
               LAA = LDA*NA 
* 
*              Generate the matrix A. 
* 
               IF( TRAN )THEN 
                  CALL DMAKE( 'GE', ' ', ' ', MA, NA, AB, 2*NMAX, AA, 
     $                        LDA, RESET, ZERO ) 
               ELSE 
                  CALL DMAKE( 'GE', ' ', ' ', MA, NA, AB, NMAX, AA, LDA, 
     $                        RESET, ZERO ) 
               END IF 
* 
*              Generate the matrix B. 
* 
               LDB = LDA 
               LBB = LAA 
               IF( TRAN )THEN 
                  CALL DMAKE( 'GE', ' ', ' ', MA, NA, AB( K + 1 ), 
     $                        2*NMAX, BB, LDB, RESET, ZERO ) 
               ELSE 
                  CALL DMAKE( 'GE', ' ', ' ', MA, NA, AB( K*NMAX + 1 ), 
     $                        NMAX, BB, LDB, RESET, ZERO ) 
               END IF 
* 
               DO 100 ICU = 1, 2 
                  UPLO = ICHU( ICU: ICU ) 
                  UPPER = UPLO.EQ.'U' 
* 
                  DO 90 IA = 1, NALF 
                     ALPHA = ALF( IA ) 
* 
                     DO 80 IB = 1, NBET 
                        BETA = BET( IB ) 
* 
*                       Generate the matrix C. 
* 
                        CALL DMAKE( 'SY', UPLO, ' ', N, N, C, NMAX, CC, 
     $                              LDC, RESET, ZERO ) 
* 
                        NC = NC + 1 
* 
*                       Save every datum before calling the subroutine. 
* 
                        UPLOS = UPLO 
                        TRANSS = TRANS 
                        NS = N 
                        KS = K 
                        ALS = ALPHA 
                        DO 10 I = 1, LAA 
                           AS( I ) = AA( I ) 
   10                   CONTINUE 
                        LDAS = LDA 
                        DO 20 I = 1, LBB 
                           BS( I ) = BB( I ) 
   20                   CONTINUE 
                        LDBS = LDB 
                        BETS = BETA 
                        DO 30 I = 1, LCC 
                           CS( I ) = CC( I ) 
   30                   CONTINUE 
                        LDCS = LDC 
* 
*                       Call the subroutine. 
* 
                        IF( TRACE ) 
     $                     WRITE( NTRA, FMT = 9994 )NC, SNAME, UPLO, 
     $                     TRANS, N, K, ALPHA, LDA, LDB, BETA, LDC 
                        IF( REWI ) 
     $                     REWIND NTRA 
                        CALL DSYR2K( UPLO, TRANS, N, K, ALPHA, AA, LDA, 
     $                               BB, LDB, BETA, CC, LDC ) 
* 
*                       Check if error-exit was taken incorrectly. 
* 
                        IF( .NOT.OK )THEN 
                           WRITE( NOUT, FMT = 9993 ) 
                           FATAL = .TRUE. 
                           GO TO 150 
                        END IF 
* 
*                       See what data changed inside subroutines. 
* 
                        ISAME( 1 ) = UPLOS.EQ.UPLO 
                        ISAME( 2 ) = TRANSS.EQ.TRANS 
                        ISAME( 3 ) = NS.EQ.N 
                        ISAME( 4 ) = KS.EQ.K 
                        ISAME( 5 ) = ALS.EQ.ALPHA 
                        ISAME( 6 ) = LDE( AS, AA, LAA ) 
                        ISAME( 7 ) = LDAS.EQ.LDA 
                        ISAME( 8 ) = LDE( BS, BB, LBB ) 
                        ISAME( 9 ) = LDBS.EQ.LDB 
                        ISAME( 10 ) = BETS.EQ.BETA 
                        IF( NULL )THEN 
                           ISAME( 11 ) = LDE( CS, CC, LCC ) 
                        ELSE 
                           ISAME( 11 ) = LDERES( 'SY', UPLO, N, N, CS, 
     $                                   CC, LDC ) 
                        END IF 
                        ISAME( 12 ) = LDCS.EQ.LDC 
* 
*                       If data was incorrectly changed, report and 
*                       return. 
* 
                        SAME = .TRUE. 
                        DO 40 I = 1, NARGS 
                           SAME = SAME.AND.ISAME( I ) 
                           IF( .NOT.ISAME( I ) ) 
     $                        WRITE( NOUT, FMT = 9998 )I 
   40                   CONTINUE 
                        IF( .NOT.SAME )THEN 
                           FATAL = .TRUE. 
                           GO TO 150 
                        END IF 
* 
                        IF( .NOT.NULL )THEN 
* 
*                          Check the result column by column. 
* 
                           JJAB = 1 
                           JC = 1 
                           DO 70 J = 1, N 
                              IF( UPPER )THEN 
                                 JJ = 1 
                                 LJ = J 
                              ELSE 
                                 JJ = J 
                                 LJ = N - J + 1 
                              END IF 
                              IF( TRAN )THEN 
                                 DO 50 I = 1, K 
                                    W( I ) = AB( ( J - 1 )*2*NMAX + K + 
     $                                       I ) 
                                    W( K + I ) = AB( ( J - 1 )*2*NMAX + 
     $                                           I ) 
   50                            CONTINUE 
                                 CALL DMMCH( 'T', 'N', LJ, 1, 2*K, 
     $                                       ALPHA, AB( JJAB ), 2*NMAX, 
     $                                       W, 2*NMAX, BETA, 
     $                                       C( JJ, J ), NMAX, CT, G, 
     $                                       CC( JC ), LDC, EPS, ERR, 
     $                                       FATAL, NOUT, .TRUE. ) 
                              ELSE 
                                 DO 60 I = 1, K 
                                    W( I ) = AB( ( K + I - 1 )*NMAX + 
     $                                       J ) 
                                    W( K + I ) = AB( ( I - 1 )*NMAX + 
     $                                           J ) 
   60                            CONTINUE 
                                 CALL DMMCH( 'N', 'N', LJ, 1, 2*K, 
     $                                       ALPHA, AB( JJ ), NMAX, W, 
     $                                       2*NMAX, BETA, C( JJ, J ), 
     $                                       NMAX, CT, G, CC( JC ), LDC, 
     $                                       EPS, ERR, FATAL, NOUT, 
     $                                       .TRUE. ) 
                              END IF 
                              IF( UPPER )THEN 
                                 JC = JC + LDC 
                              ELSE 
                                 JC = JC + LDC + 1 
                                 IF( TRAN ) 
     $                              JJAB = JJAB + 2*NMAX 
                              END IF 
                              ERRMAX = MAX( ERRMAX, ERR ) 
*                             If got really bad answer, report and 
*                             return. 
                              IF( FATAL ) 
     $                           GO TO 140 
   70                      CONTINUE 
                        END IF 
* 
   80                CONTINUE 
* 
   90             CONTINUE 
* 
  100          CONTINUE 
* 
  110       CONTINUE 
* 
  120    CONTINUE 
* 
  130 CONTINUE 
* 
*     Report result. 
* 
      IF( ERRMAX.LT.THRESH )THEN 
         WRITE( NOUT, FMT = 9999 )SNAME, NC 
      ELSE 
         WRITE( NOUT, FMT = 9997 )SNAME, NC, ERRMAX 
      END IF 
      GO TO 160 
* 
  140 CONTINUE 
      IF( N.GT.1 ) 
     $   WRITE( NOUT, FMT = 9995 )J 
* 
  150 CONTINUE 
      WRITE( NOUT, FMT = 9996 )SNAME 
      WRITE( NOUT, FMT = 9994 )NC, SNAME, UPLO, TRANS, N, K, ALPHA, 
     $   LDA, LDB, BETA, LDC 
* 
  160 CONTINUE 
      RETURN 
* 
 9999 FORMAT( ' ', A6, ' PASSED THE COMPUTATIONAL TESTS (', I6, ' CALL', 
     $      'S)' ) 
 9998 FORMAT( ' ******* FATAL ERROR - PARAMETER NUMBER ', I2, ' WAS CH', 
     $      'ANGED INCORRECTLY *******' ) 
 9997 FORMAT( ' ', A6, ' COMPLETED THE COMPUTATIONAL TESTS (', I6, ' C', 
     $      'ALLS)', /' ******* BUT WITH MAXIMUM TEST RATIO', F8.2, 
     $      ' - SUSPECT *******' ) 
 9996 FORMAT( ' ******* ', A6, ' FAILED ON CALL NUMBER:' ) 
 9995 FORMAT( '      THESE ARE THE RESULTS FOR COLUMN ', I3 ) 
 9994 FORMAT( 1X, I6, ': ', A6, '(', 2( '''', A1, ''',' ), 2( I3, ',' ), 
     $      F4.1, ', A,', I3, ', B,', I3, ',', F4.1, ', C,', I3, ')   ', 
     $      ' .' ) 
 9993 FORMAT( ' ******* FATAL ERROR - ERROR-EXIT TAKEN ON VALID CALL *', 
     $      '******' ) 
* 
*     End of DCHK5. 
* 
      END 
      SUBROUTINE DCHKE( ISNUM, SRNAMT, NOUT ) 
* 
*  Tests the error exits from the Level 3 Blas. 
*  Requires a special version of the error-handling routine XERBLA. 
*  ALPHA, BETA, A, B and C should not need to be defined. 
* 
*  Auxiliary routine for test program for Level 3 Blas. 
* 
*  -- Written on 8-February-1989. 
*     Jack Dongarra, Argonne National Laboratory. 
*     Iain Duff, AERE Harwell. 
*     Jeremy Du Croz, Numerical Algorithms Group Ltd. 
*     Sven Hammarling, Numerical Algorithms Group Ltd. 
* 
*     .. Scalar Arguments .. 
      INTEGER            ISNUM, NOUT 
      CHARACTER*6        SRNAMT 
*     .. Scalars in Common .. 
      INTEGER            INFOT, NOUTC 
      LOGICAL            LERR, OK 
*     .. Local Scalars .. 
      DOUBLE PRECISION   ALPHA, BETA 
*     .. Local Arrays .. 
      DOUBLE PRECISION   A( 2, 1 ), B( 2, 1 ), C( 2, 1 ) 
*     .. External Subroutines .. 
      EXTERNAL           CHKXER, DGEMM, DSYMM, DSYR2K, DSYRK, DTRMM, 
     $                   DTRSM 
*     .. Common blocks .. 
      COMMON             /INFOC/INFOT, NOUTC, OK, LERR 
*     .. Executable Statements .. 
*     OK is set to .FALSE. by the special version of XERBLA or by CHKXER 
*     if anything is wrong. 
      OK = .TRUE. 
*     LERR is set to .TRUE. by the special version of XERBLA each time 
*     it is called, and is then tested and re-set by CHKXER. 
      LERR = .FALSE. 
      GO TO ( 10, 20, 30, 40, 50, 60 )ISNUM 
   10 INFOT = 1 
      CALL DGEMM( '/', 'N', 0, 0, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 1 
      CALL DGEMM( '/', 'T', 0, 0, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 2 
      CALL DGEMM( 'N', '/', 0, 0, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 2 
      CALL DGEMM( 'T', '/', 0, 0, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 3 
      CALL DGEMM( 'N', 'N', -1, 0, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 3 
      CALL DGEMM( 'N', 'T', -1, 0, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 3 
      CALL DGEMM( 'T', 'N', -1, 0, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 3 
      CALL DGEMM( 'T', 'T', -1, 0, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 4 
      CALL DGEMM( 'N', 'N', 0, -1, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 4 
      CALL DGEMM( 'N', 'T', 0, -1, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 4 
      CALL DGEMM( 'T', 'N', 0, -1, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 4 
      CALL DGEMM( 'T', 'T', 0, -1, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 5 
      CALL DGEMM( 'N', 'N', 0, 0, -1, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 5 
      CALL DGEMM( 'N', 'T', 0, 0, -1, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 5 
      CALL DGEMM( 'T', 'N', 0, 0, -1, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 5 
      CALL DGEMM( 'T', 'T', 0, 0, -1, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 8 
      CALL DGEMM( 'N', 'N', 2, 0, 0, ALPHA, A, 1, B, 1, BETA, C, 2 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 8 
      CALL DGEMM( 'N', 'T', 2, 0, 0, ALPHA, A, 1, B, 1, BETA, C, 2 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 8 
      CALL DGEMM( 'T', 'N', 0, 0, 2, ALPHA, A, 1, B, 2, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 8 
      CALL DGEMM( 'T', 'T', 0, 0, 2, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 10 
      CALL DGEMM( 'N', 'N', 0, 0, 2, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 10 
      CALL DGEMM( 'T', 'N', 0, 0, 2, ALPHA, A, 2, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 10 
      CALL DGEMM( 'N', 'T', 0, 2, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 10 
      CALL DGEMM( 'T', 'T', 0, 2, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 13 
      CALL DGEMM( 'N', 'N', 2, 0, 0, ALPHA, A, 2, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 13 
      CALL DGEMM( 'N', 'T', 2, 0, 0, ALPHA, A, 2, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 13 
      CALL DGEMM( 'T', 'N', 2, 0, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 13 
      CALL DGEMM( 'T', 'T', 2, 0, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      GO TO 70 
   20 INFOT = 1 
      CALL DSYMM( '/', 'U', 0, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 2 
      CALL DSYMM( 'L', '/', 0, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 3 
      CALL DSYMM( 'L', 'U', -1, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 3 
      CALL DSYMM( 'R', 'U', -1, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 3 
      CALL DSYMM( 'L', 'L', -1, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 3 
      CALL DSYMM( 'R', 'L', -1, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 4 
      CALL DSYMM( 'L', 'U', 0, -1, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 4 
      CALL DSYMM( 'R', 'U', 0, -1, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 4 
      CALL DSYMM( 'L', 'L', 0, -1, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 4 
      CALL DSYMM( 'R', 'L', 0, -1, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 7 
      CALL DSYMM( 'L', 'U', 2, 0, ALPHA, A, 1, B, 2, BETA, C, 2 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 7 
      CALL DSYMM( 'R', 'U', 0, 2, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 7 
      CALL DSYMM( 'L', 'L', 2, 0, ALPHA, A, 1, B, 2, BETA, C, 2 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 7 
      CALL DSYMM( 'R', 'L', 0, 2, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DSYMM( 'L', 'U', 2, 0, ALPHA, A, 2, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DSYMM( 'R', 'U', 2, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DSYMM( 'L', 'L', 2, 0, ALPHA, A, 2, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DSYMM( 'R', 'L', 2, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 12 
      CALL DSYMM( 'L', 'U', 2, 0, ALPHA, A, 2, B, 2, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 12 
      CALL DSYMM( 'R', 'U', 2, 0, ALPHA, A, 1, B, 2, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 12 
      CALL DSYMM( 'L', 'L', 2, 0, ALPHA, A, 2, B, 2, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 12 
      CALL DSYMM( 'R', 'L', 2, 0, ALPHA, A, 1, B, 2, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      GO TO 70 
   30 INFOT = 1 
      CALL DTRMM( '/', 'U', 'N', 'N', 0, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 2 
      CALL DTRMM( 'L', '/', 'N', 'N', 0, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 3 
      CALL DTRMM( 'L', 'U', '/', 'N', 0, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 4 
      CALL DTRMM( 'L', 'U', 'N', '/', 0, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 5 
      CALL DTRMM( 'L', 'U', 'N', 'N', -1, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 5 
      CALL DTRMM( 'L', 'U', 'T', 'N', -1, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 5 
      CALL DTRMM( 'R', 'U', 'N', 'N', -1, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 5 
      CALL DTRMM( 'R', 'U', 'T', 'N', -1, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 5 
      CALL DTRMM( 'L', 'L', 'N', 'N', -1, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 5 
      CALL DTRMM( 'L', 'L', 'T', 'N', -1, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 5 
      CALL DTRMM( 'R', 'L', 'N', 'N', -1, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 5 
      CALL DTRMM( 'R', 'L', 'T', 'N', -1, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 6 
      CALL DTRMM( 'L', 'U', 'N', 'N', 0, -1, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 6 
      CALL DTRMM( 'L', 'U', 'T', 'N', 0, -1, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 6 
      CALL DTRMM( 'R', 'U', 'N', 'N', 0, -1, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 6 
      CALL DTRMM( 'R', 'U', 'T', 'N', 0, -1, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 6 
      CALL DTRMM( 'L', 'L', 'N', 'N', 0, -1, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 6 
      CALL DTRMM( 'L', 'L', 'T', 'N', 0, -1, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 6 
      CALL DTRMM( 'R', 'L', 'N', 'N', 0, -1, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 6 
      CALL DTRMM( 'R', 'L', 'T', 'N', 0, -1, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DTRMM( 'L', 'U', 'N', 'N', 2, 0, ALPHA, A, 1, B, 2 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DTRMM( 'L', 'U', 'T', 'N', 2, 0, ALPHA, A, 1, B, 2 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DTRMM( 'R', 'U', 'N', 'N', 0, 2, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DTRMM( 'R', 'U', 'T', 'N', 0, 2, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DTRMM( 'L', 'L', 'N', 'N', 2, 0, ALPHA, A, 1, B, 2 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DTRMM( 'L', 'L', 'T', 'N', 2, 0, ALPHA, A, 1, B, 2 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DTRMM( 'R', 'L', 'N', 'N', 0, 2, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DTRMM( 'R', 'L', 'T', 'N', 0, 2, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 11 
      CALL DTRMM( 'L', 'U', 'N', 'N', 2, 0, ALPHA, A, 2, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 11 
      CALL DTRMM( 'L', 'U', 'T', 'N', 2, 0, ALPHA, A, 2, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 11 
      CALL DTRMM( 'R', 'U', 'N', 'N', 2, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 11 
      CALL DTRMM( 'R', 'U', 'T', 'N', 2, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 11 
      CALL DTRMM( 'L', 'L', 'N', 'N', 2, 0, ALPHA, A, 2, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 11 
      CALL DTRMM( 'L', 'L', 'T', 'N', 2, 0, ALPHA, A, 2, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 11 
      CALL DTRMM( 'R', 'L', 'N', 'N', 2, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 11 
      CALL DTRMM( 'R', 'L', 'T', 'N', 2, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      GO TO 70 
   40 INFOT = 1 
      CALL DTRSM( '/', 'U', 'N', 'N', 0, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 2 
      CALL DTRSM( 'L', '/', 'N', 'N', 0, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 3 
      CALL DTRSM( 'L', 'U', '/', 'N', 0, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 4 
      CALL DTRSM( 'L', 'U', 'N', '/', 0, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 5 
      CALL DTRSM( 'L', 'U', 'N', 'N', -1, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 5 
      CALL DTRSM( 'L', 'U', 'T', 'N', -1, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 5 
      CALL DTRSM( 'R', 'U', 'N', 'N', -1, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 5 
      CALL DTRSM( 'R', 'U', 'T', 'N', -1, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 5 
      CALL DTRSM( 'L', 'L', 'N', 'N', -1, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 5 
      CALL DTRSM( 'L', 'L', 'T', 'N', -1, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 5 
      CALL DTRSM( 'R', 'L', 'N', 'N', -1, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 5 
      CALL DTRSM( 'R', 'L', 'T', 'N', -1, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 6 
      CALL DTRSM( 'L', 'U', 'N', 'N', 0, -1, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 6 
      CALL DTRSM( 'L', 'U', 'T', 'N', 0, -1, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 6 
      CALL DTRSM( 'R', 'U', 'N', 'N', 0, -1, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 6 
      CALL DTRSM( 'R', 'U', 'T', 'N', 0, -1, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 6 
      CALL DTRSM( 'L', 'L', 'N', 'N', 0, -1, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 6 
      CALL DTRSM( 'L', 'L', 'T', 'N', 0, -1, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 6 
      CALL DTRSM( 'R', 'L', 'N', 'N', 0, -1, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 6 
      CALL DTRSM( 'R', 'L', 'T', 'N', 0, -1, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DTRSM( 'L', 'U', 'N', 'N', 2, 0, ALPHA, A, 1, B, 2 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DTRSM( 'L', 'U', 'T', 'N', 2, 0, ALPHA, A, 1, B, 2 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DTRSM( 'R', 'U', 'N', 'N', 0, 2, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DTRSM( 'R', 'U', 'T', 'N', 0, 2, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DTRSM( 'L', 'L', 'N', 'N', 2, 0, ALPHA, A, 1, B, 2 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DTRSM( 'L', 'L', 'T', 'N', 2, 0, ALPHA, A, 1, B, 2 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DTRSM( 'R', 'L', 'N', 'N', 0, 2, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DTRSM( 'R', 'L', 'T', 'N', 0, 2, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 11 
      CALL DTRSM( 'L', 'U', 'N', 'N', 2, 0, ALPHA, A, 2, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 11 
      CALL DTRSM( 'L', 'U', 'T', 'N', 2, 0, ALPHA, A, 2, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 11 
      CALL DTRSM( 'R', 'U', 'N', 'N', 2, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 11 
      CALL DTRSM( 'R', 'U', 'T', 'N', 2, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 11 
      CALL DTRSM( 'L', 'L', 'N', 'N', 2, 0, ALPHA, A, 2, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 11 
      CALL DTRSM( 'L', 'L', 'T', 'N', 2, 0, ALPHA, A, 2, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 11 
      CALL DTRSM( 'R', 'L', 'N', 'N', 2, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 11 
      CALL DTRSM( 'R', 'L', 'T', 'N', 2, 0, ALPHA, A, 1, B, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      GO TO 70 
   50 INFOT = 1 
      CALL DSYRK( '/', 'N', 0, 0, ALPHA, A, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 2 
      CALL DSYRK( 'U', '/', 0, 0, ALPHA, A, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 3 
      CALL DSYRK( 'U', 'N', -1, 0, ALPHA, A, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 3 
      CALL DSYRK( 'U', 'T', -1, 0, ALPHA, A, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 3 
      CALL DSYRK( 'L', 'N', -1, 0, ALPHA, A, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 3 
      CALL DSYRK( 'L', 'T', -1, 0, ALPHA, A, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 4 
      CALL DSYRK( 'U', 'N', 0, -1, ALPHA, A, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 4 
      CALL DSYRK( 'U', 'T', 0, -1, ALPHA, A, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 4 
      CALL DSYRK( 'L', 'N', 0, -1, ALPHA, A, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 4 
      CALL DSYRK( 'L', 'T', 0, -1, ALPHA, A, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 7 
      CALL DSYRK( 'U', 'N', 2, 0, ALPHA, A, 1, BETA, C, 2 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 7 
      CALL DSYRK( 'U', 'T', 0, 2, ALPHA, A, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 7 
      CALL DSYRK( 'L', 'N', 2, 0, ALPHA, A, 1, BETA, C, 2 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 7 
      CALL DSYRK( 'L', 'T', 0, 2, ALPHA, A, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 10 
      CALL DSYRK( 'U', 'N', 2, 0, ALPHA, A, 2, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 10 
      CALL DSYRK( 'U', 'T', 2, 0, ALPHA, A, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 10 
      CALL DSYRK( 'L', 'N', 2, 0, ALPHA, A, 2, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 10 
      CALL DSYRK( 'L', 'T', 2, 0, ALPHA, A, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      GO TO 70 
   60 INFOT = 1 
      CALL DSYR2K( '/', 'N', 0, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 2 
      CALL DSYR2K( 'U', '/', 0, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 3 
      CALL DSYR2K( 'U', 'N', -1, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 3 
      CALL DSYR2K( 'U', 'T', -1, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 3 
      CALL DSYR2K( 'L', 'N', -1, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 3 
      CALL DSYR2K( 'L', 'T', -1, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 4 
      CALL DSYR2K( 'U', 'N', 0, -1, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 4 
      CALL DSYR2K( 'U', 'T', 0, -1, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 4 
      CALL DSYR2K( 'L', 'N', 0, -1, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 4 
      CALL DSYR2K( 'L', 'T', 0, -1, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 7 
      CALL DSYR2K( 'U', 'N', 2, 0, ALPHA, A, 1, B, 1, BETA, C, 2 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 7 
      CALL DSYR2K( 'U', 'T', 0, 2, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 7 
      CALL DSYR2K( 'L', 'N', 2, 0, ALPHA, A, 1, B, 1, BETA, C, 2 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 7 
      CALL DSYR2K( 'L', 'T', 0, 2, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DSYR2K( 'U', 'N', 2, 0, ALPHA, A, 2, B, 1, BETA, C, 2 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DSYR2K( 'U', 'T', 0, 2, ALPHA, A, 2, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DSYR2K( 'L', 'N', 2, 0, ALPHA, A, 2, B, 1, BETA, C, 2 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 9 
      CALL DSYR2K( 'L', 'T', 0, 2, ALPHA, A, 2, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 12 
      CALL DSYR2K( 'U', 'N', 2, 0, ALPHA, A, 2, B, 2, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 12 
      CALL DSYR2K( 'U', 'T', 2, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 12 
      CALL DSYR2K( 'L', 'N', 2, 0, ALPHA, A, 2, B, 2, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
      INFOT = 12 
      CALL DSYR2K( 'L', 'T', 2, 0, ALPHA, A, 1, B, 1, BETA, C, 1 ) 
      CALL CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
* 
   70 IF( OK )THEN 
         WRITE( NOUT, FMT = 9999 )SRNAMT 
      ELSE 
         WRITE( NOUT, FMT = 9998 )SRNAMT 
      END IF 
      RETURN 
* 
 9999 FORMAT( ' ', A6, ' PASSED THE TESTS OF ERROR-EXITS' ) 
 9998 FORMAT( ' ******* ', A6, ' FAILED THE TESTS OF ERROR-EXITS *****', 
     $      '**' ) 
* 
*     End of DCHKE. 
* 
      END 
      SUBROUTINE DMAKE( TYPE, UPLO, DIAG, M, N, A, NMAX, AA, LDA, RESET, 
     $                  TRANSL ) 
* 
*  Generates values for an M by N matrix A. 
*  Stores the values in the array AA in the data structure required 
*  by the routine, with unwanted elements set to rogue value. 
* 
*  TYPE is 'GE', 'SY' or 'TR'. 
* 
*  Auxiliary routine for test program for Level 3 Blas. 
* 
*  -- Written on 8-February-1989. 
*     Jack Dongarra, Argonne National Laboratory. 
*     Iain Duff, AERE Harwell. 
*     Jeremy Du Croz, Numerical Algorithms Group Ltd. 
*     Sven Hammarling, Numerical Algorithms Group Ltd. 
* 
*     .. Parameters .. 
      DOUBLE PRECISION   ZERO, ONE 
      PARAMETER          ( ZERO = 0.0D0, ONE = 1.0D0 ) 
      DOUBLE PRECISION   ROGUE 
      PARAMETER          ( ROGUE = -1.0D10 ) 
*     .. Scalar Arguments .. 
      DOUBLE PRECISION   TRANSL 
      INTEGER            LDA, M, N, NMAX 
      LOGICAL            RESET 
      CHARACTER*1        DIAG, UPLO 
      CHARACTER*2        TYPE 
*     .. Array Arguments .. 
      DOUBLE PRECISION   A( NMAX, * ), AA( * ) 
*     .. Local Scalars .. 
      INTEGER            I, IBEG, IEND, J 
      LOGICAL            GEN, LOWER, SYM, TRI, UNIT, UPPER 
*     .. External Functions .. 
      DOUBLE PRECISION   DBEG 
      EXTERNAL           DBEG 
*     .. Executable Statements .. 
      GEN = TYPE.EQ.'GE' 
      SYM = TYPE.EQ.'SY' 
      TRI = TYPE.EQ.'TR' 
      UPPER = ( SYM.OR.TRI ).AND.UPLO.EQ.'U' 
      LOWER = ( SYM.OR.TRI ).AND.UPLO.EQ.'L' 
      UNIT = TRI.AND.DIAG.EQ.'U' 
* 
*     Generate data in array A. 
* 
      DO 20 J = 1, N 
         DO 10 I = 1, M 
            IF( GEN.OR.( UPPER.AND.I.LE.J ).OR.( LOWER.AND.I.GE.J ) ) 
     $          THEN 
               A( I, J ) = DBEG( RESET ) + TRANSL 
               IF( I.NE.J )THEN 
*                 Set some elements to zero 
                  IF( N.GT.3.AND.J.EQ.N/2 ) 
     $               A( I, J ) = ZERO 
                  IF( SYM )THEN 
                     A( J, I ) = A( I, J ) 
                  ELSE IF( TRI )THEN 
                     A( J, I ) = ZERO 
                  END IF 
               END IF 
            END IF 
   10    CONTINUE 
         IF( TRI ) 
     $      A( J, J ) = A( J, J ) + ONE 
         IF( UNIT ) 
     $      A( J, J ) = ONE 
   20 CONTINUE 
* 
*     Store elements in array AS in data structure required by routine. 
* 
      IF( TYPE.EQ.'GE' )THEN 
         DO 50 J = 1, N 
            DO 30 I = 1, M 
               AA( I + ( J - 1 )*LDA ) = A( I, J ) 
   30       CONTINUE 
            DO 40 I = M + 1, LDA 
               AA( I + ( J - 1 )*LDA ) = ROGUE 
   40       CONTINUE 
   50    CONTINUE 
      ELSE IF( TYPE.EQ.'SY'.OR.TYPE.EQ.'TR' )THEN 
         DO 90 J = 1, N 
            IF( UPPER )THEN 
               IBEG = 1 
               IF( UNIT )THEN 
                  IEND = J - 1 
               ELSE 
                  IEND = J 
               END IF 
            ELSE 
               IF( UNIT )THEN 
                  IBEG = J + 1 
               ELSE 
                  IBEG = J 
               END IF 
               IEND = N 
            END IF 
            DO 60 I = 1, IBEG - 1 
               AA( I + ( J - 1 )*LDA ) = ROGUE 
   60       CONTINUE 
            DO 70 I = IBEG, IEND 
               AA( I + ( J - 1 )*LDA ) = A( I, J ) 
   70       CONTINUE 
            DO 80 I = IEND + 1, LDA 
               AA( I + ( J - 1 )*LDA ) = ROGUE 
   80       CONTINUE 
   90    CONTINUE 
      END IF 
      RETURN 
* 
*     End of DMAKE. 
* 
      END 
      SUBROUTINE DMMCH( TRANSA, TRANSB, M, N, KK, ALPHA, A, LDA, B, LDB, 
     $                  BETA, C, LDC, CT, G, CC, LDCC, EPS, ERR, FATAL, 
     $                  NOUT, MV ) 
* 
*  Checks the results of the computational tests. 
* 
*  Auxiliary routine for test program for Level 3 Blas. 
* 
*  -- Written on 8-February-1989. 
*     Jack Dongarra, Argonne National Laboratory. 
*     Iain Duff, AERE Harwell. 
*     Jeremy Du Croz, Numerical Algorithms Group Ltd. 
*     Sven Hammarling, Numerical Algorithms Group Ltd. 
* 
*     .. Parameters .. 
      DOUBLE PRECISION   ZERO, ONE 
      PARAMETER          ( ZERO = 0.0D0, ONE = 1.0D0 ) 
*     .. Scalar Arguments .. 
      DOUBLE PRECISION   ALPHA, BETA, EPS, ERR 
      INTEGER            KK, LDA, LDB, LDC, LDCC, M, N, NOUT 
      LOGICAL            FATAL, MV 
      CHARACTER*1        TRANSA, TRANSB 
*     .. Array Arguments .. 
      DOUBLE PRECISION   A( LDA, * ), B( LDB, * ), C( LDC, * ), 
     $                   CC( LDCC, * ), CT( * ), G( * ) 
*     .. Local Scalars .. 
      DOUBLE PRECISION   ERRI 
      INTEGER            I, J, K 
      LOGICAL            TRANA, TRANB 
*     .. Intrinsic Functions .. 
      INTRINSIC          ABS, MAX, SQRT 
*     .. Executable Statements .. 
      TRANA = TRANSA.EQ.'T'.OR.TRANSA.EQ.'C' 
      TRANB = TRANSB.EQ.'T'.OR.TRANSB.EQ.'C' 
* 
*     Compute expected result, one column at a time, in CT using data 
*     in A, B and C. 
*     Compute gauges in G. 
* 
      DO 120 J = 1, N 
* 
         DO 10 I = 1, M 
            CT( I ) = ZERO 
            G( I ) = ZERO 
   10    CONTINUE 
         IF( .NOT.TRANA.AND..NOT.TRANB )THEN 
            DO 30 K = 1, KK 
               DO 20 I = 1, M 
                  CT( I ) = CT( I ) + A( I, K )*B( K, J ) 
                  G( I ) = G( I ) + ABS( A( I, K ) )*ABS( B( K, J ) ) 
   20          CONTINUE 
   30       CONTINUE 
         ELSE IF( TRANA.AND..NOT.TRANB )THEN 
            DO 50 K = 1, KK 
               DO 40 I = 1, M 
                  CT( I ) = CT( I ) + A( K, I )*B( K, J ) 
                  G( I ) = G( I ) + ABS( A( K, I ) )*ABS( B( K, J ) ) 
   40          CONTINUE 
   50       CONTINUE 
         ELSE IF( .NOT.TRANA.AND.TRANB )THEN 
            DO 70 K = 1, KK 
               DO 60 I = 1, M 
                  CT( I ) = CT( I ) + A( I, K )*B( J, K ) 
                  G( I ) = G( I ) + ABS( A( I, K ) )*ABS( B( J, K ) ) 
   60          CONTINUE 
   70       CONTINUE 
         ELSE IF( TRANA.AND.TRANB )THEN 
            DO 90 K = 1, KK 
               DO 80 I = 1, M 
                  CT( I ) = CT( I ) + A( K, I )*B( J, K ) 
                  G( I ) = G( I ) + ABS( A( K, I ) )*ABS( B( J, K ) ) 
   80          CONTINUE 
   90       CONTINUE 
         END IF 
         DO 100 I = 1, M 
            CT( I ) = ALPHA*CT( I ) + BETA*C( I, J ) 
            G( I ) = ABS( ALPHA )*G( I ) + ABS( BETA )*ABS( C( I, J ) ) 
  100    CONTINUE 
* 
*        Compute the error ratio for this result. 
* 
         ERR = ZERO 
         DO 110 I = 1, M 
            ERRI = ABS( CT( I ) - CC( I, J ) )/EPS 
            IF( G( I ).NE.ZERO ) 
     $         ERRI = ERRI/G( I ) 
            ERR = MAX( ERR, ERRI ) 
            IF( ERR*SQRT( EPS ).GE.ONE ) 
     $         GO TO 130 
  110    CONTINUE 
* 
  120 CONTINUE 
* 
*     If the loop completes, all results are at least half accurate. 
      GO TO 150 
* 
*     Report fatal error. 
* 
  130 FATAL = .TRUE. 
      WRITE( NOUT, FMT = 9999 ) 
      DO 140 I = 1, M 
         IF( MV )THEN 
            WRITE( NOUT, FMT = 9998 )I, CT( I ), CC( I, J ) 
         ELSE 
            WRITE( NOUT, FMT = 9998 )I, CC( I, J ), CT( I ) 
         END IF 
  140 CONTINUE 
      IF( N.GT.1 ) 
     $   WRITE( NOUT, FMT = 9997 )J 
* 
  150 CONTINUE 
      RETURN 
* 
 9999 FORMAT( ' ******* FATAL ERROR - COMPUTED RESULT IS LESS THAN HAL', 
     $      'F ACCURATE *******', /'           EXPECTED RESULT   COMPU', 
     $      'TED RESULT' ) 
 9998 FORMAT( 1X, I7, 2G18.6 ) 
 9997 FORMAT( '      THESE ARE THE RESULTS FOR COLUMN ', I3 ) 
* 
*     End of DMMCH. 
* 
      END 
      LOGICAL FUNCTION LDE( RI, RJ, LR ) 
* 
*  Tests if two arrays are identical. 
* 
*  Auxiliary routine for test program for Level 3 Blas. 
* 
*  -- Written on 8-February-1989. 
*     Jack Dongarra, Argonne National Laboratory. 
*     Iain Duff, AERE Harwell. 
*     Jeremy Du Croz, Numerical Algorithms Group Ltd. 
*     Sven Hammarling, Numerical Algorithms Group Ltd. 
* 
*     .. Scalar Arguments .. 
      INTEGER            LR 
*     .. Array Arguments .. 
      DOUBLE PRECISION   RI( * ), RJ( * ) 
*     .. Local Scalars .. 
      INTEGER            I 
*     .. Executable Statements .. 
      DO 10 I = 1, LR 
         IF( RI( I ).NE.RJ( I ) ) 
     $      GO TO 20 
   10 CONTINUE 
      LDE = .TRUE. 
      GO TO 30 
   20 CONTINUE 
      LDE = .FALSE. 
   30 RETURN 
* 
*     End of LDE. 
* 
      END 
      LOGICAL FUNCTION LDERES( TYPE, UPLO, M, N, AA, AS, LDA ) 
* 
*  Tests if selected elements in two arrays are equal. 
* 
*  TYPE is 'GE' or 'SY'. 
* 
*  Auxiliary routine for test program for Level 3 Blas. 
* 
*  -- Written on 8-February-1989. 
*     Jack Dongarra, Argonne National Laboratory. 
*     Iain Duff, AERE Harwell. 
*     Jeremy Du Croz, Numerical Algorithms Group Ltd. 
*     Sven Hammarling, Numerical Algorithms Group Ltd. 
* 
*     .. Scalar Arguments .. 
      INTEGER            LDA, M, N 
      CHARACTER*1        UPLO 
      CHARACTER*2        TYPE 
*     .. Array Arguments .. 
      DOUBLE PRECISION   AA( LDA, * ), AS( LDA, * ) 
*     .. Local Scalars .. 
      INTEGER            I, IBEG, IEND, J 
      LOGICAL            UPPER 
*     .. Executable Statements .. 
      UPPER = UPLO.EQ.'U' 
      IF( TYPE.EQ.'GE' )THEN 
         DO 20 J = 1, N 
            DO 10 I = M + 1, LDA 
               IF( AA( I, J ).NE.AS( I, J ) ) 
     $            GO TO 70 
   10       CONTINUE 
   20    CONTINUE 
      ELSE IF( TYPE.EQ.'SY' )THEN 
         DO 50 J = 1, N 
            IF( UPPER )THEN 
               IBEG = 1 
               IEND = J 
            ELSE 
               IBEG = J 
               IEND = N 
            END IF 
            DO 30 I = 1, IBEG - 1 
               IF( AA( I, J ).NE.AS( I, J ) ) 
     $            GO TO 70 
   30       CONTINUE 
            DO 40 I = IEND + 1, LDA 
               IF( AA( I, J ).NE.AS( I, J ) ) 
     $            GO TO 70 
   40       CONTINUE 
   50    CONTINUE 
      END IF 
* 
   60 CONTINUE 
      LDERES = .TRUE. 
      GO TO 80 
   70 CONTINUE 
      LDERES = .FALSE. 
   80 RETURN 
* 
*     End of LDERES. 
* 
      END 
      DOUBLE PRECISION FUNCTION DBEG( RESET ) 
* 
*  Generates random numbers uniformly distributed between -0.5 and 0.5. 
* 
*  Auxiliary routine for test program for Level 3 Blas. 
* 
*  -- Written on 8-February-1989. 
*     Jack Dongarra, Argonne National Laboratory. 
*     Iain Duff, AERE Harwell. 
*     Jeremy Du Croz, Numerical Algorithms Group Ltd. 
*     Sven Hammarling, Numerical Algorithms Group Ltd. 
* 
*     .. Scalar Arguments .. 
      LOGICAL            RESET 
*     .. Local Scalars .. 
      INTEGER            I, IC, MI 
*     .. Save statement .. 
      SAVE               I, IC, MI 
*     .. Executable Statements .. 
      IF( RESET )THEN 
*        Initialize local variables. 
         MI = 891 
         I = 7 
         IC = 0 
         RESET = .FALSE. 
      END IF 
* 
*     The sequence of values of I is bounded between 1 and 999. 
*     If initial I = 1,2,3,6,7 or 9, the period will be 50. 
*     If initial I = 4 or 8, the period will be 25. 
*     If initial I = 5, the period will be 10. 
*     IC is used to break up the period by skipping 1 value of I in 6. 
* 
      IC = IC + 1 
   10 I = I*MI 
      I = I - 1000*( I/1000 ) 
      IF( IC.GE.5 )THEN 
         IC = 0 
         GO TO 10 
      END IF 
      DBEG = ( I - 500 )/1001.0D0 
      RETURN 
* 
*     End of DBEG. 
* 
      END 
      DOUBLE PRECISION FUNCTION DDIFF( X, Y ) 
* 
*  Auxiliary routine for test program for Level 3 Blas. 
* 
*  -- Written on 8-February-1989. 
*     Jack Dongarra, Argonne National Laboratory. 
*     Iain Duff, AERE Harwell. 
*     Jeremy Du Croz, Numerical Algorithms Group Ltd. 
*     Sven Hammarling, Numerical Algorithms Group Ltd. 
* 
*     .. Scalar Arguments .. 
      DOUBLE PRECISION   X, Y 
*     .. Executable Statements .. 
      DDIFF = X - Y 
      RETURN 
* 
*     End of DDIFF. 
* 
      END 
      SUBROUTINE CHKXER( SRNAMT, INFOT, NOUT, LERR, OK ) 
* 
*  Tests whether XERBLA has detected an error when it should. 
* 
*  Auxiliary routine for test program for Level 3 Blas. 
* 
*  -- Written on 8-February-1989. 
*     Jack Dongarra, Argonne National Laboratory. 
*     Iain Duff, AERE Harwell. 
*     Jeremy Du Croz, Numerical Algorithms Group Ltd. 
*     Sven Hammarling, Numerical Algorithms Group Ltd. 
* 
*     .. Scalar Arguments .. 
      INTEGER            INFOT, NOUT 
      LOGICAL            LERR, OK 
      CHARACTER*6        SRNAMT 
*     .. Executable Statements .. 
      IF( .NOT.LERR )THEN 
         WRITE( NOUT, FMT = 9999 )INFOT, SRNAMT 
         OK = .FALSE. 
      END IF 
      LERR = .FALSE. 
      RETURN 
* 
 9999 FORMAT( ' ***** ILLEGAL VALUE OF PARAMETER NUMBER ', I2, ' NOT D', 
     $      'ETECTED BY ', A6, ' *****' ) 
* 
*     End of CHKXER. 
* 
      END 
      SUBROUTINE XERBLA( SRNAME, INFO ) 
* 
*  This is a special version of XERBLA to be used only as part of 
*  the test program for testing error exits from the Level 3 BLAS 
*  routines. 
* 
*  XERBLA  is an error handler for the Level 3 BLAS routines. 
* 
*  It is called by the Level 3 BLAS routines if an input parameter is 
*  invalid. 
* 
*  Auxiliary routine for test program for Level 3 Blas. 
* 
*  -- Written on 8-February-1989. 
*     Jack Dongarra, Argonne National Laboratory. 
*     Iain Duff, AERE Harwell. 
*     Jeremy Du Croz, Numerical Algorithms Group Ltd. 
*     Sven Hammarling, Numerical Algorithms Group Ltd. 
* 
*     .. Scalar Arguments .. 
      INTEGER            INFO 
      CHARACTER*6        SRNAME 
*     .. Scalars in Common .. 
      INTEGER            INFOT, NOUT 
      LOGICAL            LERR, OK 
      CHARACTER*6        SRNAMT 
*     .. Common blocks .. 
      COMMON             /INFOC/INFOT, NOUT, OK, LERR 
      COMMON             /SRNAMC/SRNAMT 
*     .. Executable Statements .. 
      LERR = .TRUE. 
      IF( INFO.NE.INFOT )THEN 
         IF( INFOT.NE.0 )THEN 
            WRITE( NOUT, FMT = 9999 )INFO, INFOT 
         ELSE 
            WRITE( NOUT, FMT = 9997 )INFO 
         END IF 
         OK = .FALSE. 
      END IF 
      IF( SRNAME.NE.SRNAMT )THEN 
         WRITE( NOUT, FMT = 9998 )SRNAME, SRNAMT 
         OK = .FALSE. 
      END IF 
      RETURN 
* 
 9999 FORMAT( ' ******* XERBLA WAS CALLED WITH INFO = ', I6, ' INSTEAD', 
     $      ' OF ', I2, ' *******' ) 
 9998 FORMAT( ' ******* XERBLA WAS CALLED WITH SRNAME = ', A6, ' INSTE', 
     $      'AD OF ', A6, ' *******' ) 
 9997 FORMAT( ' ******* XERBLA WAS CALLED WITH INFO = ', I6, 
     $      ' *******' ) 
* 
*     End of XERBLA 
* 
      END 
 
 
 |