Как вычислять отрицательные векторы

Линейная алгебра для разработчиков игр

Эта статья является переводом цикла из четырёх статей «Linear algebra for game developers», написанных David Rosen и посвящённых линейной алгебре и её применению в разработке игр. С оригинальными статьями можно ознакомиться тут: часть 1, часть 2, часть 3 и часть 4. Я не стал публиковать переводы отдельными топиками, а объединил все статьи в одну. Думаю, что так будет удобнее воспринимать материал и работать с ним. Итак приступим.

Содержание
  1. Зачем нам линейная алгебра?
  2. Что такое вектор?
  3. Сложение векторов
  4. Вычитание векторов
  5. Умножение вектора на скаляр
  6. Длина вектора
  7. Расстояние
  8. Нормализация
  9. Скалярное произведение векторов
  10. Векторное произведение
  11. Базисный вектор
  12. Матрицы
  13. Трехмерные матрицы
  14. Вращение в двухмерном пространстве
  15. Трёхмерное вращение
  16. Вращение, определяемое осью и углом (Axis-angle rotation)
  17. Эйлеровские углы
  18. Вращение с помощью матриц
  19. Кватернионы
  20. Знакомимся с вектором
  21. Линейная алгебра
  22. Что такое вектор
  23. Как записывать
  24. Скаляр
  25. Как изображать
  26. И зачем нам это всё
  27. Что дальше
  28. Большая теория по векторам
  29. Векторы — коротко о главном
  30. Векторы и… Колумб
  31. О направлении
  32. Что такое скалярная величина?
  33. Что такое векторная величина?
  34. Как обозначаются векторы?
  35. Операции над векторами
  36. Умножение вектора на число
  37. Параллельный перенос векторов
  38. Сложение векторов по правилу треугольника
  39. Больше двух слагаемых векторов. Сложение по правилу многоугольника
  40. Вычитание векторов через сложение
  41. Вычитание векторов через треугольник
  42. Универсальное правило параллелограмма
  43. Скалярное произведение векторов
  44. Векторное произведение векторов
  45. Проекции векторов
  46. Что такое проекция вектора и с чем ее едят?
  47. Построение проекции. Определение знака
  48. Анализ углов
  49. Частные случаи проекции
  50. Способы нахождения проекций и векторов с помощью тригонометрии
  51. Действия над проекциями векторов. Решение задач
  52. Сложение проекций. Доказательство главного свойства
  53. Простейшие задачи на нахождение проекций
  54. Задачи на нахождение вектора и его угла с осью
  55. Главный метод работы с осями и проекциями в решении физических задач
  56. Заключение
  57. 📽️ Видео

Зачем нам линейная алгебра?

Одним из направлений в линейной алгебре является изучение векторов. Если в вашей игре применяется позиционирование экранных кнопок, работа с камерой и её направлением, скоростями объектов, то вам придётся иметь дело с векторами. Чем лучше вы понимаете линейную алгебру, тем больший контроль вы получаете над поведением векторов и, следовательно, над вашей игрой.

Что такое вектор?

В играх вектора используются для хранения местоположений, направлений и скоростей. Ниже приведён пример двухмерного вектора:
Как вычислять отрицательные векторы
Вектор местоположения (также называемый «радиус-вектором») показывает, что человек стоит в двух метрах восточнее и в одном метре к северу от исходной точки. Вектор скорости показывает, что за единицу времени самолёт перемещается на три километра вверх и на два — влево. Вектор направления говорит нам о том, что пистолет направлен вправо.

Как вы можете заметить, вектор сам по себе всего лишь набор цифр, который обретает тот или иной смысл в зависимости от контекста. К примеру, вектор (1, 0) может быть как направлением для оружия, как показано на картинке, так и координатами строения в одну милю к востоку от вашей текущей позиции. Или скоростью улитки, которая двигается вправо со скоростью в 1 милю в час (прим. переводчика: довольно быстро для улитки, 44 сантиметра в секунду).

Важно отслеживать единицы измерения. Допустим у нас есть вектор V (3,5,2). Это мало что говорит нам. Три чего, пять чего? В нашей игре Overgrowth расстояния указываются в метрах, а скорости в метрах в секунду. Первое число в этом векторе — это направление на восток, второе — направление вверх, третье — направление на север. Отрицательные числа обозначают противоположные направления, на запад, вниз и на юг. Местоположение, определяемое вектором V (3,5,2), находится в трёх метрах к востоку, в пяти метрах вверху и в двух метрах к северу, как показано на картинке ниже.

Как вычислять отрицательные векторы

Итак, мы изучили основы работы с векторами. Теперь узнаем как вектора использовать.

Сложение векторов

Чтобы сложить вектора, нам надо просто сложить каждую их составляющую друг с другом. Например:

(0, 1, 4) + (3, -2, 5) = (0+3, 1-2, 4+5) = (3, -1, 9)

Зачем нам нужно складывать вектора? Наиболее часто сложение векторов в играх применяется для физического интегрирования. Любой физический объект будет иметь вектора для местоположения, скорости и ускорения. Для каждого кадра (обычно это одна шестидесятая часть секунды), мы должны интегрировать два вектора: добавить скорость к местоположению и ускорение к скорости.

Давайте рассмотрим пример с прыжками Марио. Он начинает с позиции (0, 0). В момент начала прыжка его скорость (1, 3), он быстро двигается вверх и вправо. Его ускорение равно (0, -1), так как гравитация тянет его вниз. На картинке показано, как выглядит его прыжок, разбитый на семь кадров. Чёрным текстом показана его скорость в каждом фрейме.

Как вычислять отрицательные векторы

Давайте рассмотрим первые кадры поподробнее, чтобы понять как всё происходит.

Для первого кадра, мы добавляем скорость Марио (1, 3) к его местоположению (0, 0) и получаем его новые координаты (1, 3). Затем мы складываем ускорение (0, -1) с его скоростью (1, 3) и получаем новое значение скорости Марио (1, 2).

Делаем то-же самое для второго кадра. Добавляем скорость (1, 2) к местоположению (1, 3) и получаем координаты (2, 5). Затем добавляем ускорение (0, -1) к его скорости (1, 2) и получаем новую скорость (1, 1).

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

Вычитание векторов

Вычитание рассчитывается по тому-же принципу что и сложение — вычитаем соответствующие компоненты векторов. Вычитание векторов удобно для получения вектора, который показывает из одного местоположения на другое. Например, пусть игрок находится по координатам (1, 2) с лазерным ружьём, а вражеский робот находится по координатам (4, 3). Чтобы определить вектор движения лазерного луча, который поразит робота, нам надо вычесть местоположение игрока из местоположения робота. Получаем:

(4, 3) — (1, 2) = (4-1, 3-2) = (3, 1).

Как вычислять отрицательные векторы

Умножение вектора на скаляр

Когда мы говорим о векторах, мы называем отдельные числа скалярами. Например (3, 4) — вектор, а 5 — это скаляр. В играх, часто бывает нужно умножить вектор на число (скаляр). Например, моделируя простое сопротивление воздуха путём умножения скорости игрока на 0.9 в каждом кадре. Чтобы сделать это, нам надо умножить каждый компонент вектора на скаляр. Если скорость игрока (10, 20), то новая скорость будет:

0.9*(10, 20) = (0.9 * 10, 0.9 * 20) = (9, 18).

Длина вектора

Если у нас есть корабль с вектором скорости V (4, 3), нам также понадобится узнать как быстро он двигается, чтобы посчитать потребность в экранном пространстве или сколько потребуется топлива. Чтобы сделать это, нам понадобится найти длину (модуль) вектора V. Длина вектора обозначается вертикальными линиями, в нашем случае длина вектора V будет обозначаться как |V|.

Мы можем представить V как прямоугольный треугольник со сторонами 4 и 3 и, применяя теорему Пифагора, получить гипотенузу из выражения: x 2 + y 2 = h 2

В нашем случае — длину вектора H с компонентами (x, y) мы получаем из квадратного корня: sqrt(x 2 + y 2 ).

Итак, скорость нашего корабля равна:

|V| = sqrt(4 2 + 3 2 ) = sqrt(25) = 5

Как вычислять отрицательные векторы

