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

Ошибка list index out of range

05.03.2018, 17:42. Показов 2244. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть код для предсказания вторичной структуры РНК, но он выдает ошибку IndexError: list index out of range в строке:
Code
1
print(nussinov(sys.argv[1]))
Подскажите пожалуйста, как это исправить?

Сам код:

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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
## Nussinov RNA folding algorithm + recursive backtrack. Implemented by Carlos G. Oliver ##
 
import sys
 
import numpy as np
 
min_loop_length = 4
 
def pair_check(tup):
    if tup in [('A', 'U'), ('U', 'A'), ('C', 'G'), ('G', 'C')]:
        return True
    return False
 
def OPT(i,j, sequence):
    """
    returns the score of the optimal pairing between indices i and j
    """
    #base case: no pairs allowed when i and j are less than 4 bases apart
    if i >= j-min_loop_length:
        return 0
    else:
        #i and j can either be paired or not be paired, if not paired then the optimal score is OPT(i,j-1)
        unpaired = OPT(i, j-1, sequence)
 
        #check if j can be involved in a pairing with a position t
        pairing = [1 + OPT(i, t-1, sequence) + OPT(t+1, j-1, sequence) for t in range(i, j-4)\
                   if pair_check((sequence[t], sequence[j]))]
        if not pairing:
            pairing = [0]
        paired = max(pairing)
 
 
        return max(unpaired, paired)
 
 
def traceback(i, j, structure, DP, sequence):
    #in this case we've gone through the whole sequence. Nothing to do.
    if j <= i:
        return
    #if j is unpaired, there will be no change in score when we take it out, so we just recurse to the next index
    elif DP[i][j] == DP[i][j-1]:
        traceback(i, j-1, structure, DP, sequence)
    #consider cases where j forms a pair.
    else:
        #try pairing j with a matching index k to its left.
        for k in [b for b in range(i, j-min_loop_length) if pair_check((sequence[b], sequence[j]))]:
            #if the score at i,j is the result of adding 1 from pairing (j,k) and whatever score
            #comes from the substructure to its left (i, k-1) and to its right (k+1, j-1)
            if k-1 < 0:
                if DP[i][j] == DP[k+1][j-1] + 1:
                    structure.append((k,j))
                    traceback(k+1, j-1, structure, DP, sequence)
                    break
            elif DP[i][j] == DP[i][k-1] + DP[k+1][j-1] + 1:
                #add the pair (j,k) to our list of pairs
                structure.append((k,j))
                #move the recursion to the two substructures formed by this pairing
                traceback(i, k-1, structure, DP, sequence)
                traceback(k+1, j-1, structure, DP, sequence)
                break
 
def write_structure(sequence, structure):
    dot_bracket = ["." for _ in range(len(sequence))]
    for s in structure:
        dot_bracket[min(s)] = "("
        dot_bracket[max(s)] = ")"
    return "".join(dot_bracket)
 
 
#initialize matrix with zeros where can't have pairings
def initialize(N):
    #NxN matrix that stores the scores of the optimal pairings.
    DP = np.empty((N,N))
    DP[:] = np.NAN
    for k in range(0, min_loop_length):
        for i in range(N-k):
            j = i + k
            DP[i][j] = 0
    return DP
 
def nussinov(sequence):
    N = len(sequence)
    DP = initialize(N)
    structure = []
 
    #fill the DP matrix diagonally
    for k in range(min_loop_length, N):
        for i in range(N-k):
            j = i + k
            DP[i][j] = OPT(i,j, sequence)
 
    #copy values to lower triangle to avoid null references
    for i in range(N):
        for j in range(0, i):
            DP[i][j] = DP[j][i]
 
 
    traceback(0,N-1, structure, DP, sequence)
    return (write_structure(sequence, structure), structure)
if __name__ == "__main__":
    print(nussinov(sys.argv[1]))
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
05.03.2018, 17:42
Ответы с готовыми решениями:

Ошибка list assignment index out of range
Всем здравствуйте! Пытаюсь написать программу расчёта по уравнению Ван-дер-Ваальса на Python. Код прикладываю. import...

IndexError: list assignment index out of range
Написала функции. Выдает ошибку в 15 строке. Версия питона 2. Писала до этого на 3. Не думаю, что там прям криминальное отличие, но все же,...

Ошибка list index out of range
Дано натуральное трехзначное число. Если все цифры в нем одинаковы, то оставить заданное число без изменения; если все цифры в нем разные,...

5
Эксперт Python
 Аватар для dondublon
4653 / 2073 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 6
05.03.2018, 17:52
sys.argv - параметры командной строки, с которыми запущен скрипт. Стало быть, там что-то ожидается.
0
0 / 0 / 0
Регистрация: 25.09.2015
Сообщений: 20
05.03.2018, 18:04  [ТС]
Как раз в этом-то и проблема.
Должна быть входная последовательность-строка, состоящая из символов A,U,G,C, она же sequence, но почему-то не нашла в коде нигде её объявление. Может ли быть в этом проблема?
Если да - то как и где правильно её объявить и инициализировать?
Заранее спасибо за ответ.
0
431 / 302 / 90
Регистрация: 03.12.2015
Сообщений: 741
05.03.2018, 19:19
Лучший ответ Сообщение было отмечено Ljubushkina как решение

Решение

Замените код
Python
1
2
if __name__ == "__main__":
    print(nussinov(sys.argv[1]))
На
Python
1
2
3
if __name__ == "__main__":
    sequence = "AUGCAUGCAUGC"
    print(nussinov(sequence))
1
0 / 0 / 0
Регистрация: 25.09.2015
Сообщений: 20
05.03.2018, 21:34  [ТС]
Спасибо, помогло!
0
Эксперт Python
 Аватар для dondublon
4653 / 2073 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 6
12.03.2018, 14:00
Цитата Сообщение от vrm2 Посмотреть сообщение
Замените код
Не надо учить девушку плохому.

Цитата Сообщение от Ljubushkina Посмотреть сообщение
Если да - то как и где правильно её объявить и инициализировать?
В запуске скрипта.

python myscript.py AUGCAUGCAUGC
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
12.03.2018, 14:00
Помогаю со студенческими работами здесь

Ошибка 'List index out of range'
Добрый день! Возникла проблема - выскакивает ошибка 'List index out of range'. Я не понимаю, в чем ошибка. a = list(map(str,...

Ошибка list index out of range
Есть функция: def TablSopr(X1min,X1max,X2min,X2max,m1,m2): &quot;&quot;&quot;Расчет по номин.факторам таблицы сопряженности&quot;&quot;&quot; ...

Ошибка list index out of range
word, s, k, a, save = input(), , 0, , for t in range(len(word)): s.append(word) save = s for i in range(int(input())): ...

Ошибка list index out of range
Версия питона: 3.10 Я не могу разобраться как исправить ошибку list index out of range. Я делаю игру пин понк и вот строчки...

list index out of range ошибка
Задача:Даны действительные числа а1 . . . , а 50. Получить «сглаженные» значения а1 . . . , а50, заменив в исходной последовательности...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
1С: Программный отбор элементов справочника Номенклатура по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор под наименованию группы (на. . .
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
1С: Программный отбор элементов справочника Сотрудники по значению перечисления
Maks 21.03.2026
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru