P U B L I C A T I O N S
S. Brown et al., "Free-Moving Gamma-Ray Imaging with a Rotating Coded-Aperture Mask," 2024 IEEE Nuclear Science Symposium (NSS), Medical Imaging Conference (MIC) and Room Temperature Semiconductor Detector Conference (RTSD), Tampa, FL, USA, 2024, pp. 1-1, doi: 10.1109/NSS/MIC/RTSD57108.2024.10657976. keywords: {Image sensors;Three-dimensional displays;Systematics;Simultaneous localization and mapping;Noise;Nuclear imaging;Detectors;Sensors;Spinning;Image reconstruction},
Bhatt, I., & Alford, L. K., & Begley, L., & Hosseini, R., & Lichti, D. A. (2023, June), Piloting a Flexible Deadline Policy for a First-Year Computer Programming Course Paper presented at 2023 ASEE Annual Conference & Exposition, Baltimore , Maryland. 10.18260/1-2--43892
P R O J E C T S
Final Report for EECS 453: Foundations of Machine Learning
 annotated-EECS_453_Final_Project_Report%20%287%29.pdf
annotated-EECS_453_Final_Project_Report%20%287%29.pdfUniversity of Michigan: Foundations of Machine Learning Final Project
I co-developed a proof-of-concept method to interactively select samples for labeling from the NSAVP dataset for the 2D object detection task using active learning. Two methods explored were batch uncertainty sampling and downsampling with data augmentation, which showed promising results when compared with traditional manual labeling when evaluated on the YOLO object detector. Additional work can be done to improve results for uncertainty sampling when scaled to a large volume of samples. The final report is shown to the left.
Final Report for ROB 599: Autonomous Vehicles
 ROB599_AutonVehicles.pdf
ROB599_AutonVehicles.pdfUniversity of Michigan: Autonomous Vehicles (Planning and Control focus)
I co-developed open loop and closed loop control of a simulated vehicle in MATLAB + Simulink. We set up the lateral and longitudinal vehicle dynamics based on a bicycle model and various factors such as friction and gravity and then did open-loop control of a simulated vehicle. For closed-loop control, we implemented a Stanley controller and a Pure Pursuit controller for lateral control and tuned a PID controller for longitudinal control. We were able to show stability compared to the open-loop controller and execute various maneuvers.
Once the complete control of our vehicle was built from the ground up, my project partner and I applied graph-based and sampling-based planners to our vehicle, which we simulated using the Driving Scenario tool in MATLAB. We added various obstacles throughout the path and simulated driving paths, such as a square, circle, and figure eight. After evaluating the performance of various planners such as A*, Hybrid A*, RRT, and RRT*, we chose A* as our global planner and demonstrated its superior performance when planning the ego's path to waypoints while avoiding static obstacles.
Final Report for ROB 498: Robot Learning for Planning and Control
 SINDy.pdf
SINDy.pdfUniversity of Michigan: Robot Learning Final Project
The goal of the final project for my robot learning class was to give me in-depth experience with a chosen area of robot learning algorithms. The topic my project partner and I chose to explore was methods for shaping latent dynamics when learning from images. This is a particularly important topic for robot manipulators that learn from images captured by cameras and perform path planning and control.
In class, we learned about autoencoders, which includes learning dynamics. There are pros and cons for the various methods to shape latent dynamics, so we chose to compare a globally linear latent space model with a polynomial latent dynamics model (based off of the SINDy model) for the planar pushing task in particular. We used the 7 DoF Panda Arm in simulation and had the arm perform the planar pushing task (pushing an object to its goal on a table) for both models. We then compared the performance using various benchmarks such as the total number of steps it took to reach the goal for every success and the success rate with each model. Our experiments and analysis are found on the left.
Final Report for ROB 530: Mobile Robotics (SLAM)
 Localization_and_Mapping_for_the_Ford_AV_Dataset.pdf
Localization_and_Mapping_for_the_Ford_AV_Dataset.pdfUniversity of Michigan: Mobile Robotics Final Project
The final project for Mobile Robotics was an open-ended project in which groups of 5 students must contribute a new work to the SLAM space.
In this work, I co-implemented a particle filter localization algorithm and continuous counting sensor model mapping algorithm to be used with the Ford AV dataset. I worked with Python libraries to interface with ROS to use pose and lidar data to enable an accurate 3D pose estimate for a vehicle in the dataset and a map of the environment while the car drove on the freeway. This work builds off of the existing EKF localization framework for this dataset in that we implemented localization that would overcome the possible limitations of EKF and developed a mapping algorithm that did not yet exist for this dataset. I played a significant role in developing both algorithms throughout the project.
2D Pose Graph Optimization of the Intel Dataset
University of Michigan: Mobile Robotics Individual Project
In my second semester of graduate school, I took Mobile Robotics, a class entirely dedicated to SLAM. For this project, we were tasked with solving 2D and 3D pose estimation problems (in batch and incrementally) using the GTSAM library. I completed pose graph optimization for the Intel Research Lab dataset (2D) and the parking garage dataset (3D), both of which can be found here. The work done for this project involved setting up a new CMake project, implementing the pose graph optimization solutions in C++, and writing various scripts to plot the unoptimized and optimized trajectories.
Due to the Michigan Engineering Honor Code, I cannot publicly share the implementation of this project. Feel free to email me (ibhatt@umich.edu) and I can provide access to the project repository given it is used strictly to evaluate my work for future opportunities.
Robotic Systems Laboratory MBot
University of Michigan: Robotic Systems Laboratory Project
The final goal of this project was to implement various subsystems of a differential drive, non-holonomic autonomous robot. The robot was to complete two challenges: navigation to known locations in a known environment and autonomous navigation in an unknown environment. For the first challenge, I co-implemented open loop calibration and PID control in C for low-level motor control on a custom control board. For the robot's naïve position estimate, I also developed a gyro-fused odometry algorithm. The high-level autonomy code (SLAM and planning) was developed on a Raspberry Pi 4. For an improved estimation of the robot pose, I wrote and tested a particle filter in C++. Alongside localization, I implemented an occupancy grid mapping algorithm to map the environment. Combined, the SLAM system provided an accurate position estimate and map of the environment. Lastly, I completed the autonomous navigation system with the A* path planning algorithm and frontier exploration to enable the robot to navigate through an unknown environment.
5 DoF RX200 Robotic Arm
University of Michigan: Robotic Systems Laboratory Project
The final goal of this project was to implement various software subsystems for the RX200 robotic manipulator to execute simple motion tasks such as stacking, classifying, and lining up colored wooden cube blocks. I worked on the robot control system for manipulation. I co-implemented forward kinematics, inverse kinematics, and simple motion planning algorithms for various tasks through the state machine. The forward kinematics method was based on a Denavit-Hartenberg (DH) table and using the DH parameters to calculate the transformation matrix representing the pose of the desired links. The inverse kinematics method was a geometric method that included defining equations for each of the five joint angles and enumerating the possible joint angle configurations in the N-by-5 configuration space. The motion tasks were implemented in a state machine by defining a path plan for each task and leveraging methods from the kinematics and computer vision components of Armlab.
Stanford University: Deep Learning Final Project
With over 10 million hotels globally, there is a need for travel booking websites to provide accurate and reliable information to visitors. Star rating is most frequently used as a filtering criterion but is unreliable given the absence of commonly accepted standards for star rating assignment. Manual human verification can be subjective and incurs high operating costs. Several major third-party distribution platforms, e.g., Booking.com, therefore let hotel owners self-report their own star ratings, with highly inconsistent results.
I co-developed a computer-vision-based deep learning model that can more accurately assign hotel star ratings using images and meta-data (e.g. pricing, facilities). This promises a cheaper and more objective methodology when assigning hotel star ratings. The models leverage ReLU activation functions, one-hot encodings, and ResNet50.
Computer Architecture Senior Design Project
The goal of this project was to develop an out-of-order processor in SystemVerilog using a 5-stage multi-cycle processor as our baseline. We chose the Intel Pentium 6 for our design and implemented several advanced features such as superscalar execution and a load-store queue.
Embedded Systems Research Project
The basic goal of this project is to estimate an object's position in a two-dimensional space based on inertial (IMU) and WiFi signal strength (RSSI) data from a combination of Apple devices, specifically from the iPhone XR and the Apple Watch Series 3. Our algorithm combines an RSSI localization algorithm with a DCNN velocity estimator to provide an accurate position estimate.
Signal Strength Localization
RSSI measurements on a pre-determined path are compared against a database of RSSI measurements in a 9m-by-6m plane and a position is determined. The estimation corrects the integrated position from velocity over a fixed interval to improve the localization estimate.
User Velocity Estimation using a DCNN
One of my responsibilities was reproducing an algorithm from "DeepWalking: Enabling Smartphone-based Walking Speed Estimation Using Deep Learning" (Aawesh Shrestha & Myounggyu Won) which approximates a user's velocity using raw gyroscope and accelerometer data from an iPhone and an Apple Watch. The data is first filtered using a low pass filter. The magnitudes of the vertical and horizontal components are then found. A neural network is then trained on 7 minutes of velocity data collected from our pre-determined paths and tested on 3 minutes of test data. The neural network consists of convolutional, batch normalization, ReLU, fully-connected, and regression layers. I worked on the entire pipeline, from training/testing data collection to prediction and evaluation.