ArduCopter Mega: порт на обычную Arduino (тестим)

mahowik
SovGVD:

я на квадрике не смещал ничего

ну контроллер то держать будет в равновесии, но фактичеки нагрузка на моторы будет не равномерная…

iBat:

коптер прямо во время полета резко меняет направление, относительно которого стики работают.

если память не изменяет это и есть фишка симпл мода для новичков, т.е. как коптер не верти, попа его всегда к вам лицом будет 😃
это чеб не зарулиться и не потерять управление…

Alex_from_Israel
alexTAG:

Подскажите пожалуста, что я сделал не так? Коптер Y6 - все подсоединено согласно рисунка. При взлете идет юлой, как будто верт без стабилизатора!

Моторы неправильно подсоединены. На рисунках Ардукоптер. Посмотрите в Вики Мегапирата.

Ar2r:

MegaPirateNG_2.0.44_Alpah2.zip

Тротл вверх-вниз, а в планере Roll меняется.

В итоге почему-то Trotl, Yaw, Roll Поменялись местами. Где это исправить?

Если распайка приемника стандартная выблать Дефайн в APM_RC.cpp

У меня Y6 с стандартной распайкой приемника и моторы подключены, как в ВИКИ Мегапирата. Все работает адекватно. Была проблема с задними моторами, когда Yav поворачиваешь, коптер трял устойчивость. Оказалось, что были наоборот включены моторы. При отклонении стика руля направления верхние и нижние моторы ВСЕ должны работать одинаково. Или все верхние снижают обороты, а все нижние повышают. И наоборот, если в другую сторону.

Проверьте, в какую сторону вращаются моторы. Верхние против часовой стрелки, нижние по часовой.

LeonVS
iBat:

Loiter - то ли не работает, то ли я не умею его готовить.

Прежде чем мучать лойтер, надо домучать альт холд, и только когда он начнет держать высоту уже переходить к лойтер. Проблемы у вас как раз с первым пунктом, на газ в этих режимах он не реагирует, даже если его совсем сбросить, так как пытается удержать коптер на заданной высоте. Смотрите показания барометра ну и сонара если имеется.

LeonVS

Народ, а подскажите как выполнить какое то действо по достижению точки? Допустим сделать фото? Полагаю можно задействовать сервопривод… Даже есть команда “do_repeat_servo” это оно? Кто нибудь пробовал?

tusik
LeonVS:

подскажите как выполнить какое то действо по достижению точки

А еще как управлять с помощью джойстика?

LeonVS

А в ответ тишина… походу не кто сие дело еще не пробовал 😦

tusik:

А еще как управлять с помощью джойстика?

Ну самое простое наверно будет вот это дело:
hobbyking.com/…/__17165__BT_1_8_Channel_FPV_Joysti…

А так же можно тупо вывести контакты от резистора джоя и подпаятся вместо резисторов аппы 😃

tusik
LeonVS:

А так же можно тупо вывести контакты от резистора джоя и подпаятся вместо резисторов аппы

А зачем тогда в планере настройка джойстика?

LeonVS

А хз, возможно если пашет телеметрия полноценно, а не как у нас через одно место по АСР220… то скорей всего эта настройка для подключенного к компу джою 😃

SovGVD

насколько я понимаб это режим GUIDED, можно на карте тыркать - и коптер туда полетит, видимо и джойстиком от туда же рулится

Musgravehill
Sir_Alex:

Да и вообще, ерундень какая то с этими датчиками, если довольно сильно поболтать плату, то горизонт конкретно сбивается и потом потихоньку доплывает. Я думаю это из за того, что гира у нас относительно медленно опрашивается (раз в 4 мс = 250Hz). Если переделать на прерывания, то можно увеличить частоту выборок до 1KHz. Жалко у меня нету оригинального OilPan’a, что бы сравнить, как у них ведут себя датчики.

Алексей, я сейчас проверял Ардуино+AllinOne. Если “кувыркать” плату, то горизонт сбивается и медленно доплывает только за счет акселерометров. А если сильно не болтать, а делать резкие наклоны, то гиры мгновенно возвращают в горизонт. Я думаю, что в болтанку гиры дрейфуют и сбиваются, а по акселю выравнивание идет медленно (возможно, коэффициент гиры большой, а у акселя - мал, поэтому горизонт только за счет акселей медленно восстанавливается)

iBat

Что-то не так с Alpha 2. Делаю setup esc - все ок, пищит как положено. Потом можно даже погудеть нормально.
Отключаем-подключаем батарейку. ESC пищат, что тротл не в нижнем положении. Самый прикол, что это подтверждается показаниями Raw Sensors в планере - сразу после включения там где то 20% полосок на всех моторах. Хотя раньше там был почти минимум.

tusik
iBat:

это подтверждается показаниями Raw Sensors в планере

А пульт в планере калибровали?

iBat
tusik:

А пульт в планере калибровали?

В планере - нет. В терминале - да.

Musgravehill
Musgravehill:

Я думаю, что в болтанку гиры дрейфуют и сбиваются, а по акселю выравнивание идет медленно (возможно, коэффициент гиры большой, а у акселя - мал, поэтому горизонт только за счет акселей медленно восстанавливается)

Сглаживание акселя очень сильное (пробовал отказаться, горизонт плывет, все-равно)


AP_IMU_Oilpan::update(void)
{
	_gyro.x = _gyro_gain_x * _sensor_in(0, adc_values[0]);
	_gyro.y = _gyro_gain_y * _sensor_in(1, adc_values[1]);
	_gyro.z = _gyro_gain_z * _sensor_in(2, adc_values[2]);


	_accel_filtered.x = _accel_filtered.x * .98 + _accel.x * .02;
	_accel_filtered.y = _accel_filtered.y * .98 + _accel.y * .02;
	_accel_filtered.z = _accel_filtered.z * .98 + _accel.z * .02;


	return true;
}

Если в Планнере смотреть Test DCM, то значения очень быстро выравниваются в горизонт, а в Test IMU видно, что акселерометр медленно выходит на нужное значение. Значит, собака зарыта в IMU.

mahowik
Musgravehill:

Алексей, я сейчас проверял Ардуино+AllinOne. Если “кувыркать” плату, то горизонт сбивается и медленно доплывает только за счет акселерометров. А если сильно не болтать, а делать резкие наклоны, то гиры мгновенно возвращают в горизонт. Я думаю, что в болтанку гиры дрейфуют и сбиваются, а по акселю выравнивание идет медленно (возможно, коэффициент гиры большой, а у акселя - мал, поэтому горизонт только за счет акселей медленно восстанавливается)

Я както подрубал мультивийные датчики к пирату и с толкнулся с той же проблемой. На умеренно-быстрых поворотах все ок, а на оч. резких, либо если уж очень сильно кувыркать платку, сплошные доплывания. Олег тогда меня убедил что это из-за дешевых датчиков, я всеж настаивал что дело как раз в быстродейсвии системы в целом, т.к. в мультиви цикл ~300гц и гораздо сложнее выбиться из горизонта. Если память не изменяет, то у пирата цикл 50гц (по крайней мере Олег так писал), соот-но быстрые изменения угловых скоростей (высокие ускорения) система не в состоянии нормально “ловить”… Кроче Олег меня тогда убедил не суваться с вии датчиками в пират… Жаль кроче, а то может и на вийных датчиках полетел бы тогда. 😃

SovGVD

никто OSD от МегаПиратоСамолета не ковыряет щас? а то занятся, а друг уже есть =)

Musgravehill
mahowik:

быстрые изменения угловых скоростей (высокие ускорения) система не в состоянии нормально “ловить”

Александр, но почему тогда система быстро не “доплывает” в горизонт за счет акселей?
“Поколбасил” плату и замер, держу ровно и в покое: Гиры = 0, но аксели сигналят, что наклон 90-120-180 градусов!

