-
Notifications
You must be signed in to change notification settings - Fork 59
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
Add ML tool for datasets generation #149
Comments
I think that the first idea (GUI system) is fine. When you say For the second idea (auto-generated datasets that use randomness and/or without much user control), I have a few comments:
Creating different camera positions/angles is one option. Here are a few other options:
I would actually argue that this approach of "randomness" could produce better datasets than human-generated datasets. When it comes to generating ML datasets, we want to remove as much bias from the data as possible. By viewing objects from various angles and having different objects in various images (based on what is visible and what is not), we are generating data that is more generalizable than data that only views objects under a pre-defined set of conditions. Another valuable aspect of the "randomness" approach is that a lot of data is generated quickly, compared to manual dataset generation, which usually takes a while. Yes, I do agree with you that some samples in the generated data may be useless, and some human "data cleaning" may be needed once datasets are generated, but data cleaning is a normal part of the ML dataset collection process. In order to minimize the chance of generating useless data, we should implement some base-case checking on the backend for the auto-generation dataset tools that we write (for example, if we want to add functionality that randomly moves a camera in some range around a point, we'd want to ignore locations that are below the ground plane since collecting data through a surface is unrealistic). Another thing we can do to minimize useless data generation is provide users with parameters they can set to control how much variety/randomness they want in the data that's generated (for example, maybe users want to specify the range of angles/distances the camera should cover, or maybe they want to set a flag that skips scenes that have no labelled objects in them). |
One other thing to keep in mind is that feature freeze for the Fortress release is about 1 month away (2021/09/07). So, if any of the dataset generation tools break API/ABI, we should probably work on those first so that the tools can be released with the accompanying sensors in Fortress. |
I mean changing the camera sensor position not the objects position, i don't think that we need to change the position of the objects, there is no rules to change that and guarantee that we will produce a realistic scene ... this idea is valid when we have simple unrelated objects in the scene .. but if i have a street, cars and buildings and I change the position of the objects randomly, that will produce a very unrealistic scenes |
Ok, I will use the ign-gazebo APIs, but i mean that I need to use the ign-rendering APIs to create the camera and add it to the scene, and render the scene after putting the camera in the required position, and take its output image to save it So i don't know how to use that from the ign-gazebo::GUI_System |
I took a look at Google Research fuel models and the light spawn plugin, it seems that this is a data augmentation approach, and i still don't know how to do that, for example how to change the texture and guarantee a realistic data??, And i believe there is no need to change anything of the scene, users do data augmentation through image processing, they can do these things by image processing and computer vision frameworks, only if they want, data augmentation may not be good in all cases.
Users still need to perform data cleaning manually in this case, by deleting the bad data individually .. but if we produce a regular image with the correct format/size, but with bad data (unrealistic scene due to wired positions or textures), so people can not write code to remove that. |
I'm actually fairly confident that you will not need to use For example, looking at the light spawning plugin, if a user selected a In response/follow-up to your other comments/questions: how about we just focus on providing users with a way to manually create/spawn bounding box/segmentation sensors for now? This would be a part of the first suggestion you proposed. I'd imagine that you can create a GUI menu that has options to select either "bounding box" or "segmentation" sensor, and then something like a drop-down menu with parameters for the sensor(s) chosen (bounding box type, segmentation type, whether to save images or not, location to save data, etc...). |
Ok, so the approach that i will do is making a GUI system that just like the Lights plugin https://github.com/ignitionrobotics/ign-gazebo/blob/9fd8618436e49691fd0cbdaf5bf054ee9384b857/src/gui/plugins/lights/Lights.cc#L109-L132 then in the is there any problem with that approach ? or anyone have another idea ? |
Also i 've a question ... i want to get the pose of the main camera of the Scene3D plugin ... the main camera which is controlled by the mouse (I want to make the segmentation/bounding box cameras to have the same position as the main camera to collect the samples easily by controlling the camera by the mouse (moving the scene by dragging the mouse or zooming by the mouse wheel) so that the user has an easy way to change the position of the cameras how to get it ?? is it published on a certain topic or a certain event ?? |
I haven't followed the entire conversation, but I'll leave some pointers here that may hopefully help:
Before writing any code for the GUI plugin, I'd recommend creating a few sketches showing how the user is expected to interact with it. What buttons does it have? What goes where? What sequence of clicks is necessary to create a dataset?
Depending on the datasets being created, this can be more convenient to use than a GUI plugin. For example, a user can choose a set of 1000s of objects that they want to generate data for, run that headless on the cloud and upload the resulting data to some cloud storage. This would make use of a server-side scene, rather than the GUI scene. (The distinction between server-side and client-side rendering plugins is described in the Rendering plugins tutorial. That's why I think it's important to come up with a user story before deciding what approach to take. Is it better for the user to manually click through a GUI plugin to setup a scene, or is it better to run a script that runs everything automated with just some simple inputs, like the model URLs?
I'm assuming that for dataset generation, physics doesn't need to be running, right? If it needs to be running, I think using I think it could be helpful for you peeps to come up with a list of requirements and use cases for the tool. You could start by:
|
@chapulina
I think user should setup all the scenes he want to collect the samples from, not just getting the models URLs, as for the problem of object detection or segmentation, we need to collect a samples which contains many objects in the same image, so that the deep learning model can learn the spatial information .. so we cannot collect the samples via only the models URLs which will make us provide samples with only 1 object in the image (if that what you mean)
mmmm, if that is the case, what can i do to make the APIs ? without making an |
I think that what @chapulina meant is that you could specify all of the models you want to use for a scene in a script via their fuel URL. Then, when the script is executed, it creates a scene by fetching/downloading the resources provided in the URLs and then placing these resources in the scene as specified in the script. This would be quicker than manually placing objects and/or moving them. |
Yup, here's an example script pseudo-code:
The random worlds could be generated using ERB templates for example. You can customize the templates as needed, with model URLs, random poses, etc. I imagine the worlds would come with the sensors already in them, and they can be moved by some server plugin every few iterations as needed. I'd expect the sensor images to be automatically saved to a set location on disk, doing something like this ign-sensors example. ☝️ That's just one idea |
related to #135 & #134
Desired behavior
Add a ML tool to generate datasets to be used in the training of the deep learning models for computer vision applications.
This will be done by using the Segmentation & Bounding box cameras and the goal is provide an easy way to collect samples data of these sensors to generate the dataset.
Alternatives considered
N/A (this is a new feature).
Implementation suggestion
The first suggestion is to provide a GUI System in ign-gazebo that users use to collect the samples of the dataset.
The GUI will have:
...................
The second suggestion is to provide and APIs that generates samples data from the scene without the control of the user, by putting the required sensor in many random positions and take a screenshot samples
These randomness could be controlled by the user, for example by specifying a center and radius, and the tool will put the sensors in positions in the circle that is defined by that center and radius (I don't have much ideas about how to control that randomness)
I think that this approach may provide bad samples data, because it will show useless samples in some cases, and may collect the samples from a wrong view
What is your opinion about these suggestions ?
Additional context
The text was updated successfully, but these errors were encountered: