addCollision

Добавьте геометрию столкновения в твердое тело

Описание

addCollision(body,type,parameters) добавляет геометрия столкновения заданного типа type и геометрические параметры parameters к заданному твердому телу body.

пример

addCollision(body,collisionObj) добавляет геометрический объект столкновения к телу твердого тела в виде одного из этих объектов столкновения:

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

addCollision(___,tform) задает преобразование для геометрии столкновения относительно системы координат тела в дополнение к любой комбинации входных параметров от предыдущих синтаксисов.

Примеры

свернуть все

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

Загрузите модель робота

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

robot = loadrobot('kukaIiwa7','DataFormat','column');

for i = 1:robot.NumBodies
    clearCollision(robot.Bodies{i})
end

show(robot,'Collisions','on','Visuals','off');

Добавьте цилиндры столкновения

Итеративно добавляйте цилиндр столкновения к каждому телу. Пропустите некоторые тела для этой определенной модели, как они перекрываются и всегда сталкиваются с исполнительным элементом конца (тело 10).

collisionObj = collisionCylinder(0.05,0.25);

for i = 1:robot.NumBodies
    if i > 6 && i < 10
        % Skip these bodies.
    else
        addCollision(robot.Bodies{i},collisionObj)
    end
end

show(robot,'Collisions','on','Visuals','off');

Проверяйте на столкновения

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

figure
rng(0) % Set random seed for repeatability.
for i = 1:20
    config = randomConfiguration(robot);
    isColliding = checkCollision(robot,config);
    if isColliding
        show(robot,config,'Collisions','on','Visuals','off');
        title('Collision Detected')
    else
        % Skip non-collisions.
    end
end

Входные параметры

свернуть все

Твердое тело в виде rigidBody объект.

Тип геометрии для геометрии столкновения в виде строкового скаляра. Заданный тип определяет формат parameters входной параметр.

  • "box" x, y, z

  • "cylinder"[radius length]

  • "sphere"radius

  • "mesh"n-by-3 матрица вершин или имени файла STL как строка

Типы данных: char | string

Параметры геометрии столкновения в виде числового вектора, числовой матрицы или строкового скаляра. type введите определяет формат этого значения.

  • "box" x, y, z

  • "cylinder"[radius length]

  • "sphere"radius

  • "mesh"n-by-3 матрица вершин или имени файла STL как строка

Типы данных: single | double | char | string

Геометрический объект столкновения в виде collisionBox, collisionCylinder, collisionSphere, или collisionMesh объект.

Преобразование геометрии столкновения в виде гомогенного преобразования 4 на 4. Если определение столкновения возражает для collisionObj введите, эта функция применяет заданное преобразование к Pose свойство заданного столкновения возражает, чтобы преобразовать вершины столкновения в систему координат твердого тела.

Типы данных: single | double

Расширенные возможности

Генерация кода C/C++
Генерация кода C и C++ с помощью MATLAB® Coder™.

Введенный в R2020b