Задать вопрос
Ответы пользователя по тегу NumPy
  • Что эффективнее: np.array_equal или (A == B).all()?

    Vindicar
    @Vindicar
    RTFM!
    Модуль timeit в руки и вперёд, измеряй

    >>> timeit.timeit(stmt='(A == B).all()', setup='import numpy; A, B = numpy.zeros((1000,)), numpy.zeros((1000,))', number=10_000_000)
    20.43348090001382
    >>> timeit.timeit(stmt='numpy.array_equal(A, B)', setup='import numpy; A, B = numpy.zeros((1000,)), numpy.zeros((1000,))', number=10_000_000)
    27.85776079981588
    >>>


    Правда, есть у меня уверенность, что A == B создаёт временный массив, так что это менее эффективно по памяти. А вот делает ли так array_equal() - не знаю.

    EDIT: открыл исходники функции...
    return builtins.bool((a1 == a2).all())
    Ну ты понел.
    Ответ написан
    5 комментариев
  • Как решить проблему с could not convert string to float?

    Vindicar
    @Vindicar
    RTFM!
    А с чего ты взял, что ты обрабатываешь только колонки mpg и weight? astype(float) ты применяешь ко всему датасету.
    Ты бы и сам догадался, если бы не пытался засунуть всю команду в однострочник - у тебя exception бы вылетел как раз на строке с astype().
    Ответ написан
    Комментировать
  • Как в numpy максимально быстро изменить структуру данных в массиве?

    Vindicar
    @Vindicar
    RTFM!
    CUDA тут не нужна, просто не следует перебирать массив numpy питоновскими циклами.
    Если есть возможность - выражай желаемое через операции над массивом в целом. Тогда цикл организует numpy, и он это делает через нативный код, ЕМНИП - работает в разы быстрее.
    Подход ниже сожрёт больше памяти, но зато короткий, выразительный и использует только средства numpy.
    image = cv2.imread("image.png")
    image = image.astype(numpy.uint32)  # смена типа нужна, иначе при сдвиге потеряются разряды
    image_clone = (image[..., 0] << 16) | (image[..., 1] << 8) | image[..., 2]

    Если хочется заморочиться по памяти:
    image = cv2.imread("image.png")
    image_clone = numpy.zeros(image.shape[:2], numpy.uint32)
    # краткие формы операций не создают новый массив, а изменяют существующий по месту
    image_clone |= image[..., 0]
    image_clone <<= 8
    image_clone |= image[..., 1]
    image_clone <<= 8
    image_clone |= image[..., 2]


    P.S.: как там, у imread() починили уже неумение работать с юникодными путями?
    Ответ написан
    Комментировать
  • Как трансформировать 3d array в 2d array?

    Vindicar
    @Vindicar
    RTFM!
    Читай про метод reshape()
    Ответ написан
    Комментировать
  • Как настроить нейронную сеть на python?

    Vindicar
    @Vindicar
    RTFM!
    Почему ты делаешь np.mean(result)?
    Если я верно помню, softmax-слой даст наибольший отклик в элементе, соответствующем выбранному классу. Т.е. нужно сделать argmax по этому слою, чтобы узнать ответ сети.

    P.S.: обалдеть, я и не знал что в питоне есть оператор @.
    Ответ написан
  • Как получить все 3 канала изображения?

    Vindicar
    @Vindicar
    RTFM!
    По умолчанию каналы изображения в opencv идут в порядке blue, green, red.
    Так что 0 - это blue, ну и так далее.
    Ответ написан
  • Как уменьшить время прохождения кривой?

    Vindicar
    @Vindicar
    RTFM!
    1. Определи длину points через свойство shape.
    2. Раздели общий интервал на длину points.
    3. Полученное значение используй в time.sleep().
    Ответ написан
    4 комментария
  • Хочу написать функцию (python) по изменению какого элемента списка массивов(np.array) со списками, но выдает ошибку, как исправить?

    Vindicar
    @Vindicar
    RTFM!
    for a in self.weights a будет не индексами, а элементами списка. В твоём случае - массивами numpy. Аналогично
    for b in a: будет не индексами строк массива, а самими строками
    for c in b: будет не индексами столбцов, а значениями ячеек. Так что
    self.weights[a][b][c] получит вместо чисел-индексов массивы и сойдёт с ума.

    А вообще, то что ты пытаешься сделать, делается тривиальнейше.
    x = np.randint(-1000, 1000, size = (2, 3), dtype=np.float32)  # массив случайных чисел, две строки, три столбца
    x /= 100.0  # делим поэлементно на сто

    В список завернёшь сам, хотя я не понимаю почему список, а не еще одно измерение в массиве.
    Ответ написан
    Комментировать
  • Можно ли на python задать распределение по четырем моментам?

    Vindicar
    @Vindicar
    RTFM!
    Насколько я знаю, из коробки такого способа нет.
    Вообще это будет уже НЕ нормальное распределение, и я бы посоветовал попробовать применить другую модель распределения. Например, бета-распределение даёт довольно широкий диапазон форм графика плотности вероятности, и при определённом соотношении между параметрами a и b выглядит как раз как смещённое нормальное распределение.
    Ответ написан
    Комментировать
  • Как изменить одинаковые значения в нескольких элементах массива numpy не перебирая элементы циклом? Есть ли метод у нампая?

    Vindicar
    @Vindicar
    RTFM!
    area = matrix_new[100:200, 100:200]  # это делает ссылку на область массива, а не копию области!
    area[area == 250] = 255  # так что когда мы изменяем эту область, оригинал изменится.

    Должно работать быстрее, так как цикл прохода по массиву реализован внутри numpy, а не в рамках интерпретатора питона.
    Но будет есть память, если массив большой.
    Ответ написан
    3 комментария
  • Как написать след код без циклов и генераторов?

    Vindicar
    @Vindicar
    RTFM!
    Если я правильно понял решаемую задачу, то polyfit()
    Ответ написан
  • Почему в numpy берется только тонкая полоска изображения?

    Vindicar
    @Vindicar
    RTFM!
    Погоди, а что за ересь ты вообще творишь?
    im = Image.open('IMG_7760.JPG')
    a = np.asarray(im) # a - трёхмерный массив numpy (высота; ширина; каналы)
    
    for bb in a: # перебираешь элементы по первому индексу (высоте), т.е. строки изображения
        np.random.random((1,1,1)) * a #умножаешь каждый элемент (кортеж RGB) строки на одно и то же случайное число
        #и всё. Полученное произведение выбрасывается за ненадобностью. Оригинальное значение ты не заменяешь ведь.
        im = Image.fromarray(bb) #*строку* превращаешь в объект PIL.Image
        im.save('2222.JPG') #и сохраняешь этот объект в файл
        print(bb) #и выводишь на экран

    Питон делает ровно то, что ты у него просишь.
    Ответ написан
  • Python/numpy: как увеличить массив на одну строку без использования дополнительной памяти?

    Vindicar
    @Vindicar
    RTFM!
    Нельзя. В этом и состоит отличие массива от списка. Список легче растянуть, чем массив, так как массив хранит все свои данные одним блоком, а список хранит одним блоком только ссылки на свои элементы.
    Нужно либо выделять массив с запасом, либо сбрасывать данные на диск для последующего чтения в numpy-массив.
    Ответ написан
    1 комментарий
  • Как найти значения производных созданного массива numpy в python?

    Vindicar
    @Vindicar
    RTFM!
    Что такое производная функции, знаешь?
    Ну вот представь, что массив - это набор значений функции в последовательных точках.
    Правда, остаётся вопрос, какой шаг брать - т.е., насколько по оси X отстоят друг от друга нулевой элемент и первый элемент. Простейший случай - считаем координатой X индекс элемента в массиве. Но тогда производная вообще считается тривиально, так как расстояние по X между соседними точками будет равно 1. В приведённом тобой примере шаг (dx) выбирается случайно.

    В примере кода приведён простейший способ расчёта производной по двум точкам. Он прост, хотя и чувствителен к погрешностям. Есть и другие.
    Ответ написан
    2 комментария
  • Как получить из трехмерного массива numpy строки совпадающие с указанной?

    Vindicar
    @Vindicar
    RTFM!
    (a == [2,0,2]).all(axis=2)
    a == [2,0,2] даст тебе трёхмерный массив булевых значений - результат поэлементного сравнения, при этом сравнение будет идти по последнему измерению.
    all(axis=2) сгруппирует этот массив по третьему измерению, при этом группа будет истинной, только если все значения в группе истинны. Т.е. только если в этой строке все значения совпали.
    >>> a = np.array([[[1, 0, 0], [2, 0, 1], [2, 0, 2]], [[0, 0, 0], [2, 0, 3], [0, 0, 0]]])
    >>> a == [2,0,2]
    array([[[False,  True, False],
            [ True,  True, False],
            [ True,  True,  True]],
    
           [[False,  True, False],
            [ True,  True, False],
            [False,  True, False]]])
    >>> (a == [2,0,2]).all(axis=2)
    array([[False, False,  True],
           [False, False, False]])
    Ответ написан
    1 комментарий
  • Можно ли сократить код с помощью numpy?

    Vindicar
    @Vindicar
    RTFM!
    Какие числа могут быть в парах? Если любые, то дело осложняется.
    Если же небольшие целые положительные, то можно посчитать так.
    Строишь двумерный массив, где первый индекс - первое число из пары, второй - второе.
    Заполняешь нулями, потом увеличиваешь элемент на единицу каждый раз, когда встречена такая пара.
    Если две пары имеют общее число, они будут лежать на одной строке или на одном столбце.
    Тогда если пара не имеет общих чисел с другими, то сумма значений на её строке и её столбце будет 1.
    Если две пары имеют общее число, то сумма значений на их общем строке/столбце будет 2. И так далее.
    Отсюда вывод: для каждой строки и каждого столбца посчитай сумму значений минус 1 (но ограничь снизу по нулю!). Просуммируй полученные числа, и получишь ответ.
    Ответ написан
    Комментировать
  • Как решить ValueError: The truth value...?

    Vindicar
    @Vindicar
    RTFM!
    numpy намекает, что выражение rgb != bg_color вернёт не логическое значение, а массив логических значений - результатов сравнения каждого элемента. Иными словами,
    print(numpy.array([1, 2, 3]) != numpy.array([1, 2, 4])) выведет [False, False, True]
    Как следствие, непонятно, считать ли такой массив истинным или ложным если в нём несколько значений и они разные.
    Предпреждение подсказывает и как это поправить.
    Если тебе нужно любое несовпадение, то пишешь (rgb != bg_color).any().
    Если нужно, чтобы все три канала цвета были разными, то (rgb != bg_color).all().

    Но если честно, cleared_img_data - какой-то странный массив.
    Ответ написан
    1 комментарий
  • Как исправить поворот массива numpy?

    Vindicar
    @Vindicar
    RTFM!
    метод reshape() возвращает версию массива с другими размерами, а не меняет эти размеры на месте.
    Так как вы игнорируете возвращаемое значение, вы пытаетесь повернуть одномерный вектор.
    Но там ещё будут проблемы с sorted(arr_b), так как sorted() интерпретирует двумерный массив как коллекцию одномерных, и пытается сортировать только эту коллекцию.
    Ответ написан
    Комментировать