Concrete materials¶
Concrete factory¶
- structuralcodes.materials.concrete.create_concrete(fck: float, name: str | None = None, density: float = 2400.0, gamma_c: float | None = None, existing: bool = False, design_code: str | None = None, **kwargs) Concrete | None [source]¶
A factory function to create the correct type of concrete based on the desired design code.
- Parameters:
fck (float) – Characteristic strength of concrete in MPa. (if existing it is intended as the mean strength).
- Keyword Arguments:
density (float) – Density of Concrete in kg/m3 (default: 2400).
gamma_c (Optional(float)) – The partial factor for concrete.
existing (bool) – Boolean indicating if the concrete is of an existing structure (default: False).
design_code (str) – Optional string (default: None) indicating the desired standard. If None (default) the globally used design standard will be adopted. Otherwise the design standard specified will be used for the instance of the material.
- Raises:
ValueError – if the design code is not valid or does not cover concrete as a material.
Eurocode 2 (2004)¶
- class structuralcodes.materials.concrete.ConcreteEC2_2004(fck: float, name: str | None = None, density: float = 2400, gamma_c: float | None = None, alpha_cc: float | None = None, constitutive_law: Literal['elastic', 'parabolarectangle', 'bilinearcompression', 'sargin', 'popovics'] | ConstitutiveLaw | None = 'parabolarectangle', fcm: float | None = None, fctm: float | None = None, fctk_5: float | None = None, fctk_95: float | None = None, Ecm: float | None = None, eps_c1: float | None = None, eps_cu1: float | None = None, k_sargin: float | None = None, eps_c2: float | None = None, eps_cu2: float | None = None, n_parabolic_rectangular: float | None = None, eps_c3: float | None = None, eps_cu3: float | None = None, **kwargs)[source]¶
Concrete implementation for EC2 2004.
- __init__(fck: float, name: str | None = None, density: float = 2400, gamma_c: float | None = None, alpha_cc: float | None = None, constitutive_law: Literal['elastic', 'parabolarectangle', 'bilinearcompression', 'sargin', 'popovics'] | ConstitutiveLaw | None = 'parabolarectangle', fcm: float | None = None, fctm: float | None = None, fctk_5: float | None = None, fctk_95: float | None = None, Ecm: float | None = None, eps_c1: float | None = None, eps_cu1: float | None = None, k_sargin: float | None = None, eps_c2: float | None = None, eps_cu2: float | None = None, n_parabolic_rectangular: float | None = None, eps_c3: float | None = None, eps_cu3: float | None = None, **kwargs) None [source]¶
Initializes a new instance of Concrete for EC2 2004.
- Parameters:
fck (float) – Characteristic strength in MPa if concrete is not existing.
- Keyword Arguments:
name (str) – A descriptive name for concrete.
density (float) – Density of material in kg/m3 (default: 2400).
gamma_c (float, optional) – partial factor of concrete (default is 1.5).
alpha_cc (float, optional) – A factor for considering long-term effects on the strength, and effects that arise from the way the load is applied.
consitutive_law (ConstitutiveLaw | str) – A valid ConstitutiveLaw object for concrete or a string defining a valid constitutive law type for concrete. (valid options for string: ‘elastic’, ‘parabolarectangle’, ‘bilinearcompression’, ‘sargin’, ‘popovics’).
fcm (float, optional) – The mean compressive strength.
fctm (float, optional) – The mean tensile strength.
fctk_5 (float, optional) – The 5% fractile for the tensile strength.
fctk_95 (float, optional) – The 95% fractile for the tensile strength.
Ecm (float, optional) – The mean secant Young’s modulus.
eps_c1 (float, optional) – The strain at peak stress for the Sargin constitutive law.
eps_cu1 (float, optional) – The ultimate strain for the Sargin constitutive law.
k_sargin (float, optional) – The coefficient for the Sargin constitutive law.
eps_c2 (float, optional) – The strain at peak stress for the parabolic rectangular constitutive law.
eps_cu2 (float, optional) – The ultimate strain for the parabolic rectangular constitutive law.
n_parabolic_rectangular (float, optional) – The coefficient for the parabolic rectangular constitutive law.
eps_c3 (float, optional) – The strain at peak stress for the bilinear constitutive law.
eps_cu3 (float, optional) – The ultimate strain for the bilinear constitutive law.
- Raises:
ValueError – If fcm is lower than fck.
ValueError – If k_sargin is negative.
ValueError – If n_parabolic_rectangular is negative.
ValueError – If the constitutive law name is not available for the material.
ValueError – If the provided constitutive law is not valid for concrete.
ValueError – If the constitutive law name is unknown.
Warning – If fctm is larger than 0.5 * fck.
Warning – If eps_c1 is larger than 0.1.
Warning – If eps_cu1 is larger than 0.1.
Warning – If eps_c2 is larger than 0.1.
Warning – If eps_cu2 is larger than 0.1.
Warning – If n_parabolic_rectangular is larger than 5.
Warning – If eps_c3 is larger than 0.1.
Warning – If eps_cu3 is larger than 0.1.
- fcd() float [source]¶
Return the design compressive strength in MPa.
- Returns:
The design compressive strength of concrete in MPa.
- Return type:
float
- property fck: float¶
Returns fck in MPa.
- property fcm: float¶
Returns fcm in MPa.
- Returns:
The mean compressive strength in MPa.
- Return type:
float
Note
The returned value is derived from fck if fcm is not manually provided when initializing the object.
- property fctm: float¶
Returns fctm in MPa.
- Returns:
The mean tensile strength in MPa.
- Return type:
float
Note
The returned value is derived from fck if fctm is not manually provided when initializing the object.
- property fctk_5: float¶
Returns fctk_5 in MPa.
- Returns:
The lower bound tensile strength in MPa.
- Return type:
float
Note
The returned value is derived from fctm if fctk_5 is not manually provided when initializing the object.
- property fctk_95: float¶
Returns fctk_95 in MPa.
- Returns:
The upper bound tensile strength in MPa.
- Return type:
float
Note
The returned value is derived from fctm if fctk_95 is not manually provided when initializing the object.
- property Ecm: float¶
Returns Ecm in MPa.
- Returns:
The upper bound tensile strength in MPa.
- Return type:
float
Note
The returned value is derived from fcm if Ecm is not manually provided when initializing the object.
- property gamma_c: float¶
The partial factor for concrete.
- property alpha_cc: float¶
The alpha_cc factor.
- property eps_c1: float¶
Returns the strain at maximum compressive strength of concrete (fcm) for the Sargin constitutive law.
- Returns:
The strain at maximum compressive strength of concrete.
- Return type:
float
Note
The returned value is derived from fcm if eps_c1 is not manually provided when initializing the object.
- property eps_cu1: float¶
Returns the strain at concrete failure of concrete.
- Returns:
The maximum strength at failure of concrete.
- Return type:
float
Note
The returned value is derived from fcm if eps_cu1 is not manually provided when initializing the object.
- property k_sargin: float¶
Returns the coefficient for Sargin constitutive law.
- Returns:
The plastic coefficient for Sargin law.
- Return type:
float
Note
The returned value is derived from Ecm, fcm and eps_c1 if k_sargin is not manually provided when initializing the object.
- property eps_c2: float¶
Returns the strain at maximum compressive strength of concrete (fcd) for the Parabola-rectangle constitutive law.
- Returns:
The strain at maximum compressive strength of concrete.
- Return type:
float
Note
The returned value is derived from fck if eps_c2 is not manually provided when initializing the object.
- property eps_cu2: float¶
Returns the strain at concrete failure of concrete for the Parabola-rectangle constitutive law.
- Returns:
The maximum strain at failure of concrete.
- Return type:
float
Note
The returned value is derived from fck if eps_cu2 is not manually provided when initializing the object.
- property n_parabolic_rectangular: float¶
Returns the coefficient for Parabola-rectangle constitutive law.
- Returns:
The exponent for Parabola-rectangle law.
- Return type:
float
Note
The returned value is derived from fck if n_parabolic_rectangular is not manually provided when initializing the object.
- property eps_c3: float¶
Returns the strain at maximum compressive strength of concrete (fcd) for the Bi-linear constitutive law.
- Returns:
The strain at maximum compressive strength of concrete.
- Return type:
float
Note
The returned value is derived from eps_c3 if fck is not manually provided when initializing the object.
- property eps_cu3: float¶
Returns the strain at concrete failure of concrete for the Bi-linear constitutive law.
- Returns:
The maximum strain at failure of concrete.
- Return type:
float
Note
The returned value is derived from fck if eps_cu3 is not manually provided when initializing the object.
- property constitutive_law¶
Returns the ConstitutiveLaw of the object.
- property name¶
Returns the name of the material.
- property density¶
Returns the density of the material in kg/m3.
fib Model Code 2010¶
- class structuralcodes.materials.concrete.ConcreteMC2010(fck: float, name: str | None = None, density: float = 2400.0, gamma_c: float | None = None, alpha_cc: float | None = None, constitutive_law: Literal['elastic', 'parabolarectangle', 'bilinearcompression', 'sargin', 'popovics'] | ConstitutiveLaw | None = 'parabolarectangle', fcm: float | None = None, fctm: float | None = None, fctkmin: float | None = None, fctkmax: float | None = None, Eci: float | None = None, Gf: float | None = None, eps_c1: float | None = None, eps_cu1: float | None = None, k_sargin: float | None = None, eps_c2: float | None = None, eps_cu2: float | None = None, n_parabolic_rectangular: float | None = None, eps_c3: float | None = None, eps_cu3: float | None = None, **kwargs)[source]¶
Concrete implementation for MC 2010.
- __init__(fck: float, name: str | None = None, density: float = 2400.0, gamma_c: float | None = None, alpha_cc: float | None = None, constitutive_law: Literal['elastic', 'parabolarectangle', 'bilinearcompression', 'sargin', 'popovics'] | ConstitutiveLaw | None = 'parabolarectangle', fcm: float | None = None, fctm: float | None = None, fctkmin: float | None = None, fctkmax: float | None = None, Eci: float | None = None, Gf: float | None = None, eps_c1: float | None = None, eps_cu1: float | None = None, k_sargin: float | None = None, eps_c2: float | None = None, eps_cu2: float | None = None, n_parabolic_rectangular: float | None = None, eps_c3: float | None = None, eps_cu3: float | None = None, **kwargs)[source]¶
Initializes a new instance of Concrete for MC 2010.
- Parameters:
fck (float) – Characteristic strength in MPa if concrete is not existing.
- Keyword Arguments:
name (Optional(str)) – A descriptive name for concrete.
density (float) – Density of material in kg/m3 (default: 2400).
gamma_c (Optional(float)) – The partial factor for concrete.
alpha_cc (float, optional) – A factor for considering long-term effects on the strength, and effects that arise from the way the load is applied.
fcm (float, optional) – The mean compressive strength.
fctm (float, optional) – The mean tensile strength.
fctkmin (float, optional) – The minimum tensile strength.
fctkmax (float, optional) – The maximum tensile strength.
Eci (float, optional) – The initial tangent Young’s modulus.
Gf (float, optional) – The tensile fracture energy.
eps_c1 (float, optional) – The strain at peak stress for the Sargin constitutive law.
eps_cu1 (float, optional) – The ultimate strain for the Sargin constitutive law.
k_sargin (float, optional) – The coefficient for the Sargin constitutive law.
eps_c2 (float, optional) – The strain at peak stress for the parabolic rectangular constitutive law.
eps_cu2 (float, optional) – The ultimate strain for the parabolic rectangular constitutive law.
n_parabolic_rectangular (float, optional) – The coefficient for the parabolic rectangular constitutive law.
eps_c3 (float, optional) – The strain at peak stress for the bilinear constitutive law.
eps_cu3 (float, optional) – The ultimate strain for the bilinear constitutive law.
- Raises:
ValueError – If fcm is lower than fck.
ValueError – If k_sargin is negative.
ValueError – If n_parabolic_rectangular is negative.
ValueError – If the constitutive law name is not available for the material.
ValueError – If the provided constitutive law is not valid for concrete.
Warning – If Eci is lower than 1e4 or larger than 1e5.
Warning – If fctm is larger than 0.5 * fck.
Warning – If eps_c1 is larger than 0.1.
Warning – If eps_cu1 is larger than 0.1.
Warning – If eps_c2 is larger than 0.1.
Warning – If eps_cu2 is larger than 0.1.
Warning – If n_parabolic_rectangular is larger than 5.
Warning – If eps_c3 is larger than 0.1.
Warning – If eps_cu3 is larger than 0.1.
- fcd() float [source]¶
Return the design compressive strength in MPa.
- Returns:
The design compressive strength of concrete in MPa.
- Return type:
float
- property fck: float¶
Returns fck in MPa.
- property fcm: float¶
Returns fcm in MPa.
- Returns:
The mean compressive strength in MPa.
- Return type:
float
Note
The returned value is derived from fck if fcm is not manually provided when initializing the object.
- property Eci: float¶
Returns the modulus of elasticity in MPa at the concrete age of 28 days.
It is assumed a normal concrete with quartzite aggregates (alfa_e = 1)
- Returns:
The modulus of elasticity in MPa.
- Return type:
float
Note
The returned value is derived from fcm if Eci is not manually provided when initializing the object.
- property fctm: float¶
Returns fctm in MPa.
- Returns:
The mean tensile strength in MPa.
- Return type:
float
Note
The returned value is derived from fck if fctm is not manually provided when initializing the object.
- property fctkmin: float¶
Returns fctkmin in MPa.
- Returns:
The lower bound tensile strength in MPa.
- Return type:
float
Note
The returned value is derived from fctm if fctkmin is not manually provided when initializing the object.
- property fctkmax: float¶
Returns fctkmax in MPa.
- Returns:
The upper bound tensile strength in MPa.
- Return type:
float
Note
The returned value is derived from fctm if fctkmax is not manually provided when initializing the object.
- property Gf: float¶
Fracture energy of concrete.
- Returns:
The fracture energy in N/m.
- Return type:
float
Note
The returned value is derived from fck if Gf is not manually provided when initializing the object.
- property gamma_c: float¶
The partial factor for concrete.
- property alpha_cc: float¶
The alpha_cc factor.
- property eps_c1: float¶
Returns the strain at maximum compressive strength of concrete (fcm) for the Sargin constitutive law.
- Returns:
The strain at maximum compressive strength of concrete.
- Return type:
float
Note
The returned value is derived from fck if eps_c1 is not manually provided when initializing the object.
- property eps_cu1: float¶
Returns the strain at concrete failure of concrete.
- Returns:
The maximum strength at failure of concrete.
- Return type:
float
Note
The returned value is derived from fck if eps_cu1 is not manually provided when initializing the object.
- property k_sargin: float¶
Returns the coefficient for Sargin constitutive law.
- Returns:
The plastic coefficient for Sargin law.
- Return type:
float
Note
The returned value is derived from fck if k_sargin is not manually provided when initializing the object.
- property eps_c2: float¶
Returns the strain at maximum compressive strength of concrete (fcd) for the Parabola-rectangle constitutive law.
- Returns:
The strain at maximum compressive strength of concrete.
- Return type:
float
Note
The returned value is derived from fck if eps_c2 is not manually provided when initializing the object.
- property eps_cu2: float¶
Returns the strain at concrete failure of concrete for the Parabola-rectangle constitutive law.
- Returns:
The maximum strain at failure of concrete.
- Return type:
float
Note
The returned value is derived from fck if eps_cu2 is not manually provided when initializing the object.
- property n_parabolic_rectangular: float¶
Returns the coefficient for Parabola-rectangle constitutive law.
- Returns:
The exponent for Parabola-recangle law.
- Return type:
float
Note
The returned value is derived from fck if n is not manually provided when initializing the object.
- property eps_c3: float¶
Returns the strain at maximum compressive strength of concrete (fcd) for the Bi-linear constitutive law.
- Returns:
The strain at maximum compressive strength of concrete.
- Return type:
float
Note
The returned value is derived from fck if eps_c3 is not manually provided when initializing the object.
- property eps_cu3: float¶
Returns the strain at concrete failure of concrete for the Bi-linear constitutive law.
- Returns:
The maximum strain at failure of concrete.
- Return type:
float
Note
The returned value is derived from fck if eps_cu3 is not manually provided when initializing the object.
- property constitutive_law¶
Returns the ConstitutiveLaw of the object.
- property name¶
Returns the name of the material.
- property density¶
Returns the density of the material in kg/m3.
Eurocode 2 (2023)¶
- class structuralcodes.materials.concrete.ConcreteEC2_2023(fck: float, name: str | None = None, density: float = 2400.0, kE: float = 9500, strength_dev_class: Literal['CS', 'CN', 'CR', 'slow', 'normal', 'rapid'] = 'CN', gamma_c: float | None = None, constitutive_law: Literal['elastic', 'parabolarectangle', 'bilinearcompression', 'sargin', 'popovics'] | ConstitutiveLaw | None = 'parabolarectangle', fcm: float | None = None, fctm: float | None = None, fctk_5: float | None = None, fctk_95: float | None = None, Ecm: float | None = None, eps_c1: float | None = None, eps_cu1: float | None = None, k_sargin: float | None = None, eps_c2: float | None = None, eps_cu2: float | None = None, n_parabolic_rectangular: float | None = None, **kwargs)[source]¶
Concrete implementation for EC2 2023 Concrete.
- __init__(fck: float, name: str | None = None, density: float = 2400.0, kE: float = 9500, strength_dev_class: Literal['CS', 'CN', 'CR', 'slow', 'normal', 'rapid'] = 'CN', gamma_c: float | None = None, constitutive_law: Literal['elastic', 'parabolarectangle', 'bilinearcompression', 'sargin', 'popovics'] | ConstitutiveLaw | None = 'parabolarectangle', fcm: float | None = None, fctm: float | None = None, fctk_5: float | None = None, fctk_95: float | None = None, Ecm: float | None = None, eps_c1: float | None = None, eps_cu1: float | None = None, k_sargin: float | None = None, eps_c2: float | None = None, eps_cu2: float | None = None, n_parabolic_rectangular: float | None = None, **kwargs)[source]¶
Initializes a new instance of Concrete for EC2 2023.
- Parameters:
fck (float) – Characteristic strength in MPa if concrete is not existing.
- Keyword Arguments:
name (str) – A descriptive name for concrete.
density (float) – Density of material in kg/m3 (default: 2400).
kE (float) – Coefficient relating aggregates.
strength_dev_class (str, optional) – Default is CN. Possible values: CS, CN, CR, slow, normal or rapid.
gamma_c (float, optional) – Partial factor of concrete (default is 1.5).
consitutive_law (ConstitutiveLaw | str) – A valid ConstitutiveLaw object for concrete or a string defining a valid constitutive law type for concrete. (valid options for string: ‘elastic’, ‘parabolarectangle’, ‘bilinearcompression’, ‘sargin’, ‘popovics’).
fcm (float, optional) – The mean compressive strength.
fctm (float, optional) – The mean tensile strength.
fctk_5 (float, optional) – The 5% fractile for the tensile strength.
fctk_95 (float, optional) – The 95% fractile for the tensile strength.
Ecm (float, optional) – The mean secant Young’s modulus.
eps_c1 (float, optional) – The strain at peak stress for the Sargin constitutive law.
eps_cu1 (float, optional) – The ultimate strain for the Sargin constitutive law.
k_sargin (float, optional) – The coefficient for the Sargin constitutive law.
eps_c2 (float, optional) – The strain at peak stress for the parabolic rectangular constitutive law.
eps_cu2 (float, optional) – The ultimate strain for the parabolic rectangular constitutive law.
n_parabolic_rectangular (float, optional) – The coefficient for the parabolic rectangular constitutive law.
- Raises:
ValueError – If the provided strength development class is invalid.
ValueError – If gamma_c is less than zero.
ValueError – If fcm is less than fck.
ValueError – If k_sargin is negative.
ValueError – If n_parabolic_rectangular is negative.
ValueError – If the constitutive law name is not available for the material.
ValueError – If the provided constitutive law is not valid for concrete.
Warning – If eps_c1 is larger than 0.1.
Warning – If eps_cu1 is larger than 0.1.
Warning – If eps_c2 is larger than 0.1.
Warning – If eps_cu2 is larger than 0.1.
- fcd(t_ref: float = 28, t0: float = 91, fck_ref: float = 40) float [source]¶
Computes the value of the design compressive strength of concrete.
- Parameters:
t_ref (float,optional) – The reference time in days (default is 28 days).
t0 (float, optional) – Age at loading in days (default is 91 days).
fck_ref (float, optional) – The reference compressive strength in MPa (default is 40 MPa).
- Returns:
The design compressive strength of concrete in MPa.
- Return type:
float
- Raises:
ValueError – If fck_ref is less or equal to 0.
ValueError – If t_ref is less than 0.
ValueError – If t0 is less than 0.
- fctd(t_ref: float = 28) float [source]¶
Computes the value of the design tensile strength of concrete.
- Parameters:
t_ref (float, optional) – The reference time in days (default is 28 days).
- Returns:
The design tensile strength of concrete in MPa.
- Return type:
float
- Raises:
ValueError – If t_ref is less than 0.
- property fck: float¶
Returns fck in MPa.
- property fcm: float¶
Returns the mean strength of concrete.
- Returns:
The mean compressive strength in MPa.
- Return type:
float
Note
The returned value is derived from fck if fcm is not manually provided when initializing the object.
- property fctm: None¶
Returns the mean concrete tensile strength.
- Returns:
The mean concrete tensile strength.
- Return type:
float
Note
The returned value is derived from fck if fctm is not manually provided when initializing the object.
- property fctk_5: float¶
Returns the 5% fractile for the concrete tensile strength.
- Returns:
The 5% fractile for the concrete tensile strength in MPa.
- Return type:
float
Note
The returned value is derived from fctm if fctk_5 is not manually provided when initializing the object.
- property fctk_95: float¶
Returns the 95% fractile for the concrete tensile strength.
- Returns:
The 5% fractile for the concrete tensile strength in MPa.
- Return type:
float
Note
The returned value is derived from fctm if fctk_95 is not manually provided when initializing the object.
- property Ecm: float¶
Returns the secant modulus.
- Returns:
The secant concrete modulus in MPa.
- Return type:
float
Note
The returned value is derived from fcm and kE if Ecm is not manually provided when initializing the object.
- property gamma_c: float¶
The partial factor for concrete.
- property eps_c1: float¶
Returns the strain at maximum compressive strength of concrete (fcm) for the Sargin constitutive law.
- Returns:
The strain at maximum compressive strength of concrete.
- Return type:
float
Note
The returned value is derived from fcm if eps_c1 is not manually provided when initializing the object.
- property eps_cu1: float¶
Returns the strain at concrete failure of concrete.
- Returns:
The maximum strength at failure of concrete.
- Return type:
float
Note
The returned value is derived from fcm if eps_cu1 is not manually provided when initializing the object.
- property k_sargin: float¶
Returns the k coefficient for Sargin constitutive law.
- Returns:
k coefficient for Sargin constitutive law.
- Return type:
float
Note
The returned value is derived from Ecm, fcm, and eps_c1 if k_sargin is not manually provided when initializing the object.
- property eps_c2: float¶
Returns the strain at maximum compressive strength of concrete (fcd) for the Parabola-rectangle constitutive law.
- Returns:
The strain at maximum compressive strength of concrete.
- Return type:
float
Note
The returned value is the default value in the design code if not manually provided when initializing the object.
- property eps_cu2: float¶
Returns the strain at concrete failure of concrete for the Parabola-rectangle constitutive law.
- Returns:
The maximum strain at failure of concrete.
- Return type:
float
Note
The returned value is the default value in the design code if not manually provided when initializing the object.
- property n_parabolic_rectangular: float¶
Returns the coefficient for Parabola-rectangle constitutive law.
- Returns:
The exponent for Parabola-recangle law.
- Return type:
float
Note
The returned value is the default value in the design code if not manually provided when initializing the object.
- property constitutive_law¶
Returns the ConstitutiveLaw of the object.
- property name¶
Returns the name of the material.
- property density¶
Returns the density of the material in kg/m3.