From 33e6453986a1b10d1a5def2e70b99a1cb0ddc3c2 Mon Sep 17 00:00:00 2001 From: Darina Gaff Date: Thu, 21 Nov 2019 18:35:24 +0300 Subject: [PATCH 01/15] Creating new branch --- 2016-solar_project | 1 + 1 file changed, 1 insertion(+) create mode 160000 2016-solar_project diff --git a/2016-solar_project b/2016-solar_project new file mode 160000 index 00000000..a2df8244 --- /dev/null +++ b/2016-solar_project @@ -0,0 +1 @@ +Subproject commit a2df8244e8e07a313879c2bf322f8567fff2b00d From e5e619ea4aa1343481b09b7baceda0a8cb8598de Mon Sep 17 00:00:00 2001 From: fdr-smnv <49762416+fdr-smnv@users.noreply.github.com> Date: Thu, 21 Nov 2019 19:41:40 +0300 Subject: [PATCH 02/15] Added todos to readme --- README.md | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/README.md b/README.md index a542148c..099aeab4 100644 --- a/README.md +++ b/README.md @@ -1,2 +1,7 @@ # solar_project Модель Солнечной системы на языке Python + +##TODOS: +* solar_vis.py +1. Fix scale_y function. +2. Fix create_planet_image function. \ No newline at end of file From cea2f7f6c81d341df31595265a22a9856906c7aa Mon Sep 17 00:00:00 2001 From: Darina Gaff Date: Thu, 21 Nov 2019 19:52:13 +0300 Subject: [PATCH 03/15] Editing scale_y() --- solar_vis.py | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/solar_vis.py b/solar_vis.py index ae972ba4..1cb1d86c 100644 --- a/solar_vis.py +++ b/solar_vis.py @@ -54,7 +54,7 @@ def scale_y(y): **y** — y-координата модели. """ - return y # FIXME: not done yet + return int(y*scale_factor) + window_width//2 # FIXME def create_star_image(space, star): @@ -80,7 +80,10 @@ def create_planet_image(space, planet): **space** — холст для рисования. **planet** — объект планеты. """ - pass # FIXME: сделать как у звезды + x = scale_x(planet.x) + y = scale_y(planet.y) + r = planet.R + planet.image = space.create_oval([x-r, y-r], [x+r, y+r], fill=star.color) def update_system_name(space, system_name): From 53f078fd41d517a246c40ed521f913b8f4ae4406 Mon Sep 17 00:00:00 2001 From: Darina Gaff Date: Fri, 22 Nov 2019 14:59:12 +0300 Subject: [PATCH 04/15] Fixed parse_object_parameters --- solar_input.py | 109 +++++++++++++++++++++++++---------------------- solar_objects.py | 6 +-- test.txt | 1 + tests.py | 45 +++++++++++++++++++ 4 files changed, 107 insertions(+), 54 deletions(-) create mode 100644 test.txt create mode 100644 tests.py diff --git a/solar_input.py b/solar_input.py index d45e0401..7927f7c5 100644 --- a/solar_input.py +++ b/solar_input.py @@ -4,32 +4,9 @@ from solar_objects import Star, Planet -def read_space_objects_data_from_file(input_filename): - """Cчитывает данные о космических объектах из файла, создаёт сами объекты - и вызывает создание их графических образов - - Параметры: - - **input_filename** — имя входного файла - """ - - objects = [] - with open(input_filename) as input_file: - for line in input_file: - if len(line.strip()) == 0 or line[0] == '#': - continue # пустые строки и строки-комментарии пропускаем - object_type = line.split()[0].lower() - if object_type == "star": # FIXME: do the same for planet - star = Star() - parse_star_parameters(line, star) - objects.append(star) - else: - print("Unknown space object") +space_objects = [] - return objects - - -def parse_star_parameters(line, star): +def parse_object_parameters(line): """Считывает данные о звезде из строки. Входная строка должна иметь слеюущий формат: Star <радиус в пикселах> <цвет> <масса> @@ -37,31 +14,37 @@ def parse_star_parameters(line, star): Здесь (x, y) — координаты зведы, (Vx, Vy) — скорость. Пример строки: Star 10 red 1000 1 2 3 4 - - Параметры: - - **line** — строка с описание звезды. - **star** — объект звезды. - """ - - pass # FIXME: not done yet - -def parse_planet_parameters(line, planet): - """Считывает данные о планете из строки. - Предполагается такая строка: - Входная строка должна иметь слеюущий формат: - Planet <радиус в пикселах> <цвет> <масса> - - Здесь (x, y) — координаты планеты, (Vx, Vy) — скорость. - Пример строки: - Planet 10 red 1000 1 2 3 4 - - Параметры: - - **line** — строка с описание планеты. - **planet** — объект планеты. """ - pass # FIXME: not done yet... + params = line.split(' ') + type_ = params[0].lower() + R = params[1] + color = params[2] + m = params[3] + x = params[4] + y = params[5] + Vx = params[6] + Vy = params[7] + + if type_ == 'planet': + obj = Planet() + elif type_ == 'star': + obj = Star() + else: + print('Invalid type of object.') + raise ValueError + + obj.type_ = type_ + obj.R = int(R) + obj.color = color + obj.m = complex(m) + obj.Fy = complex(y) + obj.Fx = complex(x) + obj.Vy = complex(Vy) + obj.Vx = complex(Vx) + + space_objects.append(obj) + + return obj def write_space_objects_data_to_file(output_filename, space_objects): @@ -77,10 +60,34 @@ def write_space_objects_data_to_file(output_filename, space_objects): """ with open(output_filename, 'w') as out_file: for obj in space_objects: - print(out_file, "%s %d %s %f" % ('1', 2, '3', 4.5)) - # FIXME: should store real values + out_file.write(' '.join([obj.type_, str(obj.R), obj.color, str(obj.m), str(obj.Fx), str(obj.Fy), str(obj.Vx), str(obj.Vy)])) + + +def read_space_objects_data_from_file(input_filename): + """Cчитывает данные о космических объектах из файла, создаёт сами объекты + и вызывает создание их графических образов + + Параметры: + **input_filename** — имя входного файла + """ + + objects = [] + with open(input_filename) as input_file: + for line in input_file: + if len(line.strip()) == 0 or line[0] == '#': + continue # пустые строки и строки-комментарии пропускаем + object_type = line.split(' ')[0].lower() + if object_type == 'star' or object_type == 'planet': + obj = parse_object_parameters(line) + objects.append(obj) + + else: + print("Unknown space object") + + return objects # FIXME: хорошо бы ещё сделать функцию, сохранающую статистику в заданный файл... +# Статистику чего? if __name__ == "__main__": print("This module is not for direct call!") diff --git a/solar_objects.py b/solar_objects.py index 0c73668b..1118aaf3 100644 --- a/solar_objects.py +++ b/solar_objects.py @@ -8,7 +8,7 @@ class Star: а также визуальный радиус звезды в пикселах и её цвет. """ - type = "star" + type_ = "star" """Признак объекта звезды""" m = 0 @@ -48,7 +48,7 @@ class Planet: а также визуальный радиус планеты в пикселах и её цвет """ - type = "planet" + type_ = "planet" """Признак объекта планеты""" m = 0 @@ -79,4 +79,4 @@ class Planet: """Цвет планеты""" image = None - """Изображение планеты""" \ No newline at end of file + """Изображение планеты""" diff --git a/test.txt b/test.txt new file mode 100644 index 00000000..e1c671ae --- /dev/null +++ b/test.txt @@ -0,0 +1 @@ +planet 5 green (5.974e+24+0j) (149600000000+0j) 0j 0j (29760+0j) \ No newline at end of file diff --git a/tests.py b/tests.py new file mode 100644 index 00000000..a11c8ead --- /dev/null +++ b/tests.py @@ -0,0 +1,45 @@ +from solar_input import * + + +class TestSolarInput: + space_objects = [] + def test_parse_object_parameters(): + + objects = [ + 'Planet 5 green 5.974E24 149.60E9 0 0 29.76E3', + # 'Star 30 red 1.98892E30 0 0 0 0', + # 'foe negn prekk mkmktk mmop409 09' + + ] + + for i in objects: + object_type = i.split()[0].lower() + if object_type == 'planet': + o = parse_object_parameters(i) + assert o.type_ == 'planet' + assert o.R == 5 + assert o.color == 'green' + assert o.m == complex(5.974E24) + + elif object_type == 'star': + o = parse_object_parameters(i) + assert o.type_ == 'star' + assert o.R == 30 + assert o.color == 'red' + assert o.m == complex(1.98892E30) + else: + raise ValueError + + space_objects.append(o) + + def test_reader_and_writer(): + + write_space_objects_data_to_file('test.txt', space_objects) + + output_obj = read_space_objects_data_from_file('test.txt') + + for i in range(len(space_objects)): + assert space_objects[i].type_ == output_obj[i].type_ + assert space_objects[i].R == output_obj[i].R + assert space_objects[i].color == output_obj[i].color + assert space_objects[i].m == output_obj[i].m From 1f85a28cacd03e762b357519187a490b2b06774c Mon Sep 17 00:00:00 2001 From: Darina Gaff Date: Fri, 27 Dec 2019 16:13:54 +0300 Subject: [PATCH 05/15] Fixed calculate_force() and move_space_object() --- solar_model.py | 25 +++++++---- solar_vis.py | 119 ------------------------------------------------- 2 files changed, 16 insertions(+), 128 deletions(-) delete mode 100644 solar_vis.py diff --git a/solar_model.py b/solar_model.py index 7cb63d65..ce6437f9 100644 --- a/solar_model.py +++ b/solar_model.py @@ -14,14 +14,19 @@ def calculate_force(body, space_objects): **space_objects** — список объектов, которые воздействуют на тело. """ - body.Fx = body.Fy = 0 + body.Fx = 0 + body.Fy = 0 for obj in space_objects: if body == obj: continue # тело не действует гравитационной силой на само себя! - r = ((body.x - obj.x)**2 + (body.y - obj.y)**2)**0.5 - body.Fx += 1 # FIXME: нужно вывести формулу... - body.Fy += 2 # FIXME: нужно вывести формулу... - + r = ((body.x - obj.x) ** 2 + (body.y - obj.y) ** 2) ** 0.5 + dax = obj.x - body.x + day = obj.y - body.y + sin = day / r + cos = dax / r + F = (gravitational_constant * body.m * obj.m) / (r ** 2) + body.Fx += F * cos + body.Fy += F * sin def move_space_object(body, dt): """Перемещает тело в соответствии с действующей на него силой. @@ -31,10 +36,12 @@ def move_space_object(body, dt): **body** — тело, которое нужно переместить. """ - ax = body.Fx/body.m - body.x += 42 # FIXME: не понимаю как менять... - body.Vx += ax*dt - # FIXME: not done recalculation of y coordinate! + ax = body.Fx / body.m + body.x += ax * (dt ** 2) / 2 + body.Vx * dt + body.Vx += ax * dt + ay = body.Fy / body.m + body.y += ay * (dt ** 2) / 2 + body.Vy * dt + body.Vy += ay * dt def recalculate_space_objects_positions(space_objects, dt): diff --git a/solar_vis.py b/solar_vis.py deleted file mode 100644 index 1cb1d86c..00000000 --- a/solar_vis.py +++ /dev/null @@ -1,119 +0,0 @@ -# coding: utf-8 -# license: GPLv3 - -"""Модуль визуализации. -Нигде, кроме этого модуля, не используются экранные координаты объектов. -Функции, создающие гaрафические объекты и перемещающие их на экране, принимают физические координаты -""" - -header_font = "Arial-16" -"""Шрифт в заголовке""" - -window_width = 800 -"""Ширина окна""" - -window_height = 800 -"""Высота окна""" - -scale_factor = None -"""Масштабирование экранных координат по отношению к физическим. -Тип: float -Мера: количество пикселей на один метр.""" - - -def calculate_scale_factor(max_distance): - """Вычисляет значение глобальной переменной **scale_factor** по данной характерной длине""" - global scale_factor - scale_factor = 0.4*min(window_height, window_width)/max_distance - print('Scale factor:', scale_factor) - - -def scale_x(x): - """Возвращает экранную **x** координату по **x** координате модели. - Принимает вещественное число, возвращает целое число. - В случае выхода **x** координаты за пределы экрана возвращает - координату, лежащую за пределами холста. - - Параметры: - - **x** — x-координата модели. - """ - - return int(x*scale_factor) + window_width//2 - - -def scale_y(y): - """Возвращает экранную **y** координату по **y** координате модели. - Принимает вещественное число, возвращает целое число. - В случае выхода **y** координаты за пределы экрана возвращает - координату, лежащую за пределами холста. - Направление оси развёрнуто, чтобы у модели ось **y** смотрела вверх. - - Параметры: - - **y** — y-координата модели. - """ - - return int(y*scale_factor) + window_width//2 # FIXME - - -def create_star_image(space, star): - """Создаёт отображаемый объект звезды. - - Параметры: - - **space** — холст для рисования. - **star** — объект звезды. - """ - - x = scale_x(star.x) - y = scale_y(star.y) - r = star.R - star.image = space.create_oval([x - r, y - r], [x + r, y + r], fill=star.color) - - -def create_planet_image(space, planet): - """Создаёт отображаемый объект планеты. - - Параметры: - - **space** — холст для рисования. - **planet** — объект планеты. - """ - x = scale_x(planet.x) - y = scale_y(planet.y) - r = planet.R - planet.image = space.create_oval([x-r, y-r], [x+r, y+r], fill=star.color) - - -def update_system_name(space, system_name): - """Создаёт на холсте текст с названием системы небесных тел. - Если текст уже был, обновляет его содержание. - - Параметры: - - **space** — холст для рисования. - **system_name** — название системы тел. - """ - space.create_text(30, 80, tag="header", text=system_name, font=header_font) - - -def update_object_position(space, body): - """Перемещает отображаемый объект на холсте. - - Параметры: - - **space** — холст для рисования. - **body** — тело, которое нужно переместить. - """ - x = scale_x(body.x) - y = scale_y(body.y) - r = body.R - if x + r < 0 or x - r > window_width or y + r < 0 or y - r > window_height: - space.coords(body.image, window_width + r, window_height + r, - window_width + 2*r, window_height + 2*r) # положить за пределы окна - space.coords(body.image, x - r, y - r, x + r, y + r) - - -if __name__ == "__main__": - print("This module is not for direct call!") From a5b0e1b34efbc371c64ce665aa01b0b733d33f7c Mon Sep 17 00:00:00 2001 From: Darina Gaff Date: Fri, 27 Dec 2019 16:17:13 +0300 Subject: [PATCH 06/15] Updated. --- solar_vis.py | 119 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 119 insertions(+) create mode 100644 solar_vis.py diff --git a/solar_vis.py b/solar_vis.py new file mode 100644 index 00000000..071c56c2 --- /dev/null +++ b/solar_vis.py @@ -0,0 +1,119 @@ +# coding: utf-8 +# license: GPLv3 + +"""Модуль визуализации. +Нигде, кроме этого модуля, не используются экранные координаты объектов. +Функции, создающие гaрафические объекты и перемещающие их на экране, принимают физические координаты +""" + +header_font = "Arial-16" +"""Шрифт в заголовке""" + +window_width = 800 +"""Ширина окна""" + +window_height = 800 +"""Высота окна""" + +scale_factor = 100 +"""Масштабирование экранных координат по отношению к физическим. +Тип: float +Мера: количество пикселей на один метр.""" + + +def calculate_scale_factor(max_distance): + """Вычисляет значение глобальной переменной **scale_factor** по данной характерной длине""" + global scale_factor + scale_factor = 0.4*min(window_height, window_width)/max_distance + print('Scale factor:', scale_factor) + + +def scale_x(x): + """Возвращает экранную **x** координату по **x** координате модели. + Принимает вещественное число, возвращает целое число. + В случае выхода **x** координаты за пределы экрана возвращает + координату, лежащую за пределами холста. + + Параметры: + + **x** — x-координата модели. + """ + + return int(x*scale_factor + window_width//2) + + +def scale_y(y): + """Возвращает экранную **y** координату по **y** координате модели. + Принимает вещественное число, возвращает целое число. + В случае выхода **y** координаты за пределы экрана возвращает + координату, лежащую за пределами холста. + Направление оси развёрнуто, чтобы у модели ось **y** смотрела вверх. + + Параметры: + + **y** — y-координата модели. + """ + + return int(y*scale_factor + window_width//2) # FIXME + + +def create_star_image(space, star): + """Создаёт отображаемый объект звезды. + + Параметры: + + **space** — холст для рисования. + **star** — объект звезды. + """ + + x = scale_x(star.x) + y = scale_y(star.y) + r = star.R + star.image = space.create_oval([x - r, y - r], [x + r, y + r], fill=star.color) + + +def create_planet_image(space, planet): + """Создаёт отображаемый объект планеты. + + Параметры: + + **space** — холст для рисования. + **planet** — объект планеты. + """ + x = scale_x(planet.x) + y = scale_y(planet.y) + r = planet.R + planet.image = space.create_oval([x-r, y-r], [x+r, y+r], fill=planet.color) + + +def update_system_name(space, system_name): + """Создаёт на холсте текст с названием системы небесных тел. + Если текст уже был, обновляет его содержание. + + Параметры: + + **space** — холст для рисования. + **system_name** — название системы тел. + """ + space.create_text(30, 80, tag="header", text=system_name, font=header_font) + + +def update_object_position(space, body): + """Перемещает отображаемый объект на холсте. + + Параметры: + + **space** — холст для рисования. + **body** — тело, которое нужно переместить. + """ + x = scale_x(body.x) + y = scale_y(body.y) + r = body.R + if x + r < 0 or x - r > window_width or y + r < 0 or y - r > window_height: + space.coords(body.image, window_width + r, window_height + r, + window_width + 2*r, window_height + 2*r) # положить за пределы окна + space.coords(body.image, x - r, y - r, x + r, y + r) + + +if __name__ == "__main__": + print("This module is not for direct call!") From 379a92057909e18f9cba8a8132a82815fe053487 Mon Sep 17 00:00:00 2001 From: Darina Gaff Date: Fri, 27 Dec 2019 16:26:31 +0300 Subject: [PATCH 07/15] Updated function parse_object_parameters. Fixed type of class objects params --- solar_input.py | 31 ++++++++++++++----------------- 1 file changed, 14 insertions(+), 17 deletions(-) diff --git a/solar_input.py b/solar_input.py index 7927f7c5..d068fa97 100644 --- a/solar_input.py +++ b/solar_input.py @@ -6,24 +6,21 @@ space_objects = [] + +# Заменила функции parse_planet_parameters и parse_star_parameters на эту: def parse_object_parameters(line): - """Считывает данные о звезде из строки. + + """Считывает данные о звезде или планете из строки. Входная строка должна иметь слеюущий формат: Star <радиус в пикселах> <цвет> <масса> + Planet <радиус в пикселах> <цвет> <масса> - Здесь (x, y) — координаты зведы, (Vx, Vy) — скорость. + Здесь (x, y) — координаты зведы или планеты, (Vx, Vy) — скорость. Пример строки: Star 10 red 1000 1 2 3 4 """ - params = line.split(' ') - type_ = params[0].lower() - R = params[1] - color = params[2] - m = params[3] - x = params[4] - y = params[5] - Vx = params[6] - Vy = params[7] + type_, R, color, m, x, y, Vx, Vy = line.split(' ') + type_ = type_.lower() if type_ == 'planet': obj = Planet() @@ -36,11 +33,11 @@ def parse_object_parameters(line): obj.type_ = type_ obj.R = int(R) obj.color = color - obj.m = complex(m) - obj.Fy = complex(y) - obj.Fx = complex(x) - obj.Vy = complex(Vy) - obj.Vx = complex(Vx) + obj.m = float(m) + obj.Fy = float(y) + obj.Fx = float(x) + obj.Vy = float(Vy) + obj.Vx = float(Vx) space_objects.append(obj) @@ -87,7 +84,7 @@ def read_space_objects_data_from_file(input_filename): return objects # FIXME: хорошо бы ещё сделать функцию, сохранающую статистику в заданный файл... -# Статистику чего? +# D: Статистику чего? if __name__ == "__main__": print("This module is not for direct call!") From 3077d1e08276cbcc5a711ae76ccd1b0509665355 Mon Sep 17 00:00:00 2001 From: Darina Gaff Date: Fri, 27 Dec 2019 16:27:02 +0300 Subject: [PATCH 08/15] Just for study. --- planet_and_moon.py | 107 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 107 insertions(+) create mode 100644 planet_and_moon.py diff --git a/planet_and_moon.py b/planet_and_moon.py new file mode 100644 index 00000000..8d7fb5cd --- /dev/null +++ b/planet_and_moon.py @@ -0,0 +1,107 @@ +#!/usr/bin/env python3 +# https://github.com/python/cpython/tree/master/Lib/turtledemo +""" turtle-example-suite: + tdemo_planets_and_moon.py +Gravitational system simulation using the +approximation method from Feynman-lectures, +p.9-8, using turtlegraphics. +Example: heavy central body, light planet, +very light moon! +Planet has a circular orbit, moon a stable +orbit around the planet. +You can hold the movement temporarily by +pressing the left mouse button with the +mouse over the scrollbar of the canvas. +""" +from turtle import Shape, Turtle, mainloop, Vec2D as Vec + +G = 8 + +class GravSys(object): + def __init__(self): + self.planets = [] + self.t = 0 + self.dt = 0.01 + def init(self): + for p in self.planets: + p.init() + def start(self): + for i in range(10000): + self.t += self.dt + for p in self.planets: + p.step() + +class Star(Turtle): + def __init__(self, m, x, v, gravSys, shape): + Turtle.__init__(self, shape=shape) + self.penup() + self.m = m + self.setpos(x) + self.v = v + gravSys.planets.append(self) + self.gravSys = gravSys + self.resizemode("user") + self.pendown() + def init(self): + dt = self.gravSys.dt + self.a = self.acc() + self.v = self.v + 0.5*dt*self.a + def acc(self): + a = Vec(0,0) + for planet in self.gravSys.planets: + if planet != self: + v = planet.pos()-self.pos() + a += (G*planet.m/abs(v)**3)*v + return a + def step(self): + dt = self.gravSys.dt + self.setpos(self.pos() + dt*self.v) + if self.gravSys.planets.index(self) != 0: + self.setheading(self.towards(self.gravSys.planets[0])) + self.a = self.acc() + self.v = self.v + dt*self.a + +## create compound yellow/blue turtleshape for planets + +def main(): + s = Turtle() + s.reset() + s.getscreen().tracer(0,0) + s.ht() + s.pu() + s.fd(6) + s.lt(90) + s.begin_poly() + s.circle(6, 180) + s.end_poly() + m1 = s.get_poly() + s.begin_poly() + s.circle(6,180) + s.end_poly() + m2 = s.get_poly() + + planetshape = Shape("compound") + planetshape.addcomponent(m1,"orange") + planetshape.addcomponent(m2,"blue") + s.getscreen().register_shape("planet", planetshape) + s.getscreen().tracer(1,0) + + ## setup gravitational system + gs = GravSys() + sun = Star(1000000, Vec(0,0), Vec(0,-2.5), gs, "circle") + sun.color("yellow") + sun.shapesize(1.8) + sun.pu() + earth = Star(12500, Vec(210,0), Vec(0,195), gs, "planet") + earth.pencolor("green") + earth.shapesize(0.8) + moon = Star(1, Vec(220,0), Vec(0,295), gs, "planet") + moon.pencolor("blue") + moon.shapesize(0.5) + gs.init() + gs.start() + return "Done!" + +if __name__ == '__main__': + main() + mainloop() From 379d3dc9c90aeec0b00ae74cf7d549761644c7fb Mon Sep 17 00:00:00 2001 From: Darina Gaff Date: Fri, 27 Dec 2019 16:36:31 +0300 Subject: [PATCH 09/15] Changed window size --- feature | 1 - solar_vis.py | 6 +++--- 2 files changed, 3 insertions(+), 4 deletions(-) delete mode 100644 feature diff --git a/feature b/feature deleted file mode 100644 index 36b21249..00000000 --- a/feature +++ /dev/null @@ -1 +0,0 @@ -dsfsdf diff --git a/solar_vis.py b/solar_vis.py index 071c56c2..67aeb02f 100644 --- a/solar_vis.py +++ b/solar_vis.py @@ -9,13 +9,13 @@ header_font = "Arial-16" """Шрифт в заголовке""" -window_width = 800 +window_width = 500 """Ширина окна""" -window_height = 800 +window_height = 500 """Высота окна""" -scale_factor = 100 +scale_factor = None """Масштабирование экранных координат по отношению к физическим. Тип: float Мера: количество пикселей на один метр.""" From 382a7e396e02b86f8c875062f8a89704983c07c8 Mon Sep 17 00:00:00 2001 From: Darina Gaff Date: Fri, 27 Dec 2019 16:37:27 +0300 Subject: [PATCH 10/15] TO-DO: fix ZeroDivisionError --- solar_main.py | 3 +++ 1 file changed, 3 insertions(+) diff --git a/solar_main.py b/solar_main.py index d77bddca..7083e5ac 100644 --- a/solar_main.py +++ b/solar_main.py @@ -80,6 +80,9 @@ def open_file_dialog(): space.delete(obj.image) # удаление старых изображений планет in_filename = askopenfilename(filetypes=(("Text file", ".txt"),)) space_objects = read_space_objects_data_from_file(in_filename) + # FIXME ! + # ZeroDivisionError: float division by zero + # Why var max_distance is 0? max_distance = max([max(abs(obj.x), abs(obj.y)) for obj in space_objects]) calculate_scale_factor(max_distance) From 0b838f7c6ea2f912ca8421bc3152ef8055199ca3 Mon Sep 17 00:00:00 2001 From: Darina Gaff Date: Fri, 27 Dec 2019 21:22:09 +0300 Subject: [PATCH 11/15] Fixed problems --- README.md | 5 +---- solar_input.py | 4 ++-- solar_main.py | 4 ++-- solar_model.py | 13 +++++-------- solar_objects.py | 28 ++++++++++++++++++++++++++++ 5 files changed, 38 insertions(+), 16 deletions(-) diff --git a/README.md b/README.md index 099aeab4..e2b46a42 100644 --- a/README.md +++ b/README.md @@ -1,7 +1,4 @@ # solar_project Модель Солнечной системы на языке Python -##TODOS: -* solar_vis.py -1. Fix scale_y function. -2. Fix create_planet_image function. \ No newline at end of file +Работает!! \ No newline at end of file diff --git a/solar_input.py b/solar_input.py index d068fa97..549c0436 100644 --- a/solar_input.py +++ b/solar_input.py @@ -34,8 +34,8 @@ def parse_object_parameters(line): obj.R = int(R) obj.color = color obj.m = float(m) - obj.Fy = float(y) - obj.Fx = float(x) + obj.y = float(y) + obj.x = float(x) obj.Vy = float(Vy) obj.Vx = float(Vx) diff --git a/solar_main.py b/solar_main.py index 7083e5ac..35218e16 100644 --- a/solar_main.py +++ b/solar_main.py @@ -87,9 +87,9 @@ def open_file_dialog(): calculate_scale_factor(max_distance) for obj in space_objects: - if obj.type == 'star': + if obj.type_ == 'star': create_star_image(space, obj) - elif obj.type == 'planet': + elif obj.type_ == 'planet': create_planet_image(space, obj) else: raise AssertionError() diff --git a/solar_model.py b/solar_model.py index ce6437f9..00854f30 100644 --- a/solar_model.py +++ b/solar_model.py @@ -14,17 +14,14 @@ def calculate_force(body, space_objects): **space_objects** — список объектов, которые воздействуют на тело. """ - body.Fx = 0 - body.Fy = 0 + body.Fx = body.Fy = 0 for obj in space_objects: if body == obj: continue # тело не действует гравитационной силой на само себя! - r = ((body.x - obj.x) ** 2 + (body.y - obj.y) ** 2) ** 0.5 - dax = obj.x - body.x - day = obj.y - body.y - sin = day / r - cos = dax / r - F = (gravitational_constant * body.m * obj.m) / (r ** 2) + r = (((body.x - obj.x)**2) + ((body.y - obj.y)**2)) ** 0.5 + F = - gravitational_constant * body.m * obj.m/r**2 + cos = (obj.x - body.x)/r + sin = (obj.y - body.y)/r body.Fx += F * cos body.Fy += F * sin diff --git a/solar_objects.py b/solar_objects.py index 1118aaf3..d69bf6f8 100644 --- a/solar_objects.py +++ b/solar_objects.py @@ -41,6 +41,20 @@ class Star: image = None """Изображение звезды""" + def __repr__(self): + return print({ + 'type': self.type_, + 'm': self.m, + 'x': self.x, + 'y': self.y, + 'Vx': self.Vx, + 'Vy': self.Vy, + 'Fx': self.Fx, + 'Fy': self.Fy, + 'R': self.R, + 'color': self.color + }) + class Planet: """Тип данных, описывающий планету. @@ -80,3 +94,17 @@ class Planet: image = None """Изображение планеты""" + + def __repr__(self): + return print({ + 'type': self.type_, + 'm': self.m, + 'x': self.x, + 'y': self.y, + 'Vx': self.Vx, + 'Vy': self.Vy, + 'Fx': self.Fx, + 'Fy': self.Fy, + 'R': self.R, + 'color': self.color + }) From 57b572dda8bd0577245253b52500a88b69aca8d5 Mon Sep 17 00:00:00 2001 From: Darina Gaff Date: Fri, 27 Dec 2019 21:59:03 +0300 Subject: [PATCH 12/15] Change type of R --- solar_input.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/solar_input.py b/solar_input.py index 549c0436..83b1d709 100644 --- a/solar_input.py +++ b/solar_input.py @@ -31,7 +31,7 @@ def parse_object_parameters(line): raise ValueError obj.type_ = type_ - obj.R = int(R) + obj.R = float(R) obj.color = color obj.m = float(m) obj.y = float(y) From 0438f813e03e18d9492a07f692fb02262c7a0d44 Mon Sep 17 00:00:00 2001 From: Darina Gaff Date: Fri, 27 Dec 2019 22:00:00 +0300 Subject: [PATCH 13/15] Change window size --- solar_vis.py | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/solar_vis.py b/solar_vis.py index 67aeb02f..dc6ddb87 100644 --- a/solar_vis.py +++ b/solar_vis.py @@ -9,10 +9,10 @@ header_font = "Arial-16" """Шрифт в заголовке""" -window_width = 500 +window_width = 800 """Ширина окна""" -window_height = 500 +window_height = 800 """Высота окна""" scale_factor = None @@ -39,7 +39,7 @@ def scale_x(x): **x** — x-координата модели. """ - return int(x*scale_factor + window_width//2) + return int(x*scale_factor) + window_width//2 def scale_y(y): @@ -54,7 +54,7 @@ def scale_y(y): **y** — y-координата модели. """ - return int(y*scale_factor + window_width//2) # FIXME + return int(y*scale_factor) + window_width//2 # FIXME def create_star_image(space, star): From 4fb490c770a54ca499a20dab5b5ad6cddcfacc56 Mon Sep 17 00:00:00 2001 From: Darina Gaff Date: Fri, 27 Dec 2019 22:01:48 +0300 Subject: [PATCH 14/15] Fixed a formula --- solar_main.py | 3 --- solar_model.py | 4 ++-- 2 files changed, 2 insertions(+), 5 deletions(-) diff --git a/solar_main.py b/solar_main.py index 35218e16..ff209fe4 100644 --- a/solar_main.py +++ b/solar_main.py @@ -80,9 +80,6 @@ def open_file_dialog(): space.delete(obj.image) # удаление старых изображений планет in_filename = askopenfilename(filetypes=(("Text file", ".txt"),)) space_objects = read_space_objects_data_from_file(in_filename) - # FIXME ! - # ZeroDivisionError: float division by zero - # Why var max_distance is 0? max_distance = max([max(abs(obj.x), abs(obj.y)) for obj in space_objects]) calculate_scale_factor(max_distance) diff --git a/solar_model.py b/solar_model.py index 00854f30..78c1cb8e 100644 --- a/solar_model.py +++ b/solar_model.py @@ -20,8 +20,8 @@ def calculate_force(body, space_objects): continue # тело не действует гравитационной силой на само себя! r = (((body.x - obj.x)**2) + ((body.y - obj.y)**2)) ** 0.5 F = - gravitational_constant * body.m * obj.m/r**2 - cos = (obj.x - body.x)/r - sin = (obj.y - body.y)/r + cos = (-obj.x + body.x)/r + sin = (-obj.y + body.y)/r body.Fx += F * cos body.Fy += F * sin From 2a6cd4732aefbfcfbf96aae4f0df6622ae117408 Mon Sep 17 00:00:00 2001 From: Darina Gaff Date: Fri, 27 Dec 2019 23:26:06 +0300 Subject: [PATCH 15/15] Done --- solar_system.txt | 4 ++-- solar_vis.py | 6 +++--- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/solar_system.txt b/solar_system.txt index 7aa333bb..91b46927 100644 --- a/solar_system.txt +++ b/solar_system.txt @@ -1,5 +1,5 @@ -# Солнечная система -Star 2 red 1.98892E30 0 0 0 0 +# Солнце +Star 25 red 1.98892E30 0 0 0 0 # Меркурий Planet 2 orange 3.302E23 57.909E9 0 0 47.87E3 diff --git a/solar_vis.py b/solar_vis.py index dc6ddb87..138dddad 100644 --- a/solar_vis.py +++ b/solar_vis.py @@ -9,10 +9,10 @@ header_font = "Arial-16" """Шрифт в заголовке""" -window_width = 800 +window_width = 1200 """Ширина окна""" -window_height = 800 +window_height = 1000 """Высота окна""" scale_factor = None @@ -54,7 +54,7 @@ def scale_y(y): **y** — y-координата модели. """ - return int(y*scale_factor) + window_width//2 # FIXME + return int(y*scale_factor) + window_width//2.5 def create_star_image(space, star):