ifcopenshell.api.cost.unassign_cost_item_quantity
¶
Module Contents¶
- class ifcopenshell.api.cost.unassign_cost_item_quantity.Usecase¶
- execute()¶
- update_cost_item_count()¶
- ifcopenshell.api.cost.unassign_cost_item_quantity.unassign_cost_item_quantity(file: ifcopenshell.file, cost_item: ifcopenshell.entity_instance, products: list[ifcopenshell.entity_instance]) None ¶
Removes quantities of a cost item that are calculated on products
A cost item may have quantities that are parametrically calculated on physical products. This lets you remove those quantities. This means that any future changes in the physical product’s dimensions will not have any impact on the cost item.
- Parameters:
cost_item (ifcopenshell.entity_instance) – The IfcCostItem to remove quantities from
products (list[ifcopenshell.entity_instance]) – A list of IfcProducts that may have parametrically connected quantities to the cost item
- Returns:
None
- Return type:
None
Example:
schedule = ifcopenshell.api.cost.add_cost_schedule(model) item = ifcopenshell.api.cost.add_cost_item(model, cost_schedule=schedule) # Let's imagine a unit cost of 5.0 per unit volume value = ifcopenshell.api.cost.add_cost_value(model, parent=item) ifcopenshell.api.cost.edit_cost_value(model, cost_value=value, attributes={"AppliedValue": 5.0}) slab = ifcopenshell.api.root.create_entity(model, ifc_class="IfcSlab") # Usually the quantity would be automatically calculated via a # graphical authoring application but let's assign a manual quantity # for now. qto = ifcopenshell.api.pset.add_qto(model, product=slab, name="Qto_SlabBaseQuantities") ifcopenshell.api.pset.edit_qto(model, qto=qto, properties={"NetVolume": 42.0}) # Now let's parametrically link the slab's quantity to the cost # item. If the slab is edited in the future and 42.0 changes, then # the updated value will also automatically be applied to the cost # item. ifcopenshell.api.cost.assign_cost_item_quantity(model, cost_item=item, products=[slab], prop_name="NetVolume") # Let's change our mind and remove the parametric connection ifcopenshell.api.cost.unassign_cost_item_quantity(model, cost_item=item, products=[slab])