pandemonium_engine_docs/03_usage/17_performance/01_introduction.md

40 lines
1.8 KiB
Markdown
Raw Permalink Normal View History

2023-01-12 20:49:14 +01:00
2024-04-30 20:48:19 +02:00
# Optimization
2024-04-30 20:48:19 +02:00
## Introduction
2024-03-16 20:56:52 +01:00
Pandemonium follows a balanced performance philosophy. In the performance world,
there are always trade-offs, which consist of trading speed for usability
and flexibility. Some practical examples of this are:
- Rendering large amounts of objects efficiently is easy, but when a
large scene must be rendered, it can become inefficient. To solve this,
visibility computation must be added to the rendering. This makes rendering
less efficient, but at the same time, fewer objects are rendered. Therefore,
the overall rendering efficiency is improved.
- Configuring the properties of every material for every object that
needs to be rendered is also slow. To solve this, objects are sorted by
material to reduce the costs. At the same time, sorting has a cost.
- In 3D physics, a similar situation happens. The best algorithms to
handle large amounts of physics objects (such as SAP) are slow at
insertion/removal of objects and raycasting. Algorithms that allow faster
insertion and removal, as well as raycasting, will not be able to handle as
many active objects.
And there are many more examples of this! Game engines strive to be
general-purpose in nature. Balanced algorithms are always favored over
algorithms that might be fast in some situations and slow in others, or
algorithms that are fast but are more difficult to use.
2024-03-16 20:56:52 +01:00
Pandemonium is not an exception to this. While it is designed to have backends
swappable for different algorithms, the default backends prioritize balance and
flexibility over performance.
With this clear, the aim of this tutorial section is to explain how to get the
2024-03-16 20:56:52 +01:00
maximum performance out of Pandemonium. While the tutorials can be read in any order,
2023-01-12 19:29:11 +01:00
it is a good idea to start from `doc_general_optimization`.