I am implementing a Monte Carlo Tree Search algorithm in C++. I create one huge tree at a time in a for loop, a different one at each iteration. My problem is that each tree is vast and if i create 12000 trees, my program crashes because all available memory in the PC is allocated.
The thing is, that the tree that i create in the iteration 5 for example, is useless in the next iterations, so i would like to free the memory it has allocated. I create each node as std::make_shared<Node<T, A, E> where Node is a class that i have created, and the tree as an instance of a class mcts = MCTS(laneFreeState(state), backpropagation, terminationCheck,scoring)
Huge memory usage in C++ MCTS algorithm
255 Views Asked by pandy giankoulidis At
1
There are 1 best solutions below
Related Questions in C++
- How to immediately apply DISPLAYCONFIG_SCALING display scaling mode with SetDisplayConfig and DISPLAYCONFIG_PATH_TARGET_INFO
- Why can't I use templates members in its specialization?
- How to fix "Access violation executing location" when using GLFW and GLAD
- Dynamic array of structures in C++/ cannot fill a dynamic array of doubles in structure from dynamic array of structures
- How do I apply the interface concept with the base-class in design?
- File refuses to compile std::erase() even if using -std=g++23
- How can I do a successful map when the number of elements to be mapped is not consistent in Thrust C++
- Can std::bit_cast be applied to an empty object?
- Unexpected inter-thread happens-before relationships from relaxed memory ordering
- How i can move element of dynamic vector in argument of function push_back for dynamic vector
- Brick Breaker Ball Bounce
- Thread-safe lock-free min where both operands can change c++
- Watchdog Timer Reset on ESP32 using Webservers
- How to solve compiler error: no matching function for call to 'dmhFS::dmhFS()' in my case?
- Conda CMAKE CXX Compiler error while compiling Pytorch
Related Questions in HEAP-MEMORY
- Why can I not increase my Java heap space?
- How to throw an error when a program acesses a block of memory created by you that has been deallocated by a call of free?
- Does CLR add overhead fields to type which value is null?
- ApplicationInsights high memory usage
- Why does process memory grow in .Net, but managed heap size does not change?
- Javascript heap memory
- corruption memory on heap only when using one specific function
- Why when I reserve less memory in assembly .bss section it doesn't segfault until I reserve 0?
- Security scan flagged local variable for heap inspection in C Function
- Breadth First Search Causing Heap Memory Error With exponentially growing graph
- pointers from heap and instances from stack C++
- Tomcat memory utilization on Docker Containers
- How to read large file and avoid java.lang.OutOfMemoryError?
- how to return an array of struct pointers?
- Unsure how to declare and then access an int array in heap memory
Related Questions in MONTE-CARLO-TREE-SEARCH
- Optimize a function that analyses a String
- Quasi Best-First (QBF) for opening book generation with Monte Carlo Tree Search (MCTS)
- Monte Carlo simulation - implementing the uct select function
- Visit count in MCTS search keeps being zero
- How is Monte Carlo Tree Search Implemented
- MCTS backpropagation with alpha-beta estimation
- The Monte Carlo Tree Search implementation. To the Othello
- In MCTS, is choosing the node with most visits equivalent to choosing the node with the highest expected value?
- Chess Bot not playing to expected level - Monte Carlo Tree Search
- Simulation in R (loop for)
- How to fix my MCTS-based AI for the Blokus game?
- Explaining the red elements with BS that appear when training my Keras model
- Monte-carlo search tree with hidden information
- Monte carlo tree search keeps getting stuck in an infinite loop when playing (as opposed to training)
- When should a monto carlo tree search be reset?
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
Popular # Hahtags
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
The call to
std::make_sharedis usingnewto allocate memory on the heap. So when you finish using the tree, just recursively iterate it, deleting the nodes as you go (deepest first, then work backwards).