DEMoS Manifesto by Pedersen, Rasmus Ulslev
DEMoS Manifesto
Rasmus Ulslev Pedersen
November 12, 2018
Abstract
This is a manifesto for DEMoS, which is a Distributed Embedded Modular System,
but also a manifesto addressing the need for more inter-/cross-disciplinary mastery of
working knowledge related to installing this class of systems in the real world. There is
somehow room for yet another class of systems - complementary to existing embedded
systems - complementing distributed operating systems - which takes on an inter-
disciplinary cyber-physical-materiality approach, a dedicated holistic perspective that
recognizes the true value of interdisciplinary mastery vs. the implicit and overlooked
expense of narrow intra-disciplinary focus dominating much of systems development
(e.g. EE, CE, CS, SE, and IS). Interdisciplinary mastery yields its accumulated value
across the development, deployment, use, re-use, and decommission phases for this class
of systems: DEMoS is a system architected to be locally distributed, embedded, and
modular as outlined herein and with the additional goals of human interdisciplinary
mastery in this context: A potential set of goals for developing and applying DEMoS
can be found in UN Resolution 70/1.
In DEMoS [6] (demos also means ’common people’ ), the host SW tooling is mainly lim-
ited to multi-paradigm languages with open source implementations, e.g. the succinct
F# (in close competition with say C#, but also other languages). For low-level HW
description/verification, the Verilog HDL family is (with no serious competition) chosen:
System Verilog emerging as the likely specific candidate. It is considered if transpiling (a
sync./async. variant) of F# to (System) Verilog is worth-while endeavor in one form or
the other. On the embedded side, it would seem that any language with compiler sup-
port for the implemented instruction set is possible. However, multiple source language
support (even from within the native .NET family) is most likely not practical on the
target side (polyglot programming is harder in the embedded space!). In this case, F# [8]
seems to offer a realistic compromise between the different programming paradigms (sup-
porting both functional and/or OO programming. For PCB support of being distributed
and modular, a system based on high-density interconnects is considered. Interconnects
are currently thought to be based on Z-Ray® 1.0 mm micro arrays, and I call it ZMOD.
Considering also soldering, it, ZMOD, would make a kind of two-sided PCB available,
while only demanding single sided SMD processes; not an irrelevant consideration from a
1
ar
X
iv
:1
61
2.
04
19
1v
1 
 [c
s.O
H]
  1
1 D
ec
 20
16
maker perspective [1]. IO and some aspects of system control is thought to include use of
PC/mobile phone audio ports with supporting target circuitry. For example, it opens up
for programs or apps that support the the developer in some situations and the users in
other scenarios. Just consider trouble-shooting complete (perhaps even remote) systems
like drones, autonomous cars, robots, vessels or smaller power plant set-ups. Furthermore,
is it considered what USB/JTAG solution to use. FTDI offers non-programmable and
programmable USB solutions. Programmable USB solutions (e.g. VNC2) offer one way
to deal with some IO mess (like audIO/UART/SPI/modems/WiFi/WiFi beacon-based
protocols/BT/NFC/JTAG etc.), but with the annoyance of another SDK to learn. For
low-speed/high-speed, small/wide, and wired/wireless interconnects to other cores, sys-
tems, transceivers, etc., a language independent specification is considered to be useful.
For instance, to define mods based on the Z-Ray® micro arrays, XML or JSON-LD seem
good formats for this task. Another interconnect type that might prove useful is the well-
known ethernet cable, as it is easy to cut into any desired length and connect to other
”distant” (centimeters to meters away) DEMoS systems. Within one DEMoS system, a
specialized processor, targeting the CIL instructions, called CILOP, is situated between
DEMoS and the physical cores. One CILOP is similar to one Java Optimized Processor
[7]. The (physical) cores, currently referred to as Thunder-cores (TCORE), are sought
to have a non-rigid relationship to the operating system modules thus achieving distribu-
tion primarily within the embedded context. One DEMoS could encompass many CILOPS,
and those CILOPs could be run over multiple TCOREs, and those TCOREs could be
spread across multiple FPGAs. It should be noted that a future, but both difficult and
expensive, yet very interesting, option would be to ”harden” the CILOP using services
such as ”The MOSIS Service”. Coming back to the context, and thus the meaning of
being distributed, is different for embedded systems than for general distributed (operat-
ing) systems [3]. Distributed execution - i.e. as in one robot - demands extreme care
and understanding of the development environments/tools/processes as it is not trivial to
develop multiple systems (with separate debug cables etc.) as one conceptional DEMoS.
A basic un-distributed canonical implementation could consist of just one DEMoS running
in one Thunder-core. Thunder-cores must support efficient average execution as well as
real time applications. Needed ML/AI precision should be addressed by sensible FPU [2]
support carefully balancing both FPGA cost and library implementation. Thunder-cores
execute on an ISA currently aligned to ECMA-335, Partition III, because it is important
to retain a close link to the fundamental binary execution units (.DLL and .exe). Flexible
hardware is chosen in the form of affordable FPGAs/CPLDs, which allows more room for
form to follow function, and function to follow form, in a wide spectrum of imaginable use
cases with the developer possibly taking on an additional action research role. To support
and exploit the marvelous FPGAs, specialized hardware is considered, such as optimized
memory modules for garbage collection, stack fill/spill, context switching, process/app/OS
migration, virtualization, and (large) (shared) caches; the latter most likely an important
component to achieve meaningful distribution of data and computation. Considering the
2
many pros and cons of the current market for affordable FPGAs/CPLDs (currently e.g.
XILINX’s Artix-7 family and Intel Programmable Solutions Group’s MAX 10 series), the
MAX 10 series seems the better way to proceed. 1 mm BGA pitch is anyway the right
package to proceed with for both the MAX 10 as well as for the identified ISSI memory
modules. In addition, at least currently, Quartus Prime seems to offer faster development
flows enhancing the development experience (i.e. less time consuming).
For realization in actual prototypes and products, additive manufacturing principles
is a path worth serious pursuit: New software subscription models (e.g. from Autodesk)
makes integrated 3D visualization/simulation of both electrical circuits and (cyber) physi-
cal product parts (i.e. here understood as a limited example of cyber-physical-materiality
(cyberphysicalmateriality.org)) possible. In addition, DIN enclosures and DIN rails are
good ways to encapsulate sets of (reusable) interconnected PCB modules. It has been
considered to use DIP SPI ICs to make systematic testing and even support (e.g. firmware
upgrades, some black-box functionality, or data-logging) manageable; even when deployed.
It seems that Eurocircuits is a good PCB provider with international production, and
initial testing (using EAGLE) came out satisfactory. Visual debugging/inspection at (an
affordable, yet useful) 4-bit-nibble-level can be supported by just 4-5 leds together with
some cobber trace contacts that can be triggered using say a small metal screwdriver. It is
considered to focus on development and use of an AT-like bus command set perhaps with
words (both as hex. 0xAC and ASCII ”AC” as needed) like ”AC”/”DC”, ”ADC”/”DAC”,
”ACE”/”ACED”, or ”EDDA” together with small operands to achieve some support for
bus debugging, easy MSO triggering, useful readable tracing/logging, and data communi-
cation. A project hosting environment is thought to be at some Λ+ gitlab/github repos-
itory. To remain flexible and bazaar-like, research encouraging measures are taken; i.e.
using multi-letter (airport) codes (e.g. https://www.world-airport-codes.com/) to provide
a wide layer of evolutionary development possible on top of DEMoS modules (SW/HW
etc.) especially valuable to individual researchers, but also smaller R&D teams. It is meant
to strike a delicate balance between knowledge spill-overs (e.g. ecosystem thinking), yet
allowing amble space for working on (time-consuming) ”reference-able” research projects.
I have outlined an architecture for a system:
DEMoS ⇔ CILOP ⇔ TCORE ⇔ FPGA ⇔ ZMOD, which seems complicated at
first, but the goal of interdisciplinary mastery (from cyber-physical systems [4] to Micro
Information Systems [5]) is made possible by a setup which requires not many languages
to master: mostly namely F# and System Verilog (or similar substitutes on the SW and
HW layers). It is possible that DEMoS can yield both enlightening research within a new
branch of SE and also yield results in i.e. the Industrial Internet or areas such as many
of those outlined in UN General Assembly resolution 70/1 (Transforming our world: the
2030 Agenda for Sustainable Development [9]). DEMoS is cyber-physical-materiality and
there is no edge (as in ”the edge of the Internet”; e.g. IoT) anymore.
3
References
[1] Mark Hatch. The Maker Movement Manifesto. The Maker Movement Manifesto, pages
1–31, 2014.
[2] IEEE. IEEE Standard for Floating-Point Arithmetic, volume 2008. 2008.
[3] E. Jul, H. Levy, N. Hutchinson, and a. Black. Fine-grained mobility in the emerald
system. ACM SIGOPS Operating Systems Review, 21(5):105–106, 1987.
[4] Edward A Lee. Cyber Physical Systems: Design Challenges. In International
Symposium on Object/Component/Service-Oriented Real-Time Distributed Computing
(ISORC), pages 363–369, 2008.
[5] Rasmus Ulslev Pedersen. Micro information systems and ubiquitous knowledge dis-
covery. In Lecture Notes in Computer Science (including subseries Lecture Notes in
Artificial Intelligence and Lecture Notes in Bioinformatics), volume 6202 LNAI, pages
216–234, 2010.
[6] Rasmus Ulslev Pedersen. DEMOS Manifesto 2016, Invited Talk, UiO IfI, 2016.
[7] Martin Schoeberl, Wolfgang Puffitsch, Rasmus Ulslev Pedersen, and Benedikt Huber.
Worst-case execution time analysis for a Java processor. Software: Practice and Expe-
rience, 40(6):507–542, 2010.
[8] Don Syme, Tomas Petricek, and Dmitry Lomov. The F# asynchronous programming
model. In Lecture Notes in Computer Science (including subseries Lecture Notes in
Artificial Intelligence and Lecture Notes in Bioinformatics), volume 6539 LNCS, pages
175–189, 2011.
[9] United Nations General Assembly Seventieth Session. Resolution A/70/1. Transforming
our world: the 2030 Agenda for Sustainable Development, 2015.
4
