Форум программистов, компьютерный форум, киберфорум
Python
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
2 / 2 / 0
Регистрация: 24.04.2011
Сообщений: 70

TPG в Python

17.04.2012, 22:36. Показов 1008. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
(помогите пож-та сделать для одной функции хотя бы, чтобы был пример что делать дальше)
Нужно выполнить с использованием генератора синтактических анализаторов TPG на основе синтактических конструкций для типов данных, определенных при выполнении на языке Haskell.

вот такая задача, сделанная нашими общими усилиями на Хаскеле:
(функция area- площадь фигуры , getRectangles-из списка фигур выбирает треугольники, getBound-по фигуре возвращает, ограничивающий ее прямоуг-к, и другие...)
Haskell
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
data Figure =  Circle Double Double Double 
         | Rectangle Double Double Double Double
         | Triangle Double Double Double Double Double Double
         | TextField Double Double String Font deriving (Eq, Show)
 
mini :: (Double , Double , Double) -> Double
mini (a,b,c) = if (a<=b)&&(a<=c) then a else if (b<=a)&&(b<=c) then b else c
 
maxi :: (Double , Double , Double) -> Double
maxi (a,b,c) = if (a>=b)&&(a>=c) then a else if (b>=a)&&(b>=c) then b else c
 
charSize :: Font -> Double
charSize Courier = 15
charSize Lucida = 14
charSize Fixedsys = 13
 
distance :: Double -> Double -> Double -> Double -> Double
distance a b c d = sqrt ((c-a)^2+(d-b)^2)
 
data Font = Courier | Lucida | Fixedsys deriving (Eq , Show)
dl :: [a] -> Double
dl [] = 0
dl s = 1.0 + dl (tail s)
 
area :: Figure -> Double
area (Circle x y r) = 3.141592 * r * r
area (Rectangle a b c d) = (c-a)*(d-b)
area (Triangle x1 y1 x2 y2 x3 y3) = 
      let {d1 = distance x1 y1 x2 y2 ; d2 = distance x3 y3 x2 y2 ; d3 = distance x1 y1 x3 y3 ; p = (d1+d2+d3)/2}
         in sqrt (p*(p-d1)*(p-d2)*(p-d3))
area (TextField x y str fnt) = (dl str) * (charSize fnt) * 7
 
getRectangles :: [Figure] -> [Figure]
getRectangles [] = []
getRectangles ((Rectangle a b c d):xs)  = (Rectangle a b c d):(getRectangles xs)
getRectangles (_:xs) = getRectangles xs
 
getBound :: Figure -> Figure
getBound (Circle x y r) = (Rectangle (x-r) (y+r) (x+r) (y-r))
getBound (Rectangle a b c d) = Rectangle a b c d
getBound (Triangle x1 y1 x2 y2 x3 y3) = Rectangle (mini (x1,x2,x3)) (maxi (y1,y2,y3)) (maxi (x1,x2,x3)) (mini (y1,y2,y3))
getBound (TextField x y str fnt) = Rectangle x (y+charSize (fnt)) (x+7*dl(str)) y
 
getBounds :: [Figure] -> [Figure]
getBounds [] = []
getBounds s = (getBound (head s)):(getBounds (tail s))
 
beInRect :: Double -> Double -> Figure -> Bool
beInRect x y (Rectangle a b c d) = if (x>=a && x<=c && y<=b && y>=d) then True else False
 
getFigure :: Double -> Double -> [Figure] -> Maybe Figure
getFigure x y [] = Nothing
getFigure x y (s:xs) = if beInRect x y (getBound s)  then Just s else getFigure x y xs
 
move :: Figure -> Double -> Double -> Figure
move (Circle x y r) z1 z2 = (Circle (x+z1) (y+z2) r)
move (Rectangle a b c d) z1 z2 = Rectangle (a+z1) (b+z2) (c+z1) (d+z2)
move (Triangle x1 y1 x2 y2 x3 y3) z1 z2 = (Triangle (x1+z1) (y1+z2) (x2+z1) (y2+z2) (x3+z1) (y3+z2))
move (TextField x y str fnt) z1 z2 = (TextField (x+z1) (y+z2) str fnt)
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
17.04.2012, 22:36
Ответы с готовыми решениями:

Требуются комментарии к коду, TPG
объясните, пожалуйста, как это работает и то, что здесь используется(препод может тыкнуть пальцем в любое и спросить, а теории я даже найти...

tpg python помощь
помогите пожалуйста--- Выполняется с использованием генератора синтаксических анализаторов TPG на основе синтаксических конструкций...

Использование TPG
Начал изучать питончик. Для начала почитал всё, немного освоился, но вот дошло дело решить задачу с использованием TPG, не могу...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
17.04.2012, 22:36
Помогаю со студенческими работами здесь

Типы данных с использованием синтактических анализаторов TPG
Нужно выполнить с использованием генератора синтактических анализаторов TPG на основе синтактических конструкций для типов данных, ...

Программа с использованием генератора синтаксических анализаторов TPG на основе синтаксических конструкций для типов данных
Помогите прокоменнтировать! #!/usr/bin/python # -*- coding: utf-8 -*- import tpg class unit:

Software Developer Python/Data or ready to improve Python (Санкт-Петербург)
We are looking for experienced server-side developers who are interested in improving their skills and knowledge in Python and ETL/Data. We...

Python - момент истины. Python - как оружие возмездие против системы
Какие модули в python мне нужны для взлома баз данных? Перехвата информации? Внедрения в систему? Добавлено через 10 минут Хочу...

Cx_freeze python error in main script как исправить- Python
Пытался создать из .py .exe , но при запуске .exe получаю ошибку вот код setup.py from cx_Freeze import setup, Executable import os ...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru