<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://c4d.lias-lab.fr/index.php?action=history&amp;feed=atom&amp;title=WP6-20</id>
	<title>WP6-20 - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://c4d.lias-lab.fr/index.php?action=history&amp;feed=atom&amp;title=WP6-20"/>
	<link rel="alternate" type="text/html" href="https://c4d.lias-lab.fr/index.php?title=WP6-20&amp;action=history"/>
	<updated>2026-04-07T01:16:19Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.37.1</generator>
	<entry>
		<id>https://c4d.lias-lab.fr/index.php?title=WP6-20&amp;diff=876&amp;oldid=prev</id>
		<title>Grolleaue at 08:33, 10 March 2023</title>
		<link rel="alternate" type="text/html" href="https://c4d.lias-lab.fr/index.php?title=WP6-20&amp;diff=876&amp;oldid=prev"/>
		<updated>2023-03-10T08:33:15Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Revision as of 08:33, 10 March 2023&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l18&quot;&gt;Line 18:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 18:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;|-&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;|-&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;|   TRL		|| 4&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;|   TRL		|| 4&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;|-&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;| Contact || fernando.herrera at acorde.com&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;|}&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;|}&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br/&gt;&lt;/td&gt;&lt;/tr&gt;

&lt;!-- diff cache key mediawiki-mediawiki-:diff::1.12:old-665:rev-876 --&gt;
&lt;/table&gt;</summary>
		<author><name>Grolleaue</name></author>
	</entry>
	<entry>
		<id>https://c4d.lias-lab.fr/index.php?title=WP6-20&amp;diff=665&amp;oldid=prev</id>
		<title>Acorde: Created page with &quot;=ESL embedded Software Design Environment (ESDE)= {|class=&quot;wikitable&quot; |  ID|| WP6-ESDE |- |   Contributor	|| ACORDE |- |   Levels	|| Tool, Platform |- |   Require	|| Linux, Virtual Platform Development Platform |- |   Provide	|| Executable System-Level modelling, automated embedded software generation, Virtual Platform based validation |- |   Input	|| SystemC models, RTOS API target, Platform target, Platform model |- |   Output	|| Functional and time performance validat...&quot;</title>
		<link rel="alternate" type="text/html" href="https://c4d.lias-lab.fr/index.php?title=WP6-20&amp;diff=665&amp;oldid=prev"/>
		<updated>2022-10-14T09:39:18Z</updated>

		<summary type="html">&lt;p&gt;Created page with &amp;quot;=ESL embedded Software Design Environment (ESDE)= {|class=&amp;quot;wikitable&amp;quot; |  ID|| WP6-ESDE |- |   Contributor	|| ACORDE |- |   Levels	|| Tool, Platform |- |   Require	|| Linux, Virtual Platform Development Platform |- |   Provide	|| Executable System-Level modelling, automated embedded software generation, Virtual Platform based validation |- |   Input	|| SystemC models, RTOS API target, Platform target, Platform model |- |   Output	|| Functional and time performance validat...&amp;quot;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;=ESL embedded Software Design Environment (ESDE)=&lt;br /&gt;
{|class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
|  ID|| WP6-ESDE&lt;br /&gt;
|-&lt;br /&gt;
|   Contributor	|| ACORDE&lt;br /&gt;
|-&lt;br /&gt;
|   Levels	|| Tool, Platform&lt;br /&gt;
|-&lt;br /&gt;
|   Require	|| Linux, Virtual Platform Development Platform&lt;br /&gt;
|-&lt;br /&gt;
|   Provide	|| Executable System-Level modelling, automated embedded software generation, Virtual Platform based validation&lt;br /&gt;
|-&lt;br /&gt;
|   Input	|| SystemC models, RTOS API target, Platform target, Platform model&lt;br /&gt;
|-&lt;br /&gt;
|   Output	|| Functional and time performance validation. Close to production firmware generation and validation.&lt;br /&gt;
|-&lt;br /&gt;
|   C4D tooling		|| n.a.&lt;br /&gt;
|-&lt;br /&gt;
|   TRL		|| 4&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
In the past, for the design and development of a complete positioning and attitude solution like [http://glad.acorde.com GLAD], ACORDE relied on a conventional design flow where a former hih-level model using Matlab was used. Then a manual translation was done to C++, which was tested on the final physical prototype. This type of flow is illustrated in the following picture:&lt;br /&gt;
&lt;br /&gt;
[[File:wp3-15_2_04.png|frame|center| Conventional design flow followed by ACORDE for the design and development of GLAD]]&lt;br /&gt;
&lt;br /&gt;
Yet, this design flow is improvable in many aspects. While usable and proven, this approach yet presented some important disadvantages:&lt;br /&gt;
&lt;br /&gt;
* Enforcing a sequential HW/SW development. HW/SW platform availability is a pre-condition for application development. &lt;br /&gt;
* Long simulation times and lacks on the modelling language (e.g., no time modelling)&lt;br /&gt;
* High translation effort from the high-level model (in Matlab) to the implementation language.&lt;br /&gt;
&lt;br /&gt;
==Contribution and Improvements==&lt;br /&gt;
&lt;br /&gt;
In order to overcome the previos drawbacks, ACORDE has worked in COMP4DRONES on an ESL embedded Software Design Environment (ESDE) for **better productivity in embedded system design and development, and specifically suited to positioning systems*.&lt;br /&gt;
The basic idea of ESDE is summarized in the following illustration&lt;br /&gt;
&lt;br /&gt;
[[File:ACORDE-ESDE_nutshell.gif|800px]]&lt;br /&gt;
&lt;br /&gt;
ESDE enables some key features for productivity improvement:&lt;br /&gt;
&lt;br /&gt;
* Building fast especifications/models, able to capture key concerns of the application (modularity, concurrency, time model) under a unified and standard language (SystemC).&lt;br /&gt;
* Executable specifications, able to significantly speed-up functional validation vs Matlab model execution.&lt;br /&gt;
* Automated embedded software generation mechanisms that avoid a significant translation effort from the system model to the implementation binary code.&lt;br /&gt;
* The possibility to develop the firmware in parallel with the HW development, by relying on a virtual platform.&lt;br /&gt;
* The possibility to validate the production firmware (or a very close version to it), on top of a virtual platform, as a digital twin of the final physical platform&lt;br /&gt;
&lt;br /&gt;
== Detailed Description ==&lt;br /&gt;
&lt;br /&gt;
A bit more detailed description of the ESDE framework developed by ACORDE in COMP4DRONES is sketched in the following picture.&lt;br /&gt;
&lt;br /&gt;
[[File:wp3-15_2_05.png|frame|center| System-level methodology for the design and implementation of outdoor geo-referenced position&amp;amp;attitude estimation systems in COMP4DRONES]]&lt;br /&gt;
&lt;br /&gt;
== Status after C4D (Demos) and Future ==&lt;br /&gt;
&lt;br /&gt;
In C4D, ESDE has been developped to support the especification a core functionality for attitude estimation (a multi-baseline attitude estimation or mbattes),  in SystemC, which can be easily compiled into an executable model for its validation, as it is shown in this [https://youtu.be/qkNS-dlBnR0 first demo video].&lt;br /&gt;
&lt;br /&gt;
Moreover, ESDE allows the targeting of this SystemC specification onto C++ based implementation (as shown in a [https://youtu.be/cG9u-16cVU8 second video]), which can be automatically produced to different targets.&lt;br /&gt;
The targetting to a Linux-based platform supporting posix threads is illustrated on the following video, where the targeting of the mbattes SystemC specification is targeted to a Linux-based target, to generate an implementation (executable file), which is launched on a PC &lt;br /&gt;
&lt;br /&gt;
In [https://youtu.be/L8kQOf6kl88 this clip], the final result of the execution shows the correctness of the implementation.&lt;br /&gt;
&lt;br /&gt;
ESDE remains as a live project in ACORDE, which as well as positioning systems, have potential to highly improve embedded development productivity.&lt;br /&gt;
Currently, extensions for generic procedures for traceability are being developed to enable performance analysis based on the VP target.&lt;br /&gt;
&lt;br /&gt;
== Interoperability ==&lt;br /&gt;
&lt;br /&gt;
ESDE models are written in standard SystemC. &lt;br /&gt;
The implementations target standard C++. For implementing RTOS services, it currently uses either POSIX API or FreeRTOS API.&lt;br /&gt;
&lt;br /&gt;
System-Level application models relie on modules, channels, processes elements, which facilitates mapping with other C4D frameworks, like S3D. This has been tested for the mbattes example in a collaboration between ACORDE and the University of Cantabria.&lt;/div&gt;</summary>
		<author><name>Acorde</name></author>
	</entry>
</feed>