-
Notifications
You must be signed in to change notification settings - Fork 74
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Graphs for knowledge representation #63
Comments
In a sense, federated wiki itself is already a graph: http://search.fed.wiki.org:3030/graph/bundle.html Did you run into fedwiki/wiki-plugin-linkmap#2 yet? It seems we share some of the links. |
Regretfully the linkmap plugin has suffered from some neglect. It dates way back to the period where we were most interested in collecting and visualizing real-time data. The link structure of a wiki seemed a convenient source, the web-socket protocol seemed a capable channel, and the d3.js force layout seemed the most likely future for interactive visualizations. We demonstrated all of these to be true but then stopped short of making this a practical tool. The about page includes a demonstration. Here is a snapshot I just took after clicking the most central node in the graph to open the welcome page. I will list some of the deficiencies here from memory.
All this adds up to make linkmap more of an existence proof than a useful tool. I welcome suggestions for how some or all of this could become an everyday utility for all federated wiki readers and authors. |
Count me in. I have a number of Fedwiki pages listing software and On Friday, 6 November 2015, Ward Cunningham [email protected]
|
I think there are two distinct high-level use cases in this discussion: "Graphs of Wiki" and "Graphs in Wiki". "Graphs of Wiki" are representations of the network topology of pages and links in the wiki. They are machine-generated and not directly human-curated, save through edits in the original pages. "Graphs in Wiki" are networks defined in wiki markup, then transformed into visualizations, statistics, or other representations on the page. Knowledge representation is one of many use cases for a graph defined in a wiki: Such an approach could also be useful for collaborative network definitions of any kind, e.g. a social network. If we can figure out which types of networks we want humans to be able to create for the latter, it would of course be possible to write code that would generate the markup for the former. Disclaimer: I'm writing my ideas about both here as a way to explore the topics. I invoke Franklin: "I have already made this paper too long, for which I must crave pardon, not having now time to make it shorter." What problems are we trying to solve with a graph representation?Here are a few options that come to mind of computationally difficult but useful tasks for which network analytics provide new information that can help drive a decision: • Automatic community detection "A map (or graph) could aid the visualization in various groupings of patterns". An example of this is below. Graphs of WikiVisualizing fedwiki as a network. The Linkmap plugin "will ask the server to create a map of all its pages and the links between them". I think this is an interesting topic, but this wasn't the primary focus of the conversation I had with @coevolving that started this thread. Graphs in WikiDefining a network in wiki markup. As a concrete example, @coevolving created a visualization of an influence network of C.A.'s A Pattern Language Which Generates Multi-Service Centers as SVG. Of course, SVG does not separate presentation and content: Let's explore representing this network in a manner that does. First, let's describe this network as a unimodal directed graph in one dimension. What does that mean and why do we care? Knowing that the network is unimodal and that edges have uniform meaning is important for many network analytics such as community detection and centrality algorithms. Vertices: All vertices represent a pattern in the language. Since all the vertices are the same, this is formally known as a unimodal network. Edges: An edge between two vertices is directed and represents influence: "An example would be handy right about now..." The SVG of the 64 vertex multi-service center pattern language can be transformed into a TGF representation that yEd understands. TGF is purely a representation of network structure, and includes no presentation concerns. yEd can handle the presentation: Hierarchical Layout, similar to the original SVG Circular Layout, ranked by out-degree Organic layout grouped by detected communities, sized by out-degree TGF comes with trade-offs: Pros: • Human readable and writable • Easily converted to other representations and exported as CSV, graphml, TGF, etc. for offline analysis or for use in other tools, including JavaScript visualization libraries. Cons: • Doesn't easily capture more complex k-partite networks containing multiple types of vertices, and so doesn't handle @coevolving's OPM use case; more formally, such networks are multipartite edge-labeled multigraphs and are the most complex that a wiki would need to support unless someone can make a case for hypergraphs. TGF does support edge labels, and so can handle multi-dimensional graphs, but I'm not aware of a way to support vertex types. • Doesn't capture vertex or edge properties other than a label. The TGF representation above omits the url's embedded in the SVG vertices for the moment...I'll return to that below. These are serious drawbacks: Many types of systems are intuitively represented as a multidimensional network with different types of vertices and edges in the same diagram. Even for a unipartite directed graph, vertex and edge properties can be useful. TGF wasn't intended to be a universal graph format, however...hence "trivial". I took the time to illustrate what a TGF representation looks like not to espouse it or yEd, but to show that the appeal of TGF is its simplicity. Leaving off any XML or JSON syntax and presentation allows for relatively easy human reading and writing while maintaining just enough structure to make programmatic parsing easy. Extending TGF with Properties...PGF?Adding a map of properties on the TGF structure would allow arbitrarily complex graphs to be represented. TGF doesn't currently support this, but maybe we'll create a new graph representation format right here: Property Graph Format. Extending a few of the edges from the 64 patterns with the URL's from the SVG we omitted earlier could like something closer to DOT graph description language, but in a tool and domain-agnostic way:
I think this type of notation will also accommodate @coevolving's dishwasher / OPM example. A simple representation of some dishwasher states could include:
This description is similar to the "Object-Process Language" that accompanies an "Object-Process Diagram" in the OPM methodology. Note again the separation of content from presentation. Rather than support OPL in wiki, which requires a richer grammar, what does this look like in PGF?
Translating to OPL and rendering could produce a diagram similar to OPD. For a brief introduction to OPM from the principal investigator, Dov Dori, see this presentation from the MIT SDM Systems Thinking Webinar Series: The Maturation of Model-Based Systems Engineering: OPM as the ISO Conceptual Modeling Language Standard PGF could readily be transformed into something other tools understand. jsfiddle would be a great place to experiment with vis.js to prototype this idea by transforming PGF into the json format supported by vis.js. Visual EditingIt's possible to edit a network directly in JavaScript and avoid editing the text representation directly. This could simplify the otherwise somewhat burdensome task of keeping track of vertex id's when creating edges. See http://visjs.org/examples/network/other/manipulation.html for an example of a drag-and-drop interface for vertex and edge creation. Given there would be a need for persisting any edits, however, we still would need to decide how the serialized version of the graph would be represented. What do you think of this approach to "Graphs in Wiki"? Is a markup like the proposed PGF worth pursuing? Should we be solving for "Graphs of Wiki" first? Something altogether different? |
Having now read the Model Based Systems Engineering slides, and especially the section titled "Towards ontological grounding of model-based systems engineering", I am even more excited to embed relations in wiki pages. I have implemented behavior with Method plugins and shown these can be assembled into models various ways. One approach used by the Reduce plugin is to list pages with links in a reserved region of the page. See wiki. An even better approach would be to open computational pages in a lineup, confirm that it exhibits the desired computation by wiggling numbers and observing results, then compress the lineup into a single item, a Relation of pages, that can be dropped into more complex computations. |
Great. I'm really excited about cystoscope in this respect. It avoids the It's a node project, and would make a fantastic plugin. It is able to do It would be great if anyone interested in graphs could turn up to the On Saturday, 7 November 2015, Ward Cunningham [email protected]
|
@bobbyno is it OK to copy your text to Fedwiki - better still if you ad it to your site _ I can then fork it :) Reminder: 3:30pm GMT today - cytoscape.org Fedwiki plugin session - hoping some people here will be interested in joining. |
I will be online at https://plus.google.com/hangouts/_/gurhygn42rrdr4ux3kvoscwcfia |
@opn - Sure, feel free to copy this post to fedwiki. I haven't yet set up my own server, but am planning on doing so soon. Wish I could join the Cytoscape session, but have some other engagements today. It's been several years since I looked at Cytoscape and I'd forgotten about it: Looking forward to seeing what you all find out! |
@opn, @maxkfranz and I met for an hour today online and at mozfest in London. We wrote the CytoDemo plugin and experimented briefly. We wrote a graph in the wiki text editor that contained one node.
This rendered as one large dot. Makes sense. I was thrilled. But eager to move on we extended this to two dots, then three.
My mind boggles thinking of all the extra stuff we can put inside of the brackets. To show off some wiki things I suggested pulling up the second version from the journal. This worked, rendering the third and second versions side by side. I convinced Max to fork the second version back from history which he did. What we didn't explore was how a large model could be built and rendered piecemeal over multiple servers. That is a hot button for me at the moment. But I look forward to playing with the demo a little first. Max, please take a moment to add your name and repo info to the package.json and publish that plugin to npm. |
Catching up to the progress ... Cytoscape uses XGMML, which is a trivial conversion from [GML](Graph Modelling Language) ... which is different from GraphML and TGF. Since the federated wiki is written in node.js, the "Graph theory (a.k.a. network) library for analysis and visualisation" is described at http://js.cytoscape.org/:
|
In a different style (or paradigm) is recent progress on Oink Network Graph Visualization with a video. There's been some side discussion with @marubinotto and @KnowledgeGarden. |
@coevolving Yes indeed. I've got a room at oinker.me in which I am working with @marubinotto to learn how to use the platform. At the moment, that room is private, but I'm starting to think seriously about making it public. |
@WardCunningham @opn I've uploaded the plugin demo that we created during the call to https://github.com/cytoscape/wiki-plugin-cytodemo I've also uploaded it to npm : https://www.npmjs.com/package/wiki-plugin-cytodemo It might be useful for playing around with right now, but we should probably think of a more permanent place to put a more formalised plugin -- maybe under the My Google username is maxkfranz; feel free to add me to the call on Wed. Talk with you then! |
Thank you @maxkfranz for posting this. The npm module can be included in any site by the mechanisms described in Maintaining a Custom Wiki. wiki As anyone can tell from this issue alone there is considerable interest in representing and manipulating graphs in wiki. I suggested we focus first on demonstrating the capabilities of Cytoscape.js before thinking about all the ways it might fit into wiki workflows. I suggest we continue this exploration by contributing pull requests to the cytoscape repo where they might be reviewed by Max for correct and effective use of Cytoscape.js. Discussions that are more about graphs in general and possible more complete integration of Cytoscape with wiki are still welcome here. |
Dear @maxkfranz I've forked your repository for documentation purposes to a curated list of widespread wiki contributions at https://github.com/federated-wiki so it can stay somewhat attached to the federated wiki namespace. |
I'm failing to get the plugin installed properly: first it had a couple of
and: Warning: Cannot find module 'coffeeify' from
I'm not sure if I needed to add the -g option? After which I can npm install and grunt build - but the plugin does not plugin error SyntaxError: JSON.parse: unexpected character at line 1 column
Anyone tell me what I'm doing wrong? On 14 November 2015 at 20:11, jon r [email protected] wrote:
|
@opn The plugin as published did not include the edits we made to the about page. The error comes from the plugin attempting to parse the mkplugin.sh default text as if it were json. Ironically this is not an easy thing to correct since the error message does not (yet) allow for editing the item's text. I've submitted this error handling improvement: fedwiki/wiki-client#141 With this improvement I was able to insert the json from another example and get it to render, but not with all the visual control I would expect. example I will push my work-in-progress to github and send Max a pull request as soon as I have enough done to merit his attention. (cytoscape/wiki-plugin-cytodemo#3) |
OK - tried updating - Now I get this error: [email protected] node_modules/grunt
|
Related to graph representations, thanks to Patrick Durusau, just discovered this: |
Over the holidays I have been experimenting with neo4j and recording my experiences including screen shots from their ad-hoc query tool. I'm making batch import files from the federation scrape available for those who would like to follow along. wiki The nodes and relationships I import look like this. Here is a query and results for one particular who-links-here search.
|
Now, that's what I'm talkin' about!!! Many thanks, Ward. Happy New Year On Sat, Dec 26, 2015 at 3:22 PM, Ward Cunningham [email protected]
|
That looks really interesting! Make sure to let me know if you need any help with the Cytoscape side of things. Thanks |
If anyone's interested, I built a project called Wikipedia Map which is a tool that does exactly this for Wikipedia pages. However, the backend is completely separate from the front-end, not sprinkled within. This makes it very easy to adapt the project to work with new data sources, simply by changing out the API methods in the backend, without touching much of anything in the interface. If you guys want to try to adapt a similar version to work with fedwiki, you're welcome to. It's 100% open source here on GitHub |
Best @The-Penultimate-Defenestrator, there is an older project called wikiGraph, which follows a similar approach to your software. It would be interesting to see direct linking to expanded graphs like linking to federated wiki lineups. Have you ever worked with federated wikis before? |
No, I haven't. I just found this page as something describing a similar
|
@The-Penultimate-Defenestrator I have tried to answer your question in controversial/wikipedia-map#18. Let's move this conversation there. |
@opn and I have created a strawman Graph plugin with wiki-friendly graph markup. For example, the circular graph for RSP could be written in one line:
This renders as three nodes and three arcs. Node names need not be pages but if they are they will link. Names are automatically abbreviated but show full on hover. If a graph mentions the page that holds the plugin then that node is highlighted in yellow signalling "you are here".
The markup is smart about line breaks rather than requiring lots of punctuation. Subgraphs need not connect but could be connected by Graphs resident elsewhere. Graphs on other pages can be merged into arbitrarily large networks. The lineup, the neighborhood, rosters or search engines can guide retrieval. We anticipate other plugins participating, especially the Transport plugin which is happy to engage remote services for rendering large graphs. The dependency-free coffeescrip source is on github I've installed this work in progress on one wiki where anyone can try it out saving their work in browser local storage. wiki Enjoy. |
My work continues on the Graph plugin, the GRAPH option to the Transport plugin, and a graphviz endpoint on the Image Transporter. I'm now working quickly through variations of the pattern semilattice example in The Timeless Way of Building. Here are screenshots and a link. I start with an inventory of patterns. I build by clicking on adjacent patterns. I'm offered to make these blank pages but I choose instead to use the Pattern Template that I have prepared. Among other items, the template has a Graph plugin referring only to HERE, a keyword for the new page. I then cross-connect them by dragging each page flag onto the other graph. The template also has a link to the Lineup Viewer that will send the graphs to be rendered together with graphviz and returned as one more wiki page. I'm using graphviz here but any other graph rendering technology could substitute. Graphviz will handle medium to large graphs well. My transporter keeps and serves a copy of the graphs it renders independent of the wiki page it produced. For large graphs this might be the prefered way to view them. Try this yourself by finding your unique path through the Half-Hidden Garden and plot it with the Lineup Viewer. Find my notes on Knowledge Graphing on my branch of the goals wiki. |
There is an error on the
There should be a coma between |
@paul90 Thanks for the correction. Done. I guess my browser is more tolerant of malformed CORS headers. Out of curiosity, what are you using and where did this message appear.? |
We have extended the federated wiki repertoire of plugins with a subgraph notation suitable for describing, say, an individual pattern in its upward and downward context. Browsing patterns will leave a sequence of these in the lineup. With this pull request we extend the Cytodemo plugin to recognize this collection of subgraphs, merge them into a single graph and then plot this composite with Cytoscape. |
Eighteen months ago we created a graphviz plugin: https://github.com/dobbs/wiki-plugin-graphviz. Here is an example of graphs in wiki which demonstrate use of graphviz subgraphs, color schemes, and two different shapes. Short story here is that all of graphviz DOT is available. Here are a couple examples of graphs of wiki... where diagrams are computed from the wiki content: More info about the plugin and usage can be found here: https://goals.pods.wiki.dbbs.co/about-graphviz-plugin.html |
Let's start a discussion thread on potential approaches to graphs (which some might call maps) for the federated wiki. @bobbyno and I spent 90 minutes discussing this so far. I will be travelling for some weeks, so writing may help clarity, that we can discuss together on a future video call.
A story: For a new pattern language (for service systems), federated wiki should work well for one pattern each page. However, if the number of patterns gets to be large (say, 100), selecting a subset (say, 12) and appreciating the relations between them could be difficult. A map (or graph) could aid the visualization in various groupings of patterns.
Christopher Alexander himself had a artistically-drawn graph in his 1968 book on Multi-Service Centers.
Some features: To improve the quality of systems thinking (i.e. perspectives on parts and wholes), it would be helpful to differentiate between structures (e.g. part-part arrangements in space) and processes (e.g. part-part arrangements in time). This has been a direction encouraged in the systems engineering community with INCOSE, in Object Process Methodology. The essential constructs are (i) objects (drawn as rectangles), (ii) processes (drawn as ovals) and (iii) states (drawn as rounded rectangles). Edges are directed. If we could get non-technical professionals (e.g sociologists, not engineers) to draw rectangles and ovals, even if all of the edges were not correctly represented, we would be ahead. The assessment to date is that non-technical systems thinkers can't handle the 13 constructs of SysML.
Two directions
(1) We could start with Trivial Graph Format, and add some additional markup to differentiate between rectangles, ovals and rounded rectangles. TGF is not a formally accepted standard, so this could be a simpler way to represent the graph.
(2) We could aim for the DOT graph description language and choose a subset of basics to implement. The simple example of an ethane molecule doesn't look too hard. This approach may be more complicated to manage if the diagram gets large.
Technologies to learn from
(a) Tiddlymap "is a TiddlyWiki plugin that allows you to link your wiki-topics (tiddlers) in order to create clickable graphs". In TiddlyWiki 5 (i.e. the node.js version), the plugin uses Vis.js.
(b) The Graphviz plug-in for Dokuwiki " can create directed and non-directed graph images from a textual description language called 'dot' using the Graphviz program".
(c) The Graphviz extension for Mediawiki " lets you create and display graphs as in-line images on wiki pages using tools from the open-source Graphviz and Mscgen projects".
(d) yFiles for HTML "features advanced UI controls for viewing and editing diagrams and unequaled layout algorithms for automatically arranging complex diagrams at the click of a button".
(e) draw.io is a "free online diagram software for making flow charts, process diagrams, org charts, UML, ER and network diagrams", built on top of mxGraph.
@bobbyno and I talked through part of a typical dishwasher example used in systems engineering training. Objects include (i) a door and (ii) a switch. States include (i) switch open and (ii) switch closed. Processes include (i) closing the door, (ii) washing dishes, and (iii) opening the door.
The simplest implementation could be just for TGF. However, satisfying the story described above leads to a slightly larger minimal viable product.
How should we think about approaching the representation of graphs in a wiki?
The text was updated successfully, but these errors were encountered: