|
Kategorie: Diplomové, bakalářské práce |
Tento dokument chci!
Práce popisuje principy a problémy při realizaci ultrazvukového anemometru. Je popsán princip výpočtu rychlosti větru a následné korekce výpočtu. Pro realizaci jsou využity ultrazvukové sensory a microcontrolér ARM Cortex-M3. Práce se zabývá generováním PWM signálu, jeho analogovou filtrací, zesílením a odvysíláním. Na přijímací straně jeto nízkonapěťový zesilovač a komparátor. Vyvíjený kód je popsán pomocí vývojového diagramu.
In adc_peaktopeak function calculated ADC peak peak value stored
sequence. see adc_pp averaged value from last ADC sequences. first level
there are conditions. Address and variables let know number order this
function. The function called with address first field adc_array. With 32th calling this function, new wind
speed value calculated. It
means that signal was received, it’s triggered timer_post_int function. that moment variable equal to
23
.
Program continues infinite while loop. After that initialization functions are called. Second condition fulfilled after timer interrupt.3 Main function
Function start with local variable definitions. Then temp
variable adjust airspeed constant actual temperature condition. Then function adc_pp_average called inform
us about adc_pp value. Addresses of
tx_array and ty_array are given count time values first position array and
keep last averages here. Input arguments are with actual measured time, adc_pp for
time correction based peak peak ADC value received signal.4. first adc_sample function stored captured ADC samples adc_array
field. Therefore input argument first field captured ADC sequence. For
calculation ADC sequence peak peak value, adc_pp takes place. Then
adc_ppx_aver and adc_ppy_aver are used for averaging actual adc_pp value. first line the display printed
application name. we
received signal, third condition fulfilled. The last variables are and
serve for counting cycles. Here flag variable tested. used capture time from timer,
tx_array and ty_array are used buffer time averages from measurements before. don’t measure every cycle we
measure when wind speed for axis was updated. As
input argument are adc_pp variable and addresses adc_ppx_aver, adc_ppy and
i variables.
Program continue with display initialization. With first condition pwm_prepare function called. The
function returns actual adc_pp value.
The last what can measured temperature.
Functions inside third condition serve measure received signal and calculate
wind speed. The
temp variable serve for temperature measurement.
Forth conditions tests flag measurement results are convenient add actual
measured time wind speed calculation. When flag doesn’t fulfill any condition,
program waiting interrupt.
Then gpio_post_int gives measured time and the time correct range, set
flag X_WIND_CALC Y_WIND_CALC state. Here
starts measurement axis.4. Otherwise set flag measure
again with X_PWM Y_PWM state