Adding different sized/shaped displaced NumPy matrices
You just have to find the overlapping range, and then add the arrays using slicing.
b1 = np.zeros((4,5))
b2 = np.ones((4,3))
pos_v, pos_h = 2, 3 # offset
v_range1 = slice(max(0, pos_v), max(min(pos_v + b2.shape[0], b1.shape[0]), 0))
h_range1 = slice(max(0, pos_h), max(min(pos_h + b2.shape[1], b1.shape[1]), 0))
v_range2 = slice(max(0, -pos_v), min(-pos_v + b1.shape[0], b2.shape[0]))
h_range2 = slice(max(0, -pos_h), min(-pos_h + b1.shape[1], b2.shape[1]))
b1[v_range1, h_range1] += b2[v_range2, h_range2]
They're added in-place, but you could also create a new array. I might have missed some corner cases, though, but it seems to work fine.
Add submatrices at certain locations
The nice thing about array slicing in numpy is you don't need the for loops that you are using. Also the reason that it is only putting the center element is because you only put a single element there (c1[c1mid,c1mid] is a single number) here is what you could do:
z[7:12,7:12] = c1
z[7:12,27:32] = c2
z[26:33,6:14] = c3
z[25:34,25:33] = c4
Apply a function to two equally shaped numpy matrices
It seems your example is already in the docs, see the bottom of https://docs.scipy.org/doc/numpy-1.13.0/reference/generated/numpy.vectorize.html. So
import scipy.stats
pearsonr = np.vectorize(scipy.stats.pearsonr, signature='(n),(n)->(),()')
correlations = pearsonr(data["histograms"][0],regions_hist[0])
should work :)
Comparing matrices of different shapes
If I understand correctly, you are looking for the largest possible subarray that fits inside both A
and B
. You could just compare each dimension of A
and B
and take whichever is smallest:
def largest_subarray(A, B):
dims = np.minimum(A.shape, B.shape) # find smallest dimensions
idx = tuple(slice(None, dd) for dd in dims) # construct tuple of slice indices
return A[idx], B[idx] # index into A and B
For your example arrays it will return A[:3, :2], B[:3, :2]
.
Aligning two binary matrices for maximum overlap
To find the maximum overlap you can use the correlate2d
function from scipy:
import scipy
scipy.signal.correlate2d(a, b).max()
Or you can implement it from scratch using numpy (which is a little bit tricky):
import numpy as np
from numpy.lib.stride_tricks import as_strided
def max_overlap(a, b):
b_p = np.pad(b, ((a.shape[0]-1, a.shape[0]-1), (a.shape[1]-1, a.shape[1]-1)), 'constant', constant_values=0)
output_shape = (b_p.shape[0] - a.shape[0] + 1, b_p.shape[1] - a.shape[1] + 1)
b_w = as_strided(b_p, shape=output_shape + a.shape,
strides=b_p.strides*2)
c = (b_w * a).sum(axis=(2,3))
return c.max()
Is there a Rust ndarray equivalent for numpy arithmetic on a slice?
That can be done with the same two steps as those performed in Python: slicing, then add-assigning to a broadcast right-handed array.
use ndarray::Array2;
let mut a: Array2<f32> = Array2::zeros((100, 4));
{
let mut slice = a.slice_mut(s![20.., ..]);
slice += &ArrayView::from(&[1.0, 2.0, 3.0, 4.0]);
}
Slicing is done with slice_mut
and the s!
macro for defining the intended range.
The outcome of a slice is a mutable array view, and so, most operations seen in ArrayBase
are available, including arithmetic operations.
By broadcasting rules, a right-handed array of shape [4]
can be automatically broadcast to one of shape [100, 4]
for the +=
operator.
In case of other confusions in the transition from Python to Rust's ndarray
crate, the documentation contains a guide for Python users.
Related Topics
Replacing All Negative Values in Certain Columns by Another Value in Pandas
In Python, How to Split a String and Keep the Separators
Python Xlsxwriter Set Border Around Multiple Cells
How to Merge Columns from Multiple CSV Files Using Python
Check If Value from One Dataframe Exists in Another Dataframe
Datetime.Datetime Has No Attribute Datetime
How to Select All Elements Greater Than a Given Values in a Dataframe
How to Convert a 1 Channel Image into a 3 Channel With Opencv2
How Does \R (Carriage Return) Work in Python
How to Find Number of Ways That the Integers 1,2,3 Can Add Up to N
How to Split Image into Multiple Pieces in Python
Python Selenium, Find Out When a Download Has Completed
How to Check If Keras Is Using Gpu Version of Tensorflow