Muratura — §4.5¶
Verifiche per strutture in muratura secondo NTC18 §4.5.
Riferimento normativo¶
NTC18 §4.5, Tab. 4.5.II–IV, Tab. 4.5.III, Formule [4.5.1]–[4.5.12]
Include muratura armata §4.5.7 (flessione, taglio, assiale) e muratura confinata §4.5.8 (taglio, momento).
API¶
pyntc.checks.masonry
¶
Costruzioni di muratura — NTC18 §4.5.
Coefficienti parziali, resistenze di progetto, snellezza, fattori di riduzione, verifiche semplificate per muratura ordinaria.
Unita': - Tensioni/Resistenze: [N/mm^2] = [MPa] - Forze: [N] - Lunghezze: [mm] - Coefficienti: [-]
masonry_combined_eccentricity(e_x, e_y)
¶
Combinazione convenzionale delle eccentricità [mm].
NTC18 §4.5.6.2, Formula [4.5.10]: e1 = |e_x| + e_y e2 = e1/2 + |e_y|
e1 è adottato per le sezioni di estremità; e2 per la sezione a massimo momento.
Parameters¶
e_x : float Eccentricità totale dei carichi verticali [mm]. e_y : float Eccentricità da tolleranze e azioni orizzontali [mm].
Returns¶
tuple[float, float] (e1, e2): eccentricità di calcolo [mm].
Source code in src/pyntc/checks/masonry.py
masonry_confined_bending_resistance(A_s, f_yd, z)
¶
Momento resistente di progetto per muratura confinata [N·mm].
NTC18 §4.5.8.3 — Armatura nei cordoli verticali: M_Rd = A_s * f_yd * z
Parameters¶
A_s : float Area dell'armatura nei cordoli [mm²]. f_yd : float Resistenza di progetto dell'acciaio [N/mm²]. z : float Braccio tra i cordoli opposti [mm].
Returns¶
float M_Rd: momento resistente di progetto [N·mm].
Source code in src/pyntc/checks/masonry.py
masonry_confined_shear_resistance(l, t, f_vk0, gamma_M, sigma_n=0.0)
¶
Taglio resistente di progetto per muratura confinata [N].
NTC18 §4.5.8.2: f_vk = f_vk0 + 0.4 * sigma_n V_Rd = f_vk / gamma_M * l * t
Parameters¶
l : float Lunghezza del pannello [mm]. t : float Spessore del pannello [mm]. f_vk0 : float Resistenza caratteristica a taglio in assenza di sforzo normale [N/mm²]. gamma_M : float Coefficiente parziale di sicurezza per la muratura [-]. sigma_n : float, optional Tensione normale agente sul pannello [N/mm²] (default 0.0).
Returns¶
float V_Rd: taglio resistente di progetto [N].
Source code in src/pyntc/checks/masonry.py
masonry_design_compressive_strength(f_k, gamma_M)
¶
Resistenza di progetto a compressione della muratura [N/mm^2].
NTC18 §4.5.6.1, Formula [4.5.2]: f_d = f_k / gamma_M
Parameters¶
f_k : float Resistenza caratteristica a compressione della muratura [N/mm^2]. gamma_M : float Coefficiente parziale di sicurezza [-].
Returns¶
float f_d: resistenza di progetto a compressione [N/mm^2].
Source code in src/pyntc/checks/masonry.py
masonry_design_shear_strength(f_vk, gamma_M)
¶
Resistenza di progetto a taglio della muratura [N/mm^2].
NTC18 §4.5.6.1, Formula [4.5.3]: f_vd = f_vk / gamma_M
Parameters¶
f_vk : float Resistenza caratteristica a taglio della muratura [N/mm^2]. gamma_M : float Coefficiente parziale di sicurezza [-].
Returns¶
float f_vd: resistenza di progetto a taglio [N/mm^2].
Source code in src/pyntc/checks/masonry.py
masonry_eccentricity_check(e1, e2, t)
¶
Verifica dei limiti di eccentricità [-].
NTC18 §4.5.6.2, Formula [4.5.11]: e1 <= 0.33 * t e e2 <= 0.33 * t
Parameters¶
e1 : float Eccentricità alla sezione di estremità [mm]. e2 : float Eccentricità alla sezione a massimo momento [mm]. t : float Spessore della parete [mm].
Returns¶
tuple[bool, float] (verificata, ratio): verificata = True se entrambe le eccentricità rispettano il limite; ratio = max(e1, e2) / (0.33 * t).
Source code in src/pyntc/checks/masonry.py
masonry_eccentricity_coefficient(e, t)
¶
Coefficiente di eccentricita' m [-].
NTC18 §4.5.6.2, Formula [4.5.6]: m = 6 * e / t
Parameters¶
e : float Eccentricita' totale [mm]. Valore >= 0. t : float Spessore della parete [mm].
Returns¶
float Coefficiente di eccentricita' m [-].
Source code in src/pyntc/checks/masonry.py
masonry_eccentricity_m(e, t)
¶
Coefficiente di eccentricita' adimensionale m [-].
NTC18 §4.5.6.2, Formula [4.5.6]: m = 6 * e / t
Utilizzato come indice di colonna nella Tab. 4.5.III per la lettura del coefficiente di riduzione Phi.
Parameters¶
e : float Eccentricita' totale [mm]. Valore >= 0. t : float Spessore della parete [mm].
Returns¶
float Coefficiente di eccentricita' adimensionale m [-].
Source code in src/pyntc/checks/masonry.py
masonry_effective_height(rho, h)
¶
Lunghezza libera d'inflessione della parete [mm].
NTC18 §4.5.6.2, Formula [4.5.5]: h_0 = rho * h
dove rho e' il fattore laterale di vincolo (Tab. 4.5.IV).
Parameters¶
rho : float Fattore laterale di vincolo [-] (da Tab. 4.5.IV). h : float Altezza interna di piano [mm].
Returns¶
float h_0: lunghezza libera d'inflessione [mm].
Source code in src/pyntc/checks/masonry.py
masonry_horizontal_eccentricity(M_s, N)
¶
Eccentricità da azioni orizzontali [mm].
NTC18 §4.5.6.2, Formula [4.5.9]: e_s = M_s / N
Parameters¶
M_s : float Massimo momento flettente dovuto alle azioni orizzontali [N·mm]. N : float Sforzo normale nella sezione di verifica [N]. Deve essere != 0.
Returns¶
float e_s: eccentricità [mm].
Source code in src/pyntc/checks/masonry.py
masonry_lateral_restraint_factor(h, a)
¶
Fattore laterale di vincolo rho (= q in [4.5.5]) [-].
NTC18 §4.5.6.2, Tab. 4.5.IV: h/a <= 0.5: rho = 1 0.5 < h/a <= 1.0: rho = 3/2 - h/a h/a > 1.0: rho = 1 / (1 + (h/a)^2)
Parameters¶
h : float Altezza interna di piano [mm]. a : float Interasse dei muri trasversali di irrigidimento [mm].
Returns¶
float Fattore laterale di vincolo rho [-].
Source code in src/pyntc/checks/masonry.py
masonry_partial_safety_factor(element_category, mortar_type, execution_class)
¶
Coefficiente parziale di sicurezza gamma_M per muratura [-].
NTC18 §4.5.6.1, Tab. 4.5.II: Cat.I + malta garantita: classe 1 → 2.0, classe 2 → 2.5 Cat.I + malta prescritta: classe 1 → 2.2, classe 2 → 2.7 Cat.II (qualsiasi malta): classe 1 → 2.5, classe 2 → 3.0
Parameters¶
element_category : int Categoria degli elementi resistenti: 1 o 2. mortar_type : str Tipo di malta: "guaranteed" (prestazione garantita) o "prescribed" (composizione prescritta). execution_class : int Classe di esecuzione: 1 o 2.
Returns¶
float Coefficiente parziale gamma_M [-].
Source code in src/pyntc/checks/masonry.py
masonry_phi_from_table(lambda_slend, m)
¶
Coefficiente di riduzione Phi da Tab. 4.5.III — interpolazione bilineare [-].
NTC18 §4.5.6.2, Tab. 4.5.III: valori del coefficiente Phi in funzione della snellezza lambda e del coefficiente di eccentricita' m.
Tabella discreta
Righe (lambda): 0, 5, 10, 15, 20 Colonne (m): 0, 0.5, 1.0, 1.5, 2.0
Celle None indicano combinazioni non ammesse (parete troppo snella/eccentrica).
Parameters¶
lambda_slend : float Snellezza convenzionale lambda = h0/t [-], intervallo [0, 20]. m : float Coefficiente di eccentricita' m = 6*e/t [-], intervallo [0, 2.0].
Returns¶
float Coefficiente di riduzione Phi [-].
Raises¶
ValueError Se lambda_slend o m sono fuori dai limiti ammessi, oppure se la combinazione cade in una cella non tabulata (dominio non ammesso).
Source code in src/pyntc/checks/masonry.py
606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 | |
masonry_reduced_strength(Phi, f_d)
¶
Resistenza unitaria di progetto ridotta [N/mm^2].
NTC18 §4.5.6.2, Formula [4.5.4]: f_d,rid = Phi * f_d
Parameters¶
Phi : float Coefficiente di riduzione [-] (da Tab. 4.5.III). f_d : float Resistenza di progetto a compressione [N/mm^2].
Returns¶
float f_d,rid: resistenza ridotta [N/mm^2].
Source code in src/pyntc/checks/masonry.py
masonry_reduction_factor(lambda_, m)
¶
Coefficiente di riduzione Phi della resistenza [-].
NTC18 §4.5.6.2, Tab. 4.5.III — Interpolazione bilineare sui valori tabulati in funzione della snellezza lambda e del coefficiente di eccentricita' m.
Parameters¶
lambda_ : float Snellezza convenzionale [-], 0 <= lambda <= 20. m : float Coefficiente di eccentricita' m = 6*e/t [-], m >= 0.
Returns¶
float Coefficiente di riduzione Phi [-].
Source code in src/pyntc/checks/masonry.py
289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 | |
masonry_reinforced_axial_check(N_Ed, b, d, A_s, f_yd, f_k, gamma_M)
¶
Verifica a pressoflessione/compressione per muratura armata [-].
NTC18 §4.5.7.2: N_Rd = b * d * f_d + A_s * f_yd ratio = N_Ed / N_Rd (<= 1 se verifica passa)
Parameters¶
N_Ed : float Sforzo normale di progetto [N]. b : float Larghezza della sezione [mm]. d : float Altezza utile della sezione [mm]. A_s : float Area dell'armatura [mm²]. f_yd : float Resistenza di progetto dell'acciaio [N/mm²]. f_k : float Resistenza caratteristica a compressione della muratura [N/mm²]. gamma_M : float Coefficiente parziale di sicurezza per la muratura [-].
Returns¶
tuple[bool, float] (verifica_superata, ratio): - verifica_superata: True se N_Ed <= N_Rd - ratio: N_Ed / N_Rd
Source code in src/pyntc/checks/masonry.py
masonry_reinforced_flexural_resistance(b, d, A_s, f_yd, f_k, gamma_M)
¶
Momento resistente di progetto per muratura armata [N·mm].
NTC18 §4.5.7.3 — Analogia con il calcestruzzo armato: F_s = A_s * f_yd f_d = f_k / gamma_M x = F_s / (0.8 * b * f_d) M_Rd = F_s * (d - 0.4 * x)
Parameters¶
b : float Larghezza della sezione [mm]. d : float Altezza utile della sezione [mm]. A_s : float Area dell'armatura tesa [mm²]. f_yd : float Resistenza di progetto dell'acciaio [N/mm²]. f_k : float Resistenza caratteristica a compressione della muratura [N/mm²]. gamma_M : float Coefficiente parziale di sicurezza per la muratura [-].
Returns¶
float M_Rd: momento resistente di progetto [N·mm].
Source code in src/pyntc/checks/masonry.py
masonry_reinforced_shear_resistance(b, d, A_sw, s, f_ywk, gamma_s=1.15, f_vk0=0.3, gamma_M=2.0)
¶
Taglio resistente di progetto per muratura armata [N].
NTC18 §4.5.7.4: V_Rd1 = f_vk0 / gamma_M * b * d (contributo muratura) V_Rd2 = 0.9 * d * A_sw/s * f_ywk/gamma_s (contributo armatura) V_Rd = V_Rd1 + V_Rd2
Parameters¶
b : float Larghezza della sezione [mm]. d : float Altezza utile della sezione [mm]. A_sw : float Area dell'armatura trasversale in una staffa [mm²]. s : float Passo delle staffe [mm]. f_ywk : float Resistenza caratteristica dell'armatura trasversale [N/mm²]. gamma_s : float, optional Coefficiente parziale per l'acciaio (default 1.15). f_vk0 : float, optional Resistenza caratteristica a taglio in assenza di sforzo normale [N/mm²] (default 0.3 MPa). gamma_M : float, optional Coefficiente parziale di sicurezza per la muratura (default 2.0).
Returns¶
float V_Rd: taglio resistente di progetto [N].
Source code in src/pyntc/checks/masonry.py
masonry_simplified_axial_check(N_Ed, A, f_k, gamma_M)
¶
Verifica semplificata allo sforzo normale [Formula 4.5.12].
NTC18 §4.5.6.4, Formula [4.5.12]: sigma = N_Ed / (0.65 * A) <= f_k / gamma_M ratio = sigma / (f_k / gamma_M)
Le unita' di N_Ed, A, f_k devono essere coerenti tra loro (es. N_Ed [N], A [mm^2], f_k [N/mm^2]).
Parameters¶
N_Ed : float Carico verticale di progetto [N]. A : float Area totale della sezione resistente [mm^2]. f_k : float Resistenza caratteristica a compressione della muratura [N/mm^2]. gamma_M : float Coefficiente parziale di sicurezza [-].
Returns¶
tuple[bool, float] (verificata, ratio): - verificata: True se sigma <= f_k / gamma_M (ratio <= 1.0) - ratio: sigma / (f_k / gamma_M)
Source code in src/pyntc/checks/masonry.py
masonry_simplified_check(N, A, f_k, gamma_M)
¶
Verifica semplificata per edifici semplici [-].
NTC18 §4.5.6.4, Formula [4.5.12]: sigma = N / (0.65 * A) <= f_k / gamma_M
Le unita' di N, A, f_k devono essere coerenti tra loro (es. N [N], A [mm^2], f_k [N/mm^2]).
Parameters¶
N : float Carico verticale totale alla base del piano. A : float Area totale dei muri portanti allo stesso piano. f_k : float Resistenza caratteristica a compressione della muratura. gamma_M : float Coefficiente parziale di sicurezza [-].
Returns¶
tuple[bool, float] (verifica_superata, sigma): - verifica_superata: True se sigma <= f_k / gamma_M - sigma: tensione di compressione ridotta
Source code in src/pyntc/checks/masonry.py
masonry_slenderness(h_0, t)
¶
Snellezza convenzionale della parete [-].
NTC18 §4.5.4, Formula [4.5.1]: lambda = h_0 / t
Il valore non deve risultare superiore a 20.
Parameters¶
h_0 : float Lunghezza libera di inflessione della parete [mm]. t : float Spessore della parete [mm].
Returns¶
float Snellezza convenzionale lambda [-].
Source code in src/pyntc/checks/masonry.py
masonry_vertical_load_eccentricity(N1, d1, N2_sum, d2)
¶
Eccentricità totali dei carichi verticali sulla parete [mm].
NTC18 §4.5.6.2, Formula [4.5.7]: e_s1 = N1 * d1 / (N1 + ΣN2) e_s2 = ΣN2 * d2 / (N1 + ΣN2)
Parameters¶
N1 : float Carico trasmesso dal muro sovrastante [N]. d1 : float Eccentricità di N1 rispetto al piano medio del muro [mm]. N2_sum : float Somma delle reazioni di appoggio dei solai soprastanti [N]. d2 : float Eccentricità di N2 rispetto al piano medio del muro [mm].
Returns¶
tuple[float, float] (e_s1, e_s2): eccentricità [mm], possono essere positive o negative.