Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 9189361
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 17, 20262026-06-17T20:13:09+00:00 2026-06-17T20:13:09+00:00

Does the scope of a numpy ndarray function differently within a function called by

  • 0

Does the scope of a numpy ndarray function differently within a function called by multiprocessing? Here is an example:

Using python’s multiprocessing module I am calling a function like so:

for core in range(cores):
    #target could be f() or g()
    proc = mp.Process(target=f, args=(core))
    jobs.append(proc)
for job in jobs:
    job.start()
for job in jobs:
    job.join()

def f(core):
    x = 0
    x += random.randint(0,10)
    print x

def g(core):
    #Assume an array with 4 columns and n rows
    local = np.copy(globalshared_array[:,core])
    shuffled = np.random.permutation(local)

Calling f(core), the x variable is local to the process, ie. it prints a different, random integer as expected. These never exceed 10, indicating that x=0 in each process. Is that correct?

Calling g(core) and permuting a copy of the array returns 4 identically ‘shuffled’ arrays. This seems to indicate that the working copy is not local the child process. Is that correct? If so, other than using sharedmemory space, is it possible to have an ndarray be local to the child process when it needs to be filled from shared memory space?

EDIT:

Altering g(core) to add a random integer appears to have the desired effect. The array’s show a different value. Something must be occurring in permutation that is randomly ordering the columns (local to each child process) the same…ideas?

def g(core):
    #Assume an array with 4 columns and n rows
    local = np.copy(globalshared_array[:,core])
    local += random.randint(0,10)

EDIT II:
np.random.shuffle also exhibits the same behavior. The contents of the array are shuffling, but are shuffling to the same value on each core.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-17T20:13:10+00:00Added an answer on June 17, 2026 at 8:13 pm

    Calling g(core) and permuting a copy of the array returns 4 identically ‘shuffled’ arrays. This seems to indicate that the working copy is not local the child process.

    What it likely indicates is that the random number generator is initialized identically in each child process, producing the same sequence. You need to seed each child’s generator (perhaps throwing the child’s process id into the mix).

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

How does the Function Scope in JavaScript work?
I'm not sure I understand scope - does an out-of-scope variable (I'm using Ruby)
Does C have scope hiding? For example, if I have a global variable: int
Does SET IDENTITY_INSERT [Table] ON persist beyond the scope of a SQL Script? I'm
What is the scope of the exception object in C++? does it go out
I'm a novice. Does Jersey and EJB hold the same EntityManager scope? Should I
Why does the following code not allow foo(ptr) to be called ? #include <boost/scoped_ptr.hpp>
Does anyone have a translate function for x/y positions after rotation in javascript? for
ADF faces exposes a new scope(called pageflow ) in additon to to the normal
Is this ValueStore class threadsafe? Does the lock scope in GetInt(string key) need to

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.