| 
									
										
										
										
											2014-09-10 14:25:57 +02:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * ***** BEGIN GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  |  * as published by the Free Software Foundation; either version 2 | 
					
						
							|  |  |  |  * of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program; if not, write to the Free Software Foundation, | 
					
						
							|  |  |  |  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) Blender Foundation | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is: all of this file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Contributor(s): Lukas Toenne | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * ***** END GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-13 14:36:46 +02:00
										 |  |  | #ifndef __BPH_IMPLICIT_H__
 | 
					
						
							|  |  |  | #define __BPH_IMPLICIT_H__
 | 
					
						
							| 
									
										
										
										
											2014-09-10 14:25:57 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** \file implicit.h
 | 
					
						
							| 
									
										
										
										
											2014-09-13 14:36:46 +02:00
										 |  |  |  *  \ingroup bph | 
					
						
							| 
									
										
										
										
											2014-09-10 14:25:57 +02:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-11 11:14:11 +02:00
										 |  |  | #include "stdio.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-14 17:36:53 +02:00
										 |  |  | #include "BKE_collision.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-10 16:04:31 +02:00
										 |  |  | #include "BLI_utildefines.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-14 13:23:14 +02:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-12 10:21:31 +02:00
										 |  |  | //#define IMPLICIT_SOLVER_EIGEN
 | 
					
						
							|  |  |  | #define IMPLICIT_SOLVER_BLENDER
 | 
					
						
							| 
									
										
										
										
											2014-09-10 14:25:57 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-12 11:22:39 +02:00
										 |  |  | #define CLOTH_ROOT_FRAME /* enable use of root frame coordinate transform */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-10 16:59:22 +02:00
										 |  |  | #define CLOTH_FORCE_GRAVITY
 | 
					
						
							|  |  |  | #define CLOTH_FORCE_DRAG
 | 
					
						
							|  |  |  | #define CLOTH_FORCE_SPRING_STRUCTURAL
 | 
					
						
							|  |  |  | #define CLOTH_FORCE_SPRING_BEND
 | 
					
						
							| 
									
										
										
										
											2014-09-10 21:06:01 +02:00
										 |  |  | #define CLOTH_FORCE_SPRING_GOAL
 | 
					
						
							| 
									
										
										
										
											2014-09-10 23:11:56 +02:00
										 |  |  | #define CLOTH_FORCE_EFFECTORS
 | 
					
						
							| 
									
										
										
										
											2014-09-10 16:59:22 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-10 23:11:56 +02:00
										 |  |  | //#define IMPLICIT_PRINT_SOLVER_INPUT_OUTPUT
 | 
					
						
							| 
									
										
										
										
											2014-09-10 16:04:31 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-11 17:49:26 +02:00
										 |  |  | //#define IMPLICIT_ENABLE_EIGEN_DEBUG
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-14 13:23:14 +02:00
										 |  |  | struct Implicit_Data; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-10 16:04:31 +02:00
										 |  |  | BLI_INLINE void implicit_print_matrix_elem(float v) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     printf("%-8.3f", v); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-14 17:36:53 +02:00
										 |  |  | /* ==== hash functions for debugging ==== */ | 
					
						
							|  |  |  | BLI_INLINE unsigned int hash_int_2d(unsigned int kx, unsigned int ky) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | #define rot(x,k) (((x)<<(k)) | ((x)>>(32-(k))))
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	unsigned int a, b, c; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	a = b = c = 0xdeadbeef + (2 << 2) + 13; | 
					
						
							|  |  |  | 	a += kx; | 
					
						
							|  |  |  | 	b += ky; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c ^= b; c -= rot(b,14); | 
					
						
							|  |  |  | 	a ^= c; a -= rot(c,11); | 
					
						
							|  |  |  | 	b ^= a; b -= rot(a,25); | 
					
						
							|  |  |  | 	c ^= b; c -= rot(b,16); | 
					
						
							|  |  |  | 	a ^= c; a -= rot(c,4); | 
					
						
							|  |  |  | 	b ^= a; b -= rot(a,14); | 
					
						
							|  |  |  | 	c ^= b; c -= rot(b,24); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return c; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #undef rot
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | BLI_INLINE int hash_vertex(int type, int vertex) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return hash_int_2d((unsigned int)type, (unsigned int)vertex); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | BLI_INLINE int hash_collpair(int type, CollPair *collpair) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return hash_int_2d((unsigned int)type, hash_int_2d((unsigned int)collpair->face1, (unsigned int)collpair->face2)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | /* ================ */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-18 19:42:20 +02:00
										 |  |  | void BPH_mass_spring_set_rest_transform(struct Implicit_Data *data, int index, float rot[3][3]); | 
					
						
							| 
									
										
										
										
											2014-09-14 17:36:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-14 13:23:14 +02:00
										 |  |  | void BPH_mass_spring_set_motion_state(struct Implicit_Data *data, int index, const float x[3], const float v[3]); | 
					
						
							| 
									
										
										
										
											2014-09-14 17:36:53 +02:00
										 |  |  | void BPH_mass_spring_set_position(struct Implicit_Data *data, int index, const float x[3]); | 
					
						
							|  |  |  | void BPH_mass_spring_set_velocity(struct Implicit_Data *data, int index, const float v[3]); | 
					
						
							|  |  |  | void BPH_mass_spring_get_motion_state(struct Implicit_Data *data, int index, float x[3], float v[3]); | 
					
						
							| 
									
										
										
										
											2014-09-14 14:16:03 +02:00
										 |  |  | void BPH_mass_spring_set_vertex_mass(struct Implicit_Data *data, int index, float mass); | 
					
						
							| 
									
										
										
										
											2014-09-14 17:36:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-14 14:16:03 +02:00
										 |  |  | int BPH_mass_spring_init_spring(struct Implicit_Data *data, int index, int v1, int v2); | 
					
						
							| 
									
										
										
										
											2014-09-14 13:23:14 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-14 17:36:53 +02:00
										 |  |  | void BPH_mass_spring_clear_constraints(struct Implicit_Data *data); | 
					
						
							|  |  |  | void BPH_mass_spring_add_constraint_ndof0(struct Implicit_Data *data, int index, const float dV[3]); | 
					
						
							|  |  |  | void BPH_mass_spring_add_constraint_ndof1(struct Implicit_Data *data, int index, const float c1[3], const float c2[3], const float dV[3]); | 
					
						
							|  |  |  | void BPH_mass_spring_add_constraint_ndof2(struct Implicit_Data *data, int index, const float c1[3], const float dV[3]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | bool BPH_mass_spring_solve(struct Implicit_Data *data, float dt); | 
					
						
							|  |  |  | void BPH_mass_spring_apply_result(struct Implicit_Data *data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-15 14:18:40 +02:00
										 |  |  | /* Clear the force vector at the beginning of the time step */ | 
					
						
							| 
									
										
										
										
											2014-09-14 19:36:33 +02:00
										 |  |  | void BPH_mass_spring_force_clear(struct Implicit_Data *data); | 
					
						
							| 
									
										
										
										
											2014-09-15 14:18:40 +02:00
										 |  |  | /* Fictitious forces introduced by moving coordinate systems */ | 
					
						
							| 
									
										
										
										
											2014-09-18 19:42:20 +02:00
										 |  |  | void BPH_mass_spring_force_reference_frame(struct Implicit_Data *data, int index, const float acceleration[3], const float omega[3], const float domega_dt[3]); | 
					
						
							| 
									
										
										
										
											2014-09-15 14:18:40 +02:00
										 |  |  | /* Simple uniform gravity force */ | 
					
						
							| 
									
										
										
										
											2014-09-14 19:36:33 +02:00
										 |  |  | void BPH_mass_spring_force_gravity(struct Implicit_Data *data, const float g[3]); | 
					
						
							| 
									
										
										
										
											2014-09-15 14:18:40 +02:00
										 |  |  | /* Global drag force (velocity damping) */ | 
					
						
							| 
									
										
										
										
											2014-09-14 19:36:33 +02:00
										 |  |  | void BPH_mass_spring_force_drag(struct Implicit_Data *data, float drag); | 
					
						
							| 
									
										
										
										
											2014-09-16 20:44:25 +02:00
										 |  |  | /* Custom external force */ | 
					
						
							|  |  |  | void BPH_mass_spring_force_extern(struct Implicit_Data *data, int i, const float f[3], float dfdx[3][3], float dfdv[3][3]); | 
					
						
							| 
									
										
										
										
											2014-09-15 14:18:40 +02:00
										 |  |  | /* Wind force, acting on a face */ | 
					
						
							| 
									
										
										
										
											2014-09-14 19:36:33 +02:00
										 |  |  | void BPH_mass_spring_force_face_wind(struct Implicit_Data *data, int v1, int v2, int v3, int v4, const float (*winvec)[3]); | 
					
						
							| 
									
										
										
										
											2014-09-15 14:18:40 +02:00
										 |  |  | /* Wind force, acting on an edge */ | 
					
						
							| 
									
										
										
										
											2014-09-14 19:36:33 +02:00
										 |  |  | void BPH_mass_spring_force_edge_wind(struct Implicit_Data *data, int v1, int v2, const float (*winvec)[3]); | 
					
						
							| 
									
										
										
										
											2014-09-15 14:18:40 +02:00
										 |  |  | /* Linear spring force between two points */ | 
					
						
							| 
									
										
										
										
											2014-09-15 12:10:49 +02:00
										 |  |  | bool BPH_mass_spring_force_spring_linear(struct Implicit_Data *data, int i, int j, int spring_index, float restlen, | 
					
						
							|  |  |  |                                          float stiffness, float damping, bool no_compress, float clamp_force, | 
					
						
							|  |  |  |                                          float r_f[3], float r_dfdx[3][3], float r_dfdv[3][3]); | 
					
						
							| 
									
										
										
										
											2014-09-15 14:18:40 +02:00
										 |  |  | /* Bending force, forming a triangle at the base of two structural springs */ | 
					
						
							| 
									
										
										
										
											2014-09-15 12:10:49 +02:00
										 |  |  | bool BPH_mass_spring_force_spring_bending(struct Implicit_Data *data, int i, int j, int spring_index, float restlen, | 
					
						
							|  |  |  |                                           float kb, float cb, | 
					
						
							|  |  |  |                                           float r_f[3], float r_dfdx[3][3], float r_dfdv[3][3]); | 
					
						
							| 
									
										
										
										
											2014-09-19 11:15:16 +02:00
										 |  |  | /* Angular bending force based on local target vectors */ | 
					
						
							|  |  |  | bool BPH_mass_spring_force_spring_bending_angular(struct Implicit_Data *data, int i, int j, int spring_index, float restlen, | 
					
						
							|  |  |  |                                                   float stiffness, float damping, | 
					
						
							|  |  |  |                                                   float r_f[3], float r_dfdx[3][3], float r_dfdv[3][3]); | 
					
						
							| 
									
										
										
										
											2014-09-15 14:18:40 +02:00
										 |  |  | /* Global goal spring */ | 
					
						
							| 
									
										
										
										
											2014-09-15 12:10:49 +02:00
										 |  |  | bool BPH_mass_spring_force_spring_goal(struct Implicit_Data *data, int i, int spring_index, const float goal_x[3], const float goal_v[3], | 
					
						
							|  |  |  |                                        float stiffness, float damping, | 
					
						
							|  |  |  |                                        float r_f[3], float r_dfdx[3][3], float r_dfdv[3][3]); | 
					
						
							| 
									
										
										
										
											2014-09-14 19:36:33 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-16 20:44:25 +02:00
										 |  |  | /* ======== Hair Volumetric Forces ======== */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct HairVertexGrid; | 
					
						
							|  |  |  | struct HairColliderGrid; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-17 14:21:06 +02:00
										 |  |  | struct HairVertexGrid *BPH_hair_volume_create_vertex_grid(int res, const float gmin[3], const float gmax[3]); | 
					
						
							| 
									
										
										
										
											2014-09-16 20:44:25 +02:00
										 |  |  | void BPH_hair_volume_free_vertex_grid(struct HairVertexGrid *grid); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void BPH_hair_volume_add_vertex(struct HairVertexGrid *grid, const float x[3], const float v[3]); | 
					
						
							|  |  |  | void BPH_hair_volume_normalize_vertex_grid(struct HairVertexGrid *grid); | 
					
						
							| 
									
										
										
										
											2014-09-18 09:24:31 +02:00
										 |  |  | #if 0 /* XXX weighting is incorrect, disabled for now */
 | 
					
						
							| 
									
										
										
										
											2014-09-18 09:06:25 +02:00
										 |  |  | void BPH_hair_volume_vertex_grid_filter_box(struct HairVertexGrid *grid, int kernel_size); | 
					
						
							| 
									
										
										
										
											2014-09-18 09:24:31 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2014-09-16 20:44:25 +02:00
										 |  |  | void BPH_hair_volume_vertex_grid_forces(struct HairVertexGrid *grid, const float x[3], const float v[3], | 
					
						
							|  |  |  |                                         float smoothfac, float pressurefac, float minpressure, | 
					
						
							|  |  |  |                                         float f[3], float dfdx[3][3], float dfdv[3][3]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-14 13:23:14 +02:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-10 14:25:57 +02:00
										 |  |  | #endif
 |