Documentation Standards: Difference between revisions

From Open Source Ecology
Jump to navigation Jump to search
Line 25: Line 25:
==Open Hardware Documentation Outline==
==Open Hardware Documentation Outline==


<html><img src="https://docs.google.com/drawings/pub?id=1HJa6yWnQvXVHd72nemBcIkB67-w5RZBMJQlIeyc87M4&amp;w=1000&amp;h=600"></html>
<html><img src="https://docs.google.com/drawings/pub?id=1HJa6yWnQvXVHd72nemBcIkB67-w5RZBMJQlIeyc87M4&amp;w=1200&amp;h=700"></html>


[https://docs.google.com/drawings/d/1HJa6yWnQvXVHd72nemBcIkB67-w5RZBMJQlIeyc87M4/edit edit]
[https://docs.google.com/drawings/d/1HJa6yWnQvXVHd72nemBcIkB67-w5RZBMJQlIeyc87M4/edit edit]

Revision as of 14:33, 4 February 2013

Introduction

As OSE moves towards viral replicability, it is important to create effective documentation standards. This applies to the work of OSE and also towards creating a broader platform for open source product development. To this end, we are studying existing open source industry standards - to pick out existing best practice and to integrate these into a larger platform. The strategy is to remix as many existing tools as possible - while inspiring the related players to contribute to a greater platform.

The scope of Open Source Ecology involves machine and organization level items leading to the Open Source Economy. In Phase I (January, 2013), we are defining the standards for the 50 GVCS machines, which is intended to be a beta test for a larger platform that scales to any number of items - encyclopedic scope. Organizational aspects for creating the open source economy will be developed in Phase II (February, 2013).

The current priority is to standardize a format for documentation on the OSE Wiki.

Strategy

  • Start with Site Structure
  • Do a metadescription of Site Structure
  • Define available documentation tool standards
  • Prototype Site in WordPress on Open Materials
  • Transfer to Open Source Ecology site

Sample Implementation

Available Documentation Tools

Working Document

edit

Open Hardware Documentation Outline

edit

Sample

CEB Press Test

Documentation Platform Principles or Specification

  • Language agnostic platform
  • Readily publishable in part or in full in hard copy or digital copy
  • Promotes the open source economy and distributive enterprise
  • Clear contributor agreements and user license
  • Work Product is a Protocol, not Platform. Distinction is Protocol can be implemented on any platform.
  • Platform, hardware, and software agnostic. Uses open software formats; accepts proprietary formats so they can be translated.
  • Contains a commit and quality assurance mechanism
  • Upvotability and quality upgrade mechanism, versioning
  • Modular design of documentation, clear modularity standards for how documentation components fit together, and easy interfaceability between modules
  • Resource Description Format markup for semantic web compatibility. Tagging and markup for mashup and remix purposes. API for interoperability with other platforms.
  • Breadcrumbs - location guide or secondary navigation scheme
  • Well-defined tagging standards.
  • Entry-level access for contributors (not a geek protocol)
  • Entry-level access for developers
  • Incentivizes participation with other open source and closed source platforms.
  • Glossary is incuded, platform is self-explanatory.
  • Meritocratic governance
  • Provides an assessment mechanism for 'state of open-sourceness' of projects
  • Facilitates quantitative assessment or statistics about open hardware projects in general
  • Encourages DIY projects to join open source economic framework, and invites uninitiated DIY projects to add value to their work and to the world by making their work more visible
  • Fosters Technical Literacy
  • Ready verifiability of results
  • Backup strategy well-defined
  • Contributor rights clearly defined and designed as a Badge or Distinction. Crowd sourced contributions from users and developers; careful log of contributors

Work Product

edit

Value Proposition

The value that we propose to add to defining documentation standards is:

  • Basing platform on existing tools - building on open source industry standards and using non-open source tools only if necessary until they can be substituted.
  • Developing interfaces between existing tools, not developing new tools (remixing and mashup)
  • Documenting that interface with Brick Press as our test case
  • Defining a protocol for documentation based on existing tools
  • Getting feedback from the greater community, and defining a role for a Documentation Director for Scalable Open Source Product Distributive Enterprise Development Projects.

Design Rationale

The scope of effective documentation standards for OSE includes Machine, Organizational, and Wiki level areas of documentation.

Organizatinal Level

  • The organizational level involves documentation related to running a GVCS-based development, production, or other applied project.
  • Enterprise development documentation.

Machine Level

  • Understanding the standards makes it possible to navigate both graphically and via the address bar on the OSE wiki - to access any piece of documentation for any machine.
  • Machine naming is standard. Currently, the names used on the main site at opensourceecology.org are used.
  • Each machine has a Core and Supporting documentation set. The Core set includes those pieces of documentation that are indispensible for the safe and effective building and usage of GVCS tools by inexperienced builders/users. Supporting documentation is that which allows for the modification, remixing of modules, and other hacks on the machines. It also includes that information which makes replication easier, but which is not critical to such replication - by a novice builder.
  • Each Machine has a finite, well-defined set of Core Documentation and Supporting Documentation.
  • Supporting Documentation consists of Wiki-level (such as Links section or Index) and Machine-level items (such as CAE analysis - noncritical but desirable for replication)
  • Standards are consistent with Open Source Hardware Association Open Source Hardware Definition.

Wiki Level

  • Each machine has a particular set of wiki-level Supporting Documenation items - such as Links (example below). Standards are defined for each of these Supporting Documentation item

Specific Wiki Page Structure

Current work on Frame_DXF_Files indicates that a rigorous structure of documentation needs to occur for completeness. This structure should be represented as an infographic with design rationale (for documentation steps) captured.

Links

Past Work of OSE

Related Work

Meta

  • Resource Description Framework (RDF) - [3]. From Wikipedia article - Creative Commons - Uses RDF to embed license information in web pages and mp3 files.
  • Semantic Media Wiki extension - SMW adds semantic annotations that allow a wiki to function as a collaborative database - [4]
  • Semantic Web Challenge
  • Project Halo - The appendix to Paul Allen's new book, Idea Man, describes several challenges in artificial intelligence for which Project Halo is actively seeking solutions. We are actively seeking people and organizations with serious and well-grounded technical ideas that can result in significant progress against these challenges. Please use the Idea Submission Form to contact us with a sketch of your idea, along with any supporting evidence that it will be successful. Please do not send confidential or proprietary information to Project Halo using this site or through any other means. - see http://www.projecthalo.com/

Problem Statements

We would like to develop a platform for uniform tagging of open source hardware (OSH) to make it universally findable - so that it can be searched and results displayed. How to do this?

  1. Define uniform content taxonomy and standards (such as CAD, BOM, fabrication drawings, etc)
  2. Define uniform taxonomy for delivery of content and standards (such as Sketchup model, YouTube video, LibreCAD dxf file, etc)

Open source warehouse would be a platform where content would be submitted and viewed via an easy-to-use platform.

What are your thoughts on this? What are some seminal works on practical semantic tagging?