Files
allwpilib/wpimath/src/main/native/cpp/jni/StateSpaceUtilJNI.cpp

45 lines
1.2 KiB
C++
Raw Normal View History

// Copyright (c) FIRST and other WPILib contributors.
// Open Source Software; you can modify and/or share it under the terms of
// the WPILib BSD license file in the root directory of this project.
#include <jni.h>
#include <Eigen/Core>
2025-11-07 19:56:21 -05:00
#include "wpi/util/jni_util.hpp"
2025-11-07 19:55:43 -05:00
#include "org_wpilib_math_jni_StateSpaceUtilJNI.h"
2025-11-07 19:56:21 -05:00
#include "wpi/math/util/StateSpaceUtil.hpp"
using namespace wpi::java;
extern "C" {
/*
2025-11-07 19:55:43 -05:00
* Class: org_wpilib_math_jni_StateSpaceUtilJNI
* Method: isStabilizable
* Signature: (II[D[D)Z
*/
JNIEXPORT jboolean JNICALL
2025-11-07 19:55:43 -05:00
Java_org_wpilib_math_jni_StateSpaceUtilJNI_isStabilizable
(JNIEnv* env, jclass, jint states, jint inputs, jdoubleArray aSrc,
jdoubleArray bSrc)
{
JSpan<const jdouble> nativeA{env, aSrc};
JSpan<const jdouble> nativeB{env, bSrc};
Eigen::Map<const Eigen::Matrix<double, Eigen::Dynamic, Eigen::Dynamic,
Eigen::RowMajor>>
A{nativeA.data(), states, states};
Eigen::Map<const Eigen::Matrix<double, Eigen::Dynamic, Eigen::Dynamic,
Eigen::RowMajor>>
B{nativeB.data(), states, inputs};
bool isStabilizable =
frc::IsStabilizable<Eigen::Dynamic, Eigen::Dynamic>(A, B);
return isStabilizable;
}
} // extern "C"