How to fully use the CPU of my PC?
147 visualizzazioni (ultimi 30 giorni)
Mostra commenti meno recenti
Jianwei Guo
il 24 Nov 2011
Risposto: Delprat Sebastien
il 24 Giu 2024
When matlab R2011b is running a program, it only use about 20% CPU. So I'm wondering how could I make it fully use the CPU and thus takes less time to finish the program. Is there an easy way to make this?
Risposta accettata
Daniel Shub
il 24 Nov 2011
This really depends on what you are doing. For some code MATLAB can only utilize a single core of a single processor, for other code, MATLAB will automatically utilize all available cores (and maybe processors). It really depends on the underlying functions. Some things cannot be easily parallelized. Sometimes you can help MATLAB with things like parfor loops. Other times you might need something like MPI. Still other times there really is nothing you can do.
0 Commenti
Più risposte (3)
Jan
il 24 Nov 2011
You do not have any influence on the usage. E.g. if Matlab waits for values from the RAM or the slow harddisk, the processor is on idle. If you have several processor cores, but your program works sequentially, only a few Matlab commands can use more than one core, e.g. FILTER (can somebody confirm this rumor?), MIN, MAX, SUM etc.
The best method to improve the speed is the optimization of the program. A missing pre-allocation can slow down a program tremendously and cause a partial idle of the processor, for example. You can use the profiler to find the bottlenecks and post them here.
5 Commenti
Daniel Shub
il 25 Nov 2011
I think to test this you probably want to start MATLAB with and without the singleCompThread flag.
Jan
il 5 Dic 2011
@Daniel: How could a FILTER operation for a single vector be multi-threaded? The values of each output frame depend on the complete history of the former filtered signal. Therefore I cannot imagine, how this can be distributed to multiple threads.
I expect, that the filtering of a [n x 2] signal needs approximately the same time as filtering two [n x 1] signals on a dual core machine.
Michael
il 25 Nov 2011
100% CPU load is not a test that your code is optimised! It is just a sign that the hardware bottleneck may be in your processor.
0 Commenti
Delprat Sebastien
il 24 Giu 2024
There are several answer to optimize code:
- Always prealocate vectors (do not let an array increase within a loop, prealocate the array before the loop)
- Vectorize expression as much as possible (i.e. avoid loops and "." operator to perform element-wise operation). Note that conditional logic can be efficiently implemented using logical indexes)
- Use parallel toolbox to take benefits for all the CPU core. Note that not all the algorithm can be paralelized. Basically, an algorithmn or part of it, can be parallelized if loops iterations can be run in any order.
- Finally, an "hardcore" optimization consists in assignin matlab to a single core and affecting all the other softwares to other core. This not easy and should only be used for some very specific application. The ratio benefits/trouble is usualy not in favor of this option
Using the profiler is a very good way to find code lines that take most time (and so that should be optimized in priority)
0 Commenti
Vedere anche
Categorie
Scopri di più su Fourier Analysis and Filtering in Help Center e File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!