Software developpement » History » Version 8
« Previous -
Version 8/10
(diff) -
Next » -
Current version
BASTIDE, Paul, 03/23/2016 11:21 AM
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.
General principle¶
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.
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()" function that enables the tasks to wait and release the prcessing power to another task.
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.
Software definition¶
Tasks definition¶
We are going to define the following tasks and function :
- task_temp_phys(): this task is the main one, is used to send to the RF transmitter the bits.
- sensor_get_update() : task used to retrieve from the ADC the voltage value and fill the buffer with the temperature
- init_ADC(): used in sensor_update to initialize the ADC registers
- bin_volt(): used to convert the results from the ADC to a temperature
- celcius_coding() : used to convert the temperarture over a 7-bits word.
We created the following buffer to conserve the data
- bitCharBuf: contains the 7-bits word we are planning to send
We are using the following flags :
- rts_flag : Ready To Send flag, allow the main task to know when data is ready to be sent.
- cod_flag : Flag used to tell the update function that all the data has been sent and it can now retrieve the data
Sequence of events¶
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.
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 associated to the thermocouple.
When the temperature value has been identified, we are translating it to a 7-bit word by using the celcius_coding() function.
The format chosen for the 7-bits word is the following "0bsdddddd" where:
- s contains the sign of the temperature, "1" being positive and "0" bieng negative
- "dddddd" : contains the absolute value of the temperature. As the range of temperature we are considereing was determined as [-20 : +40] in the lab conditions, we can code it on 6 bits (26 = 64).
When the word is ready, we are setting the rts_flag so that the main tasks knows data is ready to be sent.
once the task_temp_phy() "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".
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