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

Ошибка с Tkinter в __call__

20.12.2023, 18:17. Показов 855. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть код, который работает у одногруппника на ноутбуке, но не работает у меня. Не могу понять в чём проблема и суть ошибки. Продолжать копать в библиотеку? Или это можно в коде исправить? Ошибка следующая (вылетает по нажатию кнопки "Обучить"):
Exception in Tkinter callback
Traceback (most recent call last):
File "C:\Users\VLAD\AppData\Local\Programs\Py thon\Python38-32\lib\tkinter\__init__.py", line 1883, in __call__
return self.func(*args)
File "F:\Универ\4 курс\1 семестр\ИТиС\хелп\fourthlab\fourthlab\Pa tternRecognition.py", line 187, in train_button_clicked
W1, b1, W2, b2 = gradient_descent(IX_train, IY_train, 0.10, 2000)
File "F:\Универ\4 курс\1 семестр\ИТиС\хелп\fourthlab\fourthlab\Pa tternRecognition.py", line 141, in gradient_descent
dW1, db1, dW2, db2 = backward_prop(Z1, A1, Z2, A2, W1, W2, X, Y)
File "F:\Универ\4 курс\1 семестр\ИТиС\хелп\fourthlab\fourthlab\Pa tternRecognition.py", line 115, in backward_prop
dZ2 = A2 - one_hot_Y
ValueError: operands could not be broadcast together with shapes (4,7000) (9,7000)
Сам код:
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
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
import numpy as np
import pandas as pd
from matplotlib import pyplot as plt
from tkinter import *
from tkinter import filedialog
from PIL import Image
from os import listdir
 
def replace_shapes(array):
    replacements = {
        'circle': 0,
        'square': 1,
        'star': 2,
        'triangle': 3
    }
    replaced_array = []
    for row in array:
        shape = row[0]  # Название фигуры находится в первом столбце
        if shape in replacements:
            replaced_row = [replacements[shape]] + list(row[1:])
            replaced_array.append(replaced_row)
        else:
            replaced_array.append(row)
    return replaced_array
 
# ------------------------------------------------------ Обучение через JPG ---------------------------------------------------------
def blackAndWhite(img):
        thresh = 150
        fn = lambda x : 255 if x > thresh else 0
        r = img.convert('L').point(fn, mode='1')
        return r
 
def resize(img):
        size = (28, 28)
        resized = img.resize(size)
        return resized
 
def filter(img):
        resized = resize(img)
        result = blackAndWhite(resized)
        return result
 
def imgToArray(img):
    return np.array([1 if pixel == 255 else 0 for pixel in img.getdata()])
 
def image_operations(img):
    img = filter(img)
    img = imgToArray(img)
    return img
 
def get_images():
    dir = 'F:/Универ/4 курс/1 семестр/ИТиС/хелп/fourthlab/fourthlab/shapes'
    img_data = []
    folders = listdir(dir)
    for folder in folders:
        folders1 = listdir(f"{dir}/{folder}")
        for folder1 in folders1:
            pictures = listdir(f"{dir}/{folder}/{folder1}")
            for npic in range(1000):
                img_name = f"F:/Универ/4 курс/1 семестр/ИТиС/хелп/fourthlab/fourthlab/shapes/{folder}/{folder1}/{pictures[npic]}"
                # print(img_name)
                img = Image.open(img_name)
                img = image_operations(img)
                img = np.insert(img, 0, folders.index(folder))
                img_data.append(img)
    return folders, img_data
 
labels, images_data = get_images()
images_data = np.array(images_data)
print(images_data.shape)
img_m, img_n = images_data.shape
np.random.shuffle(images_data)
idata_dev = images_data[0:2000].T
IY_dev = idata_dev[0]
IX_dev = idata_dev[1:img_n]
 
idata_train = images_data[2000:img_m].T
IY_train = idata_train[0]
IX_train = idata_train[1:img_n]
 
# ------------------------------------------------------ Обучение через JPG ---------------------------------------------------------
def init_params():
    W1 = np.random.rand(4, 784) * np.sqrt(1./(784))
    b1 = np.random.rand(4, 1) * np.sqrt(1./4)
    W2 = np.random.rand(4, 4) * np.sqrt(1./16)
    b2 = np.random.rand(4, 1) * np.sqrt(1./(784))
    return W1, b1, W2, b2
 
def ReLU(Z):
    return np.maximum(Z, 0)
 
def softmax(Z):
    Z = Z.astype(float)
    A = 1 / (1 + np.exp(-Z))
    return A
 
def forward_prop(W1, b1, W2, b2, X):
    Z1 = W1.dot(X) + b1
    A1 = ReLU(Z1)
    Z2 = W2.dot(A1) + b2
    A2 = softmax(Z2)
    return Z1, A1, Z2, A2
 
def ReLU_deriv(Z):
    return Z > 0
 
def one_hot(Y):
    one_hot_Y = np.zeros((Y.size, Y.max() + 1))
    one_hot_Y[np.arange(Y.size), Y] = 1
    one_hot_Y = one_hot_Y.T
    return one_hot_Y
 
def backward_prop(Z1, A1, Z2, A2, W1, W2, X, Y):
    one_hot_Y = one_hot(Y)
    dZ2 = A2 - one_hot_Y
    dW2 = 1 / img_m * dZ2.dot(A1.T)
    db2 = 1 / img_m * np.sum(dZ2)
    dZ1 = W2.T.dot(dZ2) * ReLU_deriv(Z1)
    dW1 = 1 / img_m * dZ1.dot(X.T)
    db1 = 1 / img_m * np.sum(dZ1)
    return dW1, db1, dW2, db2
 
def update_params(W1, b1, W2, b2, dW1, db1, dW2, db2, alpha):
    W1 = W1 - alpha * dW1
    b1 = b1 - alpha * db1
    W2 = W2 - alpha * dW2
    b2 = b2 - alpha * db2
    return W1, b1, W2, b2
 
def get_predictions(A2):
    return np.argmax(A2, 0)
 
def get_accuracy(predictions, Y):
    print(predictions, Y)
    return np.sum(predictions == Y) / Y.size
 
def gradient_descent(X, Y, alpha, iterations):
    W1, b1, W2, b2 = init_params()
    for i in range(iterations):
        Z1, A1, Z2, A2 = forward_prop(W1, b1, W2, b2, X)
        dW1, db1, dW2, db2 = backward_prop(Z1, A1, Z2, A2, W1, W2, X, Y)
        W1, b1, W2, b2 = update_params(
            W1, b1, W2, b2, dW1, db1, dW2, db2, alpha)
        if i % 10 == 0:
            print("Iteration: ", i)
            predictions = get_predictions(A2)
            print(get_accuracy(predictions, Y))
    return W1, b1, W2, b2
 
def make_predictions(X, W1, b1, W2, b2):
    _, _, _, A2 = forward_prop(W1, b1, W2, b2, X)
    predictions = get_predictions(A2)
    return predictions
 
def test_prediction(index, W1, b1, W2, b2):
    current_image = IX_dev[:, index, None]
    prediction = make_predictions(index, W1, b1, W2, b2)[0]
    prediction = make_predictions(current_image, W1, b1, W2, b2)[0]
    label = IY_dev[index]
    print("Prediction: ", prediction)
    print("Label: ", label)
    current_image = current_image.reshape((28, 28)).astype(float)
    plt.gray()
    plt.imshow(current_image, interpolation='nearest')
    plt.show()
 
def predict(img, W1, b1, W2, b2):
    img = image_operations(img)
    current_image = np.array(np.matrix(img).T)
    prediction = make_predictions(current_image, W1, b1, W2, b2)[0]
    predictionLabel = labels[prediction]
 
    print("Prediction: ", predictionLabel)
 
    return predictionLabel
 
def open_file_dialog():
    # Открыть диалоговое окно выбора файла
    file_path = filedialog.askopenfilename()
    if file_path:
        print("Выбранный файл:", file_path)
        imgpath.set(file_path)
 
 
def train_button_clicked():
    global W1, b1, W2, b2
    W1, b1, W2, b2 = gradient_descent(IX_train, IY_train, 0.10, 2000)
 
 
def recognize_image():
    image_path = imgpath.get()
    image = Image.open(image_path)
    image_array = np.array(
        [1 if pixel == 255 else 0 for pixel in image.getdata()])
    predict(image, W1, b1, W2, b2)
 
 
 
def main():
 
    # Создание графического интерфейса
    root = Tk()
    root.title("Распознование геометрических фигур")
 
    # Задание размера окна
    root.geometry('400x400')
 
    # Создание переменной для хранения пути к изображению
    global imgpath
    imgpath = StringVar()
 
    # Кнопка "Загрузить картинку"
    btn_load_image = Button(
        root, text="Загрузить картинку", command=open_file_dialog)
    btn_load_image.pack()
 
    # Кнопка "Обучить"
    btn_train = Button(root, text="Обучить", command=train_button_clicked)
    btn_train.pack()
 
    # Кнопка "Распознать"
    btn_recognize = Button(root, text="Распознать", command=recognize_image)
    btn_recognize.pack()
 
    # Запуск основного цикла
    root.mainloop()
 
if __name__ == '__main__':
    main()
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
20.12.2023, 18:17
Ответы с готовыми решениями:

Ошибка при попытке открыть программу через консоль, import tkinter as tk ModuleNotFoundError: No module named 'tkinter'
import tkinter as tk ModuleNotFoundError: No module named 'tkinter' Пытаюсь открыть через py main.py, находясь в директории проекта ...

(new Function).call.call.call.call.call.call(myFunc);
myFunc = function(x) { console.log('Привет!'); }; myObj = {}; (new Function).call.call.call.call.call.call(myFunc); // напишет...

Как сделать окно tkinter неактивным по нажатии на него. Оверлей на Tkinter
Здравствуйте. Пытаюсь сделать оверлей на tkinter, поскольку многие модули из интернета нерабочее на моем ПК. Уже все готово, кроме одной...

2
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7392 / 4819 / 1246
Регистрация: 30.03.2015
Сообщений: 13,694
Записей в блоге: 29
20.12.2023, 19:38
Цитата Сообщение от UndersSon Посмотреть сообщение
Продолжать копать в библиотеку? Или это можно в коде исправить?
прочитать ошибку, вроде на чистом английском все

Добавлено через 32 секунды
could not be broadcast together with shapes (4,7000) (9,7000)
0
1 / 1 / 0
Регистрация: 23.11.2021
Сообщений: 31
20.12.2023, 19:43  [ТС]
Цитата Сообщение от Welemir1 Посмотреть сообщение
прочитать ошибку
огромное спасибо, конечно, за совет, но я её прочитал уже раз 100. Как состыковать с решением до сих пор не вкурил.

Добавлено через 2 минуты
С питоном впервые столкнулся, поэтому не понимаю ничего от слова совсем.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
20.12.2023, 19:43
Помогаю со студенческими работами здесь

Ошибка в tkinter
Добрый вечер, у меня такая ошибка, при выводе кода из консоли, открывается окно, текст в этом окне не прописан, хотя по коду написана...

Ошибка по Tkinter
Суть программы в том, что на месте .!entry должен появятся текст из первой строки(текст вводится пользователем).Что-то пошло не так и оно...

Как сделать так, чтобы при использовании модуля из tkinter не открывалось окно tkinter?
Как сделать так, чтобы при использовании модуля из tkinter не открывалось окно tkinter? Я пишу приложение на kivy но использую ...

Виджеты tkinter и tkinter.ttk (используется Python 3.5.2)
1) Проблема с виджетом Scale (ползунок) модуля tkinter. Я создал ползунок от 1 до 50 (как на первой картинке). По умолчанию стоит на 1....

Ошибка в коде | tkinter
Помогите, пожалуйста, устранить ошибку в 28 строке. Ошибка: TypeError: can't multiply sequence by non-int of type 'str' from tkinter...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru