Can follow orientation, if needed (but doesnt work correctly)

main
Benjamin Kraft 2 years ago
parent 325e86bd87
commit 3be7bfafb2
  1. BIN
      Content/Blueprints/BP_Puma.uasset
  2. BIN
      Content/Blueprints/BP_Robot.uasset
  3. BIN
      Content/Blueprints/BP_Target.uasset
  4. BIN
      Content/Levels/Main.umap
  5. 4
      Source/PBDRobotics/Joint.cpp
  6. 10
      Source/PBDRobotics/Link.cpp
  7. 10
      Source/PBDRobotics/Link.h
  8. 13
      Source/PBDRobotics/Robot.cpp
  9. 6
      Source/PBDRobotics/Robot.h
  10. 4
      Source/PBDRobotics/util.h

Binary file not shown.

Binary file not shown.

@ -137,13 +137,15 @@ void UJoint::SolveVelocity(const double H) const{
//L1->AngularVelocity += I1.inverse() * R1.cross(P); //L1->AngularVelocity += I1.inverse() * R1.cross(P);
//L2->AngularVelocity -= I2.inverse() * R2.cross(P); //L2->AngularVelocity -= I2.inverse() * R2.cross(P);
constexpr double Damp = 1 - 1. / 1000; constexpr double A = 7;
const double Damp = 1 - A * H;
L1->Velocity *= Damp; L1->Velocity *= Damp;
L2->Velocity *= Damp; L2->Velocity *= Damp;
L1->AngularVelocity *= Damp; L1->AngularVelocity *= Damp;
L2->AngularVelocity *= Damp; L2->AngularVelocity *= Damp;
} }
// Rotational Damping // Rotational Damping
{ {
//constexpr double MuAng = 10000; //constexpr double MuAng = 10000;

@ -40,13 +40,12 @@ void ULink::SetupProperties(){
Position = ToEigen(GetComponentLocation()); Position = ToEigen(GetComponentLocation());
Velocity = Vector3d::Zero(); Velocity = Vector3d::Zero();
Inertia_Tensor_Local = ToEigen(GetInertiaTensor()).asDiagonal(); Inertia_Tensor_Local = ToEigen(GetInertiaTensor()).asDiagonal();
//Inertia_Tensor_Local = Matrix3d::Identity() * Mass;
Orientation = ToEigen(GetComponentQuat()); Orientation = ToEigen(GetComponentQuat());
AngularVelocity = Vector3d::Zero(); AngularVelocity = Vector3d::Zero();
if (IsBase){ if (IsBase){
Mass = 1e50; Mass = 1e50;
Inertia_Tensor_Local = Vector3d::Ones().asDiagonal() * 1e50; Inertia_Tensor_Local = Matrix3d::Identity() * 1e50;
} }
} }
@ -65,6 +64,13 @@ void ULink::SetupJoints() const {
} }
} }
FVector ULink::GetPosition() const{
return FromEigen(Position);
}
FQuat ULink::GetOrientation() const{
return FromEigen(Orientation);
}
void ULink::Update(const double H, const Vector3d& ExtTransForce, const Vector3d& ExtRotForce){ void ULink::Update(const double H, const Vector3d& ExtTransForce, const Vector3d& ExtRotForce){
// Translation // Translation

@ -36,6 +36,13 @@ public:
UPROPERTY(EditAnywhere, BlueprintReadWrite) UPROPERTY(EditAnywhere, BlueprintReadWrite)
UJoint* NextJoint; UJoint* NextJoint;
UFUNCTION(BlueprintCallable)
FVector GetPosition() const;
UFUNCTION(BlueprintCallable)
FQuat GetOrientation() const;
void Update(const double H, const Vector3d& ExtTransForce, const Vector3d& ExtRotForce); 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();
@ -52,12 +59,11 @@ public:
bool IsEffector = false; bool IsEffector = false;
Vector3d GetGravityForce() const; Vector3d GetGravityForce() const;
Matrix3d Inertia_Tensor_Local;
private: private:
UPROPERTY(EditAnywhere) UPROPERTY(EditAnywhere)
bool IsBase = false; bool IsBase = false;
Matrix3d Inertia_Tensor_Local;
void SetupJoints() const; void SetupJoints() const;
void SetupProperties(); void SetupProperties();
}; };

@ -45,11 +45,16 @@ void ARobot::Tick(const float DeltaTime){
for (int i = 0; i < SubSteps; i++){ for (int i = 0; i < SubSteps; i++){
for (auto* Link : Links){ for (auto* Link : Links){
Vector3d TransForce = Vector3d::Zero(); Vector3d TransForce = Vector3d::Zero();
Vector3d RotForce = Vector3d::Zero();
if (HasGravity) if (HasGravity)
TransForce += Link->GetGravityForce(); TransForce += Link->GetGravityForce();
if (Link->IsEffector) if (Link->IsEffector){
TransForce += Link->Mass * ToEigen(EffectorMove); FVector Translation, Rotation;
const Vector3d RotForce = Vector3d::Zero(); GetEffectorForce(Translation, Rotation);
Log(ToEigen(Rotation));
TransForce += Link->Mass * ToEigen(Translation);
RotForce += Link->Mass * ToEigen(Rotation);
}
Link->Update(h, TransForce, RotForce); Link->Update(h, TransForce, RotForce);
} }
for (const auto* Joint : Joints) for (const auto* Joint : Joints)
@ -69,3 +74,5 @@ ULink* ARobot::GetEffector() const{
return Link; return Link;
return nullptr; return nullptr;
} }
void ARobot::GetEffectorForce_Implementation(FVector& Translation, FVector& Rotation){}

@ -29,12 +29,12 @@ protected:
UPROPERTY(BlueprintReadWrite) UPROPERTY(BlueprintReadWrite)
bool HasGravity = false; bool HasGravity = false;
UPROPERTY(BlueprintReadWrite)
FVector EffectorMove = FVector::ZeroVector;
UFUNCTION(BlueprintCallable) UFUNCTION(BlueprintCallable)
ULink* GetEffector() const; ULink* GetEffector() const;
UFUNCTION(BlueprintNativeEvent)
void GetEffectorForce(FVector& Translation, FVector& Rotation);
private: private:
// Assumes First Link to have Identity Orientation and Joints Array to be in order // Assumes First Link to have Identity Orientation and Joints Array to be in order
void ResetPositionAndOrientation(); void ResetPositionAndOrientation();

@ -50,4 +50,8 @@ inline void Log(const char* S){
UE_LOG(LogTemp, Log, TEXT("%s"), *FString(S)); UE_LOG(LogTemp, Log, TEXT("%s"), *FString(S));
} }
inline void Log(const Quaterniond& Q){
UE_LOG(LogTemp, Log, TEXT("%f %f %f | %f"), Q.x(), Q.y(), Q.z(), Q.w());
}

Loading…
Cancel
Save