/[dtapublic]/pubs/papers/20060327_phd_topic_proposal/phdtopicpropa.tex
ViewVC logotype

Annotation of /pubs/papers/20060327_phd_topic_proposal/phdtopicpropa.tex

Parent Directory Parent Directory | Revision Log Revision Log


Revision 8 - (hide annotations) (download) (as text)
Fri Oct 7 03:14:27 2016 UTC (7 years, 7 months ago) by dashley
File MIME type: application/x-tex
File size: 43536 byte(s)
Commit of Ph.D. topic proposal.
1 dashley 8 %$Header: /home/dashley/cvsrep/e3ft_gpl01/e3ft_gpl01/dtaipubs/cron/2006/phdtopicpropa/phdtopicpropa.tex,v 1.20 2006/03/27 00:10:30 dashley Exp $
2     \documentclass[letterpaper,10pt,titlepage]{article}
3     %
4     %\pagestyle{headings}
5     %
6     \usepackage{amsmath}
7     \usepackage{amsfonts}
8     \usepackage{amssymb}
9     \usepackage[ansinew]{inputenc}
10     \usepackage[OT1]{fontenc}
11     \usepackage{graphicx}
12     %
13     \begin{document}
14     %-----------------------------------------------------------------------------------
15     \title{Ph.D. Topic Proposal}
16     \author{\vspace{2cm}\\David T. Ashley\\\texttt{dta@e3ft.com}\\\vspace{2cm}}
17     \date{\vspace*{8mm}\small{Version Control $ $Revision: 1.20 $ $ \\
18     Version Control $ $Date: 2006/03/27 00:10:30 $ $ (UTC) \\
19     $ $RCSfile: phdtopicpropa.tex,v $ $ \\
20     \LaTeX{} Compilation Date: \today{}}}
21     \maketitle
22    
23     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
24     %
25     \begin{abstract}
26     This document describes my Ph.D. research interests and provides
27     supporting information. The interests
28     (described in \S{}\ref{srin0}) revolve around the mathematical
29     basis of timed automata systems and code generation
30     from timed automata models.
31     \end{abstract}
32    
33     \clearpage{}
34     \pagenumbering{roman} %No page number on table of contents.
35     \tableofcontents{}
36     \clearpage{}
37     \listoffigures
38     \clearpage{}
39    
40     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
41     %Force the page number to 1. We don't want to number the table of contents
42     %page.
43     %
44     \setcounter{page}{1}
45     \pagenumbering{arabic}
46     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
47    
48     \section{The Timed Automata Framework}
49     \label{staf0}
50    
51     The framework of timed automata isn't commonplace in electrical
52     engineering, so this section provides
53     a description.
54    
55    
56     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
57    
58     \subsection{The Framework}
59     \label{staf0:stfw0}
60    
61     The formal framework of timed automata consists of systems of
62     automatons, each with discrete states, transitions, and
63     timers that can be reset to zero on transitions.
64    
65     The framework includes synchronization mechanisms between automatons (i.e.
66     automatons may interact in well-defined ways)\@. Synchronization mechanisms
67     consist of ``soft'' synchronization mechanisms and ``hard'' synchronization
68     mechanisms.
69    
70     \begin{itemize}
71     \item \emph{Soft} synchronization mechanisms involve one automaton having transition
72     functions that involve the discrete state or timers of another automaton.
73     \item \emph{Hard} synchronization mechanisms involve events. The semantics
74     of an event require two or more
75     automatons to make corresponding transitions at exactly the same time.
76     \end{itemize}
77    
78     The details of the framework aren't especially important,
79     and there are several
80     variations on the framework\footnote{Variations include
81     substates, differences in the semantics of events, and dynamics that go beyond
82     $\dot{t} = 1$ (i.e. hybrid systems).} that don't change the essential properties.
83    
84     The essential properties of the framework (that don't change with the variations) are:
85    
86     \begin{itemize}
87     \item A system of timed automata that interact via synchronization
88     mechanisms can be mathematically combined into a single
89     larger automaton with a single
90     discrete state space.
91     \item There is some symbolic method of reasoning about what values
92     timers can attain in each discrete state (polytopes, DBMs, etc.).
93     \item The symbolic reasoning about timer values often allows reasoning about
94     properties of the system (reachability, liveness, etc.).
95     \end{itemize}
96    
97     Timed automata are recognizeable to any embedded software engineer as
98     ``state machines''. A typical automotive embedded system consists of many
99     features and software components involving discrete state. For example,
100     software to control an automobile drivetrain with features like automatic 4-wheel drive
101     as well as sensor and actuator failure modes tends to have a very large discrete
102     space.
103    
104     As a contrived example of a system of timed automata, consider the problem of
105     controlling a drawbridge with one motor and two limit switches so that it goes up and down
106     with period $K_D + K_U$ (Fig. \ref{fig:staf0:stfw0:000}).
107    
108     \begin{figure}
109     \centering
110     \includegraphics[width=4.0in]{system01.eps}
111     \caption{Example Timed Automata System (Drawbridge Control)}
112     \label{fig:staf0:stfw0:000}
113     \end{figure}
114    
115     Assume that when raising the drawbridge, it is adequate to energize the motor
116     until the limit switch $U$ closes. However, when closing the drawbridge,
117     it is necessary to energize the motor for time $K_L$ beyond
118     when the limit switch $D$ closes (the $B_{DOWNLOCK}$ state in
119     Fig. \ref{fig:staf0:stfw0:01}).
120    
121     One way to design such a system is with two automata
122     (Fig. \ref{fig:staf0:stfw0:00} and Fig. \ref{fig:staf0:stfw0:01}) interacting via
123     synchronization mechnisms.
124    
125     The automaton of Fig. \ref{fig:staf0:stfw0:00} alternates between two
126     states with period $K_D + K_U$. At any point in time, the state of this
127     automaton indicates whether the drawbridge should be down or up.
128    
129     \begin{figure}
130     \centering
131     \includegraphics[height=2.5in]{exta01.eps}
132     \caption{Example Timed Automaton (Drawbridge Target Position Determination)}
133     \label{fig:staf0:stfw0:00}
134     \end{figure}
135    
136     The automaton of Fig. \ref{fig:staf0:stfw0:01} directly
137     determines the energization of the bridge motor as a function of
138     the limit switches $D$ and $U$, the discrete state of the automaton
139     of Fig. \ref{fig:staf0:stfw0:00}, and time.
140     In the $B_{IDLE}$ state, the motor is deenergized.
141     In the $B_{UP}$ state, the motor is energized to move the
142     drawbridge up. In the $B_{DOWN}$ and $B_{DOWNLOCK}$ states,
143     the motor is energized to move the drawbridge down.
144    
145     \begin{figure}
146     \centering
147     \includegraphics[width=4.6in]{exta02.eps}
148     \caption{Example Timed Automaton (Drawbridge Motor Control)}
149     \label{fig:staf0:stfw0:01}
150     \end{figure}
151    
152     Mathematically, the automata of Figs.
153     \ref{fig:staf0:stfw0:00}
154     and
155     \ref{fig:staf0:stfw0:01} can be combined to give the automaton of
156     Fig. \ref{fig:staf0:stfw0:02}\@. This mathematical operation is sometimes called the
157     ``shuffle'' operation.
158    
159     \begin{figure}
160     \centering
161     \includegraphics[width=4.6in]{exta03.eps}
162     \caption{Example Timed Automaton (Shuffle of Fig. \ref{fig:staf0:stfw0:00} and Fig. \ref{fig:staf0:stfw0:01})}
163     \label{fig:staf0:stfw0:02}
164     \end{figure}
165    
166     In Fig. \ref{fig:staf0:stfw0:02}, each of the eight discrete states
167     corresponds to one discrete state from Fig. \ref{fig:staf0:stfw0:00}
168     and one discrete state from In Fig. \ref{fig:staf0:stfw0:01}.
169     The initial state $A_{D}B_{IDLE}$ corresponds to the initial state
170     from In Fig. \ref{fig:staf0:stfw0:00} paired with the initial state
171     from Fig. \ref{fig:staf0:stfw0:01}.
172    
173     The noteworthy features of Fig. \ref{fig:staf0:stfw0:02} are:
174    
175     \begin{itemize}
176     \item It is the result of a mathematical algorithm applied to
177     Figs. \ref{fig:staf0:stfw0:00} and \ref{fig:staf0:stfw0:01}.
178     If the underlying system consisted of more than two automata, the
179     algorithm could be applied repeatedly to generate a single automaton with
180     a single large discrete state space.
181     \item The upper bound on the number of discrete states in the shuffle
182     of two automata is the product of the number of discrete states
183     in each. Note, however, that $A_{D}B_{UP}$ and $A_{U}B_{DOWN}$
184     don't ``truly'' exist. The reason is that the synchronization
185     mechanisms between the two automata ensure that these states
186     are instantly exited as soon as they are entered. Thus, a system
187     of equivalent functionality can be constructed with six discrete
188     states rather than eight.
189     \end{itemize}
190    
191     Although the preceding example is contrived, it illustrates the flavor
192     of the framework and how separate automata with synchronization mechanisms can be
193     combined (and perhaps also ``separated'' or ``factored'', \S{}\ref{srin0:star0}).
194    
195     It should also be apparent that tools can verify a great deal about
196     the system through symbolic manipulation. Properties that can be verified
197     include:
198    
199     \begin{itemize}
200     \item \emph{Reachability:} it can be symbolically determined whether
201     or not each state is reachable (the algorithms involve determining
202     symbolically which values timers can achieve in each discrete state and
203     comparing that information against transition functions---some transitions
204     cannot ever be taken).
205     \item \emph{Liveness:} it can be symbolically determined whether the system
206     can enter a state where no inputs to the system can cause all of a
207     set of states to be reachable.
208     \end{itemize}
209    
210     The example comes \emph{very} close to the way practical
211     software systems are constructed. Generally, state machines in
212     software have transition functions that involve time and the states of
213     other state machines.
214    
215    
216     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
217    
218     \subsection{Human Tendencies}
219     \label{staf0:shtd0}
220    
221     My experience in industry is that human beings do badly with the
222     design of stateful controllers. Typical tendencies:
223    
224     \begin{itemize}
225     \item \textbf{Bloating of the controller state space:}
226     \;It is very common for engineers to design a controller with
227     a discrete state space that is too large. The prototypical
228     example is an engineer who finds a way to implement a purely combinational
229     function using sequential logic.
230    
231     In the most humorous case (purely combinational logic implemented as
232     sequential logic),
233     the system usually behaves correctly. Serious software defects
234     most typically come about through \emph{subtle} design mistakes. A typical software defect
235     involves two or more software components with some interaction that enter
236     states such that the software can't recover.
237     \item \textbf{Inability to comprehend all possible behaviors of the system:}
238     Very stateful systems tend to be incompatible with human cognitive
239     ability. Even when the problem is well-defined and when the controller and
240     plant are operating perfectly, human beings don't do
241     well at considering every possible behavior.
242     \item \textbf{Inability to comprehend how the system may behave in the presence
243     of failures:}
244     Very stateful systems are often designed to be tolerant of certain types
245     of sensor and actuator failures (usually in the sense that the failures will
246     be detected and the system will employ a different algorithm to operate without
247     a specific sensor or actuator)\@. Such fault detection and tolerance
248     normally complicates the software design substantially.
249    
250     However, even without designed-in fault tolerance, there is the need to
251     design controllers to tolerate the faults that can occur in any practical system.
252     Specific scenarios that must be tolerated:
253    
254     \begin{itemize}
255     \item Spurious reset of the controller (which will normally reset the controller
256     to its initial state but leave the plant undisturbed). (This directly implies that
257     the system must recover from the initial state of the controller combined with
258     any state of the plant.)
259     \item State upset of the controller (due to electrical noise, internal software errors,
260     etc.). (This directly implies that the system must recover from any state of
261     the controller combined with any state of the plant.)
262     \end{itemize}
263    
264     Except in simple cases, human beings don't have the cognitive capacity to consider
265     all possible behaviors when both the controller and the plant may start in any state.
266     \end{itemize}
267    
268     One example that comes to mind from product development is an automobile transfer case controller
269     where it was discovered that if the electrical connector was removed, the transfer case mechanical
270     components repositioned, and the electrical connection restored; the controller would not
271     recover into normal operation. Human beings are not good at mentally exploring all possibilities, and even
272     a disciplined manual process can't be used because the combinations sometimes number in the thousands
273     or more. A mathematical framework and tool support are required.
274    
275    
276     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
277    
278     \subsection{Code Generation}
279     \label{staf0:scgn0}
280    
281     In most engineering environments, software is generated
282     from software designs that involve timed automata. (Some of the techniques
283     used to create compact code are described in \S{}\ref{sfrr0}.)
284    
285     For some types of systems, there has been success in using
286     existing tools to generate code directly from the software design
287     (using tool chains from \emph{The Math Works} or \emph{I-Logix}). It is,
288     however, known from experience that a clever human programmer can generate
289     more compact code than any existing tool; so code generation tools have
290     not penetrated cost-sensitive automotive products involving 32K of FLASH or less.
291    
292     There are two primary arguments against manual generation of code:
293    
294     \begin{itemize}
295     \item Code is redundant with respect to a software design.
296     In general, it does not make economic sense to maintain redundant
297     information using human labor.
298     \item The act of optimizing implementations typically destroys the
299     clear relationship between design and code. Furthermore, changes
300     to the design---sometimes even small ones---can invalidate the
301     mathematical basis for certain optimizations. Optimized code becomes
302     unmaintainable. It would be more economical to evaluate the viability
303     of optimizations and to generate code using software tools (rather than
304     human labor).
305     \end{itemize}
306    
307    
308     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
309    
310     \subsection{Formal Verification of Properties}
311     \label{staf0:svpr0}
312    
313     Typical design tools provide simulation capability, and there is a large
314     body of theory and best practice about how to design test cases based on
315     a stateful design.
316    
317     Still, the following problems remain:
318    
319     \begin{itemize}
320     \item Systems with a large discrete state space elude human
321     understanding.
322     \item It is very laborious to test systems with a large discrete
323     state space.
324     \item It isn't possible to fully test systems with a large
325     discrete state space.
326     \item It is possible (and common) to make a good faith effort at
327     comprehensively testing systems but still to overlook
328     unacceptable behavior.
329     \end{itemize}
330    
331     \emph{Simulation and testing are not enough.} For complex safety-critical
332     systems, simulation and testing do not provide enough assurance about the
333     behavior of the system.
334    
335     Formal verification of properties would involve making mathematical assertions
336     about how the system must and must not behave, and then allowing
337     tools to verify the properties.
338    
339     Possible types of properties:
340    
341     \begin{itemize}
342     \item \emph{Required behavior:}
343     For example: \emph{When the brake pedal switch is closed,
344     the brake lights must always come on within 200ms.}
345     \item \emph{Required absence of behavior:}
346     For example: \emph{The airbags can never deploy without at least one
347     body deformation sensor indicating body deformation.}
348     \item \emph{Liveness:}
349     For example: \emph{A certain set of states is always reachable by manipulating certain
350     inputs.}
351     \end{itemize}
352    
353     The only tool I'm aware of that allows formal verification of properties
354     is UPPAAL. However, the modeling framework of
355     UPPAAL isn't rich enough to support practical embedded systems.\footnote{The
356     tool chains from \emph{The Math Works} and \emph{I-Logix} don't attempt
357     formal verification at all.}
358    
359     I would tend to view formal verification of properties as a last line of defense
360     against egregious software defects (i.e. as a practice that cannot stand alone)\@.
361     Formal verification should be combined with all other known
362     best practices.
363    
364    
365     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
366    
367     \section{FLASH/ROM Reduction Techniques}
368     \label{sfrr0}
369    
370     In this section, I mention some of the FLASH/ROM reduction techniques
371     used by human programmers. Important points:
372    
373     \begin{itemize}
374     \item All of the techniques have a mathematical basis.
375     \item The techniques are complex to apply and best carried out by tools.
376     \item The mathematical basis of the techniques is non-trivial. There are
377     many unexplored corners.
378     \item The techniques distort the correspondence (i.e. the resemblance)
379     between design and code, and make code unmaintainable (it would be
380     better only to generate code from designs and never to maintain
381     code directly).
382     \end{itemize}
383    
384     The list of techniques presented is not exhaustive (far more techniques
385     exist).
386    
387     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
388    
389     \subsection{General Paradigm of Software Construction for Small Microcontrollers}
390     \label{sfrr0:sgsc0}
391    
392     This discussion is confined entirely to systems where a stateful design is
393     implemented directly as code (with no tabulation or compression of the design).
394     Other paradigms are possible. For example, at least one tool on the market implements
395     stateful designs as state transition tables that are evaluated at runtime by
396     a table interpreter. My experience with these types of systems is that there
397     is always a real-time performance penalty (but certainly not always a
398     FLASH penalty). My research interests do also include event-driven systems
399     and systems where the design is not implemented directly as code; but these
400     systems are not mentioned for brevity.
401    
402     The most common paradigm for small systems is ``\emph{a collection of cooperating
403     timed automatons}''. The most typical abstraction of these systems is a data-flow
404     diagram, with RAM variables (i.e. global variables) used as the interfaces.
405    
406     There is a body of theory and best practice about what separates good software designs
407     and implementations from bad (Parnas and the classic coupling and cohesion spectrums
408     come to mind). However, in small systems, it simply isn't possible to
409     implement the systems using classic ``good'' programming practice---formal parameters,
410     pointer dereferencing, and access to variables in stack frames all bloat
411     FLASH size under the weak instruction sets typical of small microcontrollers.
412    
413     It is helpful to take a step back and consider the possibility that global variables
414     (the second-strongest form of coupling in the classic coupling spectrum) aren't
415     inherently harmful; but rather that it is the way in which global variables are
416     typically used that causes harm. The harmful aspects of global variables
417     seem to be:
418    
419     \begin{itemize}
420     \item If global variables are tested \emph{and assigned} in more than place,
421     the variable actually becomes an automaton and adds to the
422     state space of the system.
423     \item Global variables lead to unrestrained connectivity: \emph{any}
424     software component can access the variables. Additionally,
425     state is not ``shed'' as functions return (as happens with formal
426     parameters and local variables)\@. This leads to connectivity
427     that often skips levels of the calling tree (making it very
428     difficult to understand the software).
429     \end{itemize}
430    
431     Small systems often have design rules to mitigate the harmful aspects of
432     global variables. The design rules tend to involve these restrictions:
433    
434     \begin{itemize}
435     \item A global variable used as an interface can be assigned by only one
436     software component (a 1-writer, $n$-reader restriction).
437     \item A global variable used as an interface has its readers/writers
438     represented in design documentation (so that the connectivity
439     created by the global variable isn't accidental or unrestrained).
440     \end{itemize}
441    
442     The design rules typically also include provisions for global variables
443     used as interfaces that are tested and assigned by more than one software
444     component (i.e. interface automatons). The simplest example of such an
445     interface is a semaphore that is
446     set \emph{T} by one software component and tested and set \emph{F} by
447     another software component, but the design rules are far more general.
448    
449     Note that tools can be used to allow a system to be phrased in a way
450     consistent with the traditional coupling spectrum but implemented
451     efficiently for small microcontrollers. For example, some compilers
452     are able to analyze the calling tree and place variables of storage
453     class \emph{automatic} into statically overlaid\footnote{Statically overlaid
454     based on the calling tree: one function's automatic variables can be overlaid
455     with another only if an analysis of the calling tree determines that
456     the two functions cannot be active at the same time.} areas of memory rather than
457     in a stack frame. Similar tool support could be developed for the notion of
458     \emph{automatic} bitfields and to restrain the connectivity introduced
459     by global variables to be consistent with the product design.
460    
461    
462     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
463    
464     \subsection{Near versus Far (Addressing Modes)}
465     \label{sfrr0:snvf0}
466    
467     Most small microcontrollers (TMS370C8, 68HC05, etc.) have two
468     non-indexed addressing modes, typically called \emph{direct} and
469     \emph{extended}. Instructions using the direct addressing mode typically
470     have the address encoded as a single byte, and can address only locations
471     \$00 through \$FF\@. Instructions using the extended addressing mode
472     typically have the address encoded as two bytes, and can address
473     locations \$0000 through \$FFFF.
474    
475     For lack of better nomenclature, I'll call the RAM locations that can be addressed
476     using short instructions \emph{near} RAM, and the RAM locations that require
477     long instructions \emph{far} RAM.
478    
479     When fixed RAM locations are used as interfaces (\S{}\ref{sfrr0:sgsc0}),
480     one can save substantial FLASH by allocating the variables that are
481     referenced most often throughout the software into near RAM.
482    
483     In automotive software, variables such as gearshift position and vehicle speed
484     are typically referenced many times throughout FLASH. Most programmers
485     would automatically place these into near RAM.
486    
487     However, for most variables, it isn't obvious whether these should be placed
488     into near or far RAM.
489    
490     Software developers often write small utility programs to scan all software
491     modules to determine the number of references to each variable. This information
492     is then used to allocate the variables with the most references into near RAM.
493    
494     The FLASH savings from using this technique is typically large. As an example,
495     assume there are ten variables each referenced 50 times throughout the software.
496     The savings of placing these variables into near RAM versus far RAM is
497     typically about $50 \times 10 = 500$ bytes of FLASH (more than 1\% of a
498     32K FLASH).
499    
500    
501     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
502    
503     \subsection{Treatment of Time}
504     \label{sfrr0:stot0}
505    
506     The way that time is measured is usually the single most important decision
507     in a small embedded system. Typically, many software components have to
508     measure time intervals, so a suboptimal decision about the mechanisms
509     greatly increases FLASH consumption.
510    
511     The best mechanism known is to arrange all software timers into
512     binary decades and to decrement the timers en masse
513     (Fig. \ref{fig:sfrr0:stot0:00}).
514    
515     \begin{figure}
516     \begin{small}
517     \begin{verbatim}
518     unsigned char modulo_counter;
519     unsigned char timers_modulo_1[MOD1_COUNT];
520     unsigned char timers_modulo_2[MOD2_COUNT];
521     unsigned char timers_modulo_4[MOD4_COUNT];
522    
523     void decrement_timers(void)
524     {
525     int i;
526    
527     modulo_counter++;
528    
529     for (i=0; i<sizeof(timers_modulo_1)/sizeof(timers_modulo_1[0]); i++)
530     {
531     if (timers_modulo_1[i])
532     timers_modulo_1[i]--;
533     }
534    
535     if (modulo_counter & 0x01)
536     {
537     for (i=0; i<sizeof(timers_modulo_2)/sizeof(timers_modulo_2[0]); i++)
538     {
539     if (timers_modulo_2[i])
540     timers_modulo_2[i]--;
541     }
542     }
543    
544     if (modulo_counter & 0x02)
545     {
546     for (i=0; i<sizeof(timers_modulo_4)/sizeof(timers_modulo_4[0]); i++)
547     {
548     if (timers_modulo_4[i])
549     timers_modulo_4[i]--;
550     }
551     }
552     }
553     \end{verbatim}
554     \end{small}
555     \caption{Software Timers Decremented En Masse}
556     \label{fig:sfrr0:stot0:00}
557     \end{figure}
558    
559     When software components must measure time, a byte
560     (\texttt{timers\_modulo\_4[2]}, for example) is set to a non-zero value.
561     A separate software component, usually resembling Fig. \ref{fig:sfrr0:stot0:00} but often
562     implemented in assembly-language,
563     decrements the byte, but not below zero.
564     A test against zero will determine if the time period has expired.
565    
566     The single-byte mechanism combined with binary decades allows any time period
567     to be measured within 1:128. For example, assume that the binary decades are
568     $2^q \times 1ms$ (1ms, 2ms, 4ms, etc.) and then that
569     we wish to measure a time period of 30 minutes. Then
570    
571     \begin{equation}
572     255 (2^q) \geq 1,800,000
573     \end{equation}
574    
575     \begin{equation}
576     q = \left\lceil \log_2 \frac{1,800,000}{255} \right\rceil = 13
577     \end{equation}
578    
579     A timer resolution of $2^{13} = 8,192$ms with a count of 219 or 220 would in practice be used.
580     For most automotive applications, measuring 30 minutes within 8 seconds is acceptable.
581    
582     It is noteworthy that using coarse software timers introduces nondeterminism
583     into the system (although I've never seen a problem in practice) and probably requires
584     some adjustment to timed automata algorithms used for verification of properties.
585    
586    
587     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
588    
589     \subsection{Bitfields of Size One}
590     \label{sfrr0:sbfi0}
591    
592     Many small microcontrollers possess extremely efficient instructions
593     for clearing, setting, and testing individual bits of RAM (especially near
594     bits). It isn't uncommon for a microcontroller to have an instruction that
595     will test a bit and conditionally branch.
596    
597     Note that economies apply only to bitfields of size one. Bitfields of
598     other sizes require the compiler to mask and shift to obtain the value of the
599     bitfield, then to shift and mask to store the value back.
600    
601     The economy of bitfields of size one has several implications for the construction
602     of embedded software.
603    
604     \begin{itemize}
605     \item Variables that are conceptually Boolean should never be
606     maintained as full bytes. Bitfields are more efficient, both
607     in FLASH and RAM.
608     \item In many cases, it is most efficient to maintain discrete state as
609     bitfields rather than as a byte. A state machine with three
610     discrete states is often most effectively implemented as two
611     bitfields with state assignments 0/0, 0/1, and 1/X.
612     \item It is often most effective to evaluate common Boolean subexpressions and store
613     the results in bitfields (\S{}\ref{sfrr0:scse0}).
614     \end{itemize}
615    
616    
617     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
618    
619     \subsection{Equivalence Classing of Discrete States}
620     \label{sfrr0:secd0}
621    
622     The most obvious way to construct a state machine in software is shown in
623     Fig. \ref{fig:sfrr0:secd0:00}. Discrete state is maintained
624     as a byte, and each state has a value $\in \{0, \ldots{}, 255\}$.
625    
626     \begin{figure}
627     \begin{small}
628     \begin{verbatim}
629     switch (state)
630     {
631     default:
632     case 0:
633     {
634     if (some_transition_condition)
635     {
636     state = 1;
637     }
638     break;
639     }
640     case 1:
641     {
642     if (some_other_transition_condition)
643     {
644     state = 0;
645     }
646     break;
647     }
648     case 2:
649     {
650     ...
651     break;
652     }
653     }
654     \end{verbatim}
655     \end{small}
656     \caption{Most Obvious Construction of State Machine in Software}
657     \label{fig:sfrr0:secd0:00}
658     \end{figure}
659    
660     The shortcoming of the approach shown in Fig. \ref{fig:sfrr0:secd0:00} is that
661     state machines are often accompanied by:
662    
663     \begin{itemize}
664     \item Combinational logic that implements combinational functions involving
665     the discrete state of the state machine being considered.
666     \item Transition functions in other state machines that depend on the discrete
667     state of the state machine being considered.
668     \end{itemize}
669    
670    
671     \begin{figure}
672     \begin{small}
673     \begin{verbatim}
674     if (
675     (state == 0) || (state == 13) || (state == 18) || (state == 30)
676     || (state == 31) || (state == 51) || (state == 99)
677     )
678     \end{verbatim}
679     \end{small}
680     \caption{Typical Test for Membership in a Set of Discrete States}
681     \label{fig:sfrr0:secd0:01}
682     \end{figure}
683    
684     This can often lead to tests of the form shown in
685     Fig. \ref{fig:sfrr0:secd0:01}.
686     Such tests are very expensive, both in FLASH consumption and in execution time.
687     A typical compiler must generate many compare instructions.
688    
689     One can make the observation that there are many machine instructions that
690     create equivalence classes within $\mathbb{Z}^+$:
691    
692     \begin{itemize}
693     \item An \emph{AND \#1} instruction may create equivalence classes such as
694     \{0, 2, 4, \ldots{}\} versus \{1, 3, 5, \ldots{}\}. Other \emph{AND} instructions
695     can create more complex equivalence classes.
696     \item A \emph{CMP \#n} instruction usually creates three equivalence classes: the integers less than $n$,
697     $n$, and the integers greater than $n$.
698     \item There are other machine instructions that create different equivalence classes.
699     \end{itemize}
700    
701     The critical question is whether one can assign discrete state values so as to
702     make the best utilization of the equivalence classes that machine instructions
703     naturally create. For example, if a test for 10 distinct discrete states occurs
704     many places in the software, it would make sense to try to assign these
705     state values so that they are part of an equivalence class that can be
706     identified immediately by one or two machine instructions.
707    
708     It should be obvious that if many different tests of discrete state are involved,
709     identifying an optimal or near-optimal assignment of discrete state values and
710     the accompanying tests would be very difficult to do by hand. This type of
711     optimization is best done by software tools.
712    
713    
714     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
715    
716     \subsection{Ordering of Transition Functions}
717     \label{sfrr0:sotf0}
718    
719     It often happens that transition functions have common subexpressions.
720     For example, consider the code snippet in Fig. \ref{fig:sfrr0:sotf0:00}.
721     The subexpression ``\texttt{A \&\& B}'' is common to both transitions
722     out of State 0.
723    
724     \begin{figure}
725     \begin{small}
726     \begin{verbatim}
727     switch (state)
728     {
729     default:
730     case 0:
731     {
732     if (A && B && C)
733     {
734     state = 1;
735     }
736     else if (A && B && !D)
737     {
738     state = 2;
739     }
740     break;
741     }
742     case 1:
743     {
744     ...
745     break;
746     }
747     case 2:
748     {
749     ...
750     break;
751     }
752     }
753     \end{verbatim}
754     \end{small}
755     \caption{State Machine Before Control Flow Removal of Common Subexpression}
756     \label{fig:sfrr0:sotf0:00}
757     \end{figure}
758    
759     The code can be optimized to evaluate this subexpression only once
760     (Fig. \ref{fig:sfrr0:sotf0:01}).
761    
762     \begin{figure}
763     \begin{small}
764     \begin{verbatim}
765     switch (state)
766     {
767     default:
768     case 0:
769     {
770     if (A && B)
771     {
772     if (C)
773     {
774     state = 1;
775     }
776     else if (!D)
777     {
778     state = 2;
779     }
780     }
781     break;
782     }
783     case 1:
784     {
785     ...
786     break;
787     }
788     case 2:
789     {
790     ...
791     break;
792     }
793     }
794     \end{verbatim}
795     \end{small}
796     \caption{State Machine After Control Flow Removal of Common Subexpression}
797     \label{fig:sfrr0:sotf0:01}
798     \end{figure}
799    
800     In the trivial case presented, it is easy to identify the subexpression
801     and rearrange the code so that it is evaluated only once. However, more complex cases
802     involve logical implication; i.e. there is not an identifiable subexpression, but there
803     is still a way to rearrange the code for better efficiency. Such analysis is
804     best done by software tools.
805    
806    
807     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
808    
809     \subsection{Common Subexpression Elimination}
810     \label{sfrr0:scse0}
811    
812     It often occurs that the same subexpression appears in transition functions from
813     more than one discrete state. It can be economical to rearrange the
814     code to evaluate such subexpressions
815     only once. Two approaches occur in practice:
816    
817     \begin{itemize}
818     \item The subexpression is evaluated once, regardless of discrete state, and the
819     result is placed in a temporary variable (often a bitfield if the expression
820     has a Boolean result).
821     \item The evaluation of the subexpression is implemented as a subroutine, and
822     the subroutine is called from more than one transition function.
823     \end{itemize}
824    
825     Each of these two approaches has advantages and disadvantages.
826    
827     Identifying common subexpressions and deciding how to eliminate the FLASH
828     penalty associated with duplicated code is a tedious task and best done
829     by software tools.
830    
831     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
832    
833     \subsection{Farey Series Approximations}
834     \label{sfrr0:sfsa0}
835    
836     Many modern microcontrollers have an efficient integer multiplication
837     instruction, and some also have an efficient integer division instruction.
838     Fixed-point arithmetic is the norm in small microcontroller work, and it
839     is common to want to approximate functions of the form
840    
841     \begin{equation}
842     y = r_I x
843     \end{equation}
844    
845     \noindent{}with $r_I \in \mathbb{R}^+$ and $x,y \in \mathbb{Z}^+$. $r_I$ is the
846     ``ideal'' scaling factor, which may be irrational.
847    
848     If the processor has an integer multiplication instruction but no division
849     instruction, it is usually most effective to choose
850    
851     \begin{equation}
852     r_A = \frac{h}{2^q} \approx r_I,
853     \end{equation}
854    
855     \noindent{}with the division by a power of two implemented via a right shift.
856    
857     However, if the processor also has an integer division instruction, we may choose
858    
859     \begin{equation}
860     r_A = \frac{h}{k} \approx r_I,
861     \end{equation}
862    
863     \noindent{}with $k$ not required to be a power of two. The specific function
864     implemented is usually
865    
866     \begin{equation}
867     y = \left\lfloor \frac{hx}{k} \right\rfloor ,
868     \end{equation}
869    
870     \noindent{}or perhaps
871    
872     \begin{equation}
873     y = \left\lfloor \frac{hx + z}{k} \right\rfloor ,
874     \end{equation}
875    
876     \noindent{}where $z \in \mathbb{Z}$ is used to shift the result so as to
877     provide a tighter bound on the error introduced due to truncation of the
878     division.
879    
880     $h$ and $k$ are constrained by the sizes of operands accepted by the
881     machine instructions ($h \leq h_{MAX}$ and $k \leq k_{MAX}$).
882     There is an algorithm from number theory (involving Farey series and
883     continued fractions) that will allow the selection of $h$ and $k$ subject
884     to the constraints. The algorithm is $O(\log N)$ and so can be applied
885     to find best rational approximations even for processors that accommodate
886     32- or 64-bit operands.\footnote{The computational complexity of the algorithm is
887     a significant point, as $2^{64}$ (or $2^{128}$) is a very large number.}
888    
889     For example, the best rational approximation to $\pi$ with
890     numerator and denominator not exceeding $2^{16}-1$ is 65,298/20,785\@.
891     On a processor with a 16-bit $\times$ 16-bit multiplication instruction and a
892     32-bit / 16-bit division instruction, one can approximate
893    
894     \begin{equation}
895     y = \pi x
896     \end{equation}
897    
898     \noindent{}with
899    
900     \begin{equation}
901     y = \left\lfloor \frac{65,\!298 x}{20,\!785} \right\rfloor
902     \end{equation}
903    
904     \noindent{}very efficiently (typically 2-4 machine instructions).
905    
906    
907     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
908    
909     \subsection{Vertical Counters}
910     \label{sfrr0:svcn0}
911    
912     The traditional arrangement for sequential logic is a
913     \texttt{switch()} statement (this might also be called
914     a ``horizontal'' counter). However, in some applications that must
915     implement many identical sequential mappings, it is
916     efficient to arrange the state vector so that the state of each sequential
917     mapping consists of a bit in the same position from several bytes. This
918     is called a ``vertical'' counter.\footnote{It is suspected that the nomenclature
919     \emph{vertical counter} comes about because if one arranges the 0s and 1s of
920     bytes horizontally, the state of an individual sequential machine consists
921     of a vertical row of bits.}
922    
923     An example of a vertical counter application is 3/3 debouncing---a filtering
924     function where a discrete input must be in the same state for 3 consecutive
925     instants of discrete time before the output may change to that state.
926    
927     If $A$ is the most recent sample, $B$ is the next-most-recent sample,
928     $C$ is the oldest sample, and $O$ is the output (assumed maintained
929     as a RAM location) Fig. \ref{fig:sfrr0:svcn0:00}
930     supplies the Karnaugh map for 3/3
931     debouncing.
932    
933     \begin{figure}
934     \centering
935     \includegraphics[height=2.0in]{kmap33db.eps}
936     \caption{Karnaugh Map Of 3/3 Debouncing}
937     \label{fig:sfrr0:svcn0:00}
938     \end{figure}
939    
940     It can be seen from the figure that the expression for the output is
941    
942     \begin{equation}
943     \label{eq:sfrr0:svcn0:01}
944     ABC + AO + BO + CO = ABC + O(A + B + C).
945     \end{equation}
946    
947     Intuitively, (\ref{eq:sfrr0:svcn0:01}) makes sense---the output
948     will be unconditionally \emph{T} if all three of the most recent samples
949     are \emph{T}
950     ($ABC$). The output will also be \emph{T} if the previous output was \emph{T}
951     and at least one of the most recent samples are \emph{T} [$O(A+B+C)$]---at least
952     one \emph{T} recent sample blocks the output from transition to \emph{F}.
953    
954     Figure \ref{fig:sfrr0:svcn0:01} supplies the C-language
955     code to implement 3/3 debouncing as a vertical mapping.
956     A C-compiler will typically implement this code very directly
957     using the bitwise logical instructions of the machine.
958    
959     \begin{figure}
960     \begin{verbatim}
961     /**************************************************************/
962     /* Assume: */
963     /* A : Most recent sample (i.e. at t(0)), arranged as */
964     /* a group of 8 bits. */
965     /* B : Next most recent sample t(-1). */
966     /* C : Oldest sample t(-2). */
967     /* output : Debounced collection of 8 bits presented to */
968     /* software internals. Note that this is both */
969     /* an input (to the combinational mapping) and */
970     /* the new result. */
971     /**************************************************************/
972    
973     output = (A & B & C) | (output & (A | B | C));
974    
975     /* End of code. */
976     \end{verbatim}
977     \caption{C-Language Implementation Of 3/3 Debouncing}
978     \label{fig:sfrr0:svcn0:01}
979     \end{figure}
980    
981    
982     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
983    
984     \section{Research Interests}
985     \label{srin0}
986    
987     This section enumerates my specific research interests.
988    
989    
990     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
991    
992     \subsection{Mathematical Properties of Timed Automata Systems}
993     \label{srin0:star0}
994    
995     I have interest in the mathematical properties of timed automata systems,
996     including these questions:
997    
998     \begin{itemize}
999     \item Can these systems be rearranged (independent of code generation) for more
1000     efficient implementation? Is there some canonical form?
1001     \item Can an automaton be ``factored'' into components (i.e. the reverse
1002     operation of ``shuffle'' illustrated in Figs.
1003     \ref{fig:staf0:stfw0:00}, \ref{fig:staf0:stfw0:01}, and \ref{fig:staf0:stfw0:02})?
1004     \item Is the factorization unique\footnote{In the same sense that the
1005     fundamental theorem of arithmetic guarantees that a composite
1006     can have only one unique factorization into primes.}
1007     or can it be made unique according
1008     to some metric?
1009     \item Can algorithms spot suboptimal designs and coach
1010     human programmers?\footnote{Example of a suboptimal design:
1011     identical behavior could be achieved using a simpler design.}
1012     \end{itemize}
1013    
1014     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
1015    
1016     \subsection{Code Generation from Systems of Timed Automata}
1017     \label{srin0:snvf0}
1018    
1019     I have interest in the mathematics of code generation from systems of timed
1020     automata. One might make the observation that all of the techniques
1021     described in \S{}\ref{sfrr0} are individual and seemingly disjoint techniques that
1022     come about through human ingenuity. I am interested in:
1023    
1024     \begin{itemize}
1025     \item Any unified mathematical framework that includes all of the techniques.
1026     For example, can one find a common framework or way of thinking that includes both
1027     Farey series approximations and vertical counters?
1028     \item Any mathematical framework that, given a smorgasbord of disjoint techniques,
1029     can predict how to apply them to obtain optimal results (this is also
1030     a function of the processor instruction set). (Cost matrices and
1031     least-squares methods come to mind immediately, but I'd like to examine
1032     this more closely.)
1033     \end{itemize}
1034    
1035     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
1036    
1037     \subsection{Code Generation and Formal Verification of Properties in the Same Framework}
1038     \label{srin0:sgvs0}
1039    
1040     There seem to be no existing tools that will allow code generation (from
1041     a timed automata model) and the
1042     verification of formal properties in the same framework. In addition, the tools
1043     that do generate code (for small systems) can't optimize as effectively as a
1044     human programmer. With a more sound mathematical basis for optimization,
1045     I believe that tools should be able to optimize more effectively
1046     than a human programmer.
1047    
1048     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
1049    
1050     \subsection{Enterprise Content Management}
1051     \label{srin0:secm0}
1052    
1053     I administer web-based version control and defect-tracking databases. This type of
1054     technology is critical because human beings don't deal well with complexity and
1055     there is the inherent need to serialize (one bug at a time, one change at a time, etc.).
1056    
1057     I have some interest in enterprise content management
1058     (see, for example, \emph{Alfresco}), especially the
1059     buy-versus-build dilemma and the difficulty
1060     and cost of developing custom in-house tools that are tailored to an individual
1061     company's processes (I have some ideas in this area).
1062    
1063    
1064     %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
1065     \end{document}
1066     %
1067     %$Log: phdtopicpropa.tex,v $
1068     %Revision 1.20 2006/03/27 00:10:30 dashley
1069     %Presumed final edits.
1070     %
1071     %Revision 1.19 2006/03/26 23:26:23 dashley
1072     %Edits.
1073     %
1074     %Revision 1.18 2006/03/26 02:22:21 dashley
1075     %Edits.
1076     %
1077     %End of $RCSfile: phdtopicpropa.tex,v $.
1078    

dashley@gmail.com
ViewVC Help
Powered by ViewVC 1.1.25