реклама на сайте
подробности

 
 
> Как вычислить угол?
Andrey_L
сообщение Jan 26 2006, 06:59
Сообщение #1


Частый гость
**

Группа: Свой
Сообщений: 125
Регистрация: 26-01-06
Из: г. Санкт-Петербург
Пользователь №: 13 622



Подскажите пожалуйста алгоритм:
есть вектор - известны x,y координаты, угол вектора гарантированно лежит в пределах [0:45гр]
необходимо вычислить этот угол. Алгоритм необходимо оптимизировать по скорости (он будет реализовываться на ADSP2185 (с фикс. точкой)) и точности вычисления.
Результат должен быть представлен в виде 16-ого числа, где: (старшие три бита я вычисляю на стадии приведения угла к диапазону [0:45гр])
Бит Вес
15 180гр
14 90гр
13 45гр
12 45/2гр
11 45/4гр
10 45/8гр
11 45/16гр
....
0 45/8192гр
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов (1 - 7)
dmyl
сообщение Jan 26 2006, 07:56
Сообщение #2


Частый гость
**

Группа: Свой
Сообщений: 123
Регистрация: 11-01-06
Пользователь №: 13 032



Встречный вопрос: Если угол лежит в 0-45, зачем тогда два старших разряда 0-180 и 0-90

Предложение: Методом последоваетльных приближений.
Если от 0 до 90, тогда
Сравниваем на каждом шаге X и Y, если больше(меньше) устанавливаем в 1 разряд начиная со старшего. X=X-Y/N Или Y=Y-X/N, по результам сравнения. N - вес, 1->45 град, 2->45/2, 4->45/4 и т.д.

Операции только вычитание и сдвиг, на каждом шаге вычисляется один разряд

А если нужен диапазон в 360 град, квадрант вычислить совсем просто.

Сообщение отредактировал dmyl - Jan 26 2006, 07:58
Go to the top of the page
 
+Quote Post
vitus_strom
сообщение Jan 26 2006, 08:34
Сообщение #3


Знающий
****

Группа: Свой
Сообщений: 553
Регистрация: 15-10-04
Пользователь №: 877



Ключевое слово CORDIC преобразование ккординат из декартовых в полярные
Go to the top of the page
 
+Quote Post
bve
сообщение Jan 26 2006, 08:44
Сообщение #4


Местный
***

Группа: Свой
Сообщений: 316
Регистрация: 20-02-05
Из: Ленинградская обл.
Пользователь №: 2 765



Есть несколько разложений арктангенса в ряд в зависимости от диапазона аргумента.
Будет 5-7 членов. На Вашем процессоре - десяток тактов.
Go to the top of the page
 
+Quote Post
dmyl
сообщение Jan 26 2006, 08:58
Сообщение #5


Частый гость
**

Группа: Свой
Сообщений: 123
Регистрация: 11-01-06
Пользователь №: 13 032



Цитата(bve @ Jan 26 2006, 12:44) *
Есть несколько разложений арктангенса в ряд в зависимости от диапазона аргумента.
Будет 5-7 членов. На Вашем процессоре - десяток тактов.

Насколько я понял, задача не просто вычислить из декарта угол, а преобразовать его к определенному коду, кратному 45гр/8192
Go to the top of the page
 
+Quote Post
bve
сообщение Jan 26 2006, 13:13
Сообщение #6


Местный
***

Группа: Свой
Сообщений: 316
Регистрация: 20-02-05
Из: Ленинградская обл.
Пользователь №: 2 765



А такое разложение автоматом получится....
Процессор - 16-тиразрядный, получаемое значение арктангенса - в радианах от минус ПИ до ПИ.
разделив ПИ на 32767, получаем что единица младшего разряда - это 45/8192.
Go to the top of the page
 
+Quote Post
Builder
сообщение Jan 28 2006, 13:53
Сообщение #7


iBuilder©
****

Группа: Свой
Сообщений: 519
Регистрация: 14-07-04
Из: Минск
Пользователь №: 322



А чем не устраивает библиотечная ф-я (atan2 (y, x))?
Слишком медленно?
Go to the top of the page
 
+Quote Post
bve
сообщение Jan 29 2006, 10:52
Сообщение #8


Местный
***

Группа: Свой
Сообщений: 316
Регистрация: 20-02-05
Из: Ленинградская обл.
Пользователь №: 2 765



Кстати, вспомнил, есть очень приличный справочник под редакцией
Абрамовиц и Стиган - "Специальные функции."
Масса разложений в ряды всевозможных функций.
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 25th July 2025 - 15:52
Рейтинг@Mail.ru


Страница сгенерированна за 0.01373 секунд с 7
ELECTRONIX ©2004-2016