Cloth Simulation
Cloth Simulation
Cloth Simulation
Cloth Simulation
Organization:
UC San Diego
Organization:
UC San Diego
Organization:
UC San Diego
Duration:
Jan 2023 - Mar 2023
Duration:
Jan 2023 - Mar 2023
Duration:
Jan 2023 - Mar 2023

Video Demo
Overview
Simulated a piece of cloth made from particles, spring-dampers (structural, shearing, bending), and triangular surfaces; rendered the scene with adjustable lights and customized textures
Realized effects of gravity, spring forces, aerodynamic force on surfaces, and collisions with ground and sphere
Developed a GUI allowing parameter adjustment, camera movement, cloth movement, changing cloth hang mode
Feature Status
The cloth simulation module uses a Mass-Spring System to simulate a piece of cloth. It currently supports the following features:
General 4. pause simulation
Cloth control & physics attributes
move cloth
translate +x (right):
D
translate -x (left):
A
translate +y (up):
W
translate -y (down):
S
translate -z (inward):
Q
translate +z (outward):
E
rotate clockwise:
C
rotate counterclockwise:
Z
stiffness: structural, shear, bending
damping: structural, shear, bending
change pin mode & drop cloth:
Pin Upper Corner
Pin Upper Edge
Drop Cloth
Friction/elasticity with ground & sphere
Wind control
wind’s howling/calm
move wind spawn
Up:
W
Down:
S
Left:
A
Right:
D
Inward:
Q
Outward:
E
wind velocity (value)
Light control
move light:
Up:
W
Down:
S
Left:
A
Right:
D
Inward:
Q
Outward:
E
change light color with hue wheel
Move camera
Up:
W
Down:
S
Left:
A
Right:
D
Inward:
Q
Outward:
E
User grab
hold mouse left button to drag the cloth
quit grab mode either by right click mouse button or unclick the checkbox
Milestones to be achieved in the coming months:
try optimization methods for both realistic considerations and performance
Architecture Design
Key Algorithms
Mass-Spring System
Blinn-Phong Illumination Model
Tech Stack
IDE:
For Windows: Visual Studio or Visual Studio Code
For Mac: Xcode or Visual Studio Code
Dependencies:
Version control: GitHub
Bug tracking: JIRA, GitHub, Notion…
Resources
API documentations:
Tutorials:
YouTube playlist Introduction to OpenGL by Mike Shah
YouTube playlist Skeletal Animation by OGLDEV
Domain knowledge:
Mathematics for 3D Game Programming and Computer Graphics, Third Edition 3rd Edition
3D Math Primer for Graphics and Game Development 2nd Edition
Fundamentals of Computer Graphics 4th Edition
Real-Time Rendering, Fourth Edition 4th Edition
Physically Based Rendering, fourth edition: From Theory to Implementation 4th Edition
OpenGL Programming Guide 9th Edition
Physics for Game Programmers 2nd Edition
Computer Animation 3rd Edition
UCSD CSE 169 Computer Animation lecture slides

Video Demo
Overview
Simulated a piece of cloth made from particles, spring-dampers (structural, shearing, bending), and triangular surfaces; rendered the scene with adjustable lights and customized textures
Realized effects of gravity, spring forces, aerodynamic force on surfaces, and collisions with ground and sphere
Developed a GUI allowing parameter adjustment, camera movement, cloth movement, changing cloth hang mode
Feature Status
The cloth simulation module uses a Mass-Spring System to simulate a piece of cloth. It currently supports the following features:
General 4. pause simulation
Cloth control & physics attributes
move cloth
translate +x (right):
D
translate -x (left):
A
translate +y (up):
W
translate -y (down):
S
translate -z (inward):
Q
translate +z (outward):
E
rotate clockwise:
C
rotate counterclockwise:
Z
stiffness: structural, shear, bending
damping: structural, shear, bending
change pin mode & drop cloth:
Pin Upper Corner
Pin Upper Edge
Drop Cloth
Friction/elasticity with ground & sphere
Wind control
wind’s howling/calm
move wind spawn
Up:
W
Down:
S
Left:
A
Right:
D
Inward:
Q
Outward:
E
wind velocity (value)
Light control
move light:
Up:
W
Down:
S
Left:
A
Right:
D
Inward:
Q
Outward:
E
change light color with hue wheel
Move camera
Up:
W
Down:
S
Left:
A
Right:
D
Inward:
Q
Outward:
E
User grab
hold mouse left button to drag the cloth
quit grab mode either by right click mouse button or unclick the checkbox
Milestones to be achieved in the coming months:
try optimization methods for both realistic considerations and performance
Architecture Design
Key Algorithms
Mass-Spring System
Blinn-Phong Illumination Model
Tech Stack
IDE:
For Windows: Visual Studio or Visual Studio Code
For Mac: Xcode or Visual Studio Code
Dependencies:
Version control: GitHub
Bug tracking: JIRA, GitHub, Notion…
Resources
API documentations:
Tutorials:
YouTube playlist Introduction to OpenGL by Mike Shah
YouTube playlist Skeletal Animation by OGLDEV
Domain knowledge:
Mathematics for 3D Game Programming and Computer Graphics, Third Edition 3rd Edition
3D Math Primer for Graphics and Game Development 2nd Edition
Fundamentals of Computer Graphics 4th Edition
Real-Time Rendering, Fourth Edition 4th Edition
Physically Based Rendering, fourth edition: From Theory to Implementation 4th Edition
OpenGL Programming Guide 9th Edition
Physics for Game Programmers 2nd Edition
Computer Animation 3rd Edition
UCSD CSE 169 Computer Animation lecture slides

Video Demo
Overview
Simulated a piece of cloth made from particles, spring-dampers (structural, shearing, bending), and triangular surfaces; rendered the scene with adjustable lights and customized textures
Realized effects of gravity, spring forces, aerodynamic force on surfaces, and collisions with ground and sphere
Developed a GUI allowing parameter adjustment, camera movement, cloth movement, changing cloth hang mode
Feature Status
The cloth simulation module uses a Mass-Spring System to simulate a piece of cloth. It currently supports the following features:
General 4. pause simulation
Cloth control & physics attributes
move cloth
translate +x (right):
D
translate -x (left):
A
translate +y (up):
W
translate -y (down):
S
translate -z (inward):
Q
translate +z (outward):
E
rotate clockwise:
C
rotate counterclockwise:
Z
stiffness: structural, shear, bending
damping: structural, shear, bending
change pin mode & drop cloth:
Pin Upper Corner
Pin Upper Edge
Drop Cloth
Friction/elasticity with ground & sphere
Wind control
wind’s howling/calm
move wind spawn
Up:
W
Down:
S
Left:
A
Right:
D
Inward:
Q
Outward:
E
wind velocity (value)
Light control
move light:
Up:
W
Down:
S
Left:
A
Right:
D
Inward:
Q
Outward:
E
change light color with hue wheel
Move camera
Up:
W
Down:
S
Left:
A
Right:
D
Inward:
Q
Outward:
E
User grab
hold mouse left button to drag the cloth
quit grab mode either by right click mouse button or unclick the checkbox
Milestones to be achieved in the coming months:
try optimization methods for both realistic considerations and performance
Architecture Design
Key Algorithms
Mass-Spring System
Blinn-Phong Illumination Model
Tech Stack
IDE:
For Windows: Visual Studio or Visual Studio Code
For Mac: Xcode or Visual Studio Code
Dependencies:
Version control: GitHub
Bug tracking: JIRA, GitHub, Notion…
Resources
API documentations:
Tutorials:
YouTube playlist Introduction to OpenGL by Mike Shah
YouTube playlist Skeletal Animation by OGLDEV
Domain knowledge:
Mathematics for 3D Game Programming and Computer Graphics, Third Edition 3rd Edition
3D Math Primer for Graphics and Game Development 2nd Edition
Fundamentals of Computer Graphics 4th Edition
Real-Time Rendering, Fourth Edition 4th Edition
Physically Based Rendering, fourth edition: From Theory to Implementation 4th Edition
OpenGL Programming Guide 9th Edition
Physics for Game Programmers 2nd Edition
Computer Animation 3rd Edition
UCSD CSE 169 Computer Animation lecture slides

Video Demo
Overview
Simulated a piece of cloth made from particles, spring-dampers (structural, shearing, bending), and triangular surfaces; rendered the scene with adjustable lights and customized textures
Realized effects of gravity, spring forces, aerodynamic force on surfaces, and collisions with ground and sphere
Developed a GUI allowing parameter adjustment, camera movement, cloth movement, changing cloth hang mode
Feature Status
The cloth simulation module uses a Mass-Spring System to simulate a piece of cloth. It currently supports the following features:
General 4. pause simulation
Cloth control & physics attributes
move cloth
translate +x (right):
D
translate -x (left):
A
translate +y (up):
W
translate -y (down):
S
translate -z (inward):
Q
translate +z (outward):
E
rotate clockwise:
C
rotate counterclockwise:
Z
stiffness: structural, shear, bending
damping: structural, shear, bending
change pin mode & drop cloth:
Pin Upper Corner
Pin Upper Edge
Drop Cloth
Friction/elasticity with ground & sphere
Wind control
wind’s howling/calm
move wind spawn
Up:
W
Down:
S
Left:
A
Right:
D
Inward:
Q
Outward:
E
wind velocity (value)
Light control
move light:
Up:
W
Down:
S
Left:
A
Right:
D
Inward:
Q
Outward:
E
change light color with hue wheel
Move camera
Up:
W
Down:
S
Left:
A
Right:
D
Inward:
Q
Outward:
E
User grab
hold mouse left button to drag the cloth
quit grab mode either by right click mouse button or unclick the checkbox
Milestones to be achieved in the coming months:
try optimization methods for both realistic considerations and performance
Architecture Design
Key Algorithms
Mass-Spring System
Blinn-Phong Illumination Model
Tech Stack
IDE:
For Windows: Visual Studio or Visual Studio Code
For Mac: Xcode or Visual Studio Code
Dependencies:
Version control: GitHub
Bug tracking: JIRA, GitHub, Notion…
Resources
API documentations:
Tutorials:
YouTube playlist Introduction to OpenGL by Mike Shah
YouTube playlist Skeletal Animation by OGLDEV
Domain knowledge:
Mathematics for 3D Game Programming and Computer Graphics, Third Edition 3rd Edition
3D Math Primer for Graphics and Game Development 2nd Edition
Fundamentals of Computer Graphics 4th Edition
Real-Time Rendering, Fourth Edition 4th Edition
Physically Based Rendering, fourth edition: From Theory to Implementation 4th Edition
OpenGL Programming Guide 9th Edition
Physics for Game Programmers 2nd Edition
Computer Animation 3rd Edition
UCSD CSE 169 Computer Animation lecture slides