Этот подход используется и для трёхмерных векторов. Длина вектора с компонентами (x, y, z) рассчитывается как sqrt(x 2 + y 2 + z 2 )

Расстояние

Если игрок P находится в точке (3, 3), а взрыв произошёл в точке E по координатам (1, 2), нам надо определить расстояние между игроком и взрывом, чтобы рассчитать степень ущерба, нанесённого игроку. Это легко сделать, комбинируя две вышеописанных операции: вычитание векторов и их длину.
Мы вычитаем P — E, чтобы получить вектор между ними. А затем определяем длину этого вектора, что и даёт нам искомое расстояние. Порядок следования операндов тут не имеет значения, |E — P| даст тот-же самый результат.

Расстояние = |P — E| = |(3, 3) — (1, 2)| = |(2, 1)| = sqrt(2 2 +1 2 ) = sqrt(5) = 2.23

Как вычислять отрицательные векторы

Нормализация

Когда мы имеем дело с направлениями (в отличие от местоположений и скоростей), важно, чтобы вектор направления имел длину, равную единице. Это сильно упрощает нам жизнь. Например, допустим орудие развёрнуто в направлении (1, 0) и выстреливает снаряд со скоростью 20 метров в секунду. Каков в данном случае вектор скорости для выпущенного снаряда?

Так как вектор направления имеет длину равную единице, мы умножаем направление на скорость снаряда и получаем вектор скорости (20, 0). Если-же вектор направления имеет отличную от единицы длину, мы не сможем сделать этого. Снаряд будет либо слишком быстрым, либо слишком медленным.

Вектор с длиной равной единице называется «нормализованным». Как сделать вектор нормализованным? Довольно просто. Мы делим каждый компонент вектора на его длину. Если, к примеру, мы хотим нормализовать вектор V с компонентами (3, 4), мы просто делим каждый компонент на его длину, то есть на 5, и получаем (3/5, 4/5). Теперь, с помощью теоремы Пифагора, мы убедимся в том, что его длина равна единице:

(3/5) 2 + (4/5) 2 = 9/25 + 16/25 = 25/25 = 1

Скалярное произведение векторов

Что такое скалярное произведение (записывается как •)? Чтобы рассчитать скалярное произведение двух векторов, мы должны умножить их компоненты, а затем сложить полученные результаты вместе

(a1, a2) • (b1, b2) = a1b1 + a2b2

Например: (3, 2) • (1, 4) = 3*1 + 2*4 = 11. На первый взгляд это кажется бесполезным, но посмотрим внимательнее на это:

Как вычислять отрицательные векторы

Здесь мы можем увидеть, что если вектора указывают в одном направлении, то их скалярное произведение больше нуля. Когда они перпендикулярны друг другу, то скалярное произведение равно нулю. И когда они указывают в противоположных направлениях, их скалярное произведение меньше нуля.
В основном, с помощью скалярного произведения векторов можно рассчитать, сколько их указывает в одном направлении. И хоть это лишь малая часть возможностей скалярного произведения, но уже очень для нас полезная.

Допустим у нас есть стражник, расположенный в G(1, 3) смотрящий в направлении D(1,1), с углом обзора 180 градусов. Главный герой игры подсматривает за ним с позиции H(3, 2). Как определить, находится-ли главный герой в поле зрения стражника или нет? Сделаем это путём скалярного произведения векторов D и V (вектора, направленного от стражника к главному герою). Мы получим следующее:

V = H — G = (3, 2) — (1, 3) = (3-1, 2-3) = (2, -1)
D•V = (1, 1) • (2, -1) = 1*2 + 1*-1 = 2-1 = 1

Так как единица больше нуля, то главный герой находится в поле зрения стражника.

Как вычислять отрицательные векторы

Мы уже знаем, что скалярное произведение имеет отношение к определению направления векторов. А каково его более точное определение? Математическое выражение скалярного произведения векторов выглядит так:

Где Θ (произносится как «theta») — угол между векторами A и B.

Это позволяет нам найти Θ (угол) с помощью выражения:

Как я говорил ранее, нормализация векторов упрощает нашу жизнь. И если A и B нормализованы, то выражение упрощается следующим образом:

Давайте опять рассмотрим сценарий со стражником. Пусть теперь угол обзора стражника будет равен 120 градусам. Получим нормализованные вектора для направления взгляда стражника (D’) и для направления от стражника к главному герою (V’). Затем определим угол между ними. Если угол более 60 градусов (половина от угла обзора), то главный герой находится вне поля зрения стражника.

D’ = D / |D| = (1, 1) / sqrt(1 2 + 1 2 ) = (1, 1) / sqrt(2) = (0.71, 0.71)
V’ = V / |V| = (2, -1) / sqrt(2 2 + (-1) 2 ) = (2,-1) / sqrt(5) = (0.89, -0.45)

Θ = acos(D’V’) = acos(0.71*0.89 + 0.71*(-0.45)) = acos(0.31) = 72

Угол между центром поля зрения стражника и местоположением главного героя составляет 72 градуса, следовательно стражник его не видит.

Как вычислять отрицательные векторы

Понимаю, что это выглядит довольно сложно, но это потому, что мы всё делаем вручную. В программе это всё довольно просто. Ниже показано как я сделал это в нашей игре Overgrowth с помощью написанных мной С++ библиотек для работы с векторами:

Векторное произведение

Допустим у нас есть корабль с пушками, которые стреляют в правую и в левую стороны по курсу. Допустим, что лодка расположена вдоль вектора направления (2, 1). В каких направлениях теперь стреляют пушки?

Это довольно просто в двухмерной графике. Чтобы повернуть направление на 90 градусов по часовой стрелке, достаточно поменять местами компоненты вектора, а затем поменять знак второму компоненту.
(a, b) превращается в (b, -a). Следовательно у корабля, расположенного вдоль вектора (2, 1), пушки справа по борту будут стрелять в направлении (1, -2), а пушки с левого борта, будут стрелять в противоположном направлении. Меняем знаки у компонент вектора и получаем (-1, 2).

Как вычислять отрицательные векторы

А что если мы хотим рассчитать это всё для трехмерной графики? Рассмотрим пример с кораблём.
У нас есть вектор мачты M, направленной прямо вверх (0, 1, 0) и направление ветра: север-северо-восток W (1, 0, 2). И мы хотим вычислить вектор направления паруса S, чтобы наилучшим образом «поймать ветер».

Для решения этой задачи мы используем векторное произведение: S = M x W.

Как вычислять отрицательные векторы

Подставим теперь нужные нам значения:

S = MxW = (0, 1, 0) x (1, 0, 2) = ([1*2 — 0*0], [0*1 — 0*2], [0*0 — 1*1]) = (2, 0, -1)

Для расчётов вручную довольно сложно, но для графических и игровых приложений я рекомендую написать функцию, подобную той, что указана ниже и не вдаваться более в детали подобных расчётов.

Векторное произведение часто используется в играх, чтобы рассчитать нормали к поверхностям. Направления, в которых «смотрит» та или иная поверхность. Например, рассмотрим треугольник с векторами вершин A, B и С. Как мы найдем направление в котором «смотрит» треугольник, то есть направление перпендикулярное его плоскости? Это кажется сложным, но у нас есть инструмент для решения этой задачи.

Используем вычитание, для определения направления из A в С (C — A), пусть это будет «грань 1» (Edge 1) и направление из A в B (B — A), пусть это будет «грань 2» (Edge 2). А затем применим векторное произведение, чтобы найти вектор, перпендикулярный им обоим, то есть перпендикулярный плоскости треугольника, также называемый «нормалью к плоскости».

Как вычислять отрицательные векторы

Вот так это выглядит в коде:

В играх основное выражение освещённости записывается как N • L, где N — это нормаль к освещаемой поверхности, а L — это нормализованный вектор направления света. В результате поверхность выглядит яркой, когда на неё прямо падает свет, и тёмной, когда этого не происходит.

Теперь перейдем к рассмотрению такого важного для разработчиков игр понятия, как «матрица преобразований» (transformation matrix).

Для начала изучим «строительные блоки» матрицы преобразований.

Базисный вектор

Допустим мы пишем игру Asteroids на очень старом «железе» и нам нужен простой двухмерный космический корабль, который может свободно вращаться в своей плоскости. Модель корабля выглядит так:

Как вычислять отрицательные векторы

Как нам рисовать корабль, когда игрок поворачивает его на произвольный градус, скажем 49 градусов против часовой стрелки. Используя тригонометрию, мы можем написать функцию двухмерного поворота, которая принимает координаты точки и угол поворота, и возвращает координаты смещённой точки:

Применяя эту функцию ко всем трём точкам, мы получим следующую картину:

Как вычислять отрицательные векторы

Операции с синусами и косинусами работают довольно медленно, но так как мы делаем расчёты лишь для трёх точек, это будет нормально работать даже на старом «железе» (прим. переводчика: в случаях, когда предполагается интенсивное использование тригонометрических функций, для ускорения вычислений, в памяти организуют таблицы значений для каждой функции и рассчитывают их во время запуска приложения. Затем при вычислении той или иной тригонометрической функции просто производится обращение к таблице).

Пусть теперь наш корабль выглядит вот так:

Как вычислять отрицательные векторы

Теперь старый подход будет слишком медленным, так как надо будет поворачивать довольно большое количество точек. Одно из элегантных решений данной проблемы будет звучать так — «Что если вместо поворота каждой точки модели корабля, мы повернём координатную решётку нашей модели?»

Как вычислять отрицательные векторы

Как это работает? Давайте посмотрим внимательнее, что собой представляют координаты.
Когда мы говорим о точке с координатами (3, 2), мы говорим, что её местоположение находится в трех шагах от точки отсчёта по координатной оси X, и двух шагах от точки отсчёта по координатной оси Y.

По-умолчанию координатные оси расположены так: вектор координатной оси X (1, 0), вектор координатной оси Y (0, 1). И мы получим расположение: 3(1, 0) + 2(0, 1). Но координатные оси не обязательно должны быть в таком положении. Если мы повернём координатные оси, в это-же время мы повернём все точки в координатной решётке.

Чтобы получить повернутые оси X и Y мы применим тригонометрические функции, о которых говорили выше. Если мы поворачиваем на 49 градусов, то новая координатная ось X будет получена путём поворота вектора (0, 1) на 49 градусов, а новая координатная ось Y будет получена путём поворота вектора (0, 1) на 49 градусов. Итак вектор новой оси X у нас будет равен (0.66, 0.75), а вектор новой оси Y будет (-0.75, 0.66). Сделаем это вручную для нашей простой модели из трёх точек, чтобы убедиться, что это работает так, как нужно:

Координаты верхней точки (0, 2), что означает, что её новое местоположение находится в 0 на новой (повёрнутой) оси X и 2 на новой оси Y:

0*(0.66,0.75) + 2*(-0.75, 0.66) = (-1.5, 1.3)

Нижняя левая точка (-1, -1), что означает, что её новое местоположение находится в -1 на повернутой оси X, и -1 на повернутой оси Y:

-1*(0.66,0.75) + -1*(-0.75, 0.66) = (0.1, -1.4)

Нижняя правая точка (1, -1), что означает её новое местоположение находится в 1 на повернутой оси X, и -1 на повернутой оси Y

1*(0.66,0.75) + -1*(-0.75, 0.66) = (1.4, 0.1)

Как вычислять отрицательные векторы

Мы показали, как координаты корабля отображаются в другой координатной сетке с повернутыми осями (или «базисными векторами»). Это удобно в нашем случае, так как избавляет нас от необходимости применять тригонометрические преобразования к каждой из точек модели корабля.

Каждый раз, когда мы изменяем базисные вектора (1, 0) и (0, 1) на (a, b) и (c, d), то новая координата точки (x, y) может быть найдена с помощью выражения:

Обычно базисные вектора равны (1, 0) и (0, 1) и мы просто получаем x(1, 0) + y(0, 1) = (x, y), и нет необходимости заботиться об этом дальше. Однако, важно помнить, что мы можем использовать и другие базисные вектора, когда нам это нужно.

Матрицы

Матрицы похожи на двухмерные вектора. Например, типичная 2×2 матрица, может выглядеть так:

Когда вы умножаете матрицу на вектор, вы суммируете скалярное произведение каждой строки с вектором, на который происходит умножение. Например, если мы умножаем вышеприведённую матрицу на вектор (x, y), то мы получаем:

Будучи записанным по-другому, это выражение выглядит так:

Выглядит знакомо, не так-ли? Это в точности такое-же выражение, которые мы использовали для смены базисных векторов. Это означает, что умножая 2×2 матрицу на двухмерный вектор, мы тем самым меняем базисные вектора. Например, если мы вставим стандартные базисные вектора в (1, 0) и (0, 1) в колонки матрицы, то мы получим:

Это единичная матрица, которая не даёт эффекта, который мы можем ожидать от нейтральных базисных векторов, которые мы указали. Если-же мы повернём базисные вектора на 49-градусов, то мы получим:

Эта матрица будет поворачивать двухмерный вектор на 49 градусов против часовой стрелки. Мы можем сделать код нашей игры Asteriods более элегантным, используя матрицы вроде этой. Например, функция поворота нашего корабля может выглядеть так:

Однако, наш код будет ещё более элегантным, если мы сможем также включить в эту матрицу перемещение корабля в пространстве. Тогда у нас будет единая структура данных, которая будет заключать в себе и применять информацию об ориентации объекта и его местоположении в пространстве.

К счастью есть способ добиться этого, хоть это и выглядит не очень элегантно. Если мы хотим переместиться с помощью вектора (e, f), мы лишь включаем его в нашу матрицу преобразования:

И добавляем дополнительную единицу в конец каждого вектора, определяющего местоположение объекта, например так:

Теперь, когда мы перемножаем их, мы получаем:

(a, c, e) • (x, y, 1) + (b, d, f) • (x, y, 1) + (0, 0, 1) • (x, y, 1)

Что, в свою очередь, может быть записано как:

x(a, b) + y(c, d) + (e, f)

Теперь у нас есть полный механизм трансформации, заключённый в одной матрице. Это важно, если не принимать в расчёт элегантность кода, так как с ней мы теперь можем использовать все стандартные манипуляции с матрицами. Например перемножить матрицы, чтобы добавить нужный эффект, или мы можем инвертировать матрицу, чтобы получить прямо противоположное положение объекта.

Трехмерные матрицы

Матрицы в трехмерном пространстве работают так-же как и в двухмерном. Я приводил примеры с двухмерными векторами и матрицами, так как их просто отобразить с помощью дисплея, показывающего двухмерную картинку. Нам просто надо определить три колонки для базисных векторов, вместо двух. Если базисные вектора это (a,b,c), (d,e,f) and (g,h,i) то наша матрица будет выглядеть так:

Если нам нужно перемещение (j,k,l), то мы добавляем дополнительную колонку и строку, как говорили раньше:

И добавляем единицу [1] в вектор, как здесь:

Вращение в двухмерном пространстве

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

Более элегантно это можно выразить в матричной форме. Чтобы определить матрицу, мы можем применить эту функцию к осям (1, 0) и (0, 1) для угла Θ, а затем включить полученные оси в колонки нашей матрицы. Итак, начнём с координатной оси X (1, 0). Если мы применим к ней нашу функцию, мы получим:

(1*cos(Θ) — 0*sin(Θ), 1*sin(Θ) + 0*cos(Θ)) = (cos(Θ), sin(Θ))

Затем, мы включаем координатную ось Y (0, 1). Получим:

(0*cos(Θ) — 1*sin(Θ), 0*sin(Θ) + 1*cos(Θ)) = (-sin(Θ), cos(Θ))

Включаем полученные координатные оси в матрицу, и получаем двухмерную матрицу вращения:

Применим эту матрицу к Сюзанне, мартышке из графического пакета Blender. Угол поворота Θ равен 45 градусов по часовой стрелке.

Как вычислять отрицательные векторы

Как видите — это работает. Но что если нам надо осуществить вращение вокруг точки, отличной от (0, 0)?
Например, мы хотим вращать голову мартышки вокруг точки, расположенной в её ухе:

Как вычислять отрицательные векторы

