Can someone help me setup the Chandrasekhar H-equation in Matlab?
Mostrar comentarios más antiguos
I have a couple errors I cannot seem to resolve. Below is the discrete equation form.

This is a homework problem so I am not looking for answers, just help to setup the problem which I will solve using various methods.
First I setup the internal structure
global ChH;
c=.8;
N=100;
meu=1:N;
meu=(meu-.5)/N;
meu=meu';
cs=.5*c/N;
ChH=ones(N,1)*meu';
ChH=cs*ChH'./(ChH+ChH');
Then I setup the rest of the function:
function [ x, ex ] = Heq_Nwt( f, df, x1, tol, nmax )
global ChH;
N=100;
n2=ones(N,N);
x1 = ones(N,N);
ch2=n2-(ChH.*(x1')); % [1 - c/2N (sum: meu*x_j /(meu+meu'))]
sm= n2./ch2; % 1/previous
ch2=x1-sm % x - previous
Problem is I am not sure what my starting value of x should be? ChH is 100x100 so x must be same dimensions for multiplication right? I converted 1 to a 100x100 matrix as well for subtraction and division? I did not include any sort of summation for internal N_summation_ j=1? Shouldn't x be a vector of length N per the equation statement given? Then why is equation structure creating matrix form?
Respuestas (2)
Ahmet Cecen
el 22 de Abr. de 2015
0 votos
I will tell you 2 things:
1) x is most definitely a vector.
2) The NxN matrix is obtained by writing the summation over j as a matrix vector product, and a matrix vector product is itself a vector.
3 comentarios
Branden Chamness
el 22 de Abr. de 2015
Ahmet Cecen
el 22 de Abr. de 2015
Ahmet Cecen
el 22 de Abr. de 2015
You are going about the implementation in a very weird way, I am not even sure you can solve it that way. The summation should never appear explicitly in your script, replace it with a matrix vector product. Paste following in a new script and publish:
%%
%
% $$ (Ax)_i = {{c}\over{2N}}\;\sum_{j=1}^{N} {{\mu_i}\over{\mu_i+\mu_j}}x_i $$
%
% $$ A_{ij} = ({{c}\over{2N}}) ({{\mu_i}\over{\mu_i+\mu_j}}) $$
Branden Chamness
el 22 de Abr. de 2015
Categorías
Más información sobre Code Performance en Centro de ayuda y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!