Fast way of Selecting Indices from Numpy ArrayHow to randomly select an item from a list?Is there a NumPy function to return the first index of something in an array?How to print the full NumPy array, without truncation?Numpy array dimensionsDump a NumPy array into a csv fileHow do I get indices of N maximum values in a NumPy array?Select rows from a DataFrame based on values in a column in pandasExecution time difference in matrix multiplication caused by parenthesesComparing zip operation with pandas slice operationWhy is Cython so much slower than Numba when iterating over NumPy arrays?

Which one is correct as adjective “protruding” or “protruded”?

How can Trident be so inexpensive? Will it orbit Triton or just do a (slow) flyby?

Non-trope happy ending?

When were female captains banned from Starfleet?

Fear of getting stuck on one programming language / technology that is not used in my country

250 Floor Tower

Not using 's' for he/she/it

Electoral considerations aside, what are potential benefits, for the US, of policy changes proposed by the tweet recognizing Golan annexation?

Calculating Wattage for Resistor in High Frequency Application?

Problem with TransformedDistribution

Is it improper etiquette to ask your opponent what his/her rating is before the game?

Is there a single word describing earning money through any means?

Does a 'pending' US visa application constitute a denial?

What should you do if you miss a job interview (deliberately)?

A social experiment. What is the worst that can happen?

Is it possible to have a strip of cold climate in the middle of a planet?

WiFi Thermostat, No C Terminal on Furnace

Yosemite Fire Rings - What to Expect?

How to implement a feedback to keep the DC gain at zero for this conceptual passive filter?

Longest common substring in linear time

Why Shazam when there is already Superman?

The IT department bottlenecks progress. How should I handle this?

Why is it that I can sometimes guess the next note?

Why did the Mercure fail?



Fast way of Selecting Indices from Numpy Array


How to randomly select an item from a list?Is there a NumPy function to return the first index of something in an array?How to print the full NumPy array, without truncation?Numpy array dimensionsDump a NumPy array into a csv fileHow do I get indices of N maximum values in a NumPy array?Select rows from a DataFrame based on values in a column in pandasExecution time difference in matrix multiplication caused by parenthesesComparing zip operation with pandas slice operationWhy is Cython so much slower than Numba when iterating over NumPy arrays?













0















I have a large array, X, out of which I must select interesting indices, as below. X is 60000 x 784. I'm wasting about a second running this at every call during a loop.



%timeit subX = X[:,indices]
890 ms ± 23.6 ms per loop (mean ± std. dev. of 7 runs, 1 loop each)


How can I access my array faster? indices is a list and can range from 500 numbers to 784.










share|improve this question






















  • Changing the array order to F order might help

    – busybear
    Mar 8 at 4:45











  • @busybear can you please elaborate?

    – saad
    Mar 8 at 4:46






  • 1





    In F order, the array is stored in memory with the first axis as contiguous data. Since you are accessing the entire first axis (column), it may be more efficient to have the data stored in this fashion--so it's not jumping around the memory space to retrieve data. The documentation will give a more thorough explanation. Not sure how much (or if) you'll get a performance boost with this though. Worth trying.

    – busybear
    Mar 8 at 4:50







  • 1





    @busybear just tried it. Down to 230ms!

    – saad
    Mar 8 at 4:57











  • Nice! That's a decent boost. You do have a lot of data so it's going to be hard to avoid having some slow down.

    – busybear
    Mar 8 at 5:03















0















I have a large array, X, out of which I must select interesting indices, as below. X is 60000 x 784. I'm wasting about a second running this at every call during a loop.



%timeit subX = X[:,indices]
890 ms ± 23.6 ms per loop (mean ± std. dev. of 7 runs, 1 loop each)


How can I access my array faster? indices is a list and can range from 500 numbers to 784.










share|improve this question






















  • Changing the array order to F order might help

    – busybear
    Mar 8 at 4:45











  • @busybear can you please elaborate?

    – saad
    Mar 8 at 4:46






  • 1





    In F order, the array is stored in memory with the first axis as contiguous data. Since you are accessing the entire first axis (column), it may be more efficient to have the data stored in this fashion--so it's not jumping around the memory space to retrieve data. The documentation will give a more thorough explanation. Not sure how much (or if) you'll get a performance boost with this though. Worth trying.

    – busybear
    Mar 8 at 4:50







  • 1





    @busybear just tried it. Down to 230ms!

    – saad
    Mar 8 at 4:57











  • Nice! That's a decent boost. You do have a lot of data so it's going to be hard to avoid having some slow down.

    – busybear
    Mar 8 at 5:03













0












0








0








I have a large array, X, out of which I must select interesting indices, as below. X is 60000 x 784. I'm wasting about a second running this at every call during a loop.



%timeit subX = X[:,indices]
890 ms ± 23.6 ms per loop (mean ± std. dev. of 7 runs, 1 loop each)


How can I access my array faster? indices is a list and can range from 500 numbers to 784.










share|improve this question














I have a large array, X, out of which I must select interesting indices, as below. X is 60000 x 784. I'm wasting about a second running this at every call during a loop.



%timeit subX = X[:,indices]
890 ms ± 23.6 ms per loop (mean ± std. dev. of 7 runs, 1 loop each)


How can I access my array faster? indices is a list and can range from 500 numbers to 784.







python numpy indexing






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Mar 8 at 4:42









saadsaad

622927




622927












  • Changing the array order to F order might help

    – busybear
    Mar 8 at 4:45











  • @busybear can you please elaborate?

    – saad
    Mar 8 at 4:46






  • 1





    In F order, the array is stored in memory with the first axis as contiguous data. Since you are accessing the entire first axis (column), it may be more efficient to have the data stored in this fashion--so it's not jumping around the memory space to retrieve data. The documentation will give a more thorough explanation. Not sure how much (or if) you'll get a performance boost with this though. Worth trying.

    – busybear
    Mar 8 at 4:50







  • 1





    @busybear just tried it. Down to 230ms!

    – saad
    Mar 8 at 4:57











  • Nice! That's a decent boost. You do have a lot of data so it's going to be hard to avoid having some slow down.

    – busybear
    Mar 8 at 5:03

















  • Changing the array order to F order might help

    – busybear
    Mar 8 at 4:45











  • @busybear can you please elaborate?

    – saad
    Mar 8 at 4:46






  • 1





    In F order, the array is stored in memory with the first axis as contiguous data. Since you are accessing the entire first axis (column), it may be more efficient to have the data stored in this fashion--so it's not jumping around the memory space to retrieve data. The documentation will give a more thorough explanation. Not sure how much (or if) you'll get a performance boost with this though. Worth trying.

    – busybear
    Mar 8 at 4:50







  • 1





    @busybear just tried it. Down to 230ms!

    – saad
    Mar 8 at 4:57











  • Nice! That's a decent boost. You do have a lot of data so it's going to be hard to avoid having some slow down.

    – busybear
    Mar 8 at 5:03
















Changing the array order to F order might help

– busybear
Mar 8 at 4:45





Changing the array order to F order might help

– busybear
Mar 8 at 4:45













@busybear can you please elaborate?

– saad
Mar 8 at 4:46





@busybear can you please elaborate?

– saad
Mar 8 at 4:46




1




1





In F order, the array is stored in memory with the first axis as contiguous data. Since you are accessing the entire first axis (column), it may be more efficient to have the data stored in this fashion--so it's not jumping around the memory space to retrieve data. The documentation will give a more thorough explanation. Not sure how much (or if) you'll get a performance boost with this though. Worth trying.

– busybear
Mar 8 at 4:50






In F order, the array is stored in memory with the first axis as contiguous data. Since you are accessing the entire first axis (column), it may be more efficient to have the data stored in this fashion--so it's not jumping around the memory space to retrieve data. The documentation will give a more thorough explanation. Not sure how much (or if) you'll get a performance boost with this though. Worth trying.

– busybear
Mar 8 at 4:50





1




1





@busybear just tried it. Down to 230ms!

– saad
Mar 8 at 4:57





@busybear just tried it. Down to 230ms!

– saad
Mar 8 at 4:57













Nice! That's a decent boost. You do have a lot of data so it's going to be hard to avoid having some slow down.

– busybear
Mar 8 at 5:03





Nice! That's a decent boost. You do have a lot of data so it's going to be hard to avoid having some slow down.

– busybear
Mar 8 at 5:03












0






active

oldest

votes











Your Answer






StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");

StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);

else
createEditor();

);

function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);



);













draft saved

draft discarded


















StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55056848%2ffast-way-of-selecting-indices-from-numpy-array%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown

























0






active

oldest

votes








0






active

oldest

votes









active

oldest

votes






active

oldest

votes















draft saved

draft discarded
















































Thanks for contributing an answer to Stack Overflow!


  • Please be sure to answer the question. Provide details and share your research!

But avoid


  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.

To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55056848%2ffast-way-of-selecting-indices-from-numpy-array%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

Identity Server 4 is not redirecting to Angular app after login2019 Community Moderator ElectionIdentity Server 4 and dockerIdentityserver implicit flow unauthorized_clientIdentityServer Hybrid Flow - Access Token is null after user successful loginIdentity Server to MVC client : Page Redirect After loginLogin with Steam OpenId(oidc-client-js)Identity Server 4+.NET Core 2.0 + IdentityIdentityServer4 post-login redirect not working in Edge browserCall to IdentityServer4 generates System.NullReferenceException: Object reference not set to an instance of an objectIdentityServer4 without HTTPS not workingHow to get Authorization code from identity server without login form

2005 Ahvaz unrest Contents Background Causes Casualties Aftermath See also References Navigation menue"At Least 10 Are Killed by Bombs in Iran""Iran"Archived"Arab-Iranians in Iran to make April 15 'Day of Fury'"State of Mind, State of Order: Reactions to Ethnic Unrest in the Islamic Republic of Iran.10.1111/j.1754-9469.2008.00028.x"Iran hangs Arab separatists"Iran Overview from ArchivedConstitution of the Islamic Republic of Iran"Tehran puzzled by forged 'riots' letter""Iran and its minorities: Down in the second class""Iran: Handling Of Ahvaz Unrest Could End With Televised Confessions""Bombings Rock Iran Ahead of Election""Five die in Iran ethnic clashes""Iran: Need for restraint as anniversary of unrest in Khuzestan approaches"Archived"Iranian Sunni protesters killed in clashes with security forces"Archived

Can't initialize raids on a new ASUS Prime B360M-A motherboard2019 Community Moderator ElectionSimilar to RAID config yet more like mirroring solution?Can't get motherboard serial numberWhy does the BIOS entry point start with a WBINVD instruction?UEFI performance Asus Maximus V Extreme