-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathControl.py
119 lines (91 loc) · 3.39 KB
/
Control.py
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
'''
import random, math
class ObjBase :
def __init__(self, in_name, in_type) -> None:
self.name = in_name
self.type = in_type
class GeomObj(ObjBase):
def __init__(self, in_name, in_type, in_method, in_item):
super().__init__(in_name, in_type)
self.method = in_method # The method used to generate the object --in
self.item = in_item # The items used to generate the object -- out
self.hasc = False
self.parent
def getc(self, in_tuple):
NotImplemented
def calcc(self):
NotImplemented
class Action:
def __init__(self, fn: function, parameter: list) -> None:
self.action = fn
self.parameter = parameter
def perform(self):
self.action.apply(*self.parameter)
class Construction(Action):
def __init__(self, functions: list, parameters: list) -> None:
super().__init__(functions, parameters)
class ModifyDPGraph(Action):
def __init__(self, functions: list, parameters: list) -> None:
super().__init__(functions, parameters)
class ModifyDD(Action):
def __init__(self, functions: list, parameters: list) -> None:
NotImplemented
class FullAction:
def __init__(self, actions : list) -> None:
self.actions = actions
def perform (self) :
NotImplemented
# the coordinate of the points will not be calculated until one calls function calcc of every object
'''
'''
class DDNode:
def __init__(self, obj:ObjBase):
self.obj = obj
self.parent
## The acyclic graph, nodes as geom objs, edge from a to b if the construction of a depends on b
## self.item [0] = name : str, self.item[i>0] : geomobj
class DPNode:
def __init__(self, obj : GeomObj, dplist: list):
self.obj = obj
self.parent_list = dplist ## all directly depending nodes to create this node
for i in self.parent_list: ## check that dp list is the same as
if not (i.obj in self.obj.item) :
print("Error, dependecy list is not a sublist of GeomObj.item")
self.affect_list = [] ## all other nodes that depends on this node
for i in self.dp_list:
i.affect_list += [self]
## rewrite this to GeomObj class, not here
def root() : return DPNode (None, [], "") ## the root DPNode has no corresponding object
def __repr__(self, level = 0) -> str:
if level == 0:
ret = self.obj.item[0] + "\n"
else:
ret = "\t" * (level - 1) + "--" + self.obj.item[0] + "\n"
for i in self.affect_list:
ret += i.__repr__(level + 1)
return ret
class DPGraph:
def __init__(self) -> None:
self.root = DPNode.root()
def hasfree(self):
## return a list of nodes has free
return None
def totallyfree(self):
## return a list of nodes is directly linked to root
return None
def __repr__(self) -> str:
return self.root.__repr__()
class ConstructionAction:
def __init__(self,in_name, in_gen_type, in_item_type) -> None:
pass
def generate(self, in_fun, in_check, in_errorinfo):
pass
def generate_check_triv(self, in_fun):
pass
class DependencyAction:
def __init__(self) -> None:
pass
def applyto (dptree : DependencyTree) -> None
class FullAction(ConstructionAction):
## we need function input string output Construction + Dependency
'''