eigts1te.pas 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. program eigts1te;
  2. uses
  3. typ,
  4. iom,
  5. eig;
  6. const
  7. m1 = -9;
  8. m2 = 37;
  9. var
  10. i, ex, nex, i1, j1, n, term: ArbInt;
  11. t: ArbFloat;
  12. d, cd, lam: array[m1..m2] of ArbFloat;
  13. begin
  14. Write(' program results eigts1te');
  15. case sizeof(ArbFloat) of
  16. 4: writeln('(single)');
  17. 6: writeln('(real)');
  18. 8: writeln('(double)');
  19. end;
  20. Read(nex);
  21. writeln;
  22. writeln('number of examples', nex: 2);
  23. writeln;
  24. for ex := 1 to nex do
  25. begin
  26. writeln('example number', ex: 2);
  27. writeln;
  28. if ex < nex then
  29. begin
  30. Read(i1, j1, n);
  31. iomrev(input, d[i1], n);
  32. iomrev(input, cd[j1 + 1], n - 1);
  33. end
  34. else
  35. begin
  36. i1 := 1;
  37. j1 := 1;
  38. n := 30;
  39. for i := 1 to n do
  40. begin
  41. t := i;
  42. d[i] := sqr(t * t);
  43. end;
  44. for i := 2 to n do
  45. cd[i] := i - 1;
  46. end;
  47. eigts1(d[i1], cd[j1 + 1], n, lam[j1], term);
  48. writeln('diag =');
  49. iomwrv(output, d[i1], n, numdig);
  50. writeln('codiag =');
  51. iomwrv(output, cd[j1 + 1], n - 1, numdig);
  52. writeln;
  53. writeln('term=', term: 2);
  54. if term = 1 then
  55. begin
  56. writeln;
  57. writeln('lambda=');
  58. iomwrv(output, lam[j1], n, numdig);
  59. end;
  60. writeln('------------------------------------------------------');
  61. end;
  62. Close(input);
  63. Close(output);
  64. end.