Codebase list octave-iso2mesh / lintian-fixes/main nodevolume.m
lintian-fixes/main

Tree @lintian-fixes/main (Download .tar.gz)

nodevolume.m @lintian-fixes/mainraw · history · blame

function nodevol=nodevolume(node,elem, evol)
%
% nodevol=nodevolume(node,elem)
%
% calculate the volumes of the cells in the barycentric dual-mesh
% (this is different from the Voronoi cells, which blong to the 
% circumcentric dual mesh)
%
% author: Qianqian Fang, <q.fang at neu.edu>
% date: 2009/12/31
%
% input:
%    node:  node coordinates
%    elem:  element table of a mesh
%
% output:
%    nodevol:   volume values for all nodes
%
% -- this function is part of iso2mesh toolbox (http://iso2mesh.sf.net)
%

dim=4;
if(size(elem,2)==3) dim=3; end

if(nargin<3)
    evol=elemvolume(node,elem(:,1:dim));
end

elemnum=size(elem,1);
nodenum=size(node,1);
nodevol=zeros(nodenum,1);
for i=1:elemnum
      nodevol(elem(i,1:dim))=nodevol(elem(i,1:dim))+evol(i);
end
nodevol=nodevol/dim;