Чтобы сделать это, мы можем начать с создания матрицы перемещения (translation matrix) T, которая перемещает объект из начальной точки в точку вращения в ухе мартышки, и матрицу вращения R, для вращения объекта вокруг начальной точки. Теперь для вращения вокруг точки, расположенной в ухе, мы можем сперва переместить точку в ухе на место начальной точки, с помощью инвертирования матрицы T, записанной как T -1 . Затем, мы вращаем объект вокруг начальной точки, с помощью матрицы R, а затем применяем матрицу T для перемещения точки вращения назад, к своему исходному положению.
Ниже дана иллюстрация к каждому из описанных шагов:

Как вычислять отрицательные векторы

Это важный шаблон, который мы будем применять позднее — применение вращения для двух противоположных трансформаций позволяет нам вращать объект в другом «пространстве». Что очень удобно и полезно.

Теперь рассмотрим трёхмерное вращение.

Трёхмерное вращение

Вращение вокруг оси Z работает по тому-же принципу, что и вращение в двухмерном пространстве. Нам лишь нужно изменить нашу старую матрицу, добавив к ней дополнительную колонку и строку:

Применим эту матрицу к трехмерной версии Сюзанны, мартышки из пакета Blender. Угол поворота Θ пусть будет равен 45 градусов по часовой стрелке.

Как вычислять отрицательные векторы

То-же самое. Вращение только вокруг оси Z ограничивает нас, как насчёт вращения вокруг произвольной оси?

Вращение, определяемое осью и углом (Axis-angle rotation)

Представление вращения, определяемого осью и углом, также известно как вращение в экспоненциальных координатах, параметризованное вращением двух величин. Вектора, определяющего вращение направляющей оси (прямая линия) и угла, описывающего величину поворота вокруг этой оси. Вращение осуществляется согласно правилу правой руки.

Итак, вращение задаётся двумя параметрами (axis, angle), где axis — вектор оси вращения, а angle — угол вращения. Этот приём довольно прост и являет собой отправную точку для множества других операций вращения, с которыми я работаю. Как практически применить вращение, определяемое осью и углом?

Допустим мы имеем дело с осью вращения, показанной на рисунке ниже:

Как вычислять отрицательные векторы

Мы знаем как вращать объект вокруг оси Z, и мы знаем как вращать объект в других пространствах. Итак, нам лишь надо создать пространство, где наша ось вращения будет являться осью Z. И если эта ось будет осью Z, то что будет являться осями X и Y? Займемся вычислениями сейчас.

Чтобы создать новые оси X и Y нам нужно лишь выбрать два вектора, которые перпендикулярны новой оси Z и перпендикулярны друг другу. Мы уже говорили ранее о векторном умножении, которое берёт два вектора и даёт в итоге перпендикулярный им вектор.

У нас есть один вектор сейчас, это ось вращения, назовём его A. Возьмём теперь случайный другой вектор B, который находится не в том-же направлении, что и вектор A. Пусть это будет (0, 0, 1) к примеру.

Теперь мы имеем ось вращения A и случайный вектор B, мы можем получить нормаль C, через векторное произведение A и B. С перпендикулярен векторам A и B. Теперь мы делаем вектор B перпендикулярным векторам A и C через их векторное произведение. И всё, у нас есть все нужные нам оси координат.

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

Тут показана иллюстрация для каждого шага:

Как вычислять отрицательные векторы

Теперь, имея информацию о новых координатных осях, мы можем составить матрицу M, включив каждую ось как колонку в эту матрицу. Нам надо убедиться, что вектор A является третьей колонкой, чтобы он был нашей новой осью координат Z.

Теперь это похоже на то, что мы делали для поворота в двухмерном пространстве. Мы можем применить инвертированную матрицу M, чтобы переместиться в новую систему координат, затем произвести вращение, согласно матрице R, чтобы повернуть объект вокруг оси Z, затем применить матрицу M, чтобы вернуться в исходное координатное пространство.

Как вычислять отрицательные векторы

Теперь мы можем вращать объект вокруг произвольной оси. В конце концов мы можем просто создать матрицу T = T = M -1 RM и использовать её много раз, без дополнительных усилий с нашей стороны. Есть более эффективные способы конвертирования вращений, определяемых осью и углом во вращения, определяемые матрицами. Просто описанный нами подход показывает многое из того, о чём мы говорили ранее.

Вращение, определяемое осью и углом, возможно, самый интуитивно понятный способ. Применяя его, очень легко инвертировать поворот, поменяв знак у угла, и легко интерполировать, путём интерполяции угла. Однако тут есть серьёзное ограничение, и заключается оно в том, что такое вращение не является суммирующим. То есть вы не можете комбинировать два вращения, определяемых осью и углом в третье.
Вращение, определяемое осью и углом — хороший способ для начала, но оно должно быть преобразовано во что-то другое, чтобы использоваться в более сложных случаях.

Эйлеровские углы

Эйлеровские углы представляют собой другой способ вращения, заключающийся в трёх вложенных вращениях относительно осей X, Y и Z. Вы, возможно, сталкивались с их применением в играх, где камера показывает действие от первого лица, либо от третьего лица.

Допустим вы играете в шутер от первого лица и вы повернулись на 30 градусов влево, а затем посмотрели на 40 градусов вверх. В конце-концов в вас стреляют, попадают, и, в результате удара, камера поворачивается вокруг своей оси на 45 градусов. Ниже показано вращение с помощью углов Эйлера (30, 40, 45).

Как вычислять отрицательные векторы

Углы Эйлера — удобное и простое в управлении средство. Но у этого способа есть два недостатка.

Первый, это вероятность возникновения ситуации под названием «блокировка оси» или «шарнирный замок» (gimbal lock). Представьте, что вы играете в шутер от первого лица, где вы можете посмотреть влево, вправо, вверх и вниз или повернуть камеру вокруг зрительной оси. Теперь представьте, что вы смотрите прямо вверх. В этой ситуации попытка взглянуть налево или направо будет аналогична попытке вращения камеры. Всё что мы можем вы этом случае, это вращать камеру вокруг своей оси, либо посмотреть вниз. Как вы можете представить, это ограничение делает непрактичным применение углов Эйлера в лётных симуляторах.

Второе — интерполяция между двумя эйлеровскими углами вращения не даёт кратчайшего пути между ними.
Например, у вас две интерполяции между двумя одинаковыми вращениями. Первая использует интерполяцию эйлеровского угла, вторая использует сферическую линейную интерполяцию (spherical linear interpolation (SLERP)), чтобы найти кратчайший путь.

Как вычислять отрицательные векторы

Итак, что-же больше подойдет для интерполяции вращений? Может быть матрицы?

Вращение с помощью матриц

Как мы уже говорили ранее, матрицы вращения хранят в себе информацию о трёх осях. Это означает, что интерполяция между двумя матрицами лишь линейно интерполирует каждую ось. В результате это даёт нам эффективный путь, то так-же привносит новые проблемы. Например, тут показаны два вращения и одно интерполированное полу-вращение:

Как вычислять отрицательные векторы

Как вы можете заметить, интерполированное вращение значительно меньше, чем любое из исходных вращений, и две оси более не перпендикулярны друг другу. Это логично, если вдуматься — середина отрезка, соединяющего любые две точки на сфере будет расположена ближе к центру сферы.

Это в свою очередь порождает известный «эффект фантика» (candy wrapper effect), при применении скелетной анимации. Ниже показана демонстрация этого эффекта на примере кролика из нашей игры Overgrowth (прим. переводчика: обратите внимание на середину туловища кролика).

Как вычислять отрицательные векторы

Вращение, основанное на матричных операциях, очень полезно, так как они могут аккумулировать вращения без всяких проблем, вроде блокировки оси (gimbal lock), и может очень эффективно применяться к точкам сцены. Вот почему поддержка вращения на матрицах встроена в графические карты. Для любого типа трёхмерной графики матричный формат вращения — это всегда итоговый применяемый способ.

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

Итак, остался только один главный формат вращения. Последний, но тем не менее, важный.

Кватернионы

Что-же такое кватернионы? Если очень кратко, то это альтернативный вариант вращения, основанный на оси и угле (axis-angle rotation), который существует в пространстве.

