Featured Posts

السبت، 8 أغسطس، 2015

Adafruit GPS shied

Adafruit GPS shield 
                     



نظام التموضع العالمي ,هو نظام يمكنك من تحديد موقعك من خلال ثلاثة اقمار صناعية موزعة بشكل دائري حول الكرة الارضية ,يقوم ال gps  باستقبال هذه البيانات و عرضها ثم نقوم بإدخال هذه البيانات الى نظام خرائط عالمي " , Here Nokia Google map "  حتى نحصل على الموقع بالتحديد.





GPS shield من أنتاج شركة أدافروت الأمريكية ,  يمكن توصيله مع اردوينو (Uno, mega, Leonardo) فقط كل ما يلزم هو تركيبه على الاردوينو ليصبح جاهز .يفضل استخدامه في التطبيقات الخارجية اذ انه يحتاج الى هوائي Antenna لاستعماله داخل الغرفة .و يفضل الانتظار مدة ما بين 60 ثانية حتى دقيقتين حتى يبدأ باستقبال البيانات و تستدل على ذلك من ترميش ضوء  LED fix حيث انه يبدأ بالترميش بشكل بطيء عند استقبال البيانات.



سوف نقوم بعمل تجارب متعددة ل :

1) اختبار ال GPS Shield و التحقق من عمله 
2) لعرض احداثيات موقع معين على serial monitor  و على شاشة عرض كرستالية LCD.
3)عمل نظام تتبع و حفظ للبيانات على SD Card

نحتاج في هذه التجربة الى :
1-اسلاك توصيل
2-بطاقة اردوينو Uno
3-GPS shield
4-شاشة عرض كرستالية LCD
5-SD  card
6-مقاومة متغيرة
7-BreadBoard

 

يجب عليك تحميل المكتبة من هنا 


التجربة الأولى : اختبار ال GPS Shield و التحقق من عمله 

اولا طريقة توصيله مع الاردوينو باستخدام برنامج fritzing
يجب علينا دائماً وضع ال Shield فوق الأردوينو في كل التجارب التي سنقوم بها .

التوصيل توضيحي بحيث يتم وضع GPS Shield فوق لوحة الأردوينو 


قبل تحميل الكود , حوّل الكبسة باتجاه Soft serial و بعد الأنتهاء من التحميل أرجعه لوضع Direct



البرنامج : 

//Connect VIN to +5V
//Connect GND to Ground
//Connect GPS RX (data into GPS) to Digit                           
//Connect GPS TX (data out from GPS) to Digital 1
Void setup () {} 
Void loop () {}


تحليل البيانات  :
نقوم بفتح شاشة ال Serial Monitor في الأردوينو , وسنرى تلقائياً تحديث للبيانات التي ستأتي من ال GPS على شاشة السيريال .


الان ما يهمنا هو السطر الذي ببدايته $GPRMC  سنقوم بشرحه بالتفصيل:

1)194509.0000 تعبر عن الوقت بالساعة ثم الدقائق ثم الثواني واخيرا جزء من الميللي من الثانية بتوقيت غرينيتش, فعليا الساعة هنا هي 19(7 مساء) و 45 دقيقة و 9 ثواني 

2)ثانيا الحرف A ويعني  (active) يعبر عن ان ال gps  قد بدأ فعلا باستقبال البيانات ,اذا كان بدلا منه حرف V(void or invalid) هذا يعني انه لم يتم الارتباط مع القمر الصناعي بعد .
بعد ذلك 07400.4168,W/4042.6142,N تعبر عن احاثيات الموقع بالنسبة لاتجاهي الشمال و الغرب 
نسمي 4042.6142  latitude  و 07400.4168  longitude حيث 40 , 74  تعبر عن الزوايا و نقوم بكتابتها على Google map  على النحو الاتي :اذا اعطانا احداثيات الشمال و الشرق نكتب قبل الرقم + و  اذا اعطانا الجنوب و الغرب نكتب – ثم ندخل الرقم كالاتي 
+40 42.6142    -74  00.4168 

3)زاوية تتبع، وهذا هو المقصود لتقريب أي اتجاه "بوصلة" نحن نسير في مقرها في سفرنا الماضي.

و الرقم 160412  يعبر عن التاريخ 16/4/2012

و هذا الكود هو blank code و يدعى,و يعطينا بيانات  NEMA خاصة باحداثيات الأقمار الصناعيه 

التجربة الثانية :توصيل ال GPS Shield مع شاشة كريستاليه LCD

الان يمكننا عرض بيانات (long,lat,alt,speed,date,time) التي يعطينا اياها القمر الصناعي على شاشة عرض كرستالية .LCD
alt: تعبر عن الارتفاع عن سطح البحر, اولا علينا التعرف على كيفية توصيل الشاشة مع الاردوينو :



طبعاً يجب وضع GPS Shield فوق الأردوينو و القيام بعملية لحام على ال shield ليسهل توصيل ال lcd معها .

البرنامج : 
// gps shield with LCD1602 
// display Basic information from GPS into LCD
// Code written By :Shahed Al Ali
#include <Adafruit_GPS.h>
#include <SoftwareSerial.h>
#include <LiquidCrystal.h>
LiquidCrystal lcd(12, 11, 5, 4, 3, 2);
SoftwareSerial mySerial(8, 7);

Adafruit_GPS GPS(&mySerial);
// If using hardware serial (e.g. Arduino Mega), comment
// out the above six lines and enable this line instead:
//Adafruit_GPS GPS(&Serial1);


// Set GPSECHO to 'false' to turn off echoing the GPS data to the Serial console
// Set to 'true' if you want to debug and listen to the raw GPS sentences. 
#define GPSECHO  true 

// this keeps track of whether we're using the interrupt
// off by default!
boolean usingInterrupt = false;
void useInterrupt(boolean); // Func prototype keeps Arduino 0023 happy
unsigned int count =1;
void setup()  
{   
  // 9600 NMEA is the default baud rate for Adafruit MTK GPS's- some use 4800
  GPS.begin(9600);
  lcd.begin(16, 2);  // uncomment this line to turn on RMC (recommended minimum) and GGA (fix data) including altitude
  GPS.sendCommand(PMTK_SET_NMEA_OUTPUT_RMCGGA);
  // uncomment this line to turn on only the "minimum recommended" data
  //GPS.sendCommand(PMTK_SET_NMEA_OUTPUT_RMCONLY);
  // For parsing data, we don't suggest using anything but either RMC only or RMC+GGA since
  // the parser doesn't care about other sentences at this time
  
  // Set the update rate
  GPS.sendCommand(PMTK_SET_NMEA_UPDATE_1HZ);   // 1 Hz update rate
  // For the parsing code to work nicely and have time to sort thru the data, and
  // print it out we don't suggest using anything higher than 1 Hz

  // Request updates on antenna status, comment out to keep quiet
  GPS.sendCommand(PGCMD_ANTENNA);

  // the nice thing about this code is you can have a timer0 interrupt go off
  // every 1 millisecond, and read data from the GPS for you. that makes the
  // loop code a heck of a lot easier!
  useInterrupt(true);

  delay(1000);
  // Ask for firmware version
 
lcd.clear();
lcd.print("GPS Shahd proj");
lcd.setCursor(0,1);
lcd.print("No connection : ( ");
}


// Interrupt is called once a millisecond, looks for any new GPS data, and stores it
SIGNAL(TIMER0_COMPA_vect) {
  char c = GPS.read();
  // if you want to debug, this is a good time to do it!
#ifdef UDR0
  if (GPSECHO)
    if (c) UDR0 = c;  
    // writing direct to UDR0 is much much faster than Serial.print 
    // but only one character can be written at a time. 
#endif
}

void useInterrupt(boolean v){
  if (v){
    // Timer0 is already used for millis() - we'll just interrupt somewhere
    // in the middle and call the "Compare A" function above
    OCR0A = 0xAF;
    TIMSK0 |= _BV(OCIE0A);
    usingInterrupt = true;
  } else {
    // do not call the interrupt function COMPA anymore
    TIMSK0 &= ~_BV(OCIE0A);
    usingInterrupt = false;
  }
}
uint32_t timer = millis();
void loop()                     // run over and over again
{
  // in case you are not using the interrupt above, you'll
  // need to 'hand query' the GPS, not suggested :(
  if (! usingInterrupt){
    // read data from the GPS in the 'main loop'
    char c = GPS.read();
    // if you want to debug, this is a good time to do it!     
  }
  
  // if a sentence is received, we can check the checksum, parse it...
  if (GPS.newNMEAreceived()) {
    // a tricky thing here is if we print the NMEA sentence, or data
    // we end up not listening and catching other sentences! 
    // so be very wary if using OUTPUT_ALLDATA and trytng to print out data
    //Serial.println(GPS.lastNMEA());   // this also sets the newNMEAreceived() flag to false
  
    if (!GPS.parse(GPS.lastNMEA()))   // this also sets the newNMEAreceived() flag to false
      return;  // we can fail to parse a sentence in which case we should just wait for another
 }

  // if millis() or timer wraps around, we'll just reset it
  if (timer > millis())  timer = millis();

  // approximately every 2 seconds or so, print out the current stats
  if (millis() - timer > 2000) { 
    timer = millis(); // reset the timer
    
      switch(count)
{
        case 1 : 
      lcd.setCursor(0,0);
      lcd.print("lat:");
      lcd.print( GPS.latitude) ;
      lcd.print(GPS.lat,3);
      lcd.setCursor(0,1);
      lcd.print("log:");
      lcd.print(GPS.longitude);
             lcd.print(GPS.lon,3);
      count++;
      break;
      case 3 :
      lcd.clear();
      lcd.print("alt:");
      lcd.print( GPS.altitude); 
      lcd.setCursor(0,1);
      lcd.print("speed:");
      lcd.print(GPS.speed);         
      count++;
      break;
      case 5 :
      lcd.clear();
      lcd.print(GPS.hour, DEC);
      lcd.print(':');;
    lcd.print(GPS.minute, DEC);
    lcd.print(':');;
    lcd.print(GPS.seconds, DEC);
    lcd.print(':');;
    lcd.println(GPS.milliseconds);
    lcd.setCursor(0,1);
    lcd.print("D:");
    lcd.print(GPS.day, DEC);
    lcd.print('/');;
    lcd.print(GPS.month, DEC); 
    lcd.print("/20");
    lcd.println(GPS.year, DEC);
    count=1;
    break; 
    default:
    count++;
    break;
      }
}
}


وهذه الصور توضع النتيجة على شاشة ال LCD






عمل نظام تتبع للاحداثيات و تخزينها على ال SD Card




ننتقل الان للحديث عن تطبيق اخر , تطبيق مهم جدا حيث تستعمل بطاقة الذاكرة في تخزين الاحداثيات التي يستقبلهاgps من الاقمار الصناعية مهما تغير مكاننا سوف تخزن هذه الاحداثيات و يصبح الرجوع اليها و ادخالها الى Google map سهل جدا.
يمكننا الحصول على الكود الخاص بها من خلال الرجوع الى المكتبة ثم اختيار (examples) ثم اختيار الكود المسمى (shield_sdlog) و يوجد مكان مخصص لوضعها في ال gps shield و يجب الانتباه الى تغيير المفتاح من direct الى soft serial , هذا التطبيق يمككنا من تتبع حركتنا بواسطة خرائط جوجل مثلاً

عند فتح ال sd card  سوف نرى الاحداثيات المخزنة ما علينا سوى ادخالها الى Google map  حسب الطريقة المذكورة سابقا.



ملف TXT من داخل ال SD Card



كما ذكرنا سابقا عند اخذ البيانات من sd card فقط نهتم بالبيانات المعطاة بعد كلمة $GPRMC 

($GPRMC20xxx5.000,A,31xx.xx80,N,035xx.xx32,E,1.02,187.10,010815D)

 نقوم بادخالها الى Google map  على النحو الاتي:

(+31  xx.xx80, +35  xx.xx32)

 و سنحصل على الموقع المطلوب.

يتم اخفاء الموقع حفاظاً ع الخصوصية .
الكاتب : شهد العلي - الأردن .




الخميس، 16 يوليو، 2015

SKYLAB SKM53 GPS


نظام التموضوع العالمي SKYLAB SKM53

SKYLAB SKM53 هو موديول ينتمي لعائلة الدارات المستقبلة لبيانات الأقمار الصناعية الخاصة بنظام التموضع العالمي GPS تتميز بسهولة استخدامها و برمجته .



سنقوم بهذه التجربة بتوصيله للاردوينو و أخذ البيانات الرئيسية القادمة من الأقمار الصناعية و عرضها على شاشة الحاسوب .

سنحتاج في هذه التجربة إلى :
1)بطاقة أردوينو
2) 
SKYLAB SKM53 GPS
3)لوحة توصيل BreadBoard
4)اسلاك توصيل jumper






بالغالب لا يعمل ال GPS داخل الأماكن المغلقه لذلك يفضل تجربته في مكان مفتوح حتى تحصل على نتائج صحيحة .

لا يوجد على هذا الموديول ضوء LED لاظهار ما اذا تم التزامن مع الاقمار الصناعية ام لا .



سأقسم هذه التجربة إلى قسمين : 

1) سيتم برمجته بواسطة الحاسوب مع برمجية مخصصة من الشركة المصنعه لهذه القطعه 

2) برمجته بواسطة الأردوينو .

القسم الأول : 

1) نفتح برنامج الأردوينو و نحمل فيه برنامج فارغ Blank code كما يلي  : 
// Blank Code
//Mohannad Rawashdeh
void setup() 
{
}

void loop() 
{
}


2) نقوم بتوصيل ال GPS بالأردوينو كما يلي  :





3) نذهب لبرنامج U Center و نختار رقم المنفذ التسلسلي الخاص بالأردوينو .






4) تأكد من ضبط سرعه الاتصال عند 9600 و من اختيار NEO 6 كما في الصورة . 





5) بعدها نضغط Connect و نرى تحديث البيانات من الGPS على الشاشة  .



الجزء الثاني : البرمجة بواسطة الأردوينو :
1)سنقوم باغلاق البرنامج السابق " مهم جداً " .
2)نقوم بتغيير التوصيل كما يلي : 




3) يجب عليك امتلاك مكتبة TinyGPS لاستخدام هذا الموديول , لتحميله من هنا .




4) نحمل البرنامج التالي :
#include <SoftwareSerial.h>
#include <TinyGPS.h>
/* 
 Skylab SKM53 GPS module test 
Connect :
SKM53     ARDUINO
VCC   >>>  5V
Tx    >>>  D3
Rx    >>>  D4
GND    >>>  GND
Arduino board LED On D13 here 
is to indicate if data available 
written By : Mohannad Rawashdeh
http://www.genotronex.com
*/
TinyGPS SKM53;
const int RXpin = 3 ;// Connect with TX pin in GPS
const int TXpin = 4 ;// Connect with RX pin in GPS
const int LedPin= 13;
SoftwareSerial Genotronex(RXpin,TXpin);
unsigned int  buadRateGPS= 9600 ; 
unsigned long buadRateUART= 115200 ; 
const unsigned int DelayGPStime = 1000 ; 
void setup()
{
  Serial.begin(buadRateUART);
  Genotronex.begin(buadRateGPS);
  Serial.println("Skylab SKM53 GPS Test");
  Serial.print("TinyGPS library version :");
  Serial.println(TinyGPS::library_version());
  Serial.print("Mohannad Rawashdeh , ");
  Serial.println("www.genotronex.com");
  pinMode(LedPin,OUTPUT);
}

void loop()
{
  bool newData = false;
  digitalWrite(LedPin,newData);
  for (unsigned long start = millis(); millis() - start < DelayGPStime;)
  {
    while (Genotronex.available())
    {
      char c = Genotronex.read();
      // Serial.write(c); // uncomment this line if you want to see the GPS data flowing
      if (SKM53.encode(c)) // Did a new valid sentence come in?
        newData = true;
         digitalWrite(LedPin,newData);
    }
  }

  if (newData)
  {
    float fLat, fLon;
    unsigned long age;
    SKM53.f_get_position(&fLat, &fLon, &age);
    int year;
    byte month, day, hour, minute, second, hundredths; 
    SKM53.crack_datetime(&year, &month, &day,&hour, &minute, &second, &hundredths);
    Serial.println("Latitude \t longitude \t SATELLITE \t   date \t    time");
    Serial.print(fLat,6);
    Serial.print("\t ");
    Serial.print(fLon, 6);
    Serial.print(" \t");
    Serial.print(SKM53.satellites());
    Serial.print("\t \t");
    Serial.print(day);
    Serial.print("/");
    Serial.print(month);
    Serial.print("/");
    Serial.print(year);
    Serial.print(" \t");
    Serial.print(hour);
    Serial.print(":");
    Serial.print(minute);
    Serial.print(":");
    Serial.println(second);
  }  
}




بعدها تستطيع فتح نافذة السيريال و قراءة البيانات الخاصة بنظام التموضع العالمي . 


ِشرح البرنامج : 

طريقة كتابة البرنامج سهلة , بالبداية الجزء الخاص بالتحقق من وجود بيانات اتصال مع القمر الصناعي هو :


 if (SKM53.encode(c)) // Did a new valid sentence come in?
        newData = true;

في حالة وجود بيانات سيتم جعل المتغير newData صحيحياً و يتحقق الشرط الخاص بقراءة البيانات الخاصة بال gps

في هذه المتغيرات يتم حفظ القيم المطلوبة مثل الاحداثيات , الوقت , التاريخ : 


    float fLat, fLon;
    unsigned long age;
    int year;
    byte month, day, hour, minute, second, hundredths; 
   

هنا هذين الأمرين يقومان بتخزين قيم الأحداثيات بالمتغيرات المخصصة لهما fLat,fLon 
    SKM53.f_get_position(&fLat, &fLon, &age);

يتم تخزين الوقت و التاريخ كلاً حسب وحدته من خلال هذا الأمر:


 SKM53.crack_datetime(&year, &month, &day,&hour, &minute, &second, &hundredth





الجمعة، 26 يونيو، 2015

VK16E SRIF 3 Gmouse GPS


نظام التموضوع العالمي VK16E gps




VK16E  هو موديول ينتمي لعائلة الدارات المستقبلة لبيانات الأقمار الصناعية الخاصة بنظام التموضع العالمي GPS تتميز بسهولة استخدامها و برمجته .

من أهم مميزاته هو سعره المنخفض و زمن تشغيل في أقل من دقيقة واحدة .


سنقوم بهذه التجربة بتوصيله للاردوينو و أخذ البيانات الرئيسية القادمة من الأقمار الصناعية و عرضها على شاشة الحاسوب .

سنحتاج في هذه التجربة إلى :
1)بطاقة أردوينو
2) GPS 
VK16E
3)لوحة توصيل BreadBoard
4)اسلاك توصيل jumper






بالغالب لا يعمل ال GPS داخل الأماكن المغلقه لذلك يفضل تجربته في مكان مفتوح حتى تحصل على نتائج صحيحة .
يوجد على هذا الموديول ضوء LED اذا التقط البيانات من القمر الصناعي يتوهج ببطئ , غير ذلك يكون لون الضوء أخضر و ثابت دون ترميش .


سأقسم هذه التجربة إلى قسمين : 

1) سيتم برمجته دون الحاجة لبرمجة الأردوينو , عوضاً عن ذلك ستصل بيانات ال GPS للحاسوب و يتم تحليل و عرض البيانات بواسطة برمجية مخصصة من الشركة المصنعه لهذه القطعه 

2) برمجته بواسطة الأردوينو .

القسم الأول : 
يمكنك استخدام لوحة أردوينو "كما سأفعل انا ادناه " او بأمكانك استخدام Serial Adapter مثل FTDI232 , CP2102 و غيرها , في حال استعمال Serial Adapter يمكنك الأنتقال مباشرة للخطوة الثالثة مع توصيل Serial Adapter بنفس الطريقة التي سنوصل فيها الأردوينو و ال GPS في هذا القسم.

1) نفتح برنامج الأردوينو و نحمل فيه برنامج فارغ Blank code كما يلي  : 
// Blank Code
//Mohannad Rawashdeh
void setup() 
{
}

void loop() 
{
}


2) نقوم بتوصيل ال GPS بالأردوينو كما يلي  :


في حال استخدام Serial adapter مثل FTDI يجب توصيله بنفس الطريقة اعلاه .



3) نذهب لبرنامج U Center و نختار رقم المنفذ التسلسلي الخاص بالأردوينو .






4) تأكد من ضبط سرعه الاتصال عند 9600 و من اختيار NEO 6 كما في الصورة . 





5) بعدها نضغط Connect و نرى تحديث البيانات من الGPS على الشاشة  .





الجزء الثاني : البرمجة بواسطة الأردوينو :

في هذا الجزء سيقوم الأردوينو بعمل تحليل للبيانات القادمة من ال gps دون الحاجة لاستخدام الحاسوب كما في القسم الأول من التجربة 

1)سنقوم باغلاق البرنامج السابق " مهم جداً " .
2)نقوم بتغيير التوصيل كما يلي : 




3) يجب عليك امتلاك مكتبة TinyGPS لاستخدام هذا الموديول , لتحميله من هنا .




4) نحمل البرنامج التالي :
#include <SoftwareSerial.h>
#include <TinyGPS.h>
/* 
VK-16E Gmouse GPS module test 
Connect :
VK-16E     ARDUINO
VCC    >>>  5V
Tx     >>>  D3
Rx     >>>  D4
GND    >>>  GND
written By : Mohannad Rawashdeh
http://www.genotronex.com
*/
TinyGPS VK16E;
const int RXpin = 3 ;// Connect with TX pin in GPS
const int TXpin = 4 ;// Connect with RX pin in GPS
SoftwareSerial Genotronex(RXpin,TXpin);
unsigned int  buadRateGPS= 9600 ; 
unsigned long buadRateUART= 115200 ; 
const unsigned int DelayGPStime = 1000 ; 
void setup()
{
  Serial.begin(buadRateUART);
  Genotronex.begin(buadRateGPS);
  Serial.println("VK16E GPS Test");
  Serial.print("TinyGPS library version :");
  Serial.println(TinyGPS::library_version());
  Serial.print("Mohannad Rawashdeh , ");
  Serial.println("www.genotronex.com");
}

void loop()
{
  bool newData = false;
  for (unsigned long start = millis(); millis() - start < DelayGPStime;)
  {
    while (Genotronex.available())
    {
      char c = Genotronex.read();
      // Serial.write(c); // uncomment this line if you want to see the GPS data flowing
      if (VK16E.encode(c)) // Did a new valid sentence come in?
        newData = true;
    }
  }

  if (newData)
  {
    float fLat, fLon;
    unsigned long age;
    VK16E.f_get_position(&fLat, &fLon, &age);
    int year;
    byte month, day, hour, minute, second, hundredths; 
    VK16E.crack_datetime(&year, &month, &day,&hour, &minute, &second, &hundredths);
    Serial.println("Latitude \t longitude \t SATELLITE \t   date \t    time");
    Serial.print(fLat,6);
    Serial.print("\t ");
    Serial.print(fLon, 6);
    Serial.print(" \t");
    Serial.print(VK16E.satellites());
    Serial.print("\t \t");
    Serial.print(day);
    Serial.print("/");
    Serial.print(month);
    Serial.print("/");
    Serial.print(year);
    Serial.print(" \t");
    Serial.print(hour);
    Serial.print(":");
    Serial.print(minute);
    Serial.print(":");
    Serial.println(second);
  }  
}




بعدها تستطيع فتح نافذة السيريال و قراءة البيانات الخاصة بنظام التموضع العالمي . 



ِشرح البرنامج : 

طريقة كتابة البرنامج سهلة , بالبداية الجزء الخاص بالتحقق من وجود بيانات اتصال مع القمر الصناعي هو :


 if (VK16E.encode(c)) // Did a new valid sentence come in?
        newData = true;

في حالة وجود بيانات سيتم جعل المتغير newData صحيحياً و يتحقق الشرط الخاص بقراءة البيانات الخاصة بال gps

في هذه المتغيرات يتم حفظ القيم المطلوبة مثل الاحداثيات , الوقت , التاريخ : 


    float fLat, fLon;
    unsigned long age;
    int year;
    byte month, day, hour, minute, second, hundredths; 
   

هنا هذين الأمرين يقومان بتخزين قيم الأحداثيات بالمتغيرات المخصصة لهما fLat,fLon 
    VK16E.f_get_position(&fLat, &fLon, &age);

يتم تخزين الوقت و التاريخ كلاً حسب وحدته من خلال هذا الأمر:


 VK16E.crack_datetime(&year, &month, &day,&hour, &minute, &second, &hundredth





الخميس، 18 يونيو، 2015

نظام التموضع العالمي NEO-6M

NEO-6M GPS 




 NEO-6M  هو موديول ينتمي لعائلة الدارات المستقبلة لبيانات الأقمار الصناعية الخاصة بنظام التموضع العالمي GPS تتميز بسهولة استخدامها و برمجتها اضافة لزمن تشغيل سريع .

تتميز هذه الدارة بوجود بطارية احتياطية , و ذاكرة فير قابلة للمسح كهربائياً EEPROM لتخزين الأعدادات الخاصة بال GPS , وتتميز بتقنية تمنع التشويش المقصود عليها Anti jamming technology , بالأضافة لدعمها اخراج البيانات ببروتوكولات مختلفه (UART , USB , SPI ) .



ما سنقوم به بهذه التجربة هي الحصول على بيانات المتعلقة بالاحداثيات الجغرافية , الوقت و التاريخ .



سنحتاج لتنفيذ هذه التجربة إلى : 

لوحة أردوينو 
الموديول NEO-6M 
اسلاك توصيل Jumper
لوحة توصيل BreadBoard



يجب الأنتباه لموضوع التغذية لمثل هذه الدارات اذ انها تعتمد على تغذية 3.3 فولت و اي فولتية أعلى من هذه الفولتية , سواءاً فولتية التغذية vcc او الفولتية المطبقة على المداخل و المخارج I/O 



بالغالب لا يعمل ال GPS داخل الأماكن المغلقه لذلك يفضل تجربته في مكان مفتوح حتى تحصل على نتائج صحيحة .
يوجد على هذا الموديول ضوء LED اذا التقط البيانات من القمر الصناعي يتوهج ببطئ , غير ذلك يكون يتوهج بشكل سريع 



سأقسم هذه التجربة إلى قسمين : 

1) سيتم برمجته بواسطة الحاسوب مع برمجية مخصصة من الشركة المصنعه لهذه القطعه 

2) برمجته بواسطة الأردوينو .

القسم الأول : 

1) نفتح برنامج الأردوينو و نحمل فيه برنامج فارغ Blank code كما يلي  : 
// Blank Code
//Mohannad Rawashdeh
void setup() 
{
}

void loop() 
{
}


2) نقوم بتوصيل ال GPS بالأردوينو كما يلي  :





3) نذهب لبرنامج U Center و نختار رقم المنفذ التسلسلي الخاص بالأردوينو .






4) تأكد من ضبط سرعه الاتصال عند 9600 و من اختيار NEO 6 كما في الصورة . 





5) بعدها نضغط Connect و نرى تحديث البيانات من الGPS على الشاشة  .



الجزء الثاني : البرمجة بواسطة الأردوينو :
1)سنقوم باغلاق البرنامج السابق " مهم جداً " .
2)نقوم بتغيير التوصيل كما يلي : 


3) نفتح برنامج الأردوينو و نتأكد من وجود مكتبه TinyGPS و وضعها بشكل صحيح في مسار المكتبات الخاصة بالأردوينو  - يمكنك تحميلها من الرابط -

4) استخدام المثال التالي وحمله على الأردوينو 
#include <SoftwareSerial.h>
#include <TinyGPS.h>
/* 
NEO 6M GPS module test 
Connect :
NEE6M     ARDUINO
VCC   >>>  3V3
Tx    >>>  D3
Rx    >>>  D4
GND    >>>  GND
written By : Mohannad Rawashdeh
http://www.genotronex.com
*/
TinyGPS NEO6M;
const int RXpin = 3 ;// Connect with TX pin in GPS
const int TXpin = 4 ;// Connect with RX pin in GPS
SoftwareSerial Genotronex(RXpin,TXpin);
unsigned int  buadRateGPS= 9600 ; 
unsigned long buadRateUART= 115200 ; 
const unsigned int DelayGPStime = 1000 ; 
void setup()
{
  Serial.begin(buadRateUART);
  Genotronex.begin(buadRateGPS);
  Serial.println("uBlox Neo 6M GPS Test");
  Serial.print("TinyGPS library version :");
  Serial.println(TinyGPS::library_version());
  Serial.print("Mohannad Rawashdeh , ");
  Serial.println("www.genotronex.com");
}

void loop()
{
  bool newData = false;
  for (unsigned long start = millis(); millis() - start < DelayGPStime;)
  {
    while (Genotronex.available())
    {
      char c = Genotronex.read();
      // Serial.write(c); // uncomment this line if you want to see the GPS data flowing
      if (NEO6M.encode(c)) // Did a new valid sentence come in?
        newData = true;
    }
  }

  if (newData)
  {
    float fLat, fLon;
    unsigned long age;
    NEO6M.f_get_position(&fLat, &fLon, &age);
    int year;
    byte month, day, hour, minute, second, hundredths; 
    NEO6M.crack_datetime(&year, &month, &day,&hour, &minute, &second, &hundredths);
    Serial.println("Latitude \t longitude \t SATELLITE \t   date \t    time");
    Serial.print(fLat,6);
    Serial.print("\t ");
    Serial.print(fLon, 6);
    Serial.print(" \t");
    Serial.print(NEO6M.satellites());
    Serial.print("\t \t");
    Serial.print(day);
    Serial.print("/");
    Serial.print(month);
    Serial.print("/");
    Serial.print(year);
    Serial.print(" \t");
    Serial.print(hour);
    Serial.print(":");
    Serial.print(minute);
    Serial.print(":");
    Serial.println(second);
  }  
}




5) بعد تحميل البرنامج , تأكد من أن الضوء LED في الGPS يتوهج ببطء و افتح نافذة السيريال سترى بيانات ال GPS كما يلي  .







طريقة كتابة البرنامج سهلة , بالبداية الجزء الخاص بالتحقق من وجود بيانات اتصال مع القمر الصناعي هو :


 if (NEO6M.encode(c)) // Did a new valid sentence come in?
        newData = true;

في حالة وجود بيانات سيتم جعل المتغير newData صحيحياً و يتحقق الشرط الخاص بقراءة البيانات الخاصة بال gps

في هذه المتغيرات يتم حفظ القيم المطلوبة مثل الاحداثيات , الوقت , التاريخ : 


    float fLat, fLon;
    unsigned long age;
    int year;
    byte month, day, hour, minute, second, hundredths; 
   

هنا هذين الأمرين يقومان بتخزين قيم الأحداثيات بالمتغيرات المخصصة لهما fLat,fLon 
    NEO6M.f_get_position(&fLat, &fLon, &age);

يتم تخزين الوقت و التاريخ كلاً حسب وحدته من خلال هذا الأمر:



 NEO6M.crack_datetime(&year, &month, &day,&hour, &minute, &second, &hundredth






 
Creative Commons License
This work is licensed under a Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License.