Changes for page Ptolemy Browser
Last modified by Richard Kreissig on 2023/09/14 10:31
Summary
-
Page properties (1 modified, 0 added, 0 removed)
-
Objects (1 modified, 0 added, 0 removed)
Details
- Page properties
-
- Content
-
... ... @@ -29,15 +29,12 @@ 29 29 30 30 = KLighD Visualization = 31 31 32 -With our KLighD visualization, we aim to develop a Ptolemy model browser that is particularly good for readingthrough Ptolemy models. It is able to directly open Ptolemy files and display them in a way very similar to what Ptolemy users are used to seeing.32 +With our KLighD visualization, we aim to develop a Ptolemy model browser that is particularly good at helping users read through Ptolemy models. It is able to directly open Ptolemy files and display them in a way very similar to what Ptolemy users are used to seeing. The biggest change with respect to how Ptolemy shows models is that our model viewer allows to expand hierarchical actors in-place, without having to open a new window. This helps users understand the context a hierarchical actor is placed in: by understanding where inputs come from and where outputs go to, users also better understand what the hierarchical actor is doing and what it is used for. 33 33 34 -* Easy to use. 35 -* Directly open Ptolemy models in .moml and .xml files. 36 -* Have the rendering resemble the Ptolemy rendering as closely as possible. 37 -* Capability to open hierarchical actors in-place, without opening a new window. 34 +This is a screenshot of the model browser displaying the model that Ptolemy showed before, with some actors expanded: 38 38 39 39 {{warning}} 40 - Extendthissection.37 +Add screenshot. 41 41 {{/warning}} 42 42 43 43 {{tip title="Try This"}} ... ... @@ -49,8 +49,44 @@ 49 49 1. Open and close some of the hierarchical actors by double-clicking them. 50 50 {{/tip}} 51 51 52 - =HowDoesThisStuffWork?=49 +We have also added further features that may be helpful when browsing models: 53 53 51 +* Annotations can be shown or hidden. 52 +* A heuristic tries to find out which actor an annotation is providing the documentation for. This is based on the distance between actors and annotations, with a threshold value after which an annotation is considered to stand alone. This attachment between annotations and actors is displayed by a dashed line, and the layout algorithm makes sure the two are placed near each other. 53 +* Relations in Ptolemy are visualized by small diamond-shaped nodes. Often, these are only used to influence the edge routing. Since we use a layout algorithm to route edges properly, theseĀ //relation vertices// are not necessary. We replace all of them by hyperedges and route the edges properly. An option lets you disable this behaviour: then, only relation vertices with exactly one incoming and one outgoing edge are removed and replaced by a simple edge. 54 +* Expanded hierarchical nodes have a background color that gets darker with each level of hierarchy. How dark this color is can be changed to adjust for projectors and printers that are not as good at showing sublte colors. 55 +* The properties of actors and ports are shown as tool tips. This does not include advanced properties, which are those properties that start with an underscore. 56 + 57 += How This Stuff Works = 58 + 59 +All of this functionality is implemented in one main plug-in and two support plug-ins: 60 + 61 +* {{code language="none"}}de.cau.cs.kieler.ptolemy.klighd{{/code}} contains the actual transformation that turns Ptolemy files into something we can display with KLighD. 62 +* {{code language="none"}}org.ptolemy{{/code}} contains a reduced Ptolemy version that we use to render actors. Not all actors are available in this distribution. 63 +* {{code language="none"}}org.ptolemy.moml{{/code}} contains an EMF model that we use to load Ptolemy files. 64 + 65 +For the rest of this page, we will describe the basics of how the transformation works and the challenges it presented. 66 + 67 +== Architecture of the Transformation == 68 + 54 54 {{warning}} 55 - Write thissection.70 +Describe the architecture. 56 56 {{/warning}} 72 + 73 +== Generating the Basic KGraph Model == 74 + 75 +{{warning}} 76 +Describe step 1. 77 +{{/warning}} 78 + 79 +== Optimizing the KGraph Model == 80 + 81 +{{warning}} 82 +Describe step 2. 83 +{{/warning}} 84 + 85 +== Adding Rendering Information to the KGraph Model == 86 + 87 +{{warning}} 88 +Describe step 3. 89 +{{/warning}}
- Confluence.Code.ConfluencePageClass[0]
-
- Id
-
... ... @@ -1,1 +1,1 @@ 1 -770069 51 +7700697 - URL
-
... ... @@ -1,1 +1,1 @@ 1 -https://rtsys.informatik.uni-kiel.de/confluence//wiki/spaces/KIELER/pages/770069 5/Ptolemy Visualization1 +https://rtsys.informatik.uni-kiel.de/confluence//wiki/spaces/KIELER/pages/7700697/Ptolemy Visualization