Hi,
If memory serves norm of a zero vector is zero, isn't it? So naively I'd expect that function to return zero, not fail in obscure way..
Broadly speaking, norm is length. Length of a zero vector is zero.
So my proposal would be to treat zero vectors as special case and do the right thing for it.
If the current implementation
vec3 normalize() const
{
return (*this) / length();
}
was to be replaced by the following, as Pavel proposed if I understand correctly,
if(length() == 0) raise scitbx::error(“a zero vector cannot be normalised”);
return (*this)/length();
this may not result in any performance hit in fact. Indeed the compiler would still be allowed to inline normalize and then the processor branch prediction unit may realise the branch throwing the exception is hardly ever taken, and take advantage of that to reorder calculations to, in effect, make the code equivalent to the current implementation. But this is the point: the current implementation is guaranteed to be optimal whether the rewrite may be optimal. So if this function appears in a critical path, you would need to check there is no performance hit.
Best wishes,
Luc