Blender Git Commits

Blender Git "temp_merge_gooseberry_hair" branch commits.

Page: 8 / 11

January 19, 2015, 17:04 (GMT)
Minor fix when gravity code is disabled.
January 19, 2015, 17:03 (GMT)
Removed unused code.

Conflicts:
source/blender/physics/intern/implicit_blender.c
January 19, 2015, 17:00 (GMT)
Added a calculation function for the fictitious forces introduced by
moving hair root reference frames.

This calculates Euler, Coriolis and Centrifugal forces which result
from describing hair in a moving reference frame.
http://en.wikipedia.org/wiki/Fictitious_force
January 19, 2015, 17:00 (GMT)
Fix for own misconception of fictitious forces in the moving hair root
frames.

These forces don't have to be calculated for each individual
contribution. Rather they can be split off and be calculated on top of
the basic force vector rotation (todo).
January 19, 2015, 16:59 (GMT)
Added back spring force definitions outside the implicit solver.

There are currently 3 types of springs: basic linear springs, goal
springs toward a fixed global target (not recommended, but works) and
bending springs.

These are agnostic to the specific spring definition in the cloth system
so hair systems can use the same API without converting everything to
cloth first.

Conflicts:
source/blender/physics/intern/implicit_blender.c
January 19, 2015, 16:57 (GMT)
Main cloth force calculation function outside of implicit core code.

Still misses spring forces.
January 19, 2015, 16:57 (GMT)
Hair volume calculation is now in its own file.

Code is currently disabled until the other main forces are in place.
January 19, 2015, 16:57 (GMT)
Moved the unused goal force calculation function to the main mass-spring
source file.
January 19, 2015, 16:57 (GMT)
Moved most of the main cloth solver function out of implicit code core.

Force calculation is disabled, will follow shortly.
January 19, 2015, 16:57 (GMT)
Moved init/free functions for solver data out of implicit core.

This also initializes spring matrix indices (off-diagonal 3x3 blocks),
which now uses a new API function.
January 19, 2015, 16:57 (GMT)
Moved "set_positions" for cloth out of core implicit solver.

API for the solver now has functions for setting of vertex motion state
and the associated root transform data.
January 19, 2015, 16:57 (GMT)
Renamed functions to make them explicitly refer to cloth, and split the
create/free functions for solver data off from the cloth solver.
January 19, 2015, 16:57 (GMT)
Moved the cloth solver code into a new subfolder/library inside Blender
code.

The implicit solver itself should remain agnostic to the specifics of
the Blender data (cloth vs. hair). This way we could avoid the bloated
data conversion chain from particles/hair to derived mesh to cloth
modifier to implicit solver data and back. Every step in this chain adds
overhead as well as rounding errors and a possibility for bugs, not to
speak of making the code horribly complicated.

The new subfolder is named "physics" since it should be the start of a
somewhat "unified" physics systems combining all the various solvers in
the same place and managing things like synchronized time steps.
January 19, 2015, 16:57 (GMT)
Desperate attempt to get stable collisions: Disable restitution and
handle only one collision contact at a time.

Collision still randomly explodes, even with differing results on the
same file. This could indicate a threading issue, possibly also related
to the dependency graph since multiple objects are involved in
collisions.
January 19, 2015, 16:56 (GMT)
Revert "Ignore velocity changes when the cloth solver does not converge."

This reverts commit c52b8ae818844965d56714a71255408873275dc1.

Sadly, at this point solver convergence is an exception rather than the
rule... Individual hairs can "explode" easily and thus disable the whole
simulation, which isn't helpful either.
January 19, 2015, 16:56 (GMT)
Ignore velocity changes when the cloth solver does not converge.

This helps keep the simulation stable as long as there are only a few
substeps that become too constrained for the solver.

Eventually we need better feedback about these solver results, so that
artists can tweak situations specifically to resolve bad solver results.
This is somewhat similar to the camera tracker, which also can run into
cases that cannot be resolved and have to be fixed manually.
January 19, 2015, 16:56 (GMT)
Moved collision response into the main cloth sim source file and fixed
some coordinate transform issues.

Collision response should be regarded as part of the dynamics system
instead of the basic collision detection.
January 19, 2015, 16:56 (GMT)
Correction for inverse constraint matrix rotation.
January 19, 2015, 16:56 (GMT)
Transform the constraint matrix and target solver vector z according to
the root frame transforms as well.

This ensures the hair constraints are actually in root space and applied
correctly by the solver.
January 19, 2015, 16:56 (GMT)
Use identity transform in the solver data roots to avoid possible errors
when this data is used outside the transform functions.
By: Miika HämäläinenLast update: Nov-07-2014 14:18MiikaHweb | 2003-2021