Real d = range_ideal_len (l, r);
Real c = range_stiffness (l, r, dist > d);
Real block_stretch = dist - d;
+
+ if (isinf (c)) /* take care of the 0*infinity_f case */
+ return 0;
return c * block_stretch;
}
for (vsize i=0; i < springs_.size (); i++)
inv_hooke += springs_[i].inverse_stretch_strength ();
+ if (inv_hooke == 0.0) /* avoid division by zero. If springs are infinitely stiff */
+ return 0.0; /* anyway, then it makes no difference what the force is */
+
assert (cur_len <= line_len_);
return (line_len_ - cur_len) / inv_hooke + force_;
}
{
Real force = max (f, blocking_force_);
Real inv_k = force < 0.0 ? inverse_compress_strength_ : inverse_stretch_strength_;
+
+ if (isinf (force))
+ {
+ programming_error ("cruelty to springs");
+ force = 0.0;
+ }
+
return distance_ + force * inv_k;
}