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

Don't use local placement for determining origin #3

Open
Moult opened this issue Jun 27, 2024 · 0 comments
Open

Don't use local placement for determining origin #3

Moult opened this issue Jun 27, 2024 · 0 comments

Comments

@Moult
Copy link

Moult commented Jun 27, 2024

In these lines of code:

ifcgref/app.py

Lines 573 to 581 in 58822ca

products = ifc_file.by_type('IfcProduct')
for product in products:
if product.Representation:
placement = product.ObjectPlacement
lpMAat = ifcopenshell.util.placement.get_local_placement(placement)
Gx , Gy = lpMAat[0][3],lpMAat[1][3]
xx = xx+Gx
yy = yy+Gy
break

It seems as though you arbitrarily take the first placement of the first product and use this as the model origin. My advice is not to do this. The reason is that there are often models (typically civil models) that will use a placement of 0,0,0 whilst their representation are at map coordinates. Also the first product might be anything, including 2D alignment segments in IFC4X3. Here are the various scenarios you will encounter:

  1. Small local coordinates for placement, small local coordinates for representations. Hooray!
  2. Large map coordinates for placement, small local coordinates for representation. Annoying, but easy to offset.
  3. Small local coordinates for placement, large map coordinates for representations. Yikes!
  4. Large coordinates for placement, large coordinates for representation. (Yes, crazy stuff like -1000000 in the placement, then +3000000 in the representation - I've come across this more than I'd like to admit)

So in general I'd advise using the same approach that we do in the BlenderBIM Add-on when detecting an arbitrary false origin to use: we check the first absolute coordinates of vertex of three meaningful representations prioritised by context. See https://github.com/IfcOpenShell/IfcOpenShell/blob/v0.8.0/src/blenderbim/blenderbim/tool/loader.py#L645-L654 and https://github.com/IfcOpenShell/IfcOpenShell/blob/v0.8.0/src/blenderbim/blenderbim/tool/loader.py#L645-L654

Notice we also use create_generic_shape - this handles context prioritisation. There can be multiple representations and so it's important to prioritise visualised bodies over others. I'm not sure how IFCJS handles this but it's something to consider.

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

No branches or pull requests

1 participant