How can I write a matlab code for the below mentioned expression?
1 次查看(过去 30 天)
显示 更早的评论
where
ne(a,b) = 0 for (a=b)
= 1 for (a not equal to b)
H(x) is the heavyside function
I have an 1D domain in x and is divided into no. of cells. and so on are the cell boundaries with i=1,2.......
is the representative point of the cell (here its the mid point of the cell)
Taking for example =5, how can I write the code in Matlab so that I get separate expressions for for i=1,2,3,4,5?
采纳的回答
Basil C.
2019-7-4
编辑:Basil C.
2019-7-4
Hi Anomitra,
For the variable 'ne' you could define it as a Np x Np with diagonal elements as 0 and non diagonal elements as 1
ne= ne=ones(Np)-diag(ones(1,Np));
For H(x) you could you the function 'heaviside'
heaviside(x(j)+x(k)-xb(i))
Also to define B(i) you could use the for loop
B=zeros(1,Np)
for i=1:Np
for j=1:Np
for k=1:j
B(i)=B(i)+0.5*(1+ne(j,k))*heaviside(x(j)+x(k)+xb(i))-heaviside(x(j)+x(k)-xb(i))*(j+k)*N(j)*N(k);
end
end
end
0 个评论
更多回答(0 个)
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Operating on Diagonal Matrices 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!