mirror of
https://github.com/TimeCrafters/FTC_2022
synced 2025-12-15 17:52:34 +00:00
Tested and refactored blackboard
This commit is contained in:
@@ -10,7 +10,6 @@ import org.timecrafters.TimeCraftersConfigurationTool.library.backend.config.Act
|
|||||||
|
|
||||||
import java.lang.reflect.Constructor;
|
import java.lang.reflect.Constructor;
|
||||||
import java.lang.reflect.InvocationTargetException;
|
import java.lang.reflect.InvocationTargetException;
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
import java.util.concurrent.CopyOnWriteArrayList;
|
import java.util.concurrent.CopyOnWriteArrayList;
|
||||||
|
|
||||||
@@ -32,7 +31,7 @@ public abstract class CyberarmEngine extends OpMode {
|
|||||||
// Array to Hold Tasks
|
// Array to Hold Tasks
|
||||||
final private CopyOnWriteArrayList<CyberarmState> backgroundTasks = new CopyOnWriteArrayList<>();
|
final private CopyOnWriteArrayList<CyberarmState> backgroundTasks = new CopyOnWriteArrayList<>();
|
||||||
// HashMap to store data for States and Tasks
|
// HashMap to store data for States and Tasks
|
||||||
private ConcurrentHashMap<String, Object> blackboard = new ConcurrentHashMap<>();
|
final private ConcurrentHashMap<String, Object> blackboard = new ConcurrentHashMap<>();
|
||||||
private int activeStateIndex = 0; // Index of currently running state
|
private int activeStateIndex = 0; // Index of currently running state
|
||||||
private boolean isRunning; // Whether engine is running or not
|
private boolean isRunning; // Whether engine is running or not
|
||||||
|
|
||||||
@@ -139,7 +138,7 @@ public abstract class CyberarmEngine extends OpMode {
|
|||||||
|
|
||||||
// Background tasks
|
// Background tasks
|
||||||
for (CyberarmState task : backgroundTasks) {
|
for (CyberarmState task : backgroundTasks) {
|
||||||
initState(task);
|
stateTelemetry(task);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -293,21 +292,44 @@ public abstract class CyberarmEngine extends OpMode {
|
|||||||
/**
|
/**
|
||||||
* Retrieve value from blackboard
|
* Retrieve value from blackboard
|
||||||
* @param key String to use to look up value
|
* @param key String to use to look up value
|
||||||
* @return Returns Object which should be autocast to the correct type
|
* @return Returns T of stored Object
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("unchecked")
|
public <T> T blackboardGet(String key) {
|
||||||
public <T> T blackboard_get(String key) {
|
|
||||||
return (T) blackboard.get(key);
|
return (T) blackboard.get(key);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String blackboardGetString(String key) {
|
||||||
|
return (String) blackboard.get(key);
|
||||||
|
}
|
||||||
|
|
||||||
|
public int blackboardGetInt(String key) {
|
||||||
|
return (int) blackboard.get(key);
|
||||||
|
}
|
||||||
|
|
||||||
|
public long blackboardGetLong(String key) {
|
||||||
|
return (long) blackboard.get(key);
|
||||||
|
}
|
||||||
|
|
||||||
|
public float blackboardGetFloat(String key) {
|
||||||
|
return (float) blackboard.get(key);
|
||||||
|
}
|
||||||
|
|
||||||
|
public double blackboardGetDouble(String key) {
|
||||||
|
return (double) blackboard.get(key);
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean blackboardGetBoolean(String key) {
|
||||||
|
return (boolean) blackboard.get(key);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set value of key to value
|
* Set value of key to value
|
||||||
* @param key String
|
* @param key String
|
||||||
* @param value Object
|
* @param value Object
|
||||||
* @return Returns T
|
* @return Returns T
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("unchecked")
|
|
||||||
public <T> T blackboard_set(String key, Object value) {
|
public <T> T blackboardSet(String key, T value) {
|
||||||
blackboard.put(key, value);
|
blackboard.put(key, value);
|
||||||
|
|
||||||
return (T) value;
|
return (T) value;
|
||||||
@@ -319,8 +341,7 @@ public abstract class CyberarmEngine extends OpMode {
|
|||||||
* @param value Object
|
* @param value Object
|
||||||
* @return Returns T
|
* @return Returns T
|
||||||
*/
|
*/
|
||||||
@SuppressWarnings("unchecked")
|
public <T> T blackboardRemove(String key, T value) {
|
||||||
public <T> T blackboard_remove(String key, Object value) {
|
|
||||||
blackboard.remove(key);
|
blackboard.remove(key);
|
||||||
|
|
||||||
return (T) value;
|
return (T) value;
|
||||||
|
|||||||
@@ -96,6 +96,6 @@ public class LeftSideAutonomousEngine extends CyberarmEngine {
|
|||||||
public void loop() {
|
public void loop() {
|
||||||
super.loop();
|
super.loop();
|
||||||
|
|
||||||
telemetry.addData("BlackBoard Input", blackboard_get("parkPlace"));
|
telemetry.addData("BlackBoard Input", blackboardGetString("parkPlace"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -148,6 +148,6 @@ public class RightFourConeAutonomousEngine extends CyberarmEngine {
|
|||||||
public void loop() {
|
public void loop() {
|
||||||
super.loop();
|
super.loop();
|
||||||
|
|
||||||
telemetry.addData("BlackBoard Input", blackboard_get("parkPlace"));
|
telemetry.addData("BlackBoard Input", blackboardGetString("parkPlace"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -97,6 +97,6 @@ public class RightSideAutonomousEngine extends CyberarmEngine {
|
|||||||
public void loop() {
|
public void loop() {
|
||||||
super.loop();
|
super.loop();
|
||||||
|
|
||||||
telemetry.addData("BlackBoard Input", blackboard_get("parkPlace"));
|
telemetry.addData("BlackBoard Input", blackboardGetString("parkPlace"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -21,7 +21,7 @@ public class ConeIdentification extends CyberarmState {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void init() {
|
public void init() {
|
||||||
engine.blackboard_set("parkPlace", "1");
|
engine.blackboardSet("parkPlace", "1");
|
||||||
robot.tfod.activate();
|
robot.tfod.activate();
|
||||||
initTime = System.currentTimeMillis();
|
initTime = System.currentTimeMillis();
|
||||||
}
|
}
|
||||||
@@ -50,11 +50,11 @@ public class ConeIdentification extends CyberarmState {
|
|||||||
engine.telemetry.addData("- Size (Width/Height)","%.0f / %.0f", width, height);
|
engine.telemetry.addData("- Size (Width/Height)","%.0f / %.0f", width, height);
|
||||||
|
|
||||||
if (recognition.getLabel().equals("#2")) {
|
if (recognition.getLabel().equals("#2")) {
|
||||||
engine.telemetry.addData("#2", engine.blackboard_set("parkPlace", "2"));
|
engine.telemetry.addData("#2", engine.blackboardSet("parkPlace", "2"));
|
||||||
} else if (recognition.getLabel().equals("#3")) {
|
} else if (recognition.getLabel().equals("#3")) {
|
||||||
engine.telemetry.addData("#3",engine.blackboard_set("parkPlace", "3"));
|
engine.telemetry.addData("#3",engine.blackboardSet("parkPlace", "3"));
|
||||||
} else {
|
} else {
|
||||||
engine.telemetry.addData("#1", engine.blackboard_set("parkPlace", "1"));
|
engine.telemetry.addData("#1", engine.blackboardSet("parkPlace", "1"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -90,12 +90,12 @@ public class ConeIdentification extends CyberarmState {
|
|||||||
bestConfidence = recognition.getConfidence();
|
bestConfidence = recognition.getConfidence();
|
||||||
|
|
||||||
if (recognition.getLabel().equals("2 Bulb")) {
|
if (recognition.getLabel().equals("2 Bulb")) {
|
||||||
engine.blackboard_set("parkPlace", "2");
|
engine.blackboardSet("parkPlace", "2");
|
||||||
} else if (recognition.getLabel().equals("3 Panel")) {
|
} else if (recognition.getLabel().equals("3 Panel")) {
|
||||||
engine.blackboard_set("parkPlace", "3");
|
engine.blackboardSet("parkPlace", "3");
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
engine.blackboard_set("parkPlace", "1");
|
engine.blackboardSet("parkPlace", "1");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -43,7 +43,7 @@ public class DriverParkPlaceState extends CyberarmState {
|
|||||||
setHasFinished(true);
|
setHasFinished(true);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
String placement = engine.blackboard_get("parkPlace");
|
String placement = engine.blackboardGetString("parkPlace");
|
||||||
if (placement != null) {
|
if (placement != null) {
|
||||||
if (!placement.equals(intendedPlacement)){
|
if (!placement.equals(intendedPlacement)){
|
||||||
setHasFinished(true);
|
setHasFinished(true);
|
||||||
|
|||||||
@@ -16,7 +16,7 @@ public class PathDecision extends CyberarmState {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void exec() {
|
public void exec() {
|
||||||
String placement = engine.blackboard_get("parkPlace");
|
String placement = engine.blackboardGetString("parkPlace");
|
||||||
setHasFinished(true);
|
setHasFinished(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,76 @@
|
|||||||
|
package org.timecrafters.minibots.cyberarm.engines;
|
||||||
|
|
||||||
|
import com.qualcomm.robotcore.eventloop.opmode.TeleOp;
|
||||||
|
|
||||||
|
import org.cyberarm.engine.V2.CyberarmEngine;
|
||||||
|
import org.cyberarm.engine.V2.CyberarmState;
|
||||||
|
|
||||||
|
@TeleOp(name = "TasksEngine", group = "testing")
|
||||||
|
public class TasksEngine extends CyberarmEngine {
|
||||||
|
@Override
|
||||||
|
public void setup() {
|
||||||
|
addTask(new CyberarmState() {
|
||||||
|
@Override
|
||||||
|
public void init() {
|
||||||
|
engine.blackboardSet("counter", 0);
|
||||||
|
engine.blackboardSet("string", "I IS STRING");
|
||||||
|
engine.blackboardSet("boolean", true);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void exec() {
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void telemetry() {
|
||||||
|
engine.telemetry.addData("TASK 1", engine.blackboardGetInt("counter"));
|
||||||
|
engine.telemetry.addData("TASK 1", "I am a task!");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
addTask(new CyberarmState() {
|
||||||
|
int lastCount = 0, blackboardLastCount = 0;
|
||||||
|
int count = 0;
|
||||||
|
double lastRuntime = 0;
|
||||||
|
@Override
|
||||||
|
public void exec() {
|
||||||
|
if (runTime() - lastRuntime >= 1000.0) {
|
||||||
|
lastRuntime = runTime();
|
||||||
|
lastCount = count;
|
||||||
|
blackboardLastCount = engine.blackboardGetInt("counter");
|
||||||
|
}
|
||||||
|
engine.blackboardSet("counter", engine.blackboardGetInt("counter") + 1);
|
||||||
|
count++;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void telemetry() {
|
||||||
|
engine.telemetry.addData("TASK 2", engine.blackboardGetString("string"));
|
||||||
|
engine.telemetry.addData("TASK 2", engine.blackboardGetBoolean("boolean"));
|
||||||
|
engine.telemetry.addData("TASK 2", engine.blackboardGetInt("counter") - blackboardLastCount);
|
||||||
|
engine.telemetry.addData("TASK 2", count - lastCount);
|
||||||
|
engine.telemetry.addData("TASK 2", engine.blackboardGetString("string_NULL") == null);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
addState(new CyberarmState() {
|
||||||
|
@Override
|
||||||
|
public void exec() {
|
||||||
|
if (runTime() >= 10_000) {
|
||||||
|
setHasFinished(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
addParallelStateToLastState(new CyberarmState() {
|
||||||
|
@Override
|
||||||
|
public void exec() {
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void telemetry() {
|
||||||
|
engine.telemetry.addData("Parallel state 1", "Hello There");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user