Добавление измерения к каждому элементу numpy.array

Я пытаюсь преобразовать каждый элемент массива numpy в сам массив (скажем, чтобы интерпретировать изображение в оттенках серого как цветное изображение). Другими словами:

>>> my_ar = numpy.array((0,5,10))
[0, 5, 10]
>>> transformed = my_fun(my_ar)  # In reality, my_fun() would do something more useful
array([
      [ 0,  0, 0], 
      [ 5, 10, 15], 
      [10, 20, 30]])
>>> transformed.shape
(3, 3)

Я пробовал:

def my_fun_e(val):
    return numpy.array((val, val*2, val*3))

my_fun = numpy.frompyfunc(my_fun_e, 1, 3)

но получите:

my_fun(my_ar)
(array([[0 0 0], [ 5 10 15], [10 20 30]], dtype=object), array([None, None, None], dtype=object), array([None, None, None], dtype=object))

и я пробовал:

my_fun = numpy.frompyfunc(my_fun_e, 1, 1)

но получите:

>>> my_fun(my_ar)
array([[0 0 0], [ 5 10 15], [10 20 30]], dtype=object)

Это близко, но не совсем верно - я получаю массив объектов, а не массив int.

Обновление 3! ОК. Я заранее понял, что мой пример был слишком простым - я не просто хочу реплицировать свои данные в третьем измерении, я хотел бы преобразовать их одновременно. Может это понятнее?

Почему в Python есть оператор "pass"?
Почему в Python есть оператор "pass"?
Оператор pass в Python - это простая концепция, которую могут быстро освоить даже новички без опыта программирования.
Некоторые методы, о которых вы не знали, что они существуют в Python
Некоторые методы, о которых вы не знали, что они существуют в Python
Python - самый известный и самый простой в изучении язык в наши дни. Имея широкий спектр применения в области машинного обучения, Data Science,...
Основы Python Часть I
Основы Python Часть I
Вы когда-нибудь задумывались, почему в программах на Python вы видите приведенный ниже код?
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
Алиса и Боб имеют неориентированный граф из n узлов и трех типов ребер:
Оптимизация кода с помощью тернарного оператора Python
Оптимизация кода с помощью тернарного оператора Python
И последнее, что мы хотели бы показать вам, прежде чем двигаться дальше, это
Советы по эффективной веб-разработке с помощью Python
Советы по эффективной веб-разработке с помощью Python
Как веб-разработчик, Python может стать мощным инструментом для создания эффективных и масштабируемых веб-приложений.
5
0
4 774
4
Перейти к ответу Данный вопрос помечен как решенный

Ответы 4

Я предлагаю:

 numpy.resize(my_ar, (3,3)).transpose()

Вы, конечно, можете адаптировать форму (my_ar.shape[0],)*2 или что-то еще

Делает ли это то, что вы хотите:

tile(my_ar, (1,1,3))

Делает ли numpy.dstack то, что вы хотите? Первые два индекса совпадают с исходным массивом, а новый третий индекс - «глубина».

>>> import numpy as N
>>> a = N.array([[1,2,3],[4,5,6],[7,8,9]])
>>> a
array([[1, 2, 3],
       [4, 5, 6],
       [7, 8, 9]])
>>> b = N.dstack((a,a,a))
>>> b
array([[[1, 1, 1],
        [2, 2, 2],
        [3, 3, 3]],

       [[4, 4, 4],
        [5, 5, 5],
        [6, 6, 6]],

       [[7, 7, 7],
        [8, 8, 8],
        [9, 9, 9]]])
>>> b[1,1]
array([5, 5, 5])

Обратите внимание, что numpy.dstack явно работает с 3-м измерением. Он также поддерживается для обратной совместимости. Предпочтительно использование numpy.stack.

johndodo 20.05.2017 18:15
Ответ принят как подходящий

Используйте карту, чтобы применить вашу функцию преобразования к каждому элементу в my_ar:

import numpy

my_ar = numpy.array((0,5,10))
print my_ar

transformed = numpy.array(map(lambda x:numpy.array((x,x*2,x*3)), my_ar))
print transformed

print transformed.shape

Другие вопросы по теме