To set up the coefficient matrix and RHS vector using pointer for a 2D unsteady heat conduction equation, we will use implicit euler for time and central differencing for space. We will use a Jacobi solver.
Assuming a 2D grid, the equation for heat conduction is:
where k is thermal conductivity, T is the temperature, and delta x and delta y are the spatial steps in the x and y directions respectively.
To discretize the equation we will use central differences. The implicit scheme allows us to write:
where T^{n+1} is the temperature at time step n+1, T^n is the temperature at time step n and r = (delta t)/(k*(delta x)^2).
Rearranging the equation, we obtain:
We can then set up a system of linear equations in the form Ax = b. To do this, we will set up a coefficient matrix, A, and a RHS vector, b.
We initialize A as a sparse matrix and b as a vector of zeros. We then loop over all internal points in the grid and set the corresponding entries in A and b.
index.tsx1185 chars42 lines
Here, "SparseMatrix" and "Vector" are classes that implement a sparse matrix and a vector respectively. "jacobiSolver" is a function that implements the Jacobi method to solve the linear system.
Note that the above code assumes that the boundary conditions are given by Tleft, Tright, Ttop, Tbottom. T0 is the initial temperature distribution. The function returns the solution as a 2D array.
gistlibby LogSnag