Гиры явно работают, потому что отлично ловят быстрые короткие наклоны (такие в полете происходят). А вот аксель BMA180 сильно зажат, что-то не дает ему быстро вернуть горизонт.

Я смотрю RAW данные - никакого доплывания там нет! Значения мгновенно встают в нужные Замедление происходит где-то в модели IMU\DCM. Частота опроса (fast_loop) 250Гц.

mahowik
Musgravehill:

Александр, но почему тогда система быстро не “доплывает” в горизонт за счет акселей? “Поколбасил” плату и замер, держу ровно и в покое: Гиры = 0, но аксели сигналят, что наклон 90-120-180 градусов!

С этим согласен, влияние акселей видимо значительно задушено в IMU…

Musgravehill:

Гиры явно работают, потому что отлично ловят быстрые короткие наклоны (такие в полете происходят)

У меня “доплывание” на 20-30гр. вопроизводилось и при разовых оч. резких наклонах (гира 3205->3200), потому и решил что не хватает пирату скорости ловить быстрые ускорения, т.к. в мультивии поблема с доплыванием на разовые резкие повороты вопроизводилась всего 3-5гр.

з.ы. хотя вот вспомнил, что тогда я не учел что НЧ фильтр в вии был 256гц а в пирате 20гц… может в этом дело, т.к. если я правильно понимаю то чем ниже значения фильтра, тем ниже способность гиры измерять высокие/быстрые угловые ускорения…

Musgravehill
mahowik:

влияние акселей видимо значительно задушено в IMU

mahowik:

не хватает пирату скорости ловить быстрые ускорения

Поэтому смысл покупать крутые датчики (?). Данные с них быстро идут, а обработка тормозит. И я не могу сказать, что AllinOne - “шумная”, очень даже нормальная.

Возможно, что система не рассчитана на работу в предельных условиях. Небольшие наклоны до 30 градусов она отлично отслеживает. Наверное, усложнение кода, чтобы он мог вернуть коптер из кувырков, вызовет рост времени цикла и задержки.


Нашел _adc_constraint = мое значение 12000; // 360degree было 5100


AP_IMU_Oilpan::_sensor_in(uint8_t channel, int adc_value)
{
    adc_in = adc_value;

    // constrain sensor readings to the sensible range

    if (fabs(adc_in) > _adc_constraint) {
        adc_constraints++;                                              // We keep track of the number of times
        adc_in = constrain(adc_in, -_adc_constraint, _adc_constraint);    // Throw out nonsensical values
    }
    return adc_in;
}
LeonVS
SovGVD:

никто OSD от МегаПиратоСамолета не ковыряет щас? а то занятся, а друг уже есть =)

Увы нет… А хотелось бы, квадрик все же это только низко и близко, а иногда хотца далеко и высоко 😃 Поэтому самолетный вариант обновленный бы точно не помешал 😃

SovGVD

я чето застрял с прошивкой e-osd, avrdude умеет шить atmega88, на e-osd atmega88p - вот думаю рассказть ему чтоб забил на различия? или 88 и 88P отличаются принципиально?

avrdude: Device signature = 0x1e930f
avrdude: Expected signature for ATMEGA88 is 1E 93 0A
         Double check chip, or use -F to override this check.

udp: обновил avrdude, теперь он знает про 88p =)
upd2: прошился, работает, показывает много инфы… осталось код в пирата вкрутить

Musgravehill

Проблема медленного доплывания горизонта решена! Вес акселя в этом процессе был зажат. Я расширил границы “ошибок” определения положения от 1.17 до 30 единиц по модулю. И повысил вес акселя от (0…1) до 10 единиц.

Положение коптера в Планнере мгновенно определяется. Как летает - не знаю.


AP_DCM::drift_correction(void)
{
	//Compensation the Roll, Pitch and Yaw drift.
	//float mag_heading_x;
	//float mag_heading_y;
	float error_course;
	float accel_magnitude;
	float accel_weight;
	float integrator_magnitude;
	//static float scaled_omega_P[3];
	//static float scaled_omega_I[3];
	static bool in_motion = false;
	Matrix3f rot_mat;

	//*****Roll and Pitch***************

	// Calculate the magnitude of the accelerometer vector
	accel_magnitude = _accel_vector.length() / 9.80665f;

	// Dynamic weighting of accelerometer info (reliability filter)
	// Weight for accelerometer info (<0.5G = 0.0, 1G = 1.0 , >1.5G = 0.0)
	//accel_weight = constrain(1 - 3 * fabs(1 - accel_magnitude), 0, 1);	// upped to (<0.66G = 0.0, 1G = 1.0 , >1.33G = 0.0)
        accel_weight = 10.0;  //повышаем вес акселя, чтобы быстрее доплывал горизонт
	//	We monitor the amount that the accelerometer based drift correction is deweighted for performance reporting
	_health = constrain(_health+(0.02 * (accel_weight - .5)), 0, 1);  //вроде нигде не используется. сэкономить время и убрать???

	// adjust the ground of reference
	_error_roll_pitch =  _dcm_matrix.c % _accel_vector;			// Equation 27  *** sign changed from prev implementation???


	// error_roll_pitch are in Accel m/s^2 units
	// Limit max error_roll_pitch to limit max omega_P and omega_I
	_error_roll_pitch.x = constrain(_error_roll_pitch.x, -30.00f, 30.00f);   //было от -1.17 до +1.17   зачем?
	_error_roll_pitch.y = constrain(_error_roll_pitch.y, -30.00f, 30.00f);  //в raw приходит от -25 до +25, не будем сужать диапазон
	_error_roll_pitch.z = constrain(_error_roll_pitch.z, -30.00f, 30.00f);

	_omega_P =  _error_roll_pitch * (_kp_roll_pitch * accel_weight);  //теперь горизонт быстро доплывет!
	_omega_I += _error_roll_pitch * (_ki_roll_pitch * accel_weight);


	//*****YAW***************

	if (_compass) {
		// We make the gyro YAW drift correction based on compass magnetic heading
		error_course = (_dcm_matrix.a.x * _compass->heading_y) - (_dcm_matrix.b.x * _compass->heading_x);	// Equation 23, Calculating YAW error

	} else {

		// Use GPS Ground course to correct yaw gyro drift
		if (_gps->ground_speed >= SPEEDFILT) {

			_course_over_ground_x = cos(ToRad(_gps->ground_course/100.0));
			_course_over_ground_y = sin(ToRad(_gps->ground_course/100.0));
			if(in_motion) {
				error_course = (_dcm_matrix.a.x * _course_over_ground_y) - (_dcm_matrix.b.x * _course_over_ground_x);	// Equation 23, Calculating YAW error
			} else  {
				float cos_psi_err, sin_psi_err;
				// This is the case for when we first start moving and reset the DCM so that yaw matches the gps ground course
				// This is just to get a reasonable estimate faster
				yaw = atan2(_dcm_matrix.b.x, _dcm_matrix.a.x);
				cos_psi_err = cos(ToRad(_gps->ground_course/100.0) - yaw);
				sin_psi_err = sin(ToRad(_gps->ground_course/100.0) - yaw);
				// Rxx = cos psi err, Rxy = - sin psi err, Rxz = 0
				// Ryx = sin psi err, Ryy = cos psi err,   Ryz = 0
				// Rzx = Rzy = 0, Rzz = 1
				rot_mat.a.x = cos_psi_err;
				rot_mat.a.y = -sin_psi_err;
				rot_mat.b.x = sin_psi_err;
				rot_mat.b.y = cos_psi_err;
				rot_mat.a.z = 0;
				rot_mat.b.z = 0;
				rot_mat.c.x = 0;
				rot_mat.c.y = 0;
				rot_mat.c.z = 1.0;

				_dcm_matrix = rot_mat * _dcm_matrix;
				in_motion =  true;
				error_course = 0;
			}

		} else {
			error_course = 0;
			in_motion = false;
		}
	}

	_error_yaw = _dcm_matrix.c * error_course;	// Equation 24, Applys the yaw correction to the XYZ rotation of the aircraft, depeding the position.

	_omega_P += _error_yaw * _kp_yaw;			// Adding yaw correction to proportional correction vector.
	_omega_I += _error_yaw * _ki_yaw;			// adding yaw correction to integrator correction vector.

	//	Here we will place a limit on the integrator so that the integrator cannot ever exceed half the saturation limit of the gyros
	integrator_magnitude = _omega_I.length();
	if (integrator_magnitude > radians(300)) {
		//_omega_I *= (0.5f * radians(300) / integrator_magnitude); // Why do we have this discontinuous?  EG, why the 0.5? Я тоже не знаю, убрал
	}

}

