Software developpement » History » Version 7

Version 6 (BASTIDE, Paul, 03/23/2016 11:02 AM) → Version 7/10 (BASTIDE, Paul, 03/23/2016 11:14 AM)

h1. Software developpement

The software we are proposing is a variation of the software proposed in the [[Sputnik strikes back:| Sputnik strikes back]] project, software desgin.
As them, we are going to retriev on a sensor data, tranform it in a more appropriate format so as to send it by the RF transmitter.

h2. General principle

p. We are developping for an RTOS, a real time operating system. As presented in the generalities //LINK HERE, this kind of software runs on a task driven event basis. That is to say we are creating tasks inside infinite loop (so that they keep running) and a scheduler will be operating the shift between the tasks.

p. In order for the tasks to release or take the processing power they need, the system rune a priority basis : tasks with higher priority, when they need to process, interrupts tsks with lower priorities ta take control. These high priorities tasks need to release the control in order for the lower priority tasks to be able to run. This is done by what we call a "context switch" functionality present in the scheduler, and notably in the _"OS_Delay()"_ *"OS_Delay()"* function that enables the tasks to wait and release the prcessing power to another task.

p. In order to set the timing between the tasks, we will implementflags, which will serve to determine when some functionalities will be accessed in the tasks. These flags have to be set by other tasks to manage the workflow between tasks.

h2. Software definition

h3. Tasks definition

p. We are going to define the following tasks and function :
* _task_temp_phys()_: task_sensor_phys(): this task is the main one, is used to send to the RF transmitter the bits.
* _sensor_get_update()_ sensor_get_update() : task used to retrieve from the ADC the voltage value and fill the buffer with the temperature
* _init_ADC()_: init_ADC(): used in sensor_update to initialize the ADC registers
* _bin_volt()_: bin_vomt(): used to convert the results from the ADC to a temperature
* _celcius_coding()_ celcius_coding() : used to convert the temperarture over a 7-bits word.

p. We created the following buffer to conserve the data
* _bitCharBuf_: bitCharBuf : contains the 7-bits word we are planning to send

p. We are using the following flags :
* _rts_flag_ rts_flag : Ready To Send flag, allow the main task to know when data is ready to be sent.
* _cod_flag_ cod_flag : Flag used to tell the update function that all the data has been sent and it can now retrieve the data

h3. Sequence of events

p. We are retrieving data from the thermocouple thanks to the _sensor_get_update()_. As the sensor is intern, we can set our own frequency in the retrieving of the data. We are supposing that the dynamic of the temperature we want to measure is slow, that's why we are going to scan on wire at a time and not simultaneoulsy.

p. Once the two analog inputs have been scanned, we are using _bin_voltage()_ function to convert the ADC output value to a voltage, and then map the voltage difference to a negative or positive temperature thanks to known tables associatde to the thermocouple.

p. Finally, when the temperature value has been identified, we are translating it to a 7-bit word by using the _celcius_coding()_ function.
When the word is ready, we are setting the _rts_flag_ so that the main tasks knows data is ready to be sent.

p. once the _task_temp_phy()_ main function "sees" that the _rts_flag_ has been set, it takes over and begins to transmit to the lower level (RF transmitter). It transmit to th RF transmitter by setting the I/O output port wired to the RF to high when a "1" has to be transmitted and to low when a "0" has to be transmitted.
As a Manchester encoding has been selected to comply with the bit rate of the RF transmitter (see [[Sptunik strikes back:]]), we are sendding for half a bit period a "1" if the bit transmitted is "1", and "0" on the second half period. The reverse is done when the bit to be transmitted is a "0".

p. Once a bit has been trasnmitted, we increase a _bitpointer_ value, refering to the index in the word to be transmitted, and we send the next bit. This continue until all the bits have been transmitted. finally, the task set the _rts_flag_ to "0" to signify the temperature has been sent, set the _cod_flag_ to "1" to ask for new data, and go back to an idle state
rts