संक्षिप्त जवाब; नहीं, आपको वास्तव में चीजों को थोड़ा अलग तरीके से करने की आवश्यकता है।
लंबे अधूरे उत्तर; मैं आपको रोबॉट के लिए उपयुक्त कुछ पीडो कोड देता हूं, जो आपको बेहतर रास्ते पर ला खड़ा करता है। सबसे पहले, कार्यों का उपयोग न करें - यह वह नहीं है जो रोबोटसी कार्यों के लिए है। उन्हें काम करने के लिए बनाया जा सकता है, हो सकता है, शायद नहीं (और आपको प्रयास करने के लिए काफी कुछ बदलावों की आवश्यकता है)।
// global variables
int distance;
int light;
main() {
while (true) {
distance = read_distance;
light = read_light;
if (task1_wantsToRun())
task1_run();
if (task2_wantsToRun())
task2_run();
}
}
यहां कुछ चीजें हैं; प्राथमिकता अप्रासंगिक हो जाती है। जैसा कि अच्छा लगता है कि प्राथमिकता के साथ रोबोटसी में कार्य हैं, वे मेरे अनुभव में निर्वाह कार्यान्वयन के लिए एक अच्छा विकल्प नहीं हैं। जैसे कारणों के लिए, प्राथमिकताओं को हमेशा सम्मानित नहीं किया जाता है, कार्यों को बाधित नहीं किया जा सकता है (कभी-कभी) इसलिए जब एक उच्च प्राथमिकता वाली घटना होती है, तो यह आपकी प्रतिक्रिया की तरह प्रतिक्रिया करने वाला नहीं है, रोबोटसी केवल हाल ही में फिर से प्रवेश कर गई है, इसलिए सेंसर तक पहुंच जैसी चीजें 1 से अधिक कार्य जोखिम भरा (I2C समय समस्याएँ) हो सकते हैं, और कुछ मामलों में यह (स्वचालित रूप से प्रदूषित सेंसर) नहीं है।
आप उपरोक्त लूप में अपनी प्राथमिकता के कार्यान्वयन को जोड़ सकते हैं क्योंकि आप काम कर रहे हैं, लेकिन यह वास्तव में शुरू करने के लिए आवश्यक नहीं है।
आपकी टिप्पणी "// बॉक्स बाधा" एक बैलिस्टिक व्यवहार का वर्णन करती है। मल्टी टास्किंग का उपयोग करके इसे लागू करना थोड़ा मुश्किल है। मैंने जो सरल लूप का उपयोग किया है वह इसे बहुत आसान बनाता है, और शुरुआत / सीखने के लिए बेहतर है।
दूसरी चीज जो मैं आपको छोड़ दूंगा, वह यह है कि साफ-सुथरी होने के साथ-साथ बहुत सारी चीजों के लिए उचित है, जो परंपरागत रूप से बेहतर है, उसे लागू करने का एक अच्छा तरीका नहीं है। वास्तव में Indeed ईवडे ’का हिस्सा निर्वाह के लिए एक अच्छा उम्मीदवार हो सकता है, लेकिन ईमानदारी से आपके अन्य कार्य को out GoOnAboutYourBusiness’ कहा जाना चाहिए। मैं यह कहता हूं क्योंकि आप शायद खोज से लेकर सबमिशन तक को बदलना नहीं चाहते हैं। पारंपरिक प्रोग्रामिंग छोरों के साथ उन लोगों को संभालें। एक एकल सेंसर के साथ, - प्रकाश संवेदक गहरा या हल्का होता है, जबकि यह अंतिम लूप था? अगर यह गहरा हो गया (काली रेखा मानकर) उसी दिशा को मोड़ते रहें, अगर यह हल्का हो जाए तो दूसरा रास्ता बंद हो जाता है, यदि यह समान रहता है, तो सीधे जाएं। आपको शायद कुछ पीआईडी जोड़ने की जरूरत है और केवल चिकनी होने के लिए बाएं और दाएं मुड़ने के बजाय स्टीयरिंग कर्व का उपयोग करें।
और हाँ, कई सेंसर मदद करते हैं। http://www.mindsensors.com/ - हाँ, यह फिल्म में वर्तमान में है (11/10/2012)
अपडेट: वास्तविक कोड
मैं इसे थोड़ी देर में आज़माऊंगा, लेकिन जो मैंने ऊपर लिखा है, उसे संकलित और प्रकाशित करता है:
#pragma config(Sensor, S1, S_LIGHT, sensorLightActive)
#pragma config(Sensor, S2, S_DISTANCE, sensorSONAR)
#pragma config(Motor, motorB, LEFT, tmotorNXT, PIDControl, encoder)
#pragma config(Motor, motorC, RIGHT, tmotorNXT, PIDControl, encoder)
//*!!Code automatically generated by 'ROBOTC' configuration wizard !!*//
int distance_value, light_value;
bool evade_wantsToRun()
{
return distance_value < 30;
}
void evade_task()
{
// full stop
motor[LEFT] = 0;
// evade the object ballistically (ie in full control)
// turn left, drive
nSyncedTurnRatio = 0;
motor[LEFT] = -20;
Sleep(500);
nSyncedTurnRatio = 100;
Sleep(1000);
// turn right, drive
nSyncedTurnRatio = 0;
motor[LEFT] = 20;
Sleep(500);
nSyncedTurnRatio = 100;
Sleep(1000);
// turn right, drive
nSyncedTurnRatio = 0;
motor[LEFT] = 20;
Sleep(500);
nSyncedTurnRatio = 100;
Sleep(1000);
// turn left, resume
nSyncedTurnRatio = 0;
motor[LEFT] = 20;
Sleep(500);
motor[LEFT] = 0;
}
///////////////////////////////
void TurnBySteer(int d)
{
// normalize -100 100 to 0 200
nSyncedTurnRatio = d + 100;
}
///////////////////////////////
typedef enum programPhase { starting, searching, following, finished };
programPhase phase = starting;
// these 'tasks' are called from a loop, thus do not need to loop themselves
void initialize()
{
nSyncedTurnRatio = 50;
nSyncedMotors = synchBC;
motor[LEFT] = 30; // start a spiral drive
phase = searching;
}
void search()
{
if (light_value < 24)
{
nSyncedTurnRatio = 100;
phase = following;
}
}
int lastLight = -1;
int currentSteer = 0;
void follow()
{
// if it is solid white we have lost the line and must stop
// if lightSensors detects dark, we are on line
// if it got lighter, we are going more off line
// if it got darker we are headed in a good direction, slow down turn in anticipation
// +++PID will be even smoother
if (light_value > 64)
{
motor[LEFT] = 0;
phase = finished;
return;
}
if (light_value < 24)
currentSteer = 0;
else if (light_value > lastLight)
currentSteer += sgn(currentSteer) * 1;
else // implied (light_value < lastLight)
currentSteer -= sgn(currentSteer) * 1;
TurnBySteer(currentSteer);
}
bool regularProcessing_wantsToRun()
{
return phase != finished;
}
void regularProcessing_task()
{
switch (phase)
{
case starting:
initialize();
break;
case searching:
search();
break;
case following:
follow();
}
}
task main()
{
// subsumption tasks in priority oder
while (true)
{
// read sensors once per loop
distance_value = SensorValue[S_DISTANCE];
light_value = SensorValue[S_LIGHT];
if (evade_wantsToRun())
evade_task();
if (regularProcessing_wantsToRun())
regularProcessing_task();
else
StopAllTasks();
EndTimeSlice(); // give others a chance, but make it as short as possible
}
}
StartTask
, क्या वे कार्य की प्राथमिकता हैं? क्या 9 सर्वोच्च प्राथमिकता है? उस मामले में,find
से अधिक प्राथमिकता नहीं होनी चाहिएtrack
? वास्तव में, की स्थितिfind
औरelse
स्थितिtrack
समान हैं। इसलिए, एक मानव के रूप में, यदि सेंसर का मूल्य थ्रेशोल्ड से बड़ा है, तो आप क्या करेंगे? सर्पिल पर जाएं या लाइन को समायोजित करने के लिए मुड़ें?