• Log InLog In
  • Register
Liquid`
Team Liquid Liquipedia
EDT 08:46
CEST 14:46
KST 21:46
  • Home
  • Forum
  • Calendar
  • Streams
  • Liquipedia
  • Features
  • Store
  • EPT
  • TL+
  • StarCraft 2
  • Brood War
  • Smash
  • Heroes
  • Counter-Strike
  • Overwatch
  • Liquibet
  • Fantasy StarCraft
  • TLPD
  • StarCraft 2
  • Brood War
  • Blogs
Forum Sidebar
Events/Features
News
Featured News
[ASL19] Finals Recap: Standing Tall9HomeStory Cup 27 - Info & Preview18Classic wins Code S Season 2 (2025)16Code S RO4 & Finals Preview: herO, Rogue, Classic, GuMiho0TL Team Map Contest #5: Presented by Monster Energy6
Community News
Flash Announces Hiatus From ASL62Weekly Cups (June 23-29): Reynor in world title form?13FEL Cracov 2025 (July 27) - $8000 live event21Esports World Cup 2025 - Final Player Roster16Weekly Cups (June 16-22): Clem strikes back1
StarCraft 2
General
Program: SC2 / XSplit / OBS Scene Switcher The SCII GOAT: A statistical Evaluation Statistics for vetoed/disliked maps Weekly Cups (June 23-29): Reynor in world title form? PiG Sty Festival #5: Playoffs Preview + Groups Recap
Tourneys
RSL: Revival, a new crowdfunded tournament series Sparkling Tuna Cup - Weekly Open Tournament WardiTV Mondays FEL Cracov 2025 (July 27) - $8000 live event Korean Starcraft League Week 77
Strategy
How did i lose this ZvP, whats the proper response Simple Questions Simple Answers
Custom Maps
[UMS] Zillion Zerglings
External Content
Mutation # 480 Moths to the Flame Mutation # 479 Worn Out Welcome Mutation # 478 Instant Karma Mutation # 477 Slow and Steady
Brood War
General
Player “Jedi” cheat on CSL SC uni coach streams logging into betting site Flash Announces Hiatus From ASL Practice Partners (Official) ASL20 Preliminary Maps
Tourneys
[BSL20] Grand Finals - Sunday 20:00 CET [Megathread] Daily Proleagues Small VOD Thread 2.0 [BSL20] GosuLeague RO16 - Tue & Wed 20:00+CET
Strategy
Simple Questions, Simple Answers I am doing this better than progamers do.
Other Games
General Games
Path of Exile Stormgate/Frost Giant Megathread Nintendo Switch Thread What do you want from future RTS games? Beyond All Reason
Dota 2
Official 'what is Dota anymore' discussion
League of Legends
Heroes of the Storm
Simple Questions, Simple Answers Heroes of the Storm 2.0
Hearthstone
Heroes of StarCraft mini-set
TL Mafia
TL Mafia Community Thread Vanilla Mini Mafia
Community
General
Russo-Ukrainian War Thread US Politics Mega-thread Summer Games Done Quick 2025! Trading/Investing Thread Things Aren’t Peaceful in Palestine
Fan Clubs
SKT1 Classic Fan Club! Maru Fan Club
Media & Entertainment
Anime Discussion Thread [Manga] One Piece [\m/] Heavy Metal Thread
Sports
2024 - 2025 Football Thread Formula 1 Discussion NBA General Discussion TeamLiquid Health and Fitness Initiative For 2023 NHL Playoffs 2024
World Cup 2022
Tech Support
Computer Build, Upgrade & Buying Resource Thread
TL Community
Blogs
Culture Clash in Video Games…
TrAiDoS
from making sc maps to makin…
Husyelt
Blog #2
tankgirl
StarCraft improvement
iopq
Trip to the Zoo
micronesia
Customize Sidebar...

Website Feedback

Closed Threads



Active: 629 users

Physics Engine - Game Programming - Page 2

Blogs > CecilSunkure
Post a Reply
Prev 1 2 All
adwodon
Profile Blog Joined September 2010
United Kingdom592 Posts
March 28 2013 17:31 GMT
#21
My masters project involved a contribution to this:

https://rivet.hepforge.org/

Not that deep inelastic scattering is likely to find itself in a physics engine for a game hah.

I've said it before in the big programming thread that at least here in the UK physicists / electrical engineers are prized higher than CS graduates in more technical positions (obviously as far as graduate employment goes) in software.

I work for a company that makes graphics / capture cards as a software engineer and they only hire physicists / electrical engineers, a CS degree wouldn't have even got me an interview.
To be honest though, most of the stuff in a physics engine isn't all that complicated in terms of the pure physics involved, but actually getting it into a fully working model in a simulation is a different matter entirely.
CecilSunkure
Profile Blog Joined May 2010
United States2829 Posts
March 28 2013 18:12 GMT
#22
On March 29 2013 02:31 adwodon wrote:
My masters project involved a contribution to this:

https://rivet.hepforge.org/

Not that deep inelastic scattering is likely to find itself in a physics engine for a game hah.

I've said it before in the big programming thread that at least here in the UK physicists / electrical engineers are prized higher than CS graduates in more technical positions (obviously as far as graduate employment goes) in software.

I work for a company that makes graphics / capture cards as a software engineer and they only hire physicists / electrical engineers, a CS degree wouldn't have even got me an interview.
To be honest though, most of the stuff in a physics engine isn't all that complicated in terms of the pure physics involved, but actually getting it into a fully working model in a simulation is a different matter entirely.

I was under the impression that lagrangian mechanics were very high level physics?
micronesia
Profile Blog Joined July 2006
United States24667 Posts
Last Edited: 2013-03-28 18:15:27
March 28 2013 18:15 GMT
#23
Lagrangians aren't that difficult to set up, and once you apply the euler-lagrange equation you get the differential equations (second order) which give the equations of motion. You can simply plug them into any DSolve equivalent to get numerical solutions for the equations of motion (in simple cases they can just be solved using typical undergraduate ODE solving methods).

Of course, some software like Mathematica will do the whole thing for you as long as you can come up with the actual expression for the Lagrangian, which for simple systems isn't that difficult. You just need to express the kinetic and potential energy in terms of some useful variables (generalized coordinates), and then say L = T - U. Punch it into your software and the work is done for you!
ModeratorThere are animal crackers for people and there are people crackers for animals.
CecilSunkure
Profile Blog Joined May 2010
United States2829 Posts
March 28 2013 18:26 GMT
#24
On March 29 2013 03:15 micronesia wrote:
Lagrangians aren't that difficult to set up, and once you apply the euler-lagrange equation you get the differential equations (second order) which give the equations of motion. You can simply plug them into any DSolve equivalent to get numerical solutions for the equations of motion (in simple cases they can just be solved using typical undergraduate ODE solving methods).

Of course, some software like Mathematica will do the whole thing for you as long as you can come up with the actual expression for the Lagrangian, which for simple systems isn't that difficult. You just need to express the kinetic and potential energy in terms of some useful variables (generalized coordinates), and then say L = T - U. Punch it into your software and the work is done for you!

Interesting. Might I point you to this? http://twvideo01.ubm-us.net/o1/vault/gdc09/slides/04-GDC09_Catto_Erin_Solver.pdf

I would like to learn to understand why this sort of math setup works for modelling and solving constraint equations. The general process for modelling and solving a constraint goes like this:
  • Create equation of position to model the constraint.
  • Derive equation to end up with one in terms of velocity.
  • Isolate velocity terms.
  • Identify Jacobian by inspection.

Then the rest is just a programmer using the Jacobian in a few lines of code (10-20 or so) in order to model complex behavioral constraints.

Could you perhaps shed some light on where all this is mathematically grounded?
micronesia
Profile Blog Joined July 2006
United States24667 Posts
Last Edited: 2013-03-28 18:39:53
March 28 2013 18:37 GMT
#25
On March 29 2013 03:26 CecilSunkure wrote:
Show nested quote +
On March 29 2013 03:15 micronesia wrote:
Lagrangians aren't that difficult to set up, and once you apply the euler-lagrange equation you get the differential equations (second order) which give the equations of motion. You can simply plug them into any DSolve equivalent to get numerical solutions for the equations of motion (in simple cases they can just be solved using typical undergraduate ODE solving methods).

Of course, some software like Mathematica will do the whole thing for you as long as you can come up with the actual expression for the Lagrangian, which for simple systems isn't that difficult. You just need to express the kinetic and potential energy in terms of some useful variables (generalized coordinates), and then say L = T - U. Punch it into your software and the work is done for you!

Interesting. Might I point you to this? http://twvideo01.ubm-us.net/o1/vault/gdc09/slides/04-GDC09_Catto_Erin_Solver.pdf

I would like to learn to understand why this sort of math setup works for modelling and solving constraint equations. The general process for modelling and solving a constraint goes like this:
  • Create equation of position to model the constraint.
  • Derive equation to end up with one in terms of velocity.
  • Isolate velocity terms.
  • Identify Jacobian by inspection.

Then the rest is just a programmer using the Jacobian in a few lines of code (10-20 or so) in order to model complex behavioral constraints.

Could you perhaps shed some light on where all this is mathematically grounded?

That is going in depth with more specific examples than I am used to, but I will help as much as I can. Remember how I said you set up the Lagrangian using generalized coordinates? Sometimes you can choose generalized coordinates such that position constraints are build into the coordinates. For example, if modeling a simple pendulum, instead of using x, y, and a constraint equation (effectively reducing two variables to one), you can use the generalized coordinate theta, which is the angle between the string and the -y axis. The length of the string can be treated as a constant, and you no longer need to worry about constraints... you build them IN TO your Lagrangian by using a smart coordinate transformation (x = Lsin(theta), y=-Lcos(theta)).

Unfortunately you can't always get away with this trick so you need to actually come up with the constraint equation(s). The constraint equation is always of the form f(x1,x2,...xn) = 0, where x1, x2, etc are each of the variables. The Euler-Lagrange equation usually says:

dL/dx - d/dt(dL/dx_prime) = 0, once for x1, again for x2, etc through all your variables (often it's just 1 or 2 variables)

However, when you have explicit constraint equations (unlike the pendulum example where we avoided it) you actually do:

dL/dx - d/dt(dL/dx_prime) - df/dx = 0, again once for each variable x1, x2, etc... just substitute xn for x in that equation

I'm doing this from memory so I would look it up in a classical mechanics textbook before taking my word for it. I'm not sure if the built-in Euler-Lagrange functions in software like Mathematica will handle the constraint equations for you or if you need to set up the Euler-Lagrange equations yourself by hand.

If you (or anyone else) is interested in a more in-depth guide to lagrangian mechanics I could probably write it, and I would actually reference my texts to be sure I was using proper notation and not making mistakes.

edit: btw I neglected to mention that the Euler-Lagrange equation is basically a summary of the calculus of variations, which is a very useful mathematical tool for classical mechanics, but it can be used in other places as well.
ModeratorThere are animal crackers for people and there are people crackers for animals.
CecilSunkure
Profile Blog Joined May 2010
United States2829 Posts
March 28 2013 18:46 GMT
#26
On March 29 2013 03:37 micronesia wrote:
If you (or anyone else) is interested in a more in-depth guide to lagrangian mechanics I could probably write it, and I would actually reference my texts to be sure I was using proper notation and not making mistakes.

Yes I'd be very interested in seeing that!
micronesia
Profile Blog Joined July 2006
United States24667 Posts
March 28 2013 18:49 GMT
#27
Okay I'll plan to put something together. Once again, it won't be geared towards as detailed of an application as how that Blizzard guy was working. It should provide a good basis provided the reader has a math background, however.

The hardest part is going to be writing out the math in an easy to read way since I'm not that familiar with latex.
ModeratorThere are animal crackers for people and there are people crackers for animals.
CecilSunkure
Profile Blog Joined May 2010
United States2829 Posts
March 28 2013 18:52 GMT
#28
On March 29 2013 03:49 micronesia wrote:
Okay I'll plan to put something together. Once again, it won't be geared towards as detailed of an application as how that Blizzard guy was working. It should provide a good basis provided the reader has a math background, however.

The hardest part is going to be writing out the math in an easy to read way since I'm not that familiar with latex.

Exciting, thanks for putting something together, I appreciate it a lot
EatThePath
Profile Blog Joined September 2009
United States3943 Posts
March 28 2013 21:20 GMT
#29
ooooh I would love to read that, please do!
Comprehensive strategic intention: DNE
i.of.the.storm
Profile Joined April 2009
United States795 Posts
March 29 2013 03:45 GMT
#30
On March 28 2013 20:35 Otolia wrote:
Show nested quote +
On March 28 2013 12:15 CecilSunkure wrote:
tldr; physics programming isn't a job position that has any demand (in my own opinion).

Like micronesia said, a physics programming is the mother of all computational science bar computational mathematics (but mathematicians are always secluded). Weather forecast, Finance, behavior modelling all of this is done by physicists.

For example, the best programmers in my theoritical physics class have written projects like : behavioral spreading of diseases, chaotic rebound (that was mine) or weather propagation. Those were simplistic but for most of us that was our first real code ever and we all wrote in C.


Yeah, I think the above statement was meant to be scoped by the games industry in particular. In research labs that kind of talent is very in demand.
Maru - The Terran hope is alive!
CecilSunkure
Profile Blog Joined May 2010
United States2829 Posts
March 29 2013 03:54 GMT
#31
On March 29 2013 12:45 i.of.the.storm wrote:
Show nested quote +
On March 28 2013 20:35 Otolia wrote:
On March 28 2013 12:15 CecilSunkure wrote:
tldr; physics programming isn't a job position that has any demand (in my own opinion).

Like micronesia said, a physics programming is the mother of all computational science bar computational mathematics (but mathematicians are always secluded). Weather forecast, Finance, behavior modelling all of this is done by physicists.

For example, the best programmers in my theoritical physics class have written projects like : behavioral spreading of diseases, chaotic rebound (that was mine) or weather propagation. Those were simplistic but for most of us that was our first real code ever and we all wrote in C.


Yeah, I think the above statement was meant to be scoped by the games industry in particular. In research labs that kind of talent is very in demand.

Ah yes, to clarify I meant for the games industry only. I don't know about the state of other industries.
Thienan567
Profile Blog Joined November 2010
United States670 Posts
March 29 2013 04:15 GMT
#32
I think this kind of blog really puts into perspective how much hard work you have to put into a physics program. That said kudos to blizz for putting in its physics engine that sometimes honestly does wow me.
Danglars
Profile Blog Joined August 2010
United States12133 Posts
March 29 2013 07:11 GMT
#33
On March 28 2013 11:23 CecilSunkure wrote:
Show nested quote +
On March 28 2013 11:11 micronesia wrote:
Something to keep in mind about coding physics engines (and other things like that): it's more effective to have a science specialist learn coding in order to apply expertise to a program than it is to try to teach the scientific expertise to someone who purely knows how to code.

For a simple 2d engine this may not be the case, but it is true in the 'working world' for the most part.

Thank you for sharing this... sounds interesting.

edit: you might want to suggest how people can learn the physics necessary to come up with their own engines! We can't all have degrees in physics :p

I would tend to agree. Most people aren't capable of writing this sort of thing on their own. And the funny thing is, is that in 2D the complexity isn't all that much simpler than in 3D. They are actually very similar, and often times just "adding another dimension" is all that is required to make such a transition.

However scientists and mathmaticians are absolutely terrible at programming. They can't really be used for any commercial products because of this. So what is really needed, is someone that is great with mathematics and specializes in computer science. These types of people however are quite rare.

Engineers can be pretty good though. I took a three programming classes while learning chemical engineering and it was easy as pie. Some of the purely engineering software you basically have to have a minor in computer science to just interact with it (most older-generation, some of the newer ones have reversed the trend). Side note on the scientists since I saw so many friends go from a mechanical or chemical engineering over to programming jobs and software engineering.

Sad about know-how, but cool article & pictures!
Great armies come from happy zealots, and happy zealots come from California!
TL+ Member
BisuDagger
Profile Blog Joined October 2009
Bisutopia19229 Posts
March 29 2013 10:54 GMT
#34
Just write an article about the dot product and cross product and you just solved all your problems for physics in game development. Add in matrices if you want to be more advanced.
ModeratorFormer Afreeca Starleague Caster: http://afreeca.tv/ASL2ENG2
Teoita
Profile Blog Joined January 2011
Italy12246 Posts
March 29 2013 11:22 GMT
#35
Lagrangians are fucking awesome i remember being completely blown away when i first figured them out lol.

If you need help with Latex i can ask a friend of mine. He's also helped with sorting out the pdf for the PvZ guide.
ModeratorProtoss all-ins are like a wok. You can throw whatever you want in there and it will turn out alright.
LaNague
Profile Blog Joined April 2010
Germany9118 Posts
Last Edited: 2013-03-29 12:34:27
March 29 2013 12:32 GMT
#36
i dont think you would need that much knowledge for basic engines.

1 semester in physics is all i had regarding classical mechanics and analysis I+II gets you differential equations, manifolds and minimizing/maximizing with conditions. What more could you possibly want for an engine :D



I think the point where its easier to use a physics guy over a computerscience/programmer guy would be for labs that go much beyond those things.
CecilSunkure
Profile Blog Joined May 2010
United States2829 Posts
Last Edited: 2013-03-29 20:13:55
March 29 2013 17:03 GMT
#37
On March 29 2013 21:32 LaNague wrote:
i dont think you would need that much knowledge for basic engines.

1 semester in physics is all i had regarding classical mechanics and analysis I+II gets you differential equations, manifolds and minimizing/maximizing with conditions. What more could you possibly want for an engine :D

I think the point where its easier to use a physics guy over a computerscience/programmer guy would be for labs that go much beyond those things.

On March 29 2013 19:54 BisuDagger wrote:
Just write an article about the dot product and cross product and you just solved all your problems for physics in game development. Add in matrices if you want to be more advanced.

It's not that simple. Things start to get very complicated very fast. Having things bounce off one another and rotate with friction is very complicated, and joints are equally so in terms of mathematics. The computer science aspect of creating a high-quality robust physics engine usable in a game is also equally as difficult.

So when I see people say things like what I've quoted above, it's really that you guys just don't know what you're talking about unless you're referring to the simplest of simulations.

Edit: On a more light-hearted note, yeah you use a ridiculous amount of dot/cross products You even use dot product in crazy places where it's not actually a dot product in theory, but the computation is the same haha
Rollin
Profile Joined March 2011
Australia1552 Posts
March 30 2013 04:22 GMT
#38
Wow this looks complex, glad my game won't need to have this stuff in it :D. Collision detection is so easy in comparison

By the way I love your stuff cecil, your game layout TL knowhow article is an amazing reference.
Throw off those chains of reason, and your prison disappears. | Check your posting frequency timeline: http://www.teamliquid.net/mytlnet/post_activity_img.php
CecilSunkure
Profile Blog Joined May 2010
United States2829 Posts
March 30 2013 04:26 GMT
#39
On March 30 2013 13:22 Rollin wrote:
Wow this looks complex, glad my game won't need to have this stuff in it :D. Collision detection is so easy in comparison

By the way I love your stuff cecil, your game layout TL knowhow article is an amazing reference.

Awe why thank you for the compliments
Prev 1 2 All
Please log in or register to reply.
Live Events Refresh
WardiTV European League
12:00
Swiss Groups Day 2
WardiTV843
TKL 411
Liquipedia
FEL
12:00
Cracov 2025: Qualifier #2
IndyStarCraft 304
CranKy Ducklings93
Liquipedia
[ Submit Event ]
Live Streams
Refresh
StarCraft 2
TKL 411
IndyStarCraft 304
Rex 114
MindelVK 37
StarCraft: Brood War
Sea 11874
Calm 9819
Rain 7794
Bisu 2965
Horang2 2419
Jaedong 1453
Hyuk 1433
Rush 526
Shuttle 509
EffOrt 297
[ Show more ]
Stork 295
Leta 278
Last 235
Mini 225
PianO 218
ToSsGirL 164
Hyun 143
ZerO 99
TY 60
hero 48
JYJ45
Movie 40
Killer 35
JulyZerg 27
ajuk12(nOOB) 24
GoRush 19
HiyA 18
Barracks 18
Sacsri 18
Free 18
zelot 17
Terrorterran 17
Icarus 6
ivOry 3
Stormgate
NightEnD20
Dota 2
qojqva2822
XcaliburYe543
canceldota91
League of Legends
singsing2834
Counter-Strike
Stewie2K998
x6flipin720
zeus536
Heroes of the Storm
Khaldor354
Other Games
Gorgc2758
B2W.Neo1336
DeMusliM533
Fuzer 418
Happy399
crisheroes376
Pyrionflax351
XaKoH 272
Hui .223
RotterdaM143
ArmadaUGS66
KnowMe53
ZerO(Twitch)17
Organizations
StarCraft: Brood War
CasterMuse 23
StarCraft 2
Blizzard YouTube
StarCraft: Brood War
BSLTrovo
sctven
[ Show 14 non-featured ]
StarCraft 2
• StrangeGG 33
• iHatsuTV 8
• AfreecaTV YouTube
• intothetv
• Kozan
• IndyKCrew
• LaughNgamezSOOP
• Migwel
• sooper7s
StarCraft: Brood War
• BSLYoutube
• STPLYoutube
• ZZZeroYoutube
Dota 2
• WagamamaTV771
• Ler41
Upcoming Events
BSL: ProLeague
5h 14m
Dewalt vs Bonyth
Replay Cast
1d 11h
Sparkling Tuna Cup
1d 21h
WardiTV European League
2 days
The PondCast
2 days
Replay Cast
3 days
RSL Revival
3 days
ByuN vs SHIN
Clem vs Reynor
Replay Cast
4 days
RSL Revival
4 days
Classic vs Cure
FEL
5 days
[ Show More ]
RSL Revival
5 days
FEL
5 days
FEL
6 days
Sparkling Tuna Cup
6 days
RSL Revival
6 days
Liquipedia Results

Completed

BSL 2v2 Season 3
HSC XXVII
Heroes 10 EU

Ongoing

JPL Season 2
BSL Season 20
Acropolis #3
KCM Race Survival 2025 Season 2
CSL 17: 2025 SUMMER
Copa Latinoamericana 4
Jiahua Invitational
Championship of Russia 2025
RSL Revival: Season 1
Murky Cup #2
BLAST.tv Austin Major 2025
ESL Impact League Season 7
IEM Dallas 2025
PGL Astana 2025
Asian Champions League '25
BLAST Rivals Spring 2025
MESA Nomadic Masters
CCT Season 2 Global Finals
IEM Melbourne 2025

Upcoming

2025 ACS Season 2: Qualifier
CSLPRO Last Chance 2025
2025 ACS Season 2
CSLPRO Chat StarLAN 3
K-Championship
uThermal 2v2 Main Event
SEL Season 2 Championship
FEL Cracov 2025
Esports World Cup 2025
StarSeries Fall 2025
FISSURE Playground #2
BLAST Open Fall 2025
BLAST Open Fall Qual
Esports World Cup 2025
BLAST Bounty Fall 2025
BLAST Bounty Fall Qual
IEM Cologne 2025
FISSURE Playground #1
TLPD

1. ByuN
2. TY
3. Dark
4. Solar
5. Stats
6. Nerchio
7. sOs
8. soO
9. INnoVation
10. Elazer
1. Rain
2. Flash
3. EffOrt
4. Last
5. Bisu
6. Soulkey
7. Mini
8. Sharp
Sidebar Settings...

Advertising | Privacy Policy | Terms Of Use | Contact Us

Original banner artwork: Jim Warren
The contents of this webpage are copyright © 2025 TLnet. All Rights Reserved.