/*
  SITL handling

  This simulates a barometer

  Andrew Tridgell November 2011
 */
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
#include <math.h>
#include <AP_Baro.h>     // ArduPilot Mega BMP085 Library
#include <SITL.h>
#include "desktop.h"
#include "util.h"

extern SITL sitl;

/*
  setup the barometer with new input
  altitude is in meters
 */
void sitl_update_barometer(float altitude)
{
	extern AP_Baro_BMP085_HIL barometer;
	double Temp, Press, y;
	static uint32_t last_update;

	// 80Hz, to match the real APM2 barometer
	if (millis() - last_update < 12) {
		return;
	}
	last_update = millis();

	Temp = 312;

	y = ((altitude-584.0) * 1000.0) / 29271.267;
	y /= (Temp / 10.0) + 273.15;
	y = 1.0/exp(y);
	y *= 95446.0;

	Press = y + (rand_float() * sitl.baro_noise);

	barometer.setHIL(Temp, Press);
}