1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-10-26 09:26:37 +00:00
openmw/components/misc
elsid 1e2aae8095
Use stable sort+unique to collect RefIDs for ESMStore records counting
The idea is to avoid std::map lookup for each CellRef. Instead generate a
sequence of added and removed RefNums into a vector then order them by RefNum
using a stable sort that preserves relative order of elements with the same
RefNum. RefIDs are stored in a different vector to avoid std::string move ctor
calls when swapping elements while sorting. Reversed iteration over added and
removed RefNums for each unique RefNum is an equivalent to what map-based
algorithm produces. The main benefit from sorting a vector is a data locality
that means less cache misses for each access. Reduces ESMStore::countRecords
perf cycles by 25%.
2021-05-15 18:45:22 +02:00
..
algorithm.hpp Use stable sort+unique to collect RefIDs for ESMStore records counting 2021-05-15 18:45:22 +02:00
barrier.hpp Do not store callback inside Misc::Barrier 2021-05-05 23:42:47 +02:00
budgetmeasurement.hpp Prevent physics death spiral by falling back to true delta time when needed 2021-03-21 20:45:46 +00:00
constants.hpp create constant and use constant in other parts of the code base 2021-03-24 14:54:46 -07:00
convert.hpp Add pathgrid to navmesh as off mesh connection 2020-06-12 21:04:02 +02:00
coordinateconverter.hpp Add pathgrid to navmesh as off mesh connection 2020-06-12 21:04:02 +02:00
endianness.hpp Add unit test for swapEndiannessInplace(). Part of Bug #5837 2021-02-09 13:09:36 -05:00
frameratelimiter.hpp Clean up MSVC warnings 2021-04-17 12:14:50 +04:00
guarded.hpp Wait until navmesh is generated for interior cells 2021-05-05 19:27:49 +02:00
hash.hpp clear up force shaders and make it less convoluted 2021-04-13 11:09:49 -07:00
helpviewer.cpp Add link to opencs documentation on readthedocs, available through 2020-04-18 20:54:21 +00:00
helpviewer.hpp Add link to opencs documentation on readthedocs, available through 2020-04-18 20:54:21 +00:00
mathutil.hpp Merge branch 'movement_refactoring' into 'master' 2020-08-27 11:54:30 +00:00
messageformatparser.cpp Implement 'g' flag 2018-08-13 20:31:11 +01:00
messageformatparser.hpp Implement 'g' flag 2018-08-13 20:31:11 +01:00
objectpool.hpp Use RAII for object ptr from pool 2020-07-04 01:15:27 +02:00
resourcehelpers.cpp Revert "Don't force DDS file usage (fixes #1392)" 2018-06-04 17:08:09 +02:00
resourcehelpers.hpp Add back resource handling workarounds to the gui code 2015-05-01 18:37:24 +02:00
rng.cpp Apply uniform random deviation to AI reaction timer 2021-03-20 14:47:54 +01:00
rng.hpp Apply uniform random deviation to AI reaction timer 2021-03-20 14:47:54 +01:00
stringops.hpp An attempt to fix the MSVC2017 build 2020-01-09 20:42:06 +04:00
thread.cpp Re-add dropped struct keyword to fix build. 2021-04-16 08:38:11 +02:00
thread.hpp Set idle priority for navmesh generation thread 2021-04-14 21:39:06 +02:00
timer.hpp Apply uniform random deviation to AI reaction timer 2021-03-20 14:47:54 +01:00
utf8stream.hpp Use utf8 lowercase function for journal index to avoid code duplication 2018-05-24 12:53:06 +04:00
weakcache.hpp Move WeakCache to components/misc 2018-09-28 16:47:47 +04:00