Added Gravity toggle Hotkey G (default off)

main
Benjamin Kraft 2 years ago
parent d0bee4a37a
commit 9b377a557b
  1. BIN
      Content/Blueprints/BP_Puma.uasset
  2. BIN
      Content/Blueprints/BP_Robot.uasset
  3. BIN
      Content/Levels/Main.umap
  4. 13
      Source/PBDRobotics/Link.cpp
  5. 10
      Source/PBDRobotics/Link.h
  6. 10
      Source/PBDRobotics/Robot.cpp
  7. 3
      Source/PBDRobotics/Robot.h

Binary file not shown.

Binary file not shown.

@ -16,12 +16,12 @@ Matrix3d ULink::GetInertia() const {
return R * Inertia_Tensor_Local * R.transpose(); return R * Inertia_Tensor_Local * R.transpose();
} }
double ULink::GetPositionalInverseMass(const Vector3d R, const Vector3d N) const{ double ULink::GetPositionalInverseMass(const Vector3d& R, const Vector3d& N) const{
const double M = Mass; const double M = Mass;
const Matrix3d I = GetInertia(); const Matrix3d I = GetInertia();
return 1 / M + R.cross(N).transpose() * I.inverse() * R.cross(N); return 1 / M + R.cross(N).transpose() * I.inverse() * R.cross(N);
} }
double ULink::GetRotationalInverseMass(const Vector3d N) const{ double ULink::GetRotationalInverseMass(const Vector3d& N) const{
const Matrix3d I = GetInertia(); const Matrix3d I = GetInertia();
return N.transpose() * I.inverse() * N; return N.transpose() * I.inverse() * N;
} }
@ -62,20 +62,13 @@ void ULink::SetupJoints() const {
} }
} }
void ULink::Update(const double H){ void ULink::Update(const double H, const Vector3d& ExtTransForce, const Vector3d& ExtRotForce){
// Translation // Translation
Vector3d ExtTransForce = Vector3d(0, 0, -9.81 * 100) * Mass * 1;
if (IsBase)
ExtTransForce = Vector3d::Zero();
Last_Position = Position; Last_Position = Position;
Velocity += H * ExtTransForce / Mass; Velocity += H * ExtTransForce / Mass;
Position += H * Velocity; Position += H * Velocity;
// Rotation
const Vector3d ExtRotForce = Vector3d::Zero();
Last_Orientation = Orientation; Last_Orientation = Orientation;
Vector3d w = AngularVelocity; Vector3d w = AngularVelocity;
AngularVelocity += H * GetInertia().inverse() * (ExtRotForce - w.cross(GetInertia() * w)); AngularVelocity += H * GetInertia().inverse() * (ExtRotForce - w.cross(GetInertia() * w));

@ -36,24 +36,24 @@ public:
UPROPERTY(EditAnywhere, BlueprintReadWrite) UPROPERTY(EditAnywhere, BlueprintReadWrite)
UJoint* NextJoint; UJoint* NextJoint;
void Update(const double H); void Update(const double H, const Vector3d& ExtTransForce, const Vector3d& ExtRotForce);
void Integrate(const double H); void Integrate(const double H);
void UpdateInternalTransform(); void UpdateInternalTransform();
// Inertia tensor in world space // Inertia tensor in world space
Matrix3d GetInertia() const; Matrix3d GetInertia() const;
double GetPositionalInverseMass(const Vector3d R, const Vector3d N) const; double GetPositionalInverseMass(const Vector3d& R, const Vector3d& N) const;
double GetRotationalInverseMass(const Vector3d N) const; double GetRotationalInverseMass(const Vector3d& N) const;
void Setup(); void Setup();
UPROPERTY(EditAnywhere) UPROPERTY(EditAnywhere)
bool IsEffector = false; bool IsEffector = false;
private:
UPROPERTY(EditAnywhere) UPROPERTY(EditAnywhere)
bool IsBase = false; bool IsBase = false;
private:
Matrix3d Inertia_Tensor_Local; Matrix3d Inertia_Tensor_Local;
void SetupJoints() const; void SetupJoints() const;

@ -41,12 +41,16 @@ void ARobot::Connect(ULink* L1, ULink* L2){
void ARobot::Tick(const float DeltaTime){ void ARobot::Tick(const float DeltaTime){
Super::Tick(DeltaTime); Super::Tick(DeltaTime);
constexpr int SubSteps = 50; constexpr int SubSteps = 50;
const double h = DeltaTime / SubSteps; const double h = DeltaTime / SubSteps;
for (int i = 0; i < SubSteps; i++){ for (int i = 0; i < SubSteps; i++){
for (auto* Link : Links) for (auto* Link : Links){
Link->Update(h); Vector3d Gravity = Vector3d::Zero();
if (HasGravity && !Link->IsBase)
Gravity = Vector3d(0, 0, -9.81 * 100) * Link->Mass;
const Vector3d RotForce = Vector3d::Zero();
Link->Update(h, Gravity, RotForce);
}
for (const auto* Joint : Joints) for (const auto* Joint : Joints)
Joint->SolvePosition(h); Joint->SolvePosition(h);
for (auto* Link : Links) for (auto* Link : Links)

@ -26,6 +26,9 @@ protected:
UFUNCTION(BlueprintCallable) UFUNCTION(BlueprintCallable)
void Connect(ULink* L1, ULink* L2); void Connect(ULink* L1, ULink* L2);
UPROPERTY(BlueprintReadWrite)
bool HasGravity = false;
private: private:
void ResetPositionAndOrientation(); void ResetPositionAndOrientation();
public: public:

Loading…
Cancel
Save