Подобно матрицам они могут аккумулировать вращения, то есть вы можете составлять из них цепочку вращений, без опаски получить блокировку оси (gimbal lock). И в то-же время, в отличие от матриц, они могут хорошо интерполироваться из одного положения в другое.

Являются-ли кватернионы лучшим решением, нежели остальные способы вращений (rotation formats)?
На сегодняшний день они комбинируют все сильные стороны других способов вращений. Но у них есть два слабых места, рассмотрев которые, мы придём к выводу, что кватернионы лучше использовать для промежуточных вращений. Итак, каковы недостатки кватернионов.

Во-первых кватернионы непросто отобразить на трёхмерном пространстве. И мы вынуждены всегда реализовывать вращение более простым способом, а затем конвертировать его. Во-вторых, кватернионы не могут эффективно вращать точки, и мы вынуждены конвертировать их в матрицы, чтобы повернуть значительное количество точек.

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

«Внутренняя кухня» механизма кватернионов не очень понятна и не интересна мне. И, возможно, не будет интересна и вам, если только вы не математик. И я советую вам найти библиотеки, которые работают с кватернионами, чтобы облегчить вам решение ваших задач с их помощью.

Математические библиотеки «Bullet» или «Blender» будут хорошим вариантом для начала.

Видео:Вектор. Сложение и вычитание. 9 класс | МатематикаСкачать

Вектор. Сложение и вычитание. 9 класс | Математика

Знакомимся с вектором

Основы линейной алгебры для тех, кого это миновало в универе.

Вы наверняка слышали много историй о программистах, которые учились в технических вузах, изучали высшую математику и теперь пользуются этими знаниями в программировании. И если кого-то это не коснулось, может быть ощущение, что он пропустил в жизни что-то важное.

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

⚠️ Математики, помогайте. Мы тут многое упростили, поэтому будем рады увидеть ваши уточнения и замечания в комментариях.

Видео:Вычитание векторов. 9 класс.Скачать

Вычитание векторов. 9 класс.

Линейная алгебра

Есть математика: она изучает абстрактные объекты и их взаимосвязи. Благодаря математике мы знаем, что если сложить два объекта с ещё двумя такими же объектами, то получится четыре объекта. И неважно, что это были за объекты: яблоки, козы или ракеты. Математика берёт наш вещественный мир и изучает его более абстрактные свойства.

Внутри математики есть алгебра: если совсем примитивно, то в алгебре мы вместо чисел начинаем подставлять буквы и изучать ещё более абстрактные свойства объектов.

Например, мы знаем, что если a + b = c , то a = c − b . Мы не знаем, что стоит на местах a, b или c, но для нас это такой абстрактный закон, который подтверждается практикой.

Внутри алгебры есть линейная алгебра — она изучает векторы, векторные пространства и другие абстрактные понятия, которые в целом относятся к некой упорядоченной информации. Например, координаты ракеты в космосе, биржевые котировки, расположение пикселей в изображении — всё это примеры упорядоченной информации, которую можно описывать векторами. И вот их изучает линейная алгебра.

В программировании линейная алгебра нужна в дата-сайенс, где из упорядоченной информации создаются алгоритмы машинного обучения.

Если представить линейную алгебру в виде дома, то вектор — это кирпич, из которого всё состоит. Сегодня разберёмся, что такое вектор и как его понимать.

Видео:ВЫЧИТАНИЕ ВЕКТОРОВ ЧАСТЬ I #егэ #огэ #математика #геометрия #профильныйегэСкачать

ВЫЧИТАНИЕ ВЕКТОРОВ ЧАСТЬ I #егэ #огэ #математика #геометрия #профильныйегэ

Что такое вектор

Вы наверняка помните вектор из школьной программы — это такая стрелочка. Она направлена в пространство и измеряется двумя параметрами: длиной и направлением. Пока длина и направление не меняются, вектор может перемещаться в пространстве.

Как вычислять отрицательные векторыФизическое представление вектора: есть длина, направление и нет начальной точки отсчёта. Такой вектор можно как угодно двигать в пространстве

У аналитиков вектор представляется в виде упорядоченного списка чисел: это может быть любая информация, которую можно измерить и последовательно записать. Для примера возьмём рынок недвижимости, который нужно проанализировать по площади и цене домов — получаем вектор, где первая цифра отвечает за площадь, а вторая — за цену. Аналогично можно сортировать любые данные.

Как вычислять отрицательные векторыАналитическое представление вектора: данные можно перевести в числа

Математики обобщают оба подхода и считают вектор одновременно стрелкой и числом — это связанные понятия, перетекающие друг в друга в зависимости от задачи. В одних случаях удобней считать, а в других — показать всё графически. В обоих случаях перед нами вектор.

Как вычислять отрицательные векторыМатематическое представление вектора: данные можно перевести в числа или график

В дата-сайенс используется математическое представление вектора — программист может обработать данные и визуализировать результат. В отличие от физического представления, стрелки векторов в математике привязаны к системе координат Х и У — они не блуждают в пространстве, а исходят из нулевой точки.

Как вычислять отрицательные векторыВекторная система координат с базовыми осями Х и Y. Место их пересечения — начало координат и корень любого вектора. Засечки на осях — это отрезки одной длины, которые мы будем использовать для определения векторных координат

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

Например, можно взять много векторов с ценами на недвижимость, как-то их проанализировать, усреднить и обучить на них алгоритм. Без векторов это были бы просто «рассыпанные» данные, а с векторами — порядок.

Видео:➡️ КАК ВЫЧИТАТЬ ВЕКТОРЫ?Скачать

➡️ КАК ВЫЧИТАТЬ ВЕКТОРЫ?

Как записывать

Вектор можно записать в строку или в столбец. Для строчной записи вектор обозначают одной буквой, ставят над ней черту, открывают круглые скобки и через запятую записывают координаты вектора. Для записи в столбец координаты вектора нужно взять в круглые или квадратные скобки — допустим любой вариант.

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

Как вычислять отрицательные векторыСпособы записи вектора

Скаляр

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

Помните физику? Есть скалярные величины и есть векторные. Скалярные как бы описывают просто состояние, например, температуру. Векторные величины ещё и описывают направление.

Видео:10 класс, 43 урок, Компланарные векторыСкачать

10 класс, 43 урок, Компланарные векторы

Как изображать

Вектор из одного числа (скаляр) отображается в виде точки на числовой прямой.

Как вычислять отрицательные векторыГрафическое представление скаляра. Записывается в круглых скобках

Вектор из двух чисел отображается в виде точки на плоскости осей Х и Y. Числа задают координаты вектора в пространстве — это такая инструкция, по которой нужно перемещаться от хвоста к стрелке вектора. Первое число показывает расстояние, которое нужно пройти вдоль оси Х; второе — расстояние по оси Y. Положительные числа на оси Х обозначают движение вправо; отрицательные — влево. Положительные числа на оси Y — идём вверх; отрицательные — вниз.

Представим вектор с числами −5 и 4. Для поиска нужной точки нам необходимо пройти влево пять шагов по оси Х, а затем подняться на четыре этажа по оси Y.

Как вычислять отрицательные векторыГрафическое представление числового вектора в двух измерениях

Вектор из трёх чисел отображается в виде точки на плоскости осей Х, Y и Z. Ось Z проводится перпендикулярно осям Х и У — это трёхмерное измерение, где вектор с упорядоченным триплетом чисел: первые два числа указывают на движение по осям Х и У, третье — куда нужно двигаться вдоль оси Z. Каждый триплет создаёт уникальный вектор в пространстве, а у каждого вектора есть только один триплет.

Если вектор состоит из четырёх и более чисел, то в теории он строится по похожему принципу: вы берёте координаты, строите N-мерное пространство и находите нужную точку. Это сложно представить и для обучения не понадобится.

Как вычислять отрицательные векторыГрафическое представление числового вектора в трёх измерениях. Для примера мы взяли координаты −5, 2, 4

Помните, что все эти записи и изображения с точки зрения алгебры не имеют отношения к нашему реальному трёхмерному пространству. Вектор — это просто какое-то количество абстрактных чисел, собранных в строгом порядке. Вектору неважно, сколько там чисел и как их изображают люди. Мы же их изображаем просто для наглядности и удобства.

