Secure Autonomous and Cyber-Physical Systems
	 Instructor: Prof. Sibin Mohan, Oregon State University
	 CS/ECE 599 | Winter 2022 Term | MW 2:00 - 3:50 PM PT | BAT 150 
	
	 MP III: V2X Misbehavior Detection Contest in VEINS
	Administrivia
	
		
		
			
			
		 
			
			
				
					| Announcement Date | Mar. 01, 2022 | 
				
					| Submission Date | Mar. 12, 2022 | 
				
					| Submission Time | 11:59 PM PT | 
				
					| Total Points | 37 | 
			
		
	
	Objective 
			In this MP, we will use our previous experience on V2X networks and misbehavior mechanisms to implement our own misbehavior detector (MBD).
			
			
			You are free to implement your own MBD solution, or use any existing MBD solution.
			
			
			We have provided you with a training and testing dataset. You are free to use the training dataset to implement your own MBD solution. You will be asked to use your MBD solution on the messages in test dataset and upload the results to the website for benchmarking.
			
			
			The link to training and test dataset is:
			https://oregonstate.box.com/s/wiorcpw31td56883nx0e6fnuyqtjsr12
			
			
			
			Objectives of this MP are as follows:
			
		- 
			Learn and experiment with custom MBD applications on the V2X domain. 
			
		
		
- 
			You can start with an existing MBD solution and modify it to improve its performance, or implement your own.
			
		
- 
			Based on the performance of your solution, possibility of publishing your implementation on a security conference.
		
Prelude
	We already made preliminary simulations for training and test sets and recorded the V2X data using VEINS and F2MD Simulators (from MP I-A). You can download the training and test sets from the links and use them to implement your custom MBD solution offline and check its performance, without having to integrate with VEINS simulator. 
	MP3 instructions
	
		Here, we define the details for the training and test datasets. The training dataset includes records for 6298 vehicles while test dataset contains 4369 vehicles, from a total of 8 hours simulation.
		
		
			-  
						
				traceJSON-$vehicleID$-$A0-15$files represent the received messages for each vehicle in the simulation. For instance, the name of chosentraceJSON-33-A7represents:
					-  $vehicleID$is the receiver vehicle ID (33).
-  $A0-15$is the vehicle's attack type. A0 represents that the receiver vehicle is genuine. We can see that approximately 20 percent of vehicles are attackers.
 
-  
				
				Every traceJSON file has 2 types of messages:
				
					-  type:2messages represent self-messages containing information from vehicle's own sensors (GPS). In this case, type:2messages contain the vehicle 33's own position and speed traces.
-  type:3messages represent the received messages from other vehicles, marked withsender: senderID. 
						
						If the sender is an attacker, the message is considered an attack message. Each message has a unique ID(messageID)that we will use to evaluate the performance of our MBD.
 
-  Both type:2andtype:3messages contain the following information, which you should utilize for implementing your MBD:
					
					- Traces (X,Y coordinates only) for the following states of corresponding vehicles:
							
						
							- Position
- Speed
- Acceleration
- Heading
 
- Noise levels (X,Y coordinates only) for the following states of corresponding vehicles. The noise is essentially the confidence of the receiver on the noise levels of sender message. The lower the noise, the more precise the state information is for that message. Note that noise may be caused by many factors such as the communication channel disturbance or sensor measurement errors.
							
						
							- Position_noise
- Speed_noise
- Acceleration_noise
- Heading_noise
 
 
- Loop over all the records on the Veremi file names (easy way) to extract attacker and genuine vehicle ID's (A0 are genuine and others are attackers). These records will serve as the ground truth labels for us to evaluate the performance of our MBD app:
			
   
 Note that these labels are masked for the test dataset, which you should use to find attack messages and upload your labels to evaluate your MBD .
 
		
		
	
	Submission Instructions
	
	- Use the training dataset to implement your MBD and create detection labels for each message in testing dataset. You should mark the attack messages with 1 and the genuine messages with 0.
- Prepare the detection label file as a simple CSV file with two columns:
 messageIDandlabel.
 
 messageIDis the unique messageID and the value for thelabelis the attack label of the message (0 for genuine messages and 1 for attacks):
 
 
		messageID,label 
 5753344,0
 5753435,1
 5753586,0
 ...
 
 You should sort your labels file based on the messageID column before uploading.
- A sample detection label file (for the training set) is provided in the training_key.csvfile, which has ground truth message labels for each messageID in training set.
 
 Prepare your labels in the same format for test set, and upload it to website for checking your performance.
 
 
- For your convenience, a template file for test data is also provided in the test_template_key.csvfile.
 
 However, labels in this file are masked (all zero). You should fill in the correct labels for each messageID in the test set using your MBD and upload your test key file, having the same format and messageIDs withtest_template_key.csv.
- You may make unlimited uploads of your detection labels until the deadline. You may choose to publish your current performance on the public dashboard, or you may keep it private. You will see the performance of others on the public dashboard, and who has currently the best performance.
The dashboard is available at: Contest Dashboard
	
	Instructions on how to use the dashboard:
	
		- 
			A public leaderboard is visible on the dashboard homepage, where you can see the performance of all participants with submission details. The "score" calculated in F-1, but you are notified of your recall after each submission as well, for your reference.
		
- 
			To start using it, register with a username and password of your choice on the  register tab. After registering, you can sign-in with your credentials from the main dashboard homepage.
		
- 
			To upload your solution, after signing in, choose publicas the submission type, choose your labels file (test_template.csv with your labels) and upload it. You will be notified of your performance after submission in less than 30 seconds and the public dashboard score will be updated.
- 
			You can also upload your results privately, choose privateas the submission type, choose your labels file (test_template.csv with your labels) and upload it. You will be notified of your performance after submission in less than 30 seconds, and you can see your submission details on your private dashboard. This will not update the public dashboard.
- 
			You can make unlimited submissions. Only the performance of your best submission so far will show up on the public dashboard. 
		
	You should submit the following for MP-3:
	
		- 
			Test labels from your MBD to the dashboard website. An F-1 score above 0.6 will receive full points from this section. [10 pt]
		
-  The following artifacts [27 pt]:
			
				- A 2-3 page report describing your MBD system/logic (20 pt)
-  discussion of your results (5 pt)
- reference to your code implementation(2 pt).
 Note that your code does not have to be "submission clean" just yet. The code is just a complementary artifact to your report, and will allow us to give more beneficial feedback for future improvements.
- The winner of the "contest" (i.e. whoever is at the head of the leaderboard at the deadline) will receive bonus points [5 pt] 
Sample MBD Implementations
	Here are some sample implementations of existing MBD research for your reference:
	- 
		
		 VeReMi: A Dataset for Comparable Evaluation of Misbehavior Detection in VANETs
		
			This paper includes general information about the dataset, evaluation methods, and plausibility detectors with their performance on attacks
		 
- 
		 VeReMi Extension: A Dataset for Comparable Evaluation of Misbehavior Detection in VANETs 
		
			This paper includes general information about the dataset with added attacks, evaluation methods, and two detection approaches with plausibility detectors, including their performance on attacks.
		 
- 
		 F2MD: Simulation Framework for Misbehavior Detection in Vehicular Networks
		
		
			This is the original paper describing the F2MD framework, our simulator in previous MBDs. The paper and source code in our simulator includes multiple MBD approaches with code implementation, including plausibility and ML based ones.
		 
- 
		 CaTch: A Confidence Range Tolerant Misbehavior Detection Approach
		
		
			Another paper that implements MBD with confidence range tolerance, using the same BSM fields with our dataset.
		 
- 
		 Vehicle Behavior Analysis to Enhance Security in VANETs
		
		
			This paper includes a new approach to MBD, which is based on a vehicle behavior and trust analysis. 
- 
		 Trust On the Security of Wireless Vehicular Ad-hoc Networking
		
		
			A simple trust logic implementation based on the distance between sender and receiver. 
- 
		 Trust mechanisms in wireless sensor networks:Attack analysis and countermeasures 
		
		
			A paper from similar discipline that describes the attack analysis and countermeasures for defense mechanisms against similar attacks in wireless sensor networks. 
- 
		 MisDis: An Efficent Misbehavior Discovering Method Based on Accountability and State Machine in VANET 
		
		
			Another MBD implementation that implements MBD solution based on the accountability of broadcast BSMs.
		 
References
	
		
			- 
				https://veins.car2x.org/documentation/
			
- 
				https://github.com/josephkamel/F2MD
			
-  Here is another well-put VEINS tutorial for reference: 
 http://kjit.bme.hu/images/Tovabbi_allomanyok/Trafficlab/Research/SUMOTRACI/SUMO-VEINS_Tutorial.pdf
- A custom simulation tutorial in VEINS:
 http://cse.iitkgp.ac.in/~soumya/micro/t2-3.pdf