Importar/exportar IFC - compilar IfcOpenShell

From FreeCAD Documentation
This page is a translated version of the page Import/Export IFC - compiling IfcOpenShell and the translation is 97% complete.
Outdated translations are marked like this.
Tutorial
Tema
Ambiente de trabajo Arquitectura
Nivel
Avanzado
Tiempo para completar
120 minutos
Autores
Pablo Gil
Versión de FreeCAD
0.19.x
Archivos de ejemplos
Ver también
None

Introducción

Fue una investigación tan dura sobre cómo obtener una copia de trabajo de IfcOpenShell-python en OSX/macOS con el fin de importar/exportar archivos IFC que estoy compartiendo este tutorial en caso de que ayude a más personas. Mi sistema es OSX 10.11.6, 64bits con Python 2.7.11, puede que te funcione si también tienes OSX ya que suelen ser de 64bits pero puede diferir del mío. El procedimiento puede ser muy similar si tienes Linux o Windows pero probablemente tenga algunas diferencias.

Requisitos

Pasos

1. Descargue o clone el proyecto completo de GitHub en https://github.com/IfcOpenShell/IfcOpenShell (siempre será la versión más reciente)

git clone https://github.com/IfcOpenShell/IfcOpenShell

2. Desde un terminal ve a la carpeta /nix/ y lanza el script. En OSX se ejecuta con:

cd nix/
./build-all.sh

Tardará desde 30 hasta 120 minutos en compilar todo. No es la forma más inteligente de compilar IfcOpenShell pero este sencillo script compilará todas las dependencias, versiones de Python, etc.

3. Una vez que termine (no recuerdo ahora pero se imprimirá algo como "Built IfcOpenShell..." y volverá a su prompt) tendrás una nueva carpeta /IfcOpenShell/build/ llena de archivos y carpetas. Por mi experiencia personal, hace dos semanas el script "build-all.sh" de nix no terminaba con éxito pero después de probarlo ayer con las últimas actualizaciones funcionó bien así que supongo que podrías experimentar algo similar en caso de que el desarrollo siga adelante... Así que ahora tienes todo lo que necesitas pero tienes que hacer algo de trabajo manual para que funcione:

4. Abre FreeCAD y abre la consola de Python y la vista de informe. Luego escribe en la consola de Python lo siguiente:

{{{1}}}

Obtendrás una línea larguísima con todas las rutas que lee FreeCAD. Puedes instalar IfcOpenShell en cualquiera de ellas, pero te sugiero que lo coloques dentro de una en la que encuentres un /site-packages/ después de un /Python/ o /python-algo/. En mi caso era /Library/Python/2.7/site-packages. (Nota: encontrarás rutas dentro del directorio de tu aplicación pero te sugiero que no las uses porque entonces IfcOpenShell sólo estará disponible para esta aplicación)

5. Una vez localizado donde quieres/tienes que instalarlo, ve allí con tu explorador de archivos (Finder en OSX). Es decir, entra en la carpeta /site-packages/

cd site-packages/

6. Abre una nueva ventana del explorador de archivos y navega hasta tu proyecto GitHub descargado: /IfcOpenShell/src/ifcopenshell-python/ y copia la carpeta completa /ifcopenshell/'.

7. Pégalo dentro de la carpeta /site-packages/. Ahora deberías tener algo como:

{{{1}}}

8. Ahora tenemos que elegir a los archivos dentro de la carpeta /build/, son:

ifcopenshell_wrapper.so
ifcopenshell_wrapper.py

pero como lo hemos compilado todo tendrás que elegir el que coincida con tu versión de FreeCAD Python. Compruébalo fácilmente leyendo la primera línea dentro de tu vista de la Python console/es de FreeCAD. En mi caso fue Python 2.7.11.

9. Ahora vamos a copiar los archivos dentro del lugar que corresponde a tu versión de Python. En mi caso fue:

/IfcOpenShell/build/Darwin/x86_64/build/ifcopenshell/[b]python-2.7[/b].10/ifcwrap/

10. Pégalos dentro de /site-packages/ifcopenshell/

11. Compruebe que todo está en su sitio:

/site-packages/ifcopenshell/__init__.py                  (1)
/site-packages/ifcopenshell/entity_instance.py           (1)
/site-packages/ifcopenshell/_ifcopenshell_wrapper.so     (2)
/site-packages/ifcopenshell/file.py                      (1)
/site-packages/ifcopenshell/geom/__init__.py             (1)
/site-packages/ifcopenshell/geom/app.py                  (1)
/site-packages/ifcopenshell/geom/main.py                 (1)
/site-packages/ifcopenshell/geom/occ_utils.py            (1)
/site-packages/ifcopenshell/guid.py                      (1)
/site-packages/ifcopenshell/ifcopenshell_wrapper.py      (2)

(1) desde el proyecto GitHub
(2) desde la carpeta /build/


12. Cierre y vuelva a abrir FreeCAD

Pruebas

Ahora que está instalado, vamos a comprobar si todo funciona como se espera:

12.1 en la consola de Python escribir:

import ifcopenshell
from ifcopenshell import geom

si no arroja ningún error significa que puede estar correctamente instalado

12.2 Ve al manual de FreeCAD de Yorik, navega a la parte inferior de la página y descarga los siguientes archivos para probar:

house.FCStd
house.ifc

12.3 Abra house.FCStd, seleccione el objeto raíz "Edificio" y expórtelo (Archivo → Exportar) estableciendo el Tipo de archivo como "Industry Foundation Classes (*.ifc)". Pulsa Guardar y si funciona y no lanza un error en la Report view/es entonces está funcionando.

12.4 Prueba final, importar house.ifc en un nuevo archivo, así que abre un nuevo archivo e importa ese archivo... tardará un poco.

13. ¡Disfruta de BIM con FreeCAD!

Reflexiones finales

Mi opinión es que FreeCAD debería tener versiones precompiladas de IfcOpenShell junto con la distribución porque construirlo por ti mismo es un dolor total y el usuario medio no lo hará (no saben cómo compilar, gestionar GitHub, etc), pero bueno, tal vez en el futuro.

Espero que te ayude.

Salud

Enlaces