Например, в векторе спокойно может быть 99 координат. Для его изображения нам понадобилось бы 99 измерений, что очень проблематично на бумаге. Но с точки зрения вектора это не проблема: перемножать и складывать векторы из двух координат можно так же, как и векторы из 9999999 координат, принципы те же.

Видео:Координаты вектора. 9 класс.Скачать

Координаты вектора. 9 класс.

И зачем нам это всё

Вектор — это «кирпичик», из которого строится дата-сайенс и машинное обучение. Например:

  • На основании векторов получаются матрицы. Если вектор — это как бы линия, то матрица — это как бы плоскость или таблица.
  • Машинное обучение в своей основе — это перемножение матриц. У тебя есть матрица с данными, которые машина знает сейчас; и тебе нужно эту матрицу «дообучить». Ты умножаешь существующую матрицу на какую-то другую матрицу и получаешь новую матрицу. Делаешь так много раз по определённым законам, и у тебя обученная модель, которую на бытовом языке называют искусственным интеллектом.

Кроме того, векторы используются в компьютерной графике, работе со звуком, инженерном и просто любом вычислительном софте.

И давайте помнить, что вектор — это не какая-то сложная абстрактная штука, а просто сумка, в которой лежат числа в определённом порядке. То, что мы называем это вектором, — просто нюанс терминологии.

Видео:Умножение вектора на число. 9 класс.Скачать

Умножение вектора на число. 9 класс.

Что дальше

В следующий раз разберём операции с векторами. Пока мы готовим материал — рекомендуем почитать интервью с Анастасией Никулиной. Анастасия ведёт ютуб-канал по дата-сайнс и работает сеньором дата-сайентистом в Росбанке.

Видео:Построение проекции вектора на осьСкачать

Построение проекции вектора на ось

Большая теория по векторам

И ты наверняка обратил внимание, что некоторые величины имеют только значение (число) – например, путь ((L)).

А некоторые имеют и число, и направление — например, перемещение ((vec)).

И сейчас ты узнаешь, почему это настолько важно.

Видео:Математика без Ху!ни. Смешанное произведение векторовСкачать

Математика без Ху!ни. Смешанное произведение векторов

Векторы — коротко о главном

Решать задачи с векторами — легко!

Видео:18+ Математика без Ху!ни. Скалярное произведение векторов. Угол между векторами.Скачать

18+ Математика без Ху!ни. Скалярное произведение векторов. Угол между векторами.

Векторы и… Колумб

В 1492 году Колумб приказал кораблям изменить курс на запад-юго-запад, полагая, что он и его команда уже прошли мимо Японии, не заметив ее островов.

Вскоре его экспедиция наткнулась на множество архипелагов, которые ошибочно принимали за земли Восточной Азии. И теперь, спустя века, американцы в октябре отмечают высадку Колумба в Новом Свете.

Кто знает, как повернулась бы история, если бы его корабли не поменяли свое направление?

Видео:Урок 9. Проекции вектора на координатные осиСкачать

Урок 9. Проекции вектора на координатные оси

О направлении

Направление – одна из важнейших характеристик движения.

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

Наверное, ты без труда заметил, что направление имеют сила, скорость, перемещение, а время, длина, масса и температура – это просто числа.

Так вот, «просто числа» — это скалярные величины (их также называют скалярами).

А «числа с направлением» — это векторные величины (их иногда называют векторы).

В физике существует множество скалярных и векторных величин.

Видео:Скалярное произведение векторов. 9 класс.Скачать

Скалярное произведение векторов. 9 класс.

Что такое скалярная величина?

Скалярная величина, в отличие от вектора, не имеет направления и определяется лишь значением (числом)

Это, например, время, длина, масса, температура (продолжи сам!)

Видео:Физика | Ликбез по векторамСкачать

Физика | Ликбез по векторам

Что такое векторная величина?

Векторная величина – это величина, которая определяется и значением, и направлением.

В случае с векторами нам важно, куда мы, например, тянем груз или в какую сторону движемся.

Например, как на этом рисунке изображен вектор силы (нам важно не только с какой силой, но и куда мы тянем груз):

Как вычислять отрицательные векторы

Видео:Коллинеарность векторовСкачать

Коллинеарность векторов

Как обозначаются векторы?

Векторы принято обозначать специальным символом – стрелочкой над названием. Вот, например, вектор перемещения: (vec)

Значение вектора – это модуль вектора, то есть его длина.

Обозначить это можно двумя способами: (left| <vec> right|) или (S)

Видео:Координаты точки и координаты вектора 1.Скачать

Координаты точки и координаты вектора 1.

Операции над векторами

Для решения задач необходимо уметь работать с векторами: складывать, вычитать, умножать их.

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

Умножение вектора на число

Если вектор умножить на какое-либо число (скаляр), мы просто «растягиваем» вектор, сохраняя его направление. Получившийся вектор сонаправлен начальному, то есть они имеют одинаковое направление.

(Если направление противоположно, обозначаем так: (vecuparrow downarrow vec))

Рассмотрим на примере, используя клетку для точности построений:

Как вычислять отрицательные векторы

Если вектор умножить на ноль, он станет нулевым.

Обязательно нужно ставить значок вектора над нулем! Нельзя говорить, что векторная величина просто равна скалярной:

Рассмотрим некоторые свойства нулевого вектора.

Если он нулевой, то его длина равна нулю! Логично, не правда ли?

А это значит, что его начало совпадает с концом, это просто какая-то точка.

Нулевой вектор – вектор, начало которого совпадает с концом.

Нулевой вектор принято считать сонаправленным любому вектору.

Его мы можем получить не только путем умножения вектора на ноль, но и путем сложения противонаправленных векторов:

А если к любому вектору прибавит нулевой, ничего не изменится:

Если вектор умножают на отрицательное число, он изменит свое направление на противоположное. Такой вектор называется обратным данному.

Как вычислять отрицательные векторы

Но такие векторы должны быть коллинеарны. Звучит как скороговорка, но ничего страшного. Главное – понять суть.

Коллинеарные векторы – векторы, лежащие на одной прямой или на параллельных прямых.

Как вычислять отрицательные векторы

Две прямые параллельны: (qparallel p)

Векторы лежат на одной прямой: они коллинеарны. По направлению видно, что они противонаправлены, это обозначается так:

Векторы лежат на параллельных прямых, они коллинеарны. При этом они сонаправлены:

Эти двое тоже коллинеарны! Они ведь лежат на параллельных прямых. При этом они противонаправлены:

(vecuparrow downarrow vec)

Коллинеарные векторы, имеющие одинаковую длину и противоположные направления, называются обратными друг другу.

Параллельный перенос векторов

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

Если передвинуть вектор, не меняя его направления и длины, он будет идентичен начальному. Это свойство – параллельный перенос.

Как вычислять отрицательные векторы

Сложение векторов по правилу треугольника

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

Как вычислять отрицательные векторы

Наша цель – найти такой вектор, который будет являться суммой двух данных:

Для начала нужно сделать так, чтобы конец одного вектора был началом другого. Для этого воспользуемся параллельным переносом:

Как вычислять отрицательные векторы

Теперь достроим до треугольника.

Но как узнать направление нужного нам вектора?

Все просто: вектор суммы идет от начала первого слагаемого к концу второго, мы словно «идём» по векторам:

Как вычислять отрицательные векторы

Это называется правилом треугольника.

Больше двух слагаемых векторов. Сложение по правилу многоугольника

Но что делать, нам нужно сложить не два, а три, пять векторов или даже больше?

Мы руководствуемся той же логикой: соединяем векторы и «идём» по ним:

Как вычислять отрицательные векторы

Это называется правилом многоугольника.

Вычитание векторов через сложение

Вычитание векторов не сложнее. Это даже можно сделать через сумму! Для этого нам понадобится понятие обратного вектора. Запишем разность так:

Тогда нам лишь остается найти сумму с обратным вектором:

Как вычислять отрицательные векторы

А сделать это очень легко по правилу треугольника:

Как вычислять отрицательные векторы

Всегда помни, что вычитание можно представлять сложением, а деление — умножением на дробь.

Вычитание векторов через треугольник

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

Итак, векторы должны выходить из одной точки. Далее мы достраиваем рисунок до треугольника и определяем положение. Рассмотрим два случая:

Как вычислять отрицательные векторы

Как вычислять отрицательные векторы

Направление вектора разности зависит от того, из какого вектора мы вычитаем. У них совпадают концы.

Универсальное правило параллелограмма

Есть еще один способ сложения и вычитания векторов.

Способ параллелограмма наиболее востребован в физике и сейчас ты поймешь, почему. Основа в том, чтобы векторы выходили из одной точки, имели одинаковое начало.

Как вычислять отрицательные векторы

Ничего не напоминает?

Именно! Когда мы делаем чертеж к задачам по физике, все силы, приложенные к телу, мы рисуем из одной точки.

В чем же заключается правило параллелограмма? С помощью параллельного переноса достроим до параллелограмма:

Как вычислять отрицательные векторы

Тогда вектор суммы будет диагональю этой фигуры. Это легко проверяется правилом треугольника. Начало этого вектора совпадает с началом двух слагаемых векторов:

Как вычислять отрицательные векторы

Другая диагональ будет являться разностью этих векторов. Направление определяем так же, как делали раньше.

Как вычислять отрицательные векторы

Скалярное произведение векторов

Еще одной важной операцией является произведение векторов. Рассмотрим скалярное произведение. Его результатом является скаляр.

Уравнение очень простое: произведение длин этих векторов на косинус угла между ними.

Как вычислять отрицательные векторы

Векторное произведение векторов

Векторное произведение векторов пригодится нам в электродинамике.

Его формула лишь немного отличается от предыдущей:

В отличие от скалярного произведения, результатом его является вектор и его даже можно изобразить!

После параллельного переноса векторов и нахождения угла между ними достроим их до параллелограмма и найдем его площадь. Площадь параллелограмма равна длине вектора произведения:

Как вычислять отрицательные векторы

Этот вектор одновременно перпендикулярен двум другим. Его направление зависит от условного порядка векторов, который либо определен какими-то фактами (когда мы будем изучать силу Лоренца), либо является свободным.

Как вычислять отрицательные векторы

Об этом мы поговорим подробнее, когда будем изучать электродинамику.

Итак, мы разобрали операции с векторами, рассмотрев даже самые сложные из них. Это было не так тяжело, верно? Так происходит не только с векторами, но и со многими другими темами. Идя от легкого к сложному, мы даже не заметили трудностей.

Ведь всегда стоит помнить о том, что даже самое длинное путешествие начинается с первого шага.

Видео:Реакция на результаты ЕГЭ 2022 по русскому языкуСкачать

Реакция на результаты ЕГЭ 2022 по русскому языку

Проекции векторов

Что такое проекция вектора и с чем ее едят?

Мы уже выяснили, что над векторами можно проводить множество операций. Здорово, когда можешь начертить векторы, достроить их до треугольника и измерить результат линейкой.

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

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

Проекция вектора – словно тень, которую он отбрасывает на ось координат. И эта тень может о многом рассказать.

Ось координат — прямая с указанными на ней направлением, началом отсчёта и выбранной единицей масштаба.

Ось можно выбрать произвольно. В зависимости от ее выбора можно либо значительно упростить решение задачи, либо сделать его очень сложным.

Именно поэтому необходимо научиться работать с проекциями и осями.

Построение проекции. Определение знака

Возьмем вектор и начертим рядом с ним произвольную ось. Назвать ее тоже можно как угодно, но мы назовем ее осью Х.

Как вычислять отрицательные векторы

Теперь опустим из начала и конца вектора перпендикуляры на эту ось. Отметим координаты начала (Х0) и конца (Х). Рассмотрим отрезок, заключенный между этими точками.

Казалось бы, мы нашли проекцию. Однако думать, что проекция является простым отрезком, – большое заблуждение.

Не все так просто: проекция может быть не только положительной. Чтобы найти проекцию, нужно из координаты конца вычесть координату начала:

Как вычислять отрицательные векторы

Проекция вектора на ось — разность между координатами проекций точек конца и начала вектора на ось.

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

Порой работать с буквами трудно. Поэтому предлагаю взять конкретный пример:

Как вычислять отрицательные векторы

Рассмотрим другой случай. В этот раз координата начала больше координаты конца, следовательно, проекция отрицательна:

Как вычислять отрицательные векторы

Рассмотрим еще один интересный случай.

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

Как вычислять отрицательные векторы

Анализ углов

Рассматривая эти ситуации, можно заметить, что знак, который принимает проекция вектора напрямую зависит от угла между вектором и осью, то есть от его направления!

Из начала вектора проведем луч, параллельный оси и направленный в ту же сторону, что и ось. Получим угол между вектором и осью.

Если угол острый, проекция положительна:

Как вычислять отрицательные векторы

Если угол тупой, проекция отрицательна:

Как вычислять отрицательные векторы

Обрати особое внимание на то, какой именно угол является углом между вектором и осью!

Частные случаи проекции

Настоящий подарок судьбы – тот момент, когда вектор параллелен оси. Это сохраняет драгоценное время при решении множества задач. Рассмотрим эти случаи.

Если вектор параллелен оси, угол между ними либо равен нулю, либо является развернутым (180 О ). Это зависит от направления.

При этом длина проекции совпадает с длиной вектора! Смотри!

Как и прежде, если вектор направлен туда же, куда и ось, проекция положительна:

Как вычислять отрицательные векторы

Если вектор направлен в другую сторону, проекция отрицательна:

Как вычислять отрицательные векторы

Если вектор направлен туда же, куда и ось, его проекция положительна. Если вектор направлен в другую сторону, его проекция отрицательна.

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

Что? Почему раньше не сказал? А… Ну…

Хватит вопросов! Вот тебе пример:

Как вычислять отрицательные векторы

(vec) направлен противоположно оси. Его проекция отрицательна.

Еще один частный случай – работа с обратными векторами.

Давай выясним, как связаны проекции данного вектора и вектора, который является ему обратным. Начертим их и обозначим координаты начал и концов:

Как вычислять отрицательные векторы

Проведем дополнительные линии и рассмотрим два получившихся треугольника. Они прямоугольны, так как проекция строится с помощью перпендикуляра к оси.

Наши векторы отличаются лишь направлением. При этом, если мы просто посмотрим на них как на прямые, мы можем сказать, что они параллельны. Их длины тоже одинаковы.

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

Как вычислять отрицательные векторы

Мы помним, что обратные векторы всегда коллинеарны. Это значит, что прямые, на которых они расположены, находятся под одним углом к оси:

Остается лишь определиться со знаками. Данный вектор направлен по оси Х, а обратный ему – против. Значит, первый положителен, а второй отрицателен. Но модули их равны, так как равны их длины.

Проекции обратных векторов равны по модулю и противоположны по знаку.

Давайте еще раз уточним.

Вектор сам по себе не может быть отрицательным (обратный вектор есть вектор, умноженный на минус единицу).

Длина вектора так же не может быть отрицательной. Длина есть модуль вектора, а модуль всегда положителен.

Проекция вектора бывает отрицательной. Это зависит от направления вектора.

Способы нахождения проекций и векторов с помощью тригонометрии

Зная угол между вектором и осью, можно не прибегать к координатам. Углы, прямоугольные треугольники… Всегда стоит помнить, что, если ты видишь прямоугольный трегольник, тригонометрия протянет тебе руку помощи.

Именно тригонометрия чаще всего применяется в задачах, где требуется работать с проекциями. Особенно она помогает в задачах на второй закон Ньютона.

Рассмотрим вектор и его проекции на оси:

Как вычислять отрицательные векторы

Можем заметить, что проекции вектора соответствуют катетам прямоугольного треугольника, который легко можно достроить:

Как вычислять отрицательные векторы

Тогда обозначим прямой угол и угол между вектором и осью:

Как вычислять отрицательные векторы

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

Из этих уравнений легко выражаются проекции.

А еще следует помнить, что из проекций мы можем найти длину данного вектора с помощью теоремы Пифагора:

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

Видео:Угол между векторами. 9 класс.Скачать

Угол между векторами. 9 класс.

Действия над проекциями векторов. Решение задач

Умение применять свои знания на практике невероятно важны. Это касается не только физики.

Мы знаем, что проекции были придуманы для того, чтобы работать не с векторами, а с числами.

Сложение проекций. Доказательство главного свойства

Предположим, у нас есть два вектора и нам нужно найти их сумму. Посчитать по клеткам нам вряд ли удастся:

Как вычислять отрицательные векторы

Спроецируем оба вектора на ось Х. Заметим, что конец одного вектора есть начало второго, то есть их координаты совпадают:

Как вычислять отрицательные векторы

Давай посчитаем проекции векторов и проекцию вектора их суммы:

Как вычислять отрицательные векторы

Мы можем заметить, что сумма проекций двух данных векторов оказалась равна проекции вектора их суммы!

Намного важнее уметь доказывать гипотезы в общем виде.

Тогда никто не сможет упрекнуть тебя в том, что твои утверждения – просто результат совпадения!

Согласно определению проекции, запишем уравнения проекций для двух данных векторов и вектора их суммы:

Как вычислять отрицательные векторы

Затем запишем, чему равна сумма этих векторов.

Как вычислять отрицательные векторы

Как вычислять отрицательные векторы

Как вычислять отрицательные векторы

Мы доказали нашу гипотезу.

Но что насчет разности?

Все очень просто! Помнишь, как мы считали разность через сумму? Здесь это делается аналогично!

Проекция суммы векторов равна сумме проекций векторов.

Проекция разности векторов равна разности проекций векторов.

Или можно записать так:

Простейшие задачи на нахождение проекций

Простейшие задачи на нахождение проекций чаще представлены в виде различных графиков или рисунков.

Давай научимся с ними работать.

Нам даны оси и векторы. Задача: найти проекции каждого из них на обе оси.

Как вычислять отрицательные векторы

Будем делать все по порядку. Для каждого вектора предлагаю сначала определить знак проекций, а затем посчитать их.

В первом случае вектор направлен против оси Х.

Значит, его проекция на эту ось будет отрицательна. Мы убедимся в этом с помощью вычислений.

Сразу бросается в глаза то, что вектор расположен перпендикулярно оси Y. Его проекция на эту ось будет равна нулю, ведь расстояние между проекциями точек начала и конца равно нулю!

Как вычислять отрицательные векторы

Рассмотрим второй вектор.

Он «сонаправлен» оси Y и «противонаправлен» оси Х. Значит, проекция на ось будет положительна, а на ось Х – отрицательна.

Убедимся в этом.

На осях для удобства отметим проекции точек начала и конца вектора, проведя перпендикуляры. Затем проведем вычисления:

Как вычислять отрицательные векторы

Рассмотрим (vec). Заметим, что он является обратным для (vec): их длины равны, а направления противоположны.

Мы помним, что в таком случае их проекции отличаются лишь знаками. И это действительно так:

Как вычислять отрицательные векторы

Поступаем с (vec) так же, как поступали с первым вектором.

Он перпендикулярен оси Х, а значит его проекция (что есть разность между проекциями точки конца и начала!) на эту ось равна нулю.

Проведя перпендикуляры, считаем проекцию на ось Y:

Как вычислять отрицательные векторы

С (vec) работать приятно: он расположен по направлению обеих осей. Обе его проекции будут положительны, остается лишь посчитать их:

Как вычислять отрицательные векторы

Задачи на нахождение вектора и его угла с осью

С помощью проекций можно найти длину вектора и его направление, а также угол, под которым он находится относительно оси.

Давай попробуем это сделать.

Даны проекции вектора на две оси. Для начала нарисуем оси:

Как вычислять отрицательные векторы

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

С проекцией на ось Х все понятно, просто поднимаем ее. Но куда поставить проекцию оси Y?

Как вычислять отрицательные векторы

Для этого нам нужно определить направление вектора. Проекция на ось Х отрицательна, значит вектор направлен в другую сторону от оси.

Проекция на ось Y положительна. Вектор смотрит в ту же сторону, что и ось.

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

Как вычислять отрицательные векторы

Теперь нужно найти длину этого вектора. Используем старую добрую теорему Пифагора:

Как вычислять отрицательные векторы

Обозначим угол (alpha ), который необходимо найти, мы учились это делать в начале изучения проекций. Он расположен вне треугольника. Мы ведь не ищем легких путей, верно?

Рассмотрим смежный ему угол (beta ). Его найти гораздо проще, а в сумме они дадут 180 градусов.

Чтобы сделать это, абстрагируемся от векторов, проекций и просто поработаем с треугольником, стороны которого равны 3, 4 и 5. Найдем синус угла (beta ) и по таблице Брадиса (либо с помощью инженерного калькулятора) определим его значение.

Вычитанием угла (beta ) из 180 градусов найдем угол (alpha ):

Как вычислять отрицательные векторы

Как вычислять отрицательные векторы

Главный метод работы с осями и проекциями в решении физических задач

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

Поэтому важно научиться искать проекции вектора и связывать их с ней.

Рассмотрим следующий рисунок (вектор F2 перпендикулярен вектору F3):

Как вычислять отрицательные векторы

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

Одним из важных этапов решение «векторной части» этих задач является правильный выбор расположения осей. Он заключается в том, чтобы расположить оси так, чтобы как можно большее число векторов оказались им параллельны.

Как правило, оси располагаются под прямым углом друг к другу, чтобы не получить лишней работы с углами.

Сделаем это для данного рисунка:

Как вычислять отрицательные векторы

Мы видим, что остальные векторы расположены к осям под каким-то углом.

Пунктиром проведем горизонтальную линию и отметим этот угол, а затем отметим другие равные ему углы:

Как вычислять отрицательные векторы

Пришло время искать проекции. У нас две оси, поэтому сделаем для удобства табличку:

Как вычислять отрицательные векторы

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

Оси перпендикулярны друг другу, поэтому некоторые проекции будут равняться нулю. Запишем это:

Как вычислять отрицательные векторы

Переходим к векторам, которые расположены под углом.

Выглядит страшно, но это не так!

Дальше идет чистая геометрия. Чтобы не запутаться, рассмотрим лишь часть рисунка. А лучше и вовсе перерисовать его часть, могут открыться много новых вещей.

Как вычислять отрицательные векторы

Из конца вектора F1 проведем перпендикуляр к оси Y. Мы получим прямоугольный треугольник, где нам известен угол (альфа) и гипотенуза (вектор).

Обозначим, что является проекцией. Это катет:

Как вычислять отрицательные векторы

Здесь на помощь придет тригонометрия. Этот катет прилежащий к известному углу. Синус угла есть проекция катета, деленная на гипотенузу. Отсюда можно выразить катет (проекцию) и записать ее в таблицу.

Вспомни, когда мы первый раз встретились с тригонометрией, изучая векторы. Мы тоже рассматривали прямоугольный треугольник.

Найдем проекцию на ось Х. Это, кажется, сложнее, ведь мы не знаем угол…

Знаем! Ведь проекция вектора на ось Х – то же самое, что противолежащий катет уже рассмотренного треугольника, смотри:

Как вычислять отрицательные векторы

Значит, проекцию на ось Х можно найти через косинус.

Не забываем смотреть на направления векторов!

Попробуй найти проекции четвертого вектора самостоятельно и сверься с таблицей.

Как вычислять отрицательные векторы

Значит, проекцию на ось Х можно найти через косинус.

Не забываем смотреть на направления векторов!

Попробуй найти проекции четвертого вектора самостоятельно и сверься с таблицей.

Видео:Аналитическая геометрия, 4 урок, Смешанное произведениеСкачать

Аналитическая геометрия, 4 урок, Смешанное произведение

Заключение

Итак, теперь мы знаем о векторах очень много! Мы выяснили, зачем они нужны и как с ними работать, а еще разобрали их роль в решении различных задач. Теперь векторы — наша прочная опора.

Именно из таких знаний складывается порой нечто более сложное и комплексное, что-то, что безусловно нам однажды поможет.

📽️ Видео

как ЛЕГКО сложить отрицательные числа , ПРИМЕРЫСкачать

как ЛЕГКО сложить отрицательные числа , ПРИМЕРЫ

Нахождение длины вектора через координаты. Практическая часть. 9 класс.Скачать

Нахождение длины вектора через координаты. Практическая часть. 9 класс.
Поделиться или сохранить к себе: