Presently, I've begun to develop a thesis concept with regards to how ontologies may be applied in a sense of personal or academic knowledge management -- nothing quite so technically aspiring as the Nepomuk ontologies, though I suppose it could "Aim" towards that, at some time, as when there would be any applications to speak of that could utilize Nepomuk's facilities for adding an ontological layer onto personal information management (PIM). Presently, I'm trying to focus more about a concept of concept -- in a manner of a literary sense of concept -- such as may presented meta-semantically in extensions of the SKOS ontology.
Considering an ontology, in a generic sense, as a form of a reference medium, orthogonally, one may endeavor to view an ontology as it being essentially a literary kind of reference medium. However an ontology -- whether in RDF, OWL as extending of RDF, KIF, Common Logic, or other format -- however stored or transmitted in its essential structures, an ontology typically contains a lot of essentially textual information. In a sense of RDF, an ontology may contain textual information in forms of short texts about resources -- texts that are likewise resources, such that may be furthermore reified as resources, within any single RDF graph medium. Perhaps it may ever be recognized as a nice susbset of application media, the set of ontological graphs altogether.
Presently, I would like to denote a simple thesis statement that I've been able to etch out the raw stuff of own knowledge, this evening: In a practical application of ontologies, focusing namely on the Web Ontology Language (OWL), one may define two categories of OWL ontology for practical applications:
- Structural Ontologies, containing definitions of OWL Class, Object Property, Datatype Property, XSD Datatypes, and Annotation Properties for applications
- Instance Ontologies, as applications of structural ontologies, such that would be applied in definition of OWL Indvidual type resources, in extending of structural ontologies.
There's a fifth concept that I would like to add to that small list, this evening, if one may endeavor to develop at least an ad hoc sense of structural geneaology. It's a concept that I've yet to find any single ontology for, however -- essentially, orthogonal to an Events ontology, if there may be any single ontology for literary endeavors about constructed objects. I do know of a small few of resources I could revisit online, as to do conduct more research about that concept, perhaps this evening. I'm afraid that it might be a bit of a disorganized list, if I'd try to itemize that set of resources, immediately. It's also a task wholly orthogonal to the thesis topic that I'd hoped I might be able to begin to write down, presently -- and although the latter may be a bit of a vague idea anyway, but it's such that I'd like to continue to whittle about, literally, towards further developing an idea for application of a small set of structural ontologies and instance ontologies in ... in no exacting usage case, as yet.
In my not being direct, in this article, I'm certainly not trying to avoid mentioning any manner of a pink elephant in the room, with regards to applications of ontologies. Orthogonally, I don't personally happen to follow the logic of the Manning/Snowden/Assange conspiracy, though I have certainly read of it.
As it being an object model however, I'd say CLIM is pretty square.
Franz, Inc. publishes a VMDK edition of their semantic information systems platform, AllegroGraph. Presently, the VMDK edition includes AllegroGraph pre-installed in a 64-bit Ubuntu 14.04 OS, the Trusty Tarpaulin edition of the Debian-based Ubuntu GNU/Linux operating system. The VMDK can be installed to a virtual appliance in VirtualBox, or any number of other desktop-based virtualization systems. In a nutshell, it provides a quick start-and-go interface for working with Franz AllegroGraph.
As far as how to configure VirtualBox networking for accessing the VMDK from outside of the VMDK's software space ... that will not be presented with details, in this article. The VirtualBox manual includes the complete details of that. This article will assume that the VirtualBox virtual guest appliance is configured with VirtualBox NAT networking, with a host interface having the IP address 172.16.42.1
Moreover, this article assumes AllegoGraph is configured in agraph.cfg, with at least the following configuration directives:
Hostname 10.0.2.15 Port 10035
Thirdly, this article will assume that the VirtualBox NAT networking is configured for port forwarding in the VirtualBox interface between the virutal host OS and the virtual guest OS, simply to the effect:
172.16.42.1:10035 <=> 10.0.2.15:10035
With such a configuration installed, a developer may apply any of the AllegroGraph clients, in developing on the virutal host OS -- with apology, developing no lengthy side-thesis about software defined networking (SDN), here, or either, about integrated development environment (IDE) platforms applicable for Common Lisp software development. In a practical sense, certainly such configuration properties can be managed via software, but even in so much of automation, it probably would help to understand at least a little bit about TCP/IP networking. Within the virtual host OS, the networking and port forwarding properties can be managed via the VBoxManage shell command. Within the virutal guest OS, as in this example, the configuration properties can be managed via both of the files, /etc/network/interfaces and /home/franz/ag/lib/agraph.cfg
So, with such a configuration installed, there are the AllegroGraph clients, and a bit more of TCP/IP networking. Beyond a context of VirtualBox host-only networking, a framework for SSH port forwarding could be applied, on top of the VirtualBox port forwarding.
Presently, this thesis article will jump, by a certain distance, to develop some concepts about object models. The development of that aspect of this thesis article must naturally entail a presentation about some concepts developed in CLIM. This article will now assume an outline format, towards an overview about CLIM.
CLIM - An Overview
- Interaction
- Menus
- Key bindings
- Modeline
- Presentation
- Presentation types
- Presentation methods
- Device Interface
- CLIM port
- CLX port
- GTK Cairo port
- ...
- HCI structures in CLIM applications
- CLIM Graft and Sheet objects
- CLIM Frame objects
- The application frame class
- ...
- CLIM Pane objects
- The application pane class
- ...
- Objects displayed on a CLIM pane
- Geometric objects via CLIM drawing forms
- Text via CLIM drawing forms
- Presentations
- ...
- CLIM and Common Lisp
- Streams in CLIM
- ...
- CLIM and X.org
- XLib
- CLX
- Adding support for XFree86 shared memory extension
- TBD
- Input methods
- Integration with window managers
- Integration with desktop environments
- ...
- CLIM and text media
- ...
- ...
- Climacs
- ...
- CLIM and CORBA
- TBD - Thesis not yet developed
- Presentation Types
- Triple Store / DB
- Triple
- subject, predicate, object
- graph
- triple ID
- Resource
- Unique Part Identifier (UPI) strings
- Class
- RDF Schema
- OWL
- Annotation properties
- rdfs:label
- skos:altLabel
- skos:prefLabel
- skos:hiddenLabel
- Graph Display
- Graph 'link' properties
- e.g. SKOS broader / narrower properties
- Graph layout
- Radial graph
- Hyperbolic graph
- Tree graph
- Resources may appear multiple times in a tree graph hierarchy
- Resource aliasing for individual presentation in tree graph
- Graph Management
- Graph Management Actions (Default)
- Open graph service connection (i.e. connect to graph server)
- Create graph DB
- Delete graph DB
- Rename (?) graph DB
- Close graph service connection (i.e. disconnect from graph server)
- Graph Management Panes
- List of "registered" graph DBs
- Registry by way of application of ... something compatible with CORBA object services (TBD) (Persistent naming, etc)
- TBD: Implementing an access control layer onto AllegroGraph triple stores
- Fundamental service interface model
- Implementation as an adapter
- Graph service: AllegroGraph
- Display management: CLIM
- Integration with CORBA
- TBD - more towards providing a triples-graph service for other graph/SPARQL servers in Common Lisp or Java
- Usage Cases
- TBD
Lastly, this article will endeavor to develop a platform-agnostic view about RDF media and CLIM -- again, presented here in an outline format.
Broader Context: CLIM + Semantic Web (A Generic Model)
- RDF Resources // URI Referencing
- See also: ODM
- Generic model for collections of RDF tuples
- Concept: tuples-index
- Registration of RDF namespace per triples-index
- Classification of ontologies
- Application: Per-ontology presentation method selection
- Examples // Use Cases
- Presentation methods for SKOS Concept classes
- Presentation methods for RTM Topic classes
- Selection criteria for classification in resource => presentation type assignment
- RDF namespace of resource's RDF URI
- Type of entity (RDS class, OWL class, RDF property, OWL object property, OWL datatype property, OWL annotation property, XSD type)
- Properties defined to entity
- Requires a full-graph search initially
- List of properties may be updated on graph change
- Concern: Concurrency
- RDFS/OWL Classes & CLIM Presentation Types
- RDFS/OWL classes available only in connection to any single tuples-index
- Presentation types may be defined as in association to an individual RDF namespace
- Presentation types may be defined as in association to an individual tuples-index
- Presentation types may be defined in individual source trees
- Such source trees may be referenced as in an index or transformation of the URI of any single ontology namespace (?)
- ? Internal table for registration of presentation types for reference via presentation methods
- Concept: Presentation of tuples
- Classic presentation mode: subject, predicate, object
- Presentation of each of a subject, predicate, object will be affected by presentation method defined for each individual resource referenced in that field of each tuple
- Concept: Presentation of reified tuples
- Append 'button' area for activating presentation layer for reification data
- Project: Object model for SPARQL
- CLIM layer
- Concept: Table view (onto SPARQL)
- per each column
- An RDF/OWL property
- Column displays resource denoted in that property
- A column heading
- per each table
- SPARQL query (as an object)
- "Key" column[s]
- applicable for sorting in table display
- Concept: Graph view (onto SPARQL)
- Concept: Metadata view (onto any single set of specifications/standards/conventions in a context of linked open data )
- Arbitrary
- Usage cases (blue sky?)
- Bibliographical display and editing [application]
- "FOAFpedia" app
- Integration platform (app) for collation of bibliographical information
- Bibliographical information for "Good Jedi"
- Is not LinkedIn
- Is not Encyclopedia Britannica, etc
- Bibliographical information for "Dark side of the moon"
- Is not INTERPOL's single registry or analogous national registries
- Topic maps
- Alternate to "Mind maps"
- Concerns
- Implementation in CLIM
- Integration with file media
- Integration with desktop/mobile computing systems
- Resource graph as a central data service on each platform
- Resource graphs on desktop platforms
- Nepomuk
- TBD
- Resource graphs on mobile platforms
- See also: androjena
- Resource graphs on enterprise server platforms
- (?)
- Service model
- Interface model
- Resource=>application dispatching on Android platform - i.e "Open with..."
- See also:
- Java Content Repository (JCR) (2.0)
- JSR-283
- Implementations (Java)
- DOM L3 Load & Save
- Towards a streams model for CORBA
- Integration with web media
- See also
- Vincent, Cristopher R. W3P: A Portable Presentation System for the World-Wide Web
- HTTP Services - Common Lisp
- CL-HTTP at NTT-Data
- Hunchentoot
- Concept: HTTP as an application-layer service
- OSI seven layer model
- TCP sockets
- Trivial request/response cycle
- Response codes
- HTTP 1.1 - See also
- In Proceedings: The Eighth International World Wide Web Conference (1999)
- Krishnamurthy et. al. Key Differences between HTTP/1.0 and HTTP/1.1
- Kaplan and Oldham. Managing TCP Connections under Persistent HTTP
- HTTP proxying
- WebDAV
- Concept: HTTP as a CORBA object service
- Web resource as object
- Accessible via HTTP/HTTPS
- Identified with a request URI
- Related: Request method (GET, POST, etc)
- May require persistent state data for access
- Persistent client identity data (cookies)
- Writable via WebDAV
- CORBA
- ODM
- Prolific mobile computing
- Mobile operating systems utilizing the Linux kernel
- Android platform
- Manufacturer-specific applicaitons
- Firefox OS
- Apple iOS
- BlackBerry
- See also: QNX
- Prolific laptop computing
- Google Chromebook
- Also based on the Linux kernel
- Microsoft Windows laptops
- ...
- Ubuntu laptops
- HP TouchSmart laptops
- FreeBSD desktop distributions
- ????
- Computing in Small Office/Home Office (SOHO) Environments
- Software Defined Networking (SDN) as scalable online service platform
- Amazon Web Services (AWS)
- OpenShift Origin
- Digital Ocean
- ...
- System on Chip (SoC) platforms and single-board computing platforms
- Texas Instruments AM35xx Sitara SoC
- BeagleBone Black
- Allwin A20 SoC
- Cubieboard 3 (Cubietruck)
- Broadcom BCM2835 SoC
- Raspberry Pi
- Alternate design concept: Computer on module (CoM)
- Juxtaposed to SoC as a design concept
- Commercially, another delivery platform for manufacturer's microcircuit designs
- e.g. Gumstix
- Company profile at Texas Instruments
- See also: Gumstix Gepetto