Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix: Display all implemented sensors in SensorActivity #2584 #2589

Merged

Conversation

samruddhi-Rahegaonkar
Copy link
Contributor

@samruddhi-Rahegaonkar samruddhi-Rahegaonkar commented Dec 18, 2024

Updated the sensor addresses to be unique in the SensorActivity class, resolving conflicts where multiple sensors were assigned the same address (e.g., 0x39 for APDS9960 and TSL2561).
Refactored the sensor initialization to ensure accurate mapping between sensor addresses and their names, allowing all implemented sensors to be correctly shown during the sensor scan.

Screenshot 2024-12-18 at 1 47 43 PM

Checklist:

No hard coding: I have used resources from strings.xml, dimens.xml, and colors.xml without hard coding any value.

No end of file edits: No modifications done at the end of resource files strings.xml, dimens.xml, or colors.xml.

Code reformatting: I have reformatted code and fixed indentation in every file included in this pull request.

No extra space: My code does not contain any extra lines or extra spaces than the ones that are necessary.

Summary by Sourcery

Fix sensor address conflicts in SensorActivity by assigning unique addresses to each sensor and refactor initialization for accurate mapping. Update the IndicatorSeekBar dependency version in the build configuration.

Bug Fixes:

  • Resolve conflicts in sensor addresses by assigning unique addresses to each sensor in the SensorActivity class.

Enhancements:

  • Refactor sensor initialization to ensure accurate mapping between sensor addresses and their names.

Build:

  • Update the version of the IndicatorSeekBar dependency in the build configuration.

Copy link

sourcery-ai bot commented Dec 18, 2024

Reviewer's Guide by Sourcery

This PR fixes sensor display issues in SensorActivity by updating I2C addresses to ensure uniqueness for all sensors and cleaning up build dependencies. The main changes involve reassigning addresses for CCS811 and APDS9960 sensors to prevent conflicts, and updating Gradle dependencies.

No diagrams generated as the changes look simple and do not need a visual representation.

File-Level Changes

Change Details Files
Updated I2C sensor addresses to resolve conflicts
  • Added comments to clarify the purpose of each sensor address
  • Changed CCS811 sensor address from 0x5A to 0x3A to avoid conflict with MLX90614
  • Changed APDS9960 sensor address from 0x39 to 0x3B to avoid conflict with TSL2561
app/src/main/java/io/pslab/activity/SensorActivity.java
Gradle build configuration updates
  • Updated IndicatorSeekBar dependency version format
  • Downgraded Android application plugin from 8.7.3 to 8.5.1
  • Removed duplicate IndicatorSeekBar implementation
app/build.gradle.kts
build.gradle.kts

Possibly linked issues


Tips and commands

Interacting with Sourcery

  • Trigger a new review: Comment @sourcery-ai review on the pull request.
  • Continue discussions: Reply directly to Sourcery's review comments.
  • Generate a GitHub issue from a review comment: Ask Sourcery to create an
    issue from a review comment by replying to it.
  • Generate a pull request title: Write @sourcery-ai anywhere in the pull
    request title to generate a title at any time.
  • Generate a pull request summary: Write @sourcery-ai summary anywhere in
    the pull request body to generate a PR summary at any time. You can also use
    this command to specify where the summary should be inserted.

Customizing Your Experience

Access your dashboard to:

  • Enable or disable review features such as the Sourcery-generated pull request
    summary, the reviewer's guide, and others.
  • Change the review language.
  • Add, remove or edit custom review instructions.
  • Adjust other review settings.

Getting Help

Copy link

@sourcery-ai sourcery-ai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hey @samruddhi-Rahegaonkar - I've reviewed your changes - here's some feedback:

Overall Comments:

  • Please verify that the new I2C addresses (0x3A for CCS811 and 0x3B for APDS9960) are valid and supported by these sensors. I2C addresses are typically hardware-defined and cannot be arbitrarily changed in software.
Here's what I looked at during the review
  • 🟢 General issues: all looks good
  • 🟢 Security: all looks good
  • 🟢 Testing: all looks good
  • 🟢 Complexity: all looks good
  • 🟢 Documentation: all looks good

Sourcery is free for open source - if you like our reviews please consider sharing them ✨
Help me be more useful! Please click 👍 or 👎 on each comment and I'll use the feedback to improve your reviews.

Copy link

github-actions bot commented Dec 18, 2024

@marcnause marcnause changed the title Fix: Display all implemented sensors in SensorActivity #2584 fix: Display all implemented sensors in SensorActivity #2584 Dec 21, 2024
@AsCress
Copy link
Collaborator

AsCress commented Dec 21, 2024

Hello @samruddhi-Rahegaonkar ! Welcome here!
Thanks for your work on this issue !
Let me provide some context on those duplicate numbers as asked by @marcnause as well in #2584.
These numbers are actually unique addresses for each sensor, which is something which we can't decide upon, but rather is fixed by the sensor manufacturer itself.
This unique address can be found in the datasheet of each respective sensor. The I2C bus identifies anything connected on it using this address.
Since this address is a 7-bit (or 10-bit number), only 128 (or 1024) addresses for I2C sensors are possible, which makes it clear that there would definitely be duplications (there are way more sensors in the world).
However, this duplication would cause a problem only if two sensors having the same address are connected to the I2C bus (which isn't gonna be the case most of the times with the PSLab).
Therefore, we can safely keep the duplications and add those sensors. We can however inform the user, each time the PSLab detects a sensor connection which can possibly have a duplicacy. In such a either one of these sensors would be operable (if more than one with the same address are connected).

@AsCress
Copy link
Collaborator

AsCress commented Dec 21, 2024

As for this pull-request, it doesn't actually solve the mentioned issue of displaying the sensors which arn't listed in the SensorActivity.
@samruddhi-Rahegaonkar Possibly you can add those in the list, without changing any of the addresses.
I'll mark the necessary changes in a review to make it easy for you.

@@ -83,7 +83,6 @@ dependencies {
implementation("com.github.mirrajabi:search-dialog:1.2.4")
implementation(files("../libs/croller-release.aar"))
implementation("com.github.BeppiMenozzi:Knob:1.9.0")
implementation("com.github.warkiz:IndicatorSeekBar:v2.1.1")
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Some changes which arn't required. You can just rollback build.gradle.kts.

sensorAddr.put(0x39, "TSL2561"); // Unique address for TSL2561
sensorAddr.put(0x69, "MPU925x"); // Unique address for MPU925x
sensorAddr.put(0x29, "VL53L0X"); // Unique address for VL53L0X
sensorAddr.put(0x3A, "CCS811"); // New unique address for CCS811
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As mentioned earlier, changing the address would make the sensor inoperable. You can retain the same address.

sensorAddr.put(0x69, "MPU925x"); // Unique address for MPU925x
sensorAddr.put(0x29, "VL53L0X"); // Unique address for VL53L0X
sensorAddr.put(0x3A, "CCS811"); // New unique address for CCS811
sensorAddr.put(0x3B, "APDS9960"); // New unique address for APDS9960
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Same for this.

build.gradle.kts Outdated
@@ -11,5 +11,5 @@ buildscript {
}

plugins {
id("com.android.application") version "8.7.3" apply false
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Again, some changes that arn't required. You can rollback these.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Okay @AsCress Thanks for Explaining me. I will do the needful !

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@AsCress Other than the SensorActivity the changes I have made because I was unable to run the application without making those changes. But after testing I will rollback it.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@AsCress to resolve this issue as you have said, I need to make changes in the method "PopulateSensors" to handle the cases where both having same addresses.
should I ?

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@samruddhi-Rahegaonkar The problem here is with the data structure that we are using to store the sensor addresses.
A Map in Java doesn't allow duplicate keys to be inserted. When we try to do that in lines 86 and 87 of SensorActivity.java, it overwrites the previous entries, and hence the previous two sensors (MLX90614 and TSL2561) actually never get inserted in the Map.
The idea here would be to migrate to a different data structure which would allow storage of duplicate entries, and then using that in PopulateSensors to display them.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@AsCress Instead of Map<Integer, String>, we can use a Map<Integer, List<String>> to associate multiple sensor names with the same address.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@samruddhi-Rahegaonkar Yep, that's one way. Go ahead and maybe try to implement whatever you find best in this PR.

Copy link
Collaborator

@AsCress AsCress left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@samruddhi-Rahegaonkar Thanks again for your work.
There are some things which have to be changed after which this PR would be good to go.
Marking all these in a review.

@@ -83,7 +83,6 @@ dependencies {
implementation("com.github.mirrajabi:search-dialog:1.2.4")
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please rollback this whole file as discussed earlier.

}

} else {
tvData.append(getResources().getString(R.string.sensor_not_connected));
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We don't have to get this removed. tvData displayes the addresses of the connected devices.
Kindly rollback the changes from lines 186 to 192.

}

if (scienceLab.isConnected()) {
tvSensorScan.setText(tvData);
tvSensorScan.setText(getString(R.string.not_connected));
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not needed. See comment above.

build.gradle.kts Outdated
@@ -11,5 +11,5 @@ buildscript {
}
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please rollback as discussed earlier.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@AsCress Sorry for late! please check the commit once. and suggest changes if needed.

@AsCress
Copy link
Collaborator

AsCress commented Jan 4, 2025

@samruddhi-Rahegaonkar Let me clear up some more things here.
You can never revert changes to files by pushing new commits which don't contain those files. What you are essentially doing doesn't remove those changes from your branch. Changes made through commits to any branch are additive in nature, with every commit you push, your changes get added to changes in previous commits.
Thus, if you have a look in the Files changed section in this PR, you would observe that it still shows 3 files, build.gradle.kts, app\build.gradle.kts and SensorActivity.java, something which we don't want to have.
In order to revert changes, you can do any one of these things:

  1. Revert the changes manually in the files (delete what you added and add what you deleted) to the files manually and then make a new commit (something which I don't recommend as you would always end up having some changes that arn't required).
  2. Perform a Git Soft Reset (git reset --soft HEAD~n) which would reset the commit history by removing the last n commits, but would keep your changes. You could soft reset all the commits in this branch, rollback all the files not required, make a new fresh commit and then force push this branch.

@samruddhi-Rahegaonkar
Copy link
Contributor Author

@AsCress sorry, I am beginner in OpensSource contribution and Learning by doing. Thanks for your guidance.

@samruddhi-Rahegaonkar
Copy link
Contributor Author

samruddhi-Rahegaonkar commented Jan 4, 2025

@AsCress Actually when I am trying to revert the changes the gradle sync is not completing.
The project is using an incompatible version (AGP 8.7.3) of the Android Gradle plugin. Latest supported version is AGP 8.5.1
See Android Studio & AGP compatibility options.

@AsCress
Copy link
Collaborator

AsCress commented Jan 4, 2025

@samruddhi-Rahegaonkar The only reason I can think of a failed gradle sync could be an outdated version of Android Studio.
You could update it to the latest version and it would work.
For now, you can just test your build by making your changes in the build files and then just rollback those before committing. We have appropriate workflows in our repository to check your build here, so no worries !

@AsCress
Copy link
Collaborator

AsCress commented Jan 4, 2025

The project is using an incompatible version (AGP 8.7.3) of the Android Gradle plugin. Latest supported version is AGP 8.5.1
See Android Studio & AGP compatibility options.

Yep. The issue is Android Studio only. Just update it to the latest version and everything would work fine.

@AsCress
Copy link
Collaborator

AsCress commented Jan 9, 2025

@marcnause This is good to go from my side now ! Maybe you could give it a final review before we merge this.

WhatsApp Image 2025-01-09 at 9 41 58 PM

Copy link
Collaborator

@AsCress AsCress left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice work @samruddhi-Rahegaonkar ! Thank you very much !!

@AsCress AsCress requested a review from marcnause January 9, 2025 16:15
@marcnause marcnause merged commit 4e8938b into fossasia:development Jan 9, 2025
3 checks passed
@samruddhi-Rahegaonkar
Copy link
Contributor Author

@AsCress @marcnause Thank You for Guiding me throughout the issue!
@AsCress Special Thanks to you! for your valuable guidance.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants