Assembly Bubble Up
Assembly Bubble Up
Hi,
Please can someone enlighten me on any ways to manage this issue:
Say I have a Root assembly with 2 sub assemblies, each with 2 detail parts inside. If open up 'Sub assembly 1' on it's own and create a sketch in a detail part, then save the sub assembly and close it, on opening the Root it will require a rebuild and a save. To me this means the Root is constantly going to be out of date when working in an environment with many users. Coming from CATIA I am not familiar with this exact behaviour, please share your experience of how best to manage this issue.
Many thanks
Please can someone enlighten me on any ways to manage this issue:
Say I have a Root assembly with 2 sub assemblies, each with 2 detail parts inside. If open up 'Sub assembly 1' on it's own and create a sketch in a detail part, then save the sub assembly and close it, on opening the Root it will require a rebuild and a save. To me this means the Root is constantly going to be out of date when working in an environment with many users. Coming from CATIA I am not familiar with this exact behaviour, please share your experience of how best to manage this issue.
Many thanks
Re: Assembly Bubble Up
How you can "manage" the issue depends on what failure modes occur in your workflow due to said issue.
The assembly is defined as being made up of individual parts and/or subassemblies. When those parts or subassemblies change, the main assembly is changed. Therefore the main assembly must be rebuilt (i.e. examine all of its parts and see what changed).
Since I've never used CATIA myself, I'd be curious to understand how CATIA can build up assemblies of parts and not have this same issue.
The assembly is defined as being made up of individual parts and/or subassemblies. When those parts or subassemblies change, the main assembly is changed. Therefore the main assembly must be rebuilt (i.e. examine all of its parts and see what changed).
Since I've never used CATIA myself, I'd be curious to understand how CATIA can build up assemblies of parts and not have this same issue.
Re: Assembly Bubble Up
Yeah, that's the way it works in SW. If you want to make sure you have the most up to date version, everybody has to save and then reload (File>Reload is available in parts and assemblies, but not for drawings, for drawings you have to exit and reopen).
If you are using PDM, then there should be an option to reload with latest versions of parts, but that requires that the changes have been checked in. You should get a notice that your assembly is out of date.
There is also the "multi-user environment" option to check if your read-only files are out of date.
If you are using PDM, then there should be an option to reload with latest versions of parts, but that requires that the changes have been checked in. You should get a notice that your assembly is out of date.
There is also the "multi-user environment" option to check if your read-only files are out of date.
Blog: http://dezignstuff.com
- Frederick_Law
- Posts: 1948
- Joined: Mon Mar 08, 2021 1:09 pm
- Location: Toronto
- x 1638
- x 1471
Re: Assembly Bubble Up
You changed the part, SW tell you the part is changed.
What's your issue?
Maybe use PDM and don't check in the part until its "ready".
What's your issue?
Maybe use PDM and don't check in the part until its "ready".
Re: Assembly Bubble Up
Hi Frederick,
Thank you for your frank and to the point response. I know I have changed a part. My issue is that I don't see why changing a detail part in a sub assembly invokes a rebuild and save on the root assembly way up the tree. To me this behaviour is unintuitive but I just have to accept this is how SW works.
Thank you others for your responses too. At least this confirms to me this behaviour is unavoidable. As for using PDM.....I'll pass, we have proper PLM
Thank you for your frank and to the point response. I know I have changed a part. My issue is that I don't see why changing a detail part in a sub assembly invokes a rebuild and save on the root assembly way up the tree. To me this behaviour is unintuitive but I just have to accept this is how SW works.
Thank you others for your responses too. At least this confirms to me this behaviour is unavoidable. As for using PDM.....I'll pass, we have proper PLM
Re: Assembly Bubble Up
As I mentioned before, the assembly is made up of parts. If you change a part, the assembly must reflect that change. Rebuild involves examining all the parts and making sure the geometry etc. in the assembly window accurately reflects all the parts.
Again, having never worked in CATIA myself, can someone please explain how you can change a part in CATIA without changing components that contain it? Does CATIA not have assemblies? I cannot fathom how you could build an assembly, then change one of its parts without actually changing the assembly.
Again, having never worked in CATIA myself, can someone please explain how you can change a part in CATIA without changing components that contain it? Does CATIA not have assemblies? I cannot fathom how you could build an assembly, then change one of its parts without actually changing the assembly.
Re: Assembly Bubble Up
I may have missed a subtlety of the question.... Were you asking why the root (top level) assembly has to rebuild instead of only rebuilding the subassembly? Changing the part by itself does not directly trigger the top level assembly rebuild. Changing the part triggers a rebuild (and change) to the subassembly it contains. This change to the subassembly is what triggers the rebuild of the top level assembly. So it's exactly as your subject line states: the changes "bubble up" through the tree.
Re: Assembly Bubble Up
Hi Josh,
Yes, indeed. I don't see why the root cares that a change has been made to a feature on a detail part. Just seems to me too much rebuilding and saving has to be done at the highest level.
To answer your question about CATIA, the bubble up is far less sensitive. My original example was a root assembly with sub assemblies. In CATIA you can open a sub assembly without the root, change some detail part features within it and there will be no save required on the sub assembly and there would be no bubble up to the root assembly. The assemblies are just containers for parts. Why would they care if a detail part has changed? They would only care if a detail part has, for example, moved in the context of that sub assembly.
Likewise, If i did something like move the position of the sub assembly, then the root would require a save but simply changing a detail part would not cause a modification of the assembly. Hope that clears it up for you.
Yes, indeed. I don't see why the root cares that a change has been made to a feature on a detail part. Just seems to me too much rebuilding and saving has to be done at the highest level.
To answer your question about CATIA, the bubble up is far less sensitive. My original example was a root assembly with sub assemblies. In CATIA you can open a sub assembly without the root, change some detail part features within it and there will be no save required on the sub assembly and there would be no bubble up to the root assembly. The assemblies are just containers for parts. Why would they care if a detail part has changed? They would only care if a detail part has, for example, moved in the context of that sub assembly.
Likewise, If i did something like move the position of the sub assembly, then the root would require a save but simply changing a detail part would not cause a modification of the assembly. Hope that clears it up for you.
Re: Assembly Bubble Up
So, does CATIA not have mates or any sort of relationships between parts in assemblies?
For example, let's say I model an automotive starter. It's a subassembly. One of its parts is a housing with mounting holes. I put this starter subassembly in the engine assembly, mating the mounting holes on the housing to holes on a bracket in the top-level engine assembly. This defines the position of the starter in the engine assembly.
Now I close everything, open up the housing part, and I move or delete the mounting holes. With CATIA, what happens when you open the top-level assembly?
For example, let's say I model an automotive starter. It's a subassembly. One of its parts is a housing with mounting holes. I put this starter subassembly in the engine assembly, mating the mounting holes on the housing to holes on a bracket in the top-level engine assembly. This defines the position of the starter in the engine assembly.
Now I close everything, open up the housing part, and I move or delete the mounting holes. With CATIA, what happens when you open the top-level assembly?
- jcapriotti
- Posts: 1869
- Joined: Wed Mar 10, 2021 6:39 pm
- Location: The south
- x 1214
- x 1999
Re: Assembly Bubble Up
If you change a part, for example, update a hole diameter or location. That affects the assemblies that call for it. Mates may need to re-evaluate, which could change positions of the other parts in the sub-assembly. Also the stored 3d body data that eDrawings uses to view models needs to update.John wrote: ↑Fri May 21, 2021 11:30 am Hi Josh,
Yes, indeed. I don't see why the root cares that a change has been made to a feature on a detail part. Just seems to me too much rebuilding and saving has to be done at the highest level.
To answer your question about CATIA, the bubble up is far less sensitive. My original example was a root assembly with sub assemblies. In CATIA you can open a sub assembly without the root, change some detail part features within it and there will be no save required on the sub assembly and there would be no bubble up to the root assembly. The assemblies are just containers for parts. Why would they care if a detail part has changed? They would only care if a detail part has, for example, moved in the context of that sub assembly.
Likewise, If i did something like move the position of the sub assembly, then the root would require a save but simply changing a detail part would not cause a modification of the assembly. Hope that clears it up for you.
There could be cases where SolidWorks could do a better job of recognizing when a change occurs that affects the geometry of the part. A force rebuild will flag the file as dirty regardless if anything actually changed, a regular rebuild will not. I think they just play it safe and flag it most times. Then there is the older version of files. Any file opened that was last saved in an older version of SolidWorks will flag to be saved.
Jason
Re: Assembly Bubble Up
Hi Josh,
Your scenario is somewhat different. Mates are at the assembly level and by deleting the hole you have affected the condition of the mate. I agree this changes the modification of the assembly. CATIA would do the same.
Let me turn that situation around though. Let's say you followed your steps but positioned the part without mates and saved everything. Why would the assembly then care if you deleted the holes in the detail part? You have not changed any property of the assembly....
Your scenario is somewhat different. Mates are at the assembly level and by deleting the hole you have affected the condition of the mate. I agree this changes the modification of the assembly. CATIA would do the same.
Let me turn that situation around though. Let's say you followed your steps but positioned the part without mates and saved everything. Why would the assembly then care if you deleted the holes in the detail part? You have not changed any property of the assembly....
- Glenn Schroeder
- Posts: 1522
- Joined: Mon Mar 08, 2021 11:43 am
- Location: southeast Texas
- x 1759
- x 2132
Re: Assembly Bubble Up
The Assembly would care because you changed the Part, which is a portion of the Assembly.John wrote: ↑Fri May 21, 2021 12:48 pm Hi Josh,
Your scenario is somewhat different. Mates are at the assembly level and by deleting the hole you have affected the condition of the mate. I agree this changes the modification of the assembly. CATIA would do the same.
Let me turn that situation around though. Let's say you followed your steps but positioned the part without mates and saved everything. Why would the assembly then care if you deleted the holes in the detail part? You have not changed any property of the assembly....
You have changed a property of the Assembly. The Part is a property of the Assembly.
"On the days when I keep my gratitude higher than my expectations, well, I have really good days."
Ray Wylie Hubbard in his song "Mother Blues"
Ray Wylie Hubbard in his song "Mother Blues"
Re: Assembly Bubble Up
In Solidworks this seems to be the case. To my mind this brings no advantage, only additional challenges and forever saving things that haven't fundamentally changed, all the way up to the root....Really I was asking as a way to know if this behaviour can be changed. I think I have my answer... Many thanks to all
Re: Assembly Bubble Up
I think SW tends to be a bit more "Brute Force" than elegant. Rather than recognizing that a part has changed and then checking to see whether that part change effects some item, other than that part, in the assembly it just says "Part changed, Rebuild". Simplistic and probably "Easier" but also a pain when things like changing a 1/4-20 to a 5/16-18 that has nothing to do with anything in the assembly ends up causing a rebuild.John wrote: ↑Fri May 21, 2021 1:44 pm In Solidworks this seems to be the case. To my mind this brings no advantage, only additional challenges and forever saving things that haven't fundamentally changed, all the way up to the root....Really I was asking as a way to know if this behaviour can be changed. I think I have my answer... Many thanks to all
In essence the models are constantly rebuilding which is yet another resource hog that ends up bogging down the entire system.
Re: Assembly Bubble Up
You've changed the weight of the assembly. It might not matter on a large structure, but on a tiny device meant for space flight it might. SW has no way of knowing what constitutes a meaningful change.
I can think of very few changes to a part that would not have some concrete affect on the assembly.
Re: Assembly Bubble Up
From what you have been saying, functionally there is zero difference between how CATIA handles these things vs SolidWorks, other than that SW may rebuild and save slightly more often. SW does save some details of parts and subassemblies in the main assembly to improve performance so that it doesn't have to read all details directly from the source files every time. Whenever a source file changes, the assembly recognizes that this has happened and updates itself. CATIA MUST do the exact same thing. As has been mentioned, CATIA may do a better job of recognizing when changed components do not cause a change in the data that it saves with the top level, but this also makes zero difference to what you mentioned in your first post, which is multiple users simultaneously editing components of the assembly. In either case, CATIA or SW, the assembly becomes out of date as soon as you edit a part, no matter what depth.John wrote: ↑Fri May 21, 2021 1:44 pm In Solidworks this seems to be the case. To my mind this brings no advantage, only additional challenges and forever saving things that haven't fundamentally changed, all the way up to the root....Really I was asking as a way to know if this behaviour can be changed. I think I have my answer... Many thanks to all
Re: Assembly Bubble Up
You can load the latest part into the assembly without rebuilding the assembly. The only time you would need to rebuild the assembly is if something changed on the part that effected function in the assembly. If you wanted weight, CG etc that information would be pulled from the latest part that is now in your assembly.JSculley wrote: ↑Fri May 21, 2021 3:03 pm You've changed the weight of the assembly. It might not matter on a large structure, but on a tiny device meant for space flight it might. SW has no way of knowing what constitutes a meaningful change.
I can think of very few changes to a part that would not have some concrete affect on the assembly.
Re: Assembly Bubble Up
@josh - Nope, I can edit a detail part in a sub assembly, for example change a sketch dimension and this will not invoke a save on anything other than the changed part. I'm not really trying to make a comparison. Just to understand the behaviour of a different program