Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/11: Рейтинг темы: голосов - 11, средняя оценка - 5.00
1 / 1 / 0
Регистрация: 08.01.2021
Сообщений: 37

Valueerror cannot compute fingerprint of empty list Numba

10.06.2021, 18:43. Показов 2392. Ответов 11

Студворк — интернет-сервис помощи студентам
Решил попробовать ускорить код при помощи Numba, но получаю ошибку
Cписок точно не пустой, т.к до этого он выводится и без Numba работает
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
10.06.2021, 18:43
Ответы с готовыми решениями:

Программа не видит последовательность и выдает ошибку ValueError: max() arg is an empty sequence
Задача Программа считывает последовательность цифр из файла(построчно) и выводит на экран самую длинную возрастающую последовательность, ее...

ValueError: list.remove(x): x not in list
Добрый день, продолжаю делать игру в города, в процессе сократил до городов только России, добавил несколько условий(ниже) однако, когда...

Как отклавливать экзепшн Prelude.head: empty list?
Привет народ, как вы обрабатываете такое исключение? Точнее будет сказать, эту ошибку т.к как я понял это разные вещи в хаскеле. Заключал...

11
5516 / 2869 / 571
Регистрация: 07.11.2019
Сообщений: 4,759
10.06.2021, 18:51
PyoNov, странно, а у меня работает без ошибок.
0
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7391 / 4818 / 1246
Регистрация: 30.03.2015
Сообщений: 13,693
Записей в блоге: 29
10.06.2021, 20:38
странно, а у меня на том же коде пишет что список таки пустой, в 55 строке.
0
1 / 1 / 0
Регистрация: 08.01.2021
Сообщений: 37
10.06.2021, 21:37  [ТС]
Цитата Сообщение от Welemir1 Посмотреть сообщение
странно, а у меня на том же коде пишет что список таки пустой, в 55 строке.
Cогласен, очень странно. Но он не может быть пустой, т.к до этого я его выводил
0
1 / 1 / 0
Регистрация: 08.01.2021
Сообщений: 37
10.06.2021, 21:44  [ТС]
Цитата Сообщение от Welemir1 Посмотреть сообщение
странно, а у меня на том же коде пишет что список таки пустой, в 55 строке.
Слушай, есть вопрос. Это может быть связано с 3-им аргументом в функции? Можешь помочь, как исправить?
0
Эксперт Python
8850 / 4501 / 1864
Регистрация: 27.03.2020
Сообщений: 7,317
10.06.2021, 21:51
PyoNov, возможно из-за: в цикле на последнем шаге remaining пустой (i+1)
0
1 / 1 / 0
Регистрация: 08.01.2021
Сообщений: 37
10.06.2021, 21:56  [ТС]
Цитата Сообщение от Gdez Посмотреть сообщение
возможно из-за: в цикле на последнем шаге remaining пустой (i+1)
убрал, ошибка осталась
0
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7391 / 4818 / 1246
Регистрация: 30.03.2015
Сообщений: 13,693
Записей в блоге: 29
11.06.2021, 05:43
PyoNov, с 3 аргументом не связано. А выше я просто шутил как и другой участник форума. Мы намекали тебе что ты не выложил кода и задаешь вопрос.
Посмотри документацию по этой функции -нет ли там подробностей применения ну и наконец погугли ошибку, ты явно не первый
0
1 / 1 / 0
Регистрация: 08.01.2021
Сообщений: 37
11.06.2021, 12:24  [ТС]
Цитата Сообщение от Welemir1 Посмотреть сообщение
Мы намекали тебе что ты не выложил кода и задаешь вопрос.
А, точно... сорри, я genius(Затупок)
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
options = webdriver.ChromeOptions()
options.add_extension(r'F:\FloatFinder\CSGOFloat-Market-Checker_v2.4.1.crx')
browser = webdriver.Chrome(options=options)
 
def getFloats():
    global floats, items
    select = Select(browser.find_element_by_xpath('//*[@id="pageSize"]'))
    select.select_by_visible_text('25')
    time.sleep(1)
    browser.find_element_by_xpath('//*[@id="csgofloat_sort_by_float"]/span').click()
    time.sleep(3)
    items = browser.find_elements_by_class_name("csgofloat-itemfloat")
    for i in range (0,25):
        tempFloat = items[i].text
        tempFloat = re.sub("[|F|l|o|a|t|:| |]","",tempFloat)
        floats.append(Decimal(tempFloat))
    return floats
 
@njit(fastmath=True)
def subset_sum(numbers, target, partial=[]):
    s = sum(partial)
    print("Ищем")
 
    # check if the partial sum is equals to target
    if s == target: 
        print ("sum(%s)=%s" % (partial, target))
    if s >= target:
        return  # if we reach the number why bother to continue
 
    for i in range(len(numbers)):
        n = numbers[i]
        remaining = numbers[i+1:]
        subset_sum(remaining, target, partial + [n]) 
 
 
floats = []
browser.get('https://steamcommunity.com/market/listings/730/SCAR-20%20%7C%20Contractor%20%28Well-Worn%29?')
time.sleep(2)
 
 
getFloats()
for i in range(0,25):
        print(floats[i])
start_time = time.time()
subset_sum(floats,Decimal(1.90895608067513))
print("--- %s seconds ---" % (time.time() - start_time))
print('Конец')
0
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7391 / 4818 / 1246
Регистрация: 30.03.2015
Сообщений: 13,693
Записей в блоге: 29
11.06.2021, 12:38
PyoNov, я не понимаю вот как можно браться за нумбу и селениум не зная питона? вот ты глобалки совершенно зря используешь и даже не понимаешь этого, Вот тут можно посмотреть

Цитата Сообщение от PyoNov Посмотреть сообщение
return floats
ну и где ты это используешь?а должен использовать ВМЕСТО глобалок

Цитата Сообщение от PyoNov Посмотреть сообщение
subset_sum(remaining, target, partial + [n])
функция рекурсивна, значит дело то не во флоатс, а втом что на одном из очередных вызовов в списке может не остаться значений! Я бы предложил отладчиком посмотреть, но боюсь ты не умеешь им пользоваться.

Вопрос -зачем тебе нумба? питон прямо медленно считает твою конкретную задачу?
0
1 / 1 / 0
Регистрация: 08.01.2021
Сообщений: 37
11.06.2021, 14:32  [ТС]
Цитата Сообщение от Welemir1 Посмотреть сообщение
Вопрос -зачем тебе нумба? питон прямо медленно считает твою конкретную задачу?
прям медленно
0
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
11.06.2021, 18:40
Цитата Сообщение от PyoNov Посмотреть сообщение
прям медленно
Вычислительная сложность задачи о сумме подмножеств зависит от двух параметров — числа N элементов множества и точности P (определяется как число двоичных разрядов в числах, составляющих множество). Замечание: здесь буквы N и P не имеют ничего общего с классом задач NP.

Сложность наилучшего известного алгоритма экспоненциальна по наименьшему из двух параметров N и P. Таким образом, задача наиболее трудна, когда N и P имеют один порядок. Задача становится лёгкой только при очень маленьких N или P.
Цитата Сообщение от PyoNov Посмотреть сообщение
получаю ошибку.... ValueError: cannot compute fingerprint of empty list
Это известная проблема с numba. Numba не ускоряет Python код: она транслирует его в С++ и затем выполняет.
И не всякий Python код можно оттранслировать в С++.

P.S. Обходной путь решения проблемы - инициализация списка любым стартовым значением, которое затем нужно игнорировать.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
11.06.2021, 18:40
Помогаю со студенческими работами здесь

Lenovo B580: `Lenovo Fingerprint ` или `AuthenTec TrueSuite Fingerprint ` качать ?
FingerPrint USB\VID_147E&PID_1002&REV_0048 USB\VID_147E&PID_1002 Какой драйвер качать с сайта Lenovo ? "Lenovo...

Как определить Empty или не Empty массив?
Добрый вечер! Встрял в ситуацию... Заполняю массив в цикле значениями из базы данных вот так while ($row =...

В чем разница между !empty и empty?
И парочку примеров для лучшего понимания, если не сложно

Как запустить один compute shader на одной GPU, а второй compute shader на второй GPU через один и тот же скрипт Unity?
У меня программа которая требует огромной вычислительной мощности. По этому, просто необходимо распределить нагрузку compute shaders на...

Numba использует GPU?
Здравствуйте! После запуска кода с циклом в диспетчере задач вижу 50% нагрузку всех ядер ЦП, действительно ли numba использует GPU? Тест...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru