In addition to Weibo, there is also WeChat
Please pay attention
WeChat public account
Shulou
2025-02-22 Update From: SLTechnology News&Howtos shulou NAV: SLTechnology News&Howtos > IT Information >
Share
Shulou(Shulou.com)11/24 Report--
The original title: "give me a physics engine, I can also" predict "the World Cup? "
The World Cup is in full swing, and who will win the Hercules Cup has become a favorite topic in every World Cup. Many professional institutions are not willing to lag behind, one after another use their own professional models and data for analysis, and give the odds of each team winning the championship. But have you ever thought that you can "predict" the World Cup at home without 998, as long as you have a physics engine?
Hercules Cup | Tu Yuan FIFA World Cup Trophy-Wallpapers Den this prediction is not the other prediction. You must have guessed that the editor's next introduction is neither the "immortal beast" prediction like Paul the octopus, nor the mysterious data analysis of professional forecasting institutions. Next, the editor will lead the students into the interactive version of the World Cup Forecast World Cup 😎 under the era of the Universe.
Octopus Paul | Tuyuan www.wbur.org I don't know how many students know such a sentence: "Welcome to Live Football 8, the international version of the game world" 🤔 Live 8, I believe it is a whole generation of football game tricks, like the editor also used to build their own "dream team", to gallop the world arena, won trophies.
Welcome to the game world of Live Football 8 International Edition | the editor of Picture Source Live Football 8 International Chinese commentary Edition will take another exam. how many students know about Laplace demon? This is a demon who accurately knows the position and momentum of all atoms in the universe and is adept at using Newton's laws. He can accurately deduce history and predict the future through the laws of mechanics.
D é mon de Laplace | Tu Yuan www.etsy.com read here, I believe the students have been able to guess: if there is such a football game, which can truly restore all the physical composition of each game, including the field, football and the physical condition and mental decisions of the players on both sides, then we will become the "Laplace demon" of this game. And can simulate the game to give an accurate prediction of the real game results.
If we open our minds a little bit bigger, we can even set up an AI that can "evolve" for both sides of the game, and let them fight each other constantly, and evolve themselves through the computer's own "left and right struggle", so as to screen out the strongest football tactics, which in turn helps the team to be invincible in reality.
Fight between left and right | Tuyuan mobile phone Sohu (sohu.com) and no matter whether the above dark magic can really be realized or not, it is undeniable that today's football games are really realistic, regardless of all kinds of weird football ballistics to the expressions and costumes of characters, are no different from reality under the rendering of the game light and shadow. However, I wonder if the students have ever wondered why the games in the computer can reproduce the football match so vividly and let the players feel the real technical movements and reactions of the players. Next, let the editor lead you into the physics engine world behind the football game, 🧐.
The reality, the FIFA, and then the reality eight that the editor of the physics engine played at that time was roughly like this:
Qizu | the image source malavida.com is visible, but its character shape is still a little "rusty", and the grass behind is more like a simple piece of shoddy map 🤣. Let's take a look at the game scenarios in recent years (take FIFA22 as an example):
FIFA 22 | is the image source EA SPORTS both real and cool? Now the reason why games can bring such a real experience is inseparable from the support of the game engine behind it.
The game engine used in FIFA22 is the famous Frost engine:
Frost engine | Source USgamer, as the most basic physical part of the frost engine, is the Havok physics engine [1]:
Havok engine | Image source Attack of the Fanboy which supports many simulations of physical phenomena in real life and makes the movements of characters more realistic through continuous technical iterations.
Havok engine demo | Picture Source [Game Lab] bilibili, which has been applied to many 3A masterpieces, such as:
Some games with Havok engine, how many can you recognize? | Tu Yuan Havok and the game engine, as its name implies, is like the engine of a game, which is the core component of a game. Games such as football rolling, players' confrontations and collisions are all based on the physical part of the game: the physics engine. At the bottom of the physics engine, it also contains full principles of hard core physics. Students might as well follow the editor to watch and play the "hardest" World Cup. 😎
Physics engine: rigid body dynamics, collision detection and constraints a mature physics engine, its core mainly includes the following three parts [2]:
1. Rigid body dynamics part
two。 Collision detection part
3. Constraint part
Through the above three processes, the physics engine can iterate and calculate the position and speed information of each object using a loop shown in the following figure. When the iteration speed is fast enough and the iteration result is accurate enough, the motion of the object displayed on the screen can be called "lifelike".
The core loop in the physics engine updates the information of the object through a series of iterative calculations that conform to the laws of physics, thus making the game world lifelike.
Next, let the editor introduce you one by one.
Rigid body dynamics first of all, to let the computer know where and what kind of object exists in the game scene, and how it moves, we need to find a suitable way to describe the shape, position, speed and so on. In the process of modeling, a complex object can often be regarded as a combination of many relatively simple rigid bodies. As a building blocks, we first examine rigid body dynamics.
A typical rigid body | Image source [3] rigid body (rigid body) is defined as an object whose shape becomes zero, and the distance between any two points on it, no matter how the rigid body moves, is constant [3]. In high school physics, it is believed that students have studied the kinematics of particles, which is described by Newton's three laws [4]:
Newton's three laws
Inspired by particle kinematics, in the study of rigid body kinematics, we also try to learn from the successful experience in describing particles and further expand them in order to correctly describe a rigid body with shape and volume. In view of the fact that a rigid body moves as a whole, we can first define its centroid:
Centroid
Among them, the sum corresponds to the discrete distribution of the mass of the rigid body, while the integral corresponds to the rigid body of the continuous mass distribution.
As the name implies, the center of mass is the center of the mass of a rigid body, and all the dynamic properties related to the translation of the rigid body can be replaced by the center of mass. The centroid also has many interesting properties, such as the following picture, if the centroid of a toy bird happens to be designed in the mouth, one can hold it up with one finger without tipping it over.
A small toy made of centroid characteristics | Image Source [5] but at the same time, because a rigid body can be regarded as a collection of a series of particles and has a certain distribution in space, it is not enough to use centroids to describe its dynamic characteristics. we also need to study the rotation of the rigid body.
In order to study the rotation of the rigid body, first make clear the following conventions and marks [6]: as shown in the following figure, it is assumed that XYZ is the laboratory coordinate system in which we observe (fixed coordinate system), while x1x2x3 is fixed on the rigid body and translates and rotates together (called dynamic coordinate system). Some conventions in the figure are as follows:
Convention and mark
Then any infinitesimal displacement of the rigid body:
Can be expressed as an infinitesimal translation along with its center of mass
And an infinitesimal rotation around the origin of the moving coordinate system
Sum:
Infinitesimal displacement of rigid body
In this way, the position of any point on the rigid body can be easily described by us. Next, we derive the above expression item by term to examine the velocity of each point on the rigid body:
They are the velocity of a certain point on the rigid body for the fixed coordinate system, the translational velocity of the rigid body center and the rotational angular velocity of the rigid body. Thus it can be seen that the velocity of any point on a rigid body can be decomposed by the translational velocity and angular velocity of the rigid body:
The following is to study the force and motion equation of the rigid body: first, deal with the translational part and assume that the total mass of the rigid body is
There are
Furthermore, there is an equation of motion of rigid body translation:
The equation of motion of rigid body translation
This is consistent with the equation of motion of the particle, and this result once again verifies the rationality of using the center of mass to describe the translation of the rigid body.
In order to describe the equation of motion of rotation, the moment of inertia tensor of a rigid body is defined.
Moment of inertia tensor
The above formula corresponds to the discrete case, for the continuous mass distribution, each component only needs to be replaced by the following integral:
Furthermore, the intrinsic angular momentum of a rigid body can be defined.
You might as well choose the inertial reference frame so that the velocity of the rigid body center in the reference frame is 0 (which can always be done), and define the total torque of the rigid body.
Then there is the equation of motion of the rotational part of the rigid body:
Equation of motion of rigid body rotation
Collision detection now we already know how to describe the position and motion of a rigid body, but there are usually a lot of objects in the game scene, according to the usual intuition of the physical world, if two objects are moving toward each other, it is bound to collide and bounce off at some point. In the physics engine, there is a special collision detection algorithm to deal with this problem.
Generally, the collision detection of objects is divided into two stages, the first part is the rough Broad-Phase part, and the second part is the more detailed Narrow-Phase part. First of all, take a look at Broad-Phase detection [7]:
In Broad-Phase detection, it is to roughly estimate whether two objects are likely to collide, so as to reduce the workload for later Narrow-Phase detection. First, define the Bounding Volume of an object [8]: the volume of the smallest box that can completely enclose the object.
The most commonly used Bounding Volume methods are AABB (axis-aligned bounding boxes), OBB (oriented bounding boxes), and Bounding Circle/Sphere, which are shown in the following figure:
Among the three commonly used Bounding, the most commonly used and the most resource-saving one is the first, AABB. In this Bounding mode, to judge whether two objects may collide, we only need to detect whether the cuboids surrounding the two objects are likely to collide, thus turning the pre-detection of the collision of irregular objects into the detection of coincidence between regular cuboids.
When detecting whether there is a collision, the Sweep and Prune method [9] is usually used. Its main idea is as follows: under the AABB method, the two ends of the length occupied by each object are marked as (bfocus e) on each axis, as shown in the following figure, taking the x axis as an example:
The Sweep and Prune method marks the boundaries of three objects under the AABB method on the coordinate axes, and produces three (bline e) pairs:
Thus, for any two objects I and j, if one of the following inequalities is determined to be true:
That is, it is determined that the two objects are likely to collide (about to or have already been).
For example, the grapes and football on the top are satisfied.
This inequality, as can be seen from the figure, does coincide with the projection of the two objects on the x-axis.
After the Broad-Phase test, we have selected all the possible collision pairs, and only need to conduct a more detailed Narrow-Phase test for these pairs, which are briefly described as follows:
First of all, to investigate the concavity and convexity of an object, because the convex polyhedron has more convenient characteristics of collision detection, so we expect to use more convex polyhedron to approximate the actual physical object.
A convex polyhedron can be defined as a polyhedron in which the line segments connected by any two points in a geometric body fall in the geometric body. On the contrary, the concave polyhedron has a two-point connection of the geometry, which can not be completely contained in the geometry.
Convex polyhedron and concave polyhedron can be seen, and convex polyhedron has more regular shape than concave polyhedron, which is part of the reason why convex polyhedron can better judge whether collision occurs in practical calculation. But fortunately, through the Quickhull algorithm [10], we can easily generate convex polyhedron approximation of any concave polyhedron:
Quickhull algorithm indicates | Image Source [10] now the problem we face is simplified to how to carefully judge whether two convex polyhedrons collide or not. One intuitive idea is to judge the contours of two objects point by point, whether there is a point of one polygon surrounded by all the boundary points of another polygon. However, in the actual physics engine, a more optimized calculation method is usually used to balance the calculation cost. One of the more convenient methods is called Separating Axis Theorem (SAT), and its basic principle is [11]: for two convex polyhedrons, the condition that they do not intersect is that there is a straight line, so that the projections on the line do not intersect.
The SAT algorithm shows that, for example, in the hexagon and trapezoid above, there is a projection axis (Axis) on which the two projections do not intersect, then determine that the two objects do not collide, which is also consistent with direct intuitive cognition.
Now that we know how to determine whether two objects collide or not, what happens after the collision if two objects collide? Let's take particle collisions as an example to illustrate how the physics engine handles collisions.
The collision can be divided into elastic collision and inelastic collision (including completely inelastic collision and partial elastic collision). First of all, looking at the elastic collision, for the elastic collision of two ideal spheres, the momentum and energy are conserved in the process. If the mass is M1 and m2, the initial velocity is U1 and U2, and the velocity after collision is v1 and v2, then there is [12]:
For inelastic collisions, define the recovery coefficient
Recovery coefficient
There is a post-collision speed:
It can be seen that a recovery coefficient of 0 corresponds to a completely inelastic collision, while a recovery coefficient of 1 corresponds to a complete elastic collision. The recovery coefficient is usually related to the material and physical properties of the two colliding objects, which is an empirical parameter and needs to be set separately between the two objects.
Here, how two objects in the physics engine determine whether they collide or not, and how they continue to evolve after a collision, has been figured out in at least one feasible way. But just knowing the above is not enough to complete a complete physics engine, because in the real physical world, there are constraints everywhere [15], such as a small block sliding down a slope, it must keep itself on the slope in the course of motion, and cannot suddenly penetrate the slope or fly into the sky.
Small blocks on the slope, force analysis and constraints | Source [15] Let's take a look at the constraints used in the physics engine.
Constraints can be seen from the above discussion, constraints usually mean real physical restrictions on the position and speed of objects, so that there will not be abnormal, counterintuitive phenomena (such as the occasional bug in the game, that is, the constraint does not calculate the 🤣)
A case of constraint calculation failure | Image source baidu.com so, in the physics engine, how are constraints calculated? Let's use a simple example to illustrate:
For example, for a small ball in a bowl, we release the ball from the edge of the bowl and make it move freely in the bowl.
Come to the bowl quickly 😋 simplify the inner wall of the bowl to a hemispherical surface, set its radius to R, and simplify the ball to a particle, then it is not difficult to get the following constraints:
It means that the distance from the ball to the origin O of the coordinate system above is always the radius of the bowl, which corresponds to the physical reality that the ball is constrained to the bowl wall.
Next, write the above constraints in a more formal form:
Among them, C (r) is called constraint equation, which is equivalent to the above constraint condition. The accurate description of the object is obtained by combining the constraint equation with the kinematics equation at the beginning. In the part of solving the constraints of the physics engine, it is necessary to modify the configuration that violates the constraints in the process of calculation, usually by introducing a binding force artificially to ensure that there is no unreasonable game situation in the end. (mom doesn't have to worry about my mold anymore, 😗.)
Finally. I believe that through the above study, students must have a more basic understanding of physics engine 🤔, but of course, just like birds flying do not need to understand aerodynamics, students do not need to know every principle of game engine to play games, but as one of the most widely spread forms of entertainment in the world today, the core of games: game engines, especially physics engines. But a large number of the most basic physical principles are applied. It is precisely because of the accurate description of the real world by the laws of physics that people are able to build a lifelike stage in the computer-built world, on which there are disputes among different countries, earthly adventures, passionate races, eagles hitting the sky, live football, and so on. But the editor also hopes that after reading this popular science article, when they open the reality 8 again in the future, they will more or less think of As the core support of the game, the laws of physics, its powerful power and its endless charm. As for the Laplace demon prediction at the beginning, there may still be a long way to go, but the idea of left-right wrestling has been used in a variety of scenarios, such as the famous Alpha Go Zero.
Finally, I hope that students can enjoy both the games and the endless charm of this World Cup, just as the theme song of the 1998 World Cup in France sang, "Here we go, ah, GOGOGO, ah," 👻.
Reference:
Slide up and read
[1]: frost engine _ Baidu Encyclopedia (baidu.com)
[2]: Video Game Physics Tutorial | Toptal
[3]: Rigid body-Wikipedia
[4]: Newton's Law of Motion (Law of Physics) _ Baidu Encyclopedia (baidu.com)
[5]: Center of mass-Wikipedia
[6]: Landau theoretical Physics course (Volume 01), Mechanics (5th Edition), Landau, Li Fosiz, Li Junfeng, Ju Guoxing, higher Education Press, 2007
[7]: Chapter 32. Broad-Phase Collision Detection with CUDA | NVIDIA Developer
[8]: Bounding volume-Wikipedia
[9]: Sweep and prune-Wikipedia
[10]: Quickhull-Wikipedia
[11]: Hyperplane separation theorem-Wikipedia
[12]: Elastic collision-Wikipedia
[13]: Coefficient of restitution-Wikipedia
[14]: Inelastic collision-Wikipedia
[15]: Constraint (classical mechanics)-Wikipedia
This article comes from the official account of Wechat: Institute of Physics, Chinese Academy of Sciences (ID:cas-iop), author: Callo
Welcome to subscribe "Shulou Technology Information " to get latest news, interesting things and hot topics in the IT industry, and controls the hottest and latest Internet news, technology news and IT industry trends.
Views: 0
*The comments in the above article only represent the author's personal views and do not represent the views and positions of this website. If you have more insights, please feel free to contribute and share.
Continue with the installation of the previous hadoop.First, install zookooper1. Decompress zookoope
"Every 5-10 years, there's a rare product, a really special, very unusual product that's the most un
© 2024 shulou.com SLNews company. All rights reserved.