processor use only 13% when excuting function/script

2 views (last 30 days)
Hello,
I am calculating spread pattern of quite a large amount of projectiles. When I run the full model it take more than 1600 sec cpu time ( profiler info) This is actually quite long since I need to test a lot different setting.
I am using R2012a win 64 version and I have a 8GB ram with Intel® Core™i7QM CPU @2.2Ghz with window 7 professional.(HP Elitebook 8560w)
Now I don't know much about 'using different cores of the CPU' but I can see that there are 8 cores and the total CPU use does not exceed 12-13%, since 100%/8 is 13% it seems like only 1 core is used? Is that correct and if yes, can I do something to make all cores working? or any other action? It seems lile only 1/8 of my computer is used
thanks for any help regards,Jürgen

Accepted Answer

Walter Roberson
Walter Roberson on 15 Aug 2012
Some call patterns, when operating on "large enough" data (size can depend on the exact pattern), will call LAPACK or BLAS to do the work. Both of those libraries are highly optimized and multithreaded even without the Parallel Processing Toolbox.
Call patterns that do not happen to match the ones handled by the libraries, or if the data is not "big enough", are handled single processor unless the Parallel Processing Toolbox is used (and parallel processing is requested.)
The Parallel Processing Toolbox allows explicit requests for parallelization; code (at some level!) has to be written specially to use it. There are several facilities in the PCT, to allow the code to be broken up in different ways. But MATLAB will not just "figure out for itself" which parallel processing to use: it has to be coded in. Sometimes the changes might be quite small, but sometimes the code changes might be extensive.
  8 Comments
Walter Roberson
Walter Roberson on 17 Aug 2012
In such a case, you should be able to use parfor() or distributed arrays, I suspect.
Jürgen
Jürgen on 17 Aug 2012
okay thanks, I'll take a look at the price :-) but anyway for the coming period all except that I will have to wait while the programm is executing, one way I tried is to open a second time matlab and write new code and testing while the other application is do his thing.

Sign in to comment.

More Answers (1)

per isakson
per isakson on 15 Aug 2012
Basically, Matlab uses one core, which explains 12-13%. (Single threaded.)
Some Matlab functions use several cores.
Parallel Toolbox is needed to use all 8 cores.
  3 Comments
Friedrich
Friedrich on 16 Aug 2012
No it isn’t. It’s the same.
Consider I am offer you:
a.) 10% of 100 dollar
b.) 25% of 40 dollar
Which one would you choose? It doesn’t matter because it’s the same(10 dollar in both cases)
It doesn’t matter if you use 25% of 4 Cores (which is basically one core) or if you use 12-13% of 8 cores (which is also one core)
If one would follow your logic, the best would be using 1 Core CPU because then you use 100% of your capacity. But thats not what you want.
Jürgen
Jürgen on 17 Aug 2012
interesting, okay that way you are right but I saw it different: I know have a quite new laptop with a good processor, let's say a 100 dollar processor to stay in your example, but I can use only 12.5% so 12.5 dollar is used, but my older computer with a 50 dollar processor and only dual core will use 50% or 25 dollar, I mean, habing a super processor that has only 1/8 use, can by less effective than a poor pr0cessor used on 50%, no??

Sign in to comment.

Categories

Find more on Resizing and Reshaping Matrices in Help Center and File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!