mindspore/scripts/build
He Wei 41dcac9c49 Replace std::unordered_map/set with robin-hood-hashing
Robin-hood-hashing (https://github.com/martinus/robin-hood-hashing)
is considered faster then std::unordered_map/set,
so we use it to improve mindspore performance.

1. robin_hood head file in `third_party/robin_hood/include`;
2. In `utils/hash_map.h` and `utils/hash_set.h`, we define:
 - mindspore::HashMap as an alias of robin_hood::unordered_map;
 - mindspore::HashSet as an alias of robin_hood::unordered_set;
3. Replace:
 - `#include <unordered_map>` --> `#include "utils/hash_map.h"`;
 - `#include <unordered_set>` --> `#include "utils/hash_set.h"`;
 - `std::unordered_map` --> `mindspore::HashMap`;
 - `std::unordered_set` --> `mindspore::HashSet`;
 - `map.insert(std::pair(key, value))` --> `map.emplace(key, value)`;
 - `[] (const std::pair<K, V> &p) {..} ` --> `[] (const auto &p) {..} `;
4. Fix issues found by switch to robin_hood:
 - AnfNodeConfig hash and equal;
 - Fix a bug in `Slice::operator==()`;
 - Fix a bug in `CNode::HasPrimalAttr()`;
 - Fix map.erase() usage bugs: `map.erase(iter++)` --> `iter = map.erase(iter)`;
 - Fix some iterator invalidated problem;
5. Some std::unordered_map/set can not replace by robin_hood:
 - As parameter of functions that exposed to python by pybind11;
 - Use bad hash that cause robin_hood::map over_flow, such as AbstractBasePtrListHasher;
6. Update cpp unit tests;
7. Add build option '-F' to enable robin_hood, default on.
2021-11-24 10:47:40 +08:00
..
build_mindspore.sh Replace std::unordered_map/set with robin-hood-hashing 2021-11-24 10:47:40 +08:00
default_options.sh Replace std::unordered_map/set with robin-hood-hashing 2021-11-24 10:47:40 +08:00
option_proc_debug.sh split huge build.sh 2021-09-08 21:14:22 +08:00
option_proc_lite.sh split huge build.sh 2021-09-08 21:14:22 +08:00
option_proc_mindspore.sh Replace std::unordered_map/set with robin-hood-hashing 2021-11-24 10:47:40 +08:00
parse_device.sh GraphKernel supports CPU 2021-09-29 23:34:16 +08:00
process_options.sh Replace std::unordered_map/set with robin-hood-hashing 2021-11-24 10:47:40 +08:00
usage.sh Replace std::unordered_map/set with robin-hood-hashing 2021-11-24 10:47:40 +08:00