конец.
--------------------
Другая идея. Показания акселя делятся на 4 (adc_value[4] = ((rawADC_BMA180[3]<<8) | (rawADC_BMA180[2])) >> 2; ).
То есть, разрешение снижается искуственно. Если в AP_ADC_ADS7844.cpp убрать деление (adc_value[4] = ((rawADC_BMA180[3]<<8) | (rawADC_BMA180[2])); ), то диапазон значений возрастает.
Но это влечет за собой:
AP_IMU_Oilpan.h _gravity = 11200, а не 2730; ///< 1G (For BMA180) in the raw data coming from the accelerometer
_accel_scale = 9.80665 / 11200, а не 2730;
_adc_constraint = ? станет больше ? 5100; // 360degree
_accel_total_cal_change = ? больше? 4.0;
_accel_max_cal_offset = Больше? 250.0;
Возможно, где-то еще будут переполнения. Если купить серьезные аксели и гиры, то код придется адаптировать(?)

Sir_Alex
Musgravehill:

Другая идея. Показания акселя делятся на 4 (adc_value[4] = ((rawADC_BMA180[3]<<8) | (rawADC_BMA180[2])) >> 2; ). То есть, разрешение снижается искуственно. Если в AP_ADC_ADS7844.cpp убрать деление (adc_value[4] = ((rawADC_BMA180[3]<<8) | (rawADC_BMA180[2])); ), то диапазон значений возрастает. Но это влечет за собой: AP_IMU_Oilpan.h _gravity = 11200, а не 2730; ///< 1G (For BMA180) in the raw data coming from the accelerometer _accel_scale = 9.80665 / 11200, а не 2730; _adc_constraint = ? станет больше ? 5100; // 360degree _accel_total_cal_change = ? больше? 4.0; _accel_max_cal_offset = Больше? 250.0; Возможно, где-то еще будут переполнения. Если купить серьезные аксели и гиры, то код придется адаптировать(?)

Это не так. BMA180 имеет 14 бит разрешение, вот на эти 2 бита и смещается значение. Так что все там правильно.

По гире, я думаю проблема в том, что она работает на частоте 250Гц, что не достаточно для отработки быстрых перемещений. Надо повышать частоту, например до 500Гц или 1КГц. Предполагаю, что надо задействовать INT Gyro, что бы успевать считывать с нее данные.

Musgravehill
Musgravehill:

Проблема медленного доплывания горизонта решена!

rcopen.com/forum/f123/topic232641/2963

Вот что бывает после болтанки в руке:

www.youtube.com/watch?v=ELLuJsubUr4

Sir_Alex:

Это не так. BMA180 имеет 14 бит разрешение, вот на эти 2 бита и смещается значение. Так что все там правильно.

В мультивие BMA180 смещается >>5. Странно, но ладно.

Sir_Alex:

По гире, я думаю проблема в том, что она работает на частоте 250Гц, что не достаточно для отработки быстрых перемещений. Надо повышать частоту, например до 500Гц или 1КГц. Предполагаю, что надо задействовать INT Gyro, что бы успевать считывать с нее данные.

Это было бы отлично! По гире видно, что очень быстрые наклоны она не отрабатывает, кратковременные скачки не успевают захватиться и интегрироваться.