Week 8
Group Meeting, Documentation, and Debug Method
Author: Yak Fishman
Date: 3/19/2018
Hours: 7
Continued documentation on code
Group Meeting
Started to work on the debug setting
Group assesment
Author: Yak Fishman
Date: 3/19/2018
Hours: 7
Continued documentation on code
Group Meeting
Started to work on the debug setting
Group assesment
Author: Patrick Naughton
Date: 3/15/2018
Hours: 2.5
Created a `setup.sh` script to automate the setup process of new Raspberry Pis.
Changed the `Network` class so that it reads the machine's internet address so that it knows what to `bind` to (instead of looking in a .conf file). This means we no longer need to use a static ip (maybe).
(Hopefully) Fixed the termination of the listening process.
See code contributions here: https://github.com/patricknaughton01/comm_scripts/commits/master
Next Steps:
Author: Patrick Naughton
Date: 3/9/2018
Hours: 1
Reviewed progress with Dr. Zhang. It is her opinion that we should begin working with actual cars as soon as possible because there are liable to be unforeseen issues.
The demo would likely be more impressive with more vehicles. Thus, it would be nice to have Jacob and Yak work on actually constructing some cars.
Next Steps:
Author: Patrick Naughton
Date: 3/5/2018
Hours: 2
Tried to test and debugged receiver Pi. Discovered some syntax errors and logged those to GitHub (will resolve in coming days/weeks).
Met with Professor Mell to give a progress update.
Could not find a second working Pi, Professor Mell said he will discuss it with Dr. Zhang.
See code contributions here: https://github.com/patricknaughton01/comm_scripts/commits/master
Next Steps:
Author: Yak Fishman
Date: 3/5/2018
Hours: 4
Continued documentation on code
Group Meetings
Got git set up and learned how to effectively use repository
Author: Patrick Naughton
Date: 3/2/2018
Hours: 2
Added documentation to the test methods.
Set up Yak with git.
See code contributions here: https://github.com/patricknaughton01/comm_scripts/commits/master
Next Steps:
Author: Patrick Naughton
Date: 2/26/2018
Hours: 2
Added documentation to the tests and to some methods in the messages classes.
Merged all of the branches with master so that they are now up to date.
Met with other PiCar students to discuss progress.
See code contributions here: https://github.com/patricknaughton01/comm_scripts/commits/master
Next Steps:
Author: Patrick Naughton
Date: 2/25/2018
Hours: 1
Finished up most of the work for timing tests.
See code contributions here: https://github.com/patricknaughton01/comm_scripts/commits/master
Next Steps:
Author: Jacob Cytron
Date: 2/23/2018
Hours: 3
Had class meeting and gave presentation
Learned more syntax for socket coding
Had meeting with instructor
Worked on doc strings and methods (see repository)
Author: Patrick Naughton
Date: 2/23/2018
Hours: 3
Met with class to give presentation.
Began work on timing tests to ensure messages send quickly enough.
See code contributions here: https://github.com/patricknaughton01/comm_scripts/commits/master
Next Steps:
Author: Patrick Naughton
Date: 2/19/2018
Hours: 3
Met with Dr. Zhang and rest of the group to give WiFi presentation.
Met with group to discuss way forward.
Set up git repository on Jacob's and Yak's computers.
See code contributions here: https://github.com/patricknaughton01/comm_scripts/commits/master
Author: Yak Fishman
Date: 2/19/2018
Hours: 4.5
More Python learning
Started documentation on code
Group Meeting
Cleaned up log, website, and presentation
Author: Jacob Cytron
Date: 2/19/2018
Hours: 4
Set up repository, set up collaboration, and installed PyCharm to be able to push to GitHub
Read up on syntax for socket coding, plan to do more of this later
Group Meeting with TA
Completed the Broadcast method in the network module (see repository)
Author: Patrick Naughton
Date: 2/18/2018
Hours: 2
Created a small tutorial on git, posted in Useful Links above.
Worked on Message classes. For specifics, see https://github.com/patricknaughton01/comm_scripts/commits/master
Next Steps:
Author: Patrick Naughton
Date: 2/13/2018
Hours: 1
Built out some of the receiving functions in the Network class. Have not tested yet, not documented either.
Decided to use multiprocessing instead of threading because they offer abort capabilities.
Created a config directory to save settings for the Network. May be used in the final product instead of the package.
Next Steps:
Author: Patrick Naughton
Date: 2/12/2018
Hours: 0.5
Experimented with the threading library and made an example in network.py.
Author: Patrick Naughton
Date: 2/12/2018
Hours: 2.5
Demonstrated 3 way communication successfully.
Created model and added to GitHub: https://www.draw.io/#G1nteipWO6p85XItbLYPe8M1n9dVy68YSa
Next Steps:
Challenges:
Author: Yak Fishman
Date: 2/12/2018
Hours: 5
More Python learning
Continued reading the posted links and other research
Group Meeting
Author: Jacob Cytron
Date: 2/12/2018
Hours: 5
Watched a series of great in-depth tutorials on coding Python on a RaspberryPi
Group Meeting with TA: We experimented with and successfully implemented 3-way communication between PiCars
Worked on model for Python code
Author: Jacob Cytron
Date: 2/09/2018
Hours: 3
Watched Python tutorials
Made adjustments to the Gantt chart
In-class Meeting
Author: Patrick Naughton
Date: 2/9/2018
Hours: 2.5
Created two python scripts, send.py and recv.py to send and receive messages using python's built in socket library.
Configured the above scripts to broadcast to any device operating on the same network.
Created and updated a Github for the code.
Next Steps:
Challenges:
Author: Patrick Naughton
Date: 2/5/2018
Hours: 1
Finished up presentation on Wi Fi.
Researched how to send udp packets with python.
Next Steps:
Challenges:
Author: Patrick Naughton
Date: 2/5/2018
Hours: 4
Met with group to discuss wifi adapter. Decided that we don't need it because it will not improve the success of our simulation. Still important when considering scale-ability to actual cars.
Used nmap to find all Raspberry Pi's in the LAN. Very slow (on the order of 10's of seconds).
Met with Dr. Zhang to discuss progress. Decided it was worthwhile to prepare a primer on Wi Fi both to help other groups get background on the project and to formalize some of our own knowledge.
A grad student mentioned the use of UDP (user datagram protocol) to exchange information. Good because it doesn't require an initialization handshake and transmits quickly. Python has a built in library (socket) that interfaces with this protocol. It also supports broadcasting to an entire subnet, potentially eliminating the need for nmap. Will research further.
Began presentation on Wi Fi.
Next Steps:
Challenges:
Author: Yak Fishman
Date: 2/5/2018
Hours: 5
Finished the presentation and cleaned up the Gantt chart
Continued reading the posted links and other research
Author: Patrick Naughton
Date: 2/4/2018
Hours: 2
Working a little bit out of order but experimented to see how we can ping all Pi's on the LAN efficiently. It appears that using an nmap package (https://www.raspberrypi.org/documentation/remote-access/ip-address.md) might work.
Given the above information, it might be wise to reorder our Gantt chart to make sure we can ping multiple Pi's on the same network before we start trying to send specific information to ensure that our solution is scaleable.
Installed babeld package and found out that there is very little support for it. Likely will not use.
Discovered that the Raspberry Pi's built in WiFi only can support 2.4 GHz (https://liliputing.com/2016/02/raspberry-pi-3-to-feature-on-board-wifi-bluetooth.html), meaning that if we want to be more accurate (adhere more closely to the 802.11p protocol), we should buy an adapter that supports 5 GHz. Will discuss in meeting
Next Steps:
Challenges:
Author: Jacob Cytron
Date: 2/2/2018
Hours: 1
Finished the majority of the Gantt chart during our in-class meeting.
Began work on the presentation.
Author: Patrick Naughton
Date: 2/2/2018
Hours: 1
Began work on the Gantt Chart to distribute the work load.
Began the presentation for the class presentation.
Author: Jacob Cytron
Date: 2/2/2018
Hours: 2
Watched assorted videos on learning Python
Read through more of the links
Author: Yak Fishman
Date: 2/2/2018
Hours: 7
Attended group meeting and discussed group goals.
Continued research into materials and read linked articles.
Began to brush up on Python for future coding we will do
Author: Patrick Naughton
Date: 2/1/2018
Hours: 2
Successfully pinged one Raspberry Pi from the other one over an ad hoc network.
Configured each Pi to create an ad-hoc network on startup and assign itself a static IP address.
Relevant files:
Next steps:
Author: Patrick Naughton
Date: 1/31/2018
Hours: 0.5
Confirmed that ad-hoc networking is feasible. Used one Raspberry Pi to create a Wi-Fi access point that my phone could detect.
Additionally, no Wi-Fi adapter was necessary because the Raspberry Pi model 3 comes with it's own native Wi-Fi capabilities.
Next steps:
Author: Patrick Naughton
Date: 1/29/2018
Hours: 2.5
Got a key to the lab so that we can access materials.
Met with group to discuss objectives and potential challenges.
Acquired 2 Raspberry Pis to experiment with in order to see how easy it is to establish ad hoc communication.
Met with Dr. Zhang to discuss progress.
Discussed potential for different demos. A "mirroring" demo may be more feasible if other groups are not as successful as hoped.
Met with other groups to see their progress.
First Weekly Meeting
Author: Jacob Cytron
Date: 1/29/2018
Hours: 1
I attended the first weekly meeting. We clarified our end goals for the piCar project and talked over how we will accomplish our goals.
PiCar Research
Author: Jacob Cytron
Date: 1/28/2018
Hours: 2
I read some articles on the 802.11 modules and I also read through the thesis on the DriveIt communication between Raspberry Pi cars.
Yet Another WiFi Adapter
Author: Patrick Naughton
Date: 1/28/2018
Hours: 1
Found yet another WiFi adapter, this one suggested by a paper specifically about using the Raspberry Pi as an "on board unit" for DSRC in a VANET. This specific adapter, at least upon initial inspection, looks like it would be a good candidate because it has Linux support, can run in ad hoc mode (CTRL-F the documentation for ad hoc, it specifies how to set it up), and runs in the 5GHz band with backwards compatibility for the 802.11a protocol. Additionally, the authors of the paper successfully used it to establish communication on a Raspberry Pi, meaning this is possible.
Adapter: https://www.amazon.com/TP-Link-Wireless-Adapter-Archer-T1U/dp/B016K088UC
Adapter documentation: https://images-na.ssl-images-amazon.com/images/I/C1BISG1QKyS.pdf
A Better WiFi Adapter and a Tutorial
Author: Patrick Naughton
Date: 1/28/2018
Hours: 1
Just found a Wi-Fi adapter compatible with the 802.11a standard. It does not come with a driver on the latest version of the Raspberry Pi, which could actually be a good thing because it means we can compile the driver ourselves (modifying open source designs to suit our needs). Links to the adapter and tutorial can be found at the end of the post.
This is available on Amazon (https://www.amazon.com/Edimax-EW-7811UTC-Dual-Band-Connectivity-Exceeding/dp/B00FW6T36Y/ref=sr_1_1?ie=UTF8&qid=1517199327&sr=8-1&keywords=AC600+Wireless+Dual-Band+Mini+USB+Adapter+EW-7811UTC) for about $16
Tutorial: https://layereight.de/raspberry-pi/2016/08/25/raspbian-rtl8812au.html
Link to github for open source driver: https://github.com/gnab/rtl8812au
Reference: adapters that work with Raspberry Pi: https://elinux.org/RPi_USB_Wi-Fi_Adapters
WiFi Adapter and more
Author: Patrick Naughton
Date: 1/27/2018
Hours: 1.5
Based on this article (http://ieeexplore.ieee.org/stamp/stamp.jsp?tp=&arnumber=6060057&tag=1), we should be able to use an 802.11a driver to mimic a worst case scenario 802.11p driver. The paper concludes that with minor software adjustments,
VANET solutions that are validated using this approximation will also work on real hardware with better signal quality. As long as experimenters are aware of the limitations of the presented solution, it can be successfully applied as a cost-effective tool for VANET research.
We therefore need not find an 802.11p module - a more common 802.11a module will do.
Unfortunately, finding an 802.11a module is also surprisingly difficult. However, an 802.11n module should be able to operate in 802.11a mode because they share the same frequency (5GHz). This means an 802.11n module should suit our needs, as long as we can modify the device driver to make the minor adjustments the above paper discusses. Directly below is an example of such a driver.
https://www.canakit.com/raspberry-pi-wifi.html
In addition to supporting 802.11n operation, the dongle must also support ad hoc mode. This is because that seems to be the best way to set up a network mesh among multiple raspberry pis. Instructions for doing so can be found at the following link:
http://www.ericerfanian.com/mobile-mesh-networks-with-the-raspberry-pi-part-1/
Using an ad-hoc network mesh seems to be the best available solution. DSRC/WAVE, which nearly every source cites as the way to send emergency communications between cars, is an ad hoc network (https://www.hindawi.com/journals/jat/2017/2750452/). Such a network does not rely on external routers, so even if the cars lose internet access, they can still communicate with one another.
Link Dump
Author: Patrick Naughton
Date: 1/26/2018
Hours: ~10-15
Link dump of all the papers/modules I've found regarding this project.
https://www.hindawi.com/journals/jat/2017/2750452/
http://sandhill.com/wp-content/files_mf/whitepapervehicle_to_vehicle_communicationeinfochips.pdf
http://www.promiot.com/v2x/vtx-201
https://www.ietf.org/mail-archive/web/its/current/msg00935.html
http://dimme.net/tag/raspberry-pi/ <-- This is the master's thesis that's really good/thorough
https://www.unex.com.tw/products/dsrc-v2x/technology/v2x-on-board-unit/1609x-stack/detail/obu-201u
https://www.academia.edu/20878754/Accessible_customizable_high-performance_IEEE_802.11p_vehicular_communication_solution?auto=download
Author: Patrick Naughton
Date: 1/26/2018
Link to modification article. Hopefully we can use this to modify an existing 802.11a (WiFi) module to fit our needs.
http://ieeexplore.ieee.org/stamp/stamp.jsp?tp=&arnumber=6060057&tag=1
Author: Patrick Naughton
First log