Advertisement
Pagoniusz

Untitled

Mar 24th, 2015
320
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 2.65 KB | None | 0 0
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <math.h>
  4.  
  5. #define foreach(a, b, c) for (int a = b; a < c; a++)
  6. #define for_i foreach(i, 0, n)
  7. #define for_j foreach(j, 0, n)
  8. #define for_k foreach(k, 0, n)
  9. #define for_ij for_i for_j
  10. #define for_ijk for_ij for_k
  11. #define _dim int n
  12. #define _swap(x, y) { typeof(x) tmp = x; x = y; y = tmp; }
  13. #define _sum_k(a, b, c, s) { s = 0; foreach(k, a, b) s+= c; }
  14.  
  15. typedef double **mat;
  16.  
  17. #define _zero(a) mat_zero(a, n)
  18. void mat_zero(mat x, int n) { for_ij x[i][j] = 0; }
  19.  
  20. #define _new(a) a = mat_new(n)
  21. mat mat_new(_dim)
  22. {
  23.     mat x = malloc(sizeof(double*) * n);
  24.     x[0]  = malloc(sizeof(double) * n * n);
  25.  
  26.     for_i x[i] = x[0] + n * i;
  27.     _zero(x);
  28.  
  29.     return x;
  30. }
  31.  
  32. #define _copy(a) mat_copy(a, n)
  33. mat mat_copy(void *s, _dim)
  34. {
  35.     mat x = mat_new(n);
  36.     for_ij x[i][j] = ((double (*)[n])s)[i][j];
  37.     return x;
  38. }
  39.  
  40. #define _del(x) mat_del(x)
  41. void mat_del(mat x) { free(x[0]); free(x); }
  42.  
  43. #define _QUOT(x) #x
  44. #define QUOTE(x) _QUOT(x)
  45. #define _show(a) printf(QUOTE(a)" =");mat_show(a, 0, n)
  46. void mat_show(mat x, char *fmt, _dim)
  47. {
  48.     if (!fmt) fmt = "%8.4g";
  49.     for_i {
  50.         printf(i ? "      " : " [ ");
  51.         for_j {
  52.             printf(fmt, x[i][j]);
  53.             printf(j < n - 1 ? "  " : i == n - 1 ? " ]\n" : "\n");
  54.         }
  55.     }
  56. }
  57.  
  58. #define _mul(a, b) mat_mul(a, b, n)
  59. mat mat_mul(mat a, mat b, _dim)
  60. {
  61.     mat c = _new(c);
  62.     for_ijk c[i][j] += a[i][k] * b[k][j];
  63.     return c;
  64. }
  65.  
  66. #define _pivot(a, b) mat_pivot(a, b, n)
  67. void mat_pivot(mat a, mat p, _dim)
  68. {
  69.     for_ij { p[i][j] = (i == j); }
  70.     for_i  {
  71.         int max_j = i;
  72.         foreach(j, i, n)
  73.             if (fabs(a[j][i]) > fabs(a[max_j][i])) max_j = j;
  74.  
  75.         if (max_j != i)
  76.             for_k { _swap(p[i][k], p[max_j][k]); }
  77.     }
  78. }
  79.  
  80. #define _LU(a, l, u, p) mat_LU(a, l, u, p, n)
  81. void mat_LU(mat A, mat L, mat U, mat P, _dim)
  82. {
  83.     _zero(L); _zero(U);
  84.     _pivot(A, P);
  85.  
  86.     mat Aprime = _mul(P, A);
  87.  
  88.     for_i  { L[i][i] = 1; }
  89.     for_ij {
  90.         double s;
  91.         if (j <= i) {
  92.             _sum_k(0, j, L[j][k] * U[k][i], s)
  93.             U[j][i] = Aprime[j][i] - s;
  94.         }
  95.         if (j >= i) {
  96.             _sum_k(0, i, L[j][k] * U[k][i], s);
  97.             L[j][i] = (Aprime[j][i] - s) / U[i][i];
  98.         }
  99.     }
  100.  
  101.     _del(Aprime);
  102. }
  103.  
  104. double A3[][3] = {{ 1, 3, 5 }, { 2, 4, 7 }, { 1, 1, 0 }};
  105. double A4[][4] = {{11, 9, 24, 2}, {1, 5, 2, 6}, {3, 17, 18, 1}, {2, 5, 7, 1}};
  106.  
  107. int main()
  108. {
  109.     int n = 3;
  110.     mat A, L, P, U;
  111.  
  112.     _new(L); _new(P); _new(U);
  113.     A = _copy(A3);
  114.     _LU(A, L, U, P);
  115.     _show(A); _show(L); _show(U); _show(P);
  116.     _del(A);  _del(L);  _del(U);  _del(P);
  117.  
  118.     printf("\n");
  119.  
  120.     n = 4;
  121.  
  122.     _new(L); _new(P); _new(U);
  123.     A = _copy(A4);
  124.     _LU(A, L, U, P);
  125.     _show(A); _show(L); _show(U); _show(P);
  126.     _del(A);  _del(L);  _del(U);  _del(P);
  127.  
  128.     return 0;
  129. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement