ماتریس سختی المان خرپایی با جهتگیری دلخواه
ماتریس سختی ساده (با فرض سطح مقطع ثابت و مدول یانگ) فقط برای یک عضو خرپایی که در راستای یک محور مختصات قرار دارد معتبر است. در سازههای واقعی، اعضای خرپا میتوانند در هر زاویهای جهتگیری شوند. برای مدیریت این موضوع، باید یک ماتریس سختی استخراج کنیم که نیروها و جابجاییها را در یک سیستم مختصات جهانی مشترک (x, y) به هم مرتبط کند.

روش کار به شرح زیر است: ۱. با ماتریس سختی ساده در یک سیستم مختصات محلی (x’، y’) که با عضو همراستاست شروع کنید. ۲. یک ماتریس تبدیل، T، که سیستمهای مختصات محلی و جهانی را به هم مرتبط میکند، توسعه دهید. ۳. از این ماتریس تبدیل برای تبدیل ماتریس سختی محلی به ماتریس سختی جهانی مطلوب استفاده کنید.
ماتریس سختی محلی (Kمحلی)
برای یک عضو خرپایی که با محور محلی x’ خود همراستاست، فقط میتواند در برابر نیروها مقاومت کند و جابجاییها را فقط در امتداد آن محور تجربه کند. هر نیرو یا جابجایی عمود بر عضو (در جهت y’) با سختی صفر همراه است زیرا باعث تغییر طول نمیشود.
بنابراین، میتوانیم ماتریس سختی را برای عضو در سیستم مختصات دوبعدی محلی آن که دارای چهار درجه آزادی (u₁’، v₁’، u₂’، v₂’) است، به صورت زیر بنویسیم:
این ماتریس ۴×۴ ماتریس سختی در سیستم مختصات محلی، Kمحلی است.

تبدیل مختصات
اجازه دهید سیستم مختصات جهانی (x، y) به اندازه یک زاویه θ نسبت به سیستم محلی (x’، y’) چرخیده باشد.

قبلاً آموختیم که هر بردار را میتوان با استفاده از یک ماتریس چرخش دوبعدی استاندارد از یک سیستم به سیستم دیگر تبدیل کرد. رابطه بین مؤلفههای محلی [Vx’, Vy’] و مؤلفههای جهانی [Vx, Vy] به صورت زیر است: c = cos(θ) و s = sin(θ). ماتریس چرخش برابر است با: میتوانیم این را به بردارهای جابجایی در هر گره اعمال کنیم. فرض کنید جابجاییهای جهانی q و جابجاییهای محلی u’ باشند:
- در گره ۱:
- در گره ۲:
میتوانیم اینها را در یک تبدیل واحد برای کل عضو ترکیب کنیم. این، ماتریس تبدیل، T را تعریف میکند:
یک رابطه مشابه برای بردارهای نیرو وجود دارد:
چون T یک ماتریس متعامد یکه است، معکوس آن برابر با ترانهاده آن است T-1 = TT. بنابراین، از معادله فوق نتیجه میشود که:
اکنون میتوانیم ماتریس سختی را در سیستم مختصات جهانی با ترکیب این روابط استخراج کنیم:
- با رابطه بنیادی در سیستم محلی شروع کنید:
محلی - تبدیل جابجایی u’ = Tq را جایگزین کنید:
محلی - هر دو طرف را در TT پیشضرب کنید تا نیروهای جهانی F را به دست آورید:
محلی - تشخیص دهید که سمت چپ، بردار نیروی جهانی، F = **TTF’ است:
این معادله اکنون به شکل جهانی F = Kجهانیq است. بنابراین، معادله اصلی تبدیل برای ماتریسهای سختی را اثبات کردهایم:
با انجام این ضرب ماتریسی، به شکل صریح ماتریس سختی جهانی برای یک عضو خرپایی با جهتگیری دلخواه میرسیم:
این ماتریس ۴×۴ اکنون میتواند در فرایند برهمنهی مستقیم (اسمبل) که در بخش اول توضیح داده شد، برای ساخت ماتریس سختی جهانی کل سازه خرپایی استفاده شود.
مثال زیر، فرایند کامل تبدیل مختصات و اسمبل سختی را پیادهسازی میکند.
مثال: تحلیل یک سازه خرپایی سهمیلهای
خرپای زیر را در نظر بگیرید که یک نیروی افقی و یک نیروی قائم را تحمل میکند (شکل را ببینید). فرض کنید مدول یانگ و سطح مقطع برای همه اعضا یکسان است: E = 100 GPa، A = 200 mm2.

سیستم مختصات جهانی و گرهها: یک سیستم مختصات جهانی با مبدأ در گره ۱ برقرار میکنیم.
- گره ۱: (0, 0)
- گره ۲: (0, 2)
- گره ۳: (2, 2)

درجات آزادی جهانی (DOFs): سازه دارای ۳ گره با ۲ درجه آزادی در هر گره () است، که در مجموع ۶ درجه آزادی جهانی را تشکیل میدهد. ابتدا درجات آزادی آزاد را شمارهگذاری میکنیم و سپس درجات آزادی تکیهگاهی (محدود). این کار محاسبات بعدی را سادهتر میکند.
- درجات آزادی آزاد (در گره ۳):
- : جابجایی قائم در گره ۱
- : جابجایی افقی در گره ۳
- : جابجایی قائم در گره ۳
- درجات آزادی تکیهگاهی (در گرههای ۱ و ۲):
- : جابجایی افقی در گره ۱
- : جابجایی افقی در گره ۲
- : جابجایی قائم در گره ۲
از آنجایی که گره ۱ روی یک غلتک و گره ۲ لولایی است، جابجاییهای متناظر آنها باید صفر باشند:

مرحله ۲: استخراج ماتریس سختی هر عضو در مختصات جهانی
اکنون، هر یک از سه عضو خرپایی را بهطور جداگانه تحلیل میکنیم، ماتریس سختی ۴×۴ آن را در سیستم مختصات جهانی محاسبه کرده و سطرها و ستونها را بهطور صریح با شمارههای درجه آزادی جهانی متناظر برچسبگذاری میکنیم.
عضو ① (گرههای ۱ تا ۲):
- طول:
- زاویه: عضو قائم است، بنابراین .
- کسینوسها: ، .
- نگاشت DOF: درجات آزادی محلی برای این عضو () با درجات آزادی جهانی () متناظر است.
- ماتریس سختی:

عضو ② (گرههای ۲ تا ۳):
- طول:
- زاویه: عضو افقی است، بنابراین .
- کسینوسها: ، .
- نگاشت DOF: درجات آزادی محلی برای این عضو () با درجات آزادی جهانی () متناظر است.
- ماتریس سختی:
عضو ③ (گرههای ۱ تا ۳):
- طول:
- زاویه: عضو در زاویه ۴۵ درجه قرار دارد، بنابراین .
- کسینوسها: ، .
- نگاشت DOF: درجات آزادی محلی برای این عضو () با درجات آزادی جهانی () متناظر است.
- ماتریس سختی: برای این عضو، ، ، .
مرحله ۳: اسمبل ماتریس سختی جهانی ()
اکنون ماتریس سختی جهانی ۶×۶ را با افزودن مؤلفههای هر ماتریس عضو در محلهای صحیح، با هدایت برچسبهای DOF جهانی، اسمبل میکنیم. ماتریس نهایی حاصل جمع سه ماتریس سختی عضو است که به فضای جهانی ۶×۶ گسترش یافتهاند.
برای مثال، بیایید جمله جهانی را پیدا کنیم که متناظر با اندرکنش بین DOFهای جهانی و است. در هر ماتریس عضو به دنبال درایه (q₁, q₁) میگردیم:
- عضو ①: درایه در سطر و ستون است.
- عضو ②: سطر یا ستون ندارد. سهم آن در صفر است.
- عضو ③: درایه در سطر و ستون برابر است.
- مجموع: .
به عنوان مثالی دیگر، بیایید جمله خارج قطری (سطر ۱، ستون ۶) را پیدا کنیم:
- عضو ①: درایه در سطر و ستون برابر است.
- عضو ②: DOFهای و را ندارد. سهم آن صفر است.
- عضو ③: DOFهای و را ندارد. سهم آن صفر است.
- مجموع: .
این فرایند افزودن مقادیر بر اساس شاخصهای سطر و ستون جهانی آنها (برهمنهی مستقیم) برای تمام ۳۶ درایه ماتریس سختی جهانی تکرار میشود.
مرحله ۴: افرازبندی و حل دستگاه
دستگاه کامل است. این ماتریس ۶×۶ اسمبلشده منفرد است زیرا هنوز شرایط تکیهگاهی را اعمال نکردهایم. دستگاه را با افرازبندی آن به DOFهای آزاد و تکیهگاهی حل میکنیم.
که در آن افرازها عبارتاند از: * جابجاییهای آزاد: (اینها مجهولات هستند). * جابجاییهای تکیهگاهی: . * نیروهای اعمالی: . * واکنشهای تکیهگاهی: (اینها نیز مجهول هستند).
این معادله افرازشده منفرد به دو معادله ماتریسی جداگانه گسترش مییابد:
حل برای جابجاییهای مجهول شرط مرزی شناختهشده را اعمال میکنیم. این، معادله اول را بسیار ساده میکند: ماتریس افراز ۳×۳ بالا-چپ ماتریس جهانی است که متناظر با DOFهای آزاد ، و میباشد. اکنون میتوانیم جابجاییهای مجهول را با معکوسگیری از این ماتریس کوچک و غیرمنفرد ۱ حل کنیم: این محاسبه مقادیر عددی جابجاییهای افقی و قائم در گره ۳ را به دست میدهد.
حل برای واکنشهای تکیهگاهی هنگامی که بردار جابجایی معلوم شد، میتوانیم از معادله دوم (دوباره با ) برای یافتن نیروهای واکنش تکیهگاهی مجهول استفاده کنیم: این گام نهایی یک ضرب ماتریس-بردار ساده است که چهار نیروی واکنش در تکیهگاهها (گرههای ۱ و ۲) را به دست میدهد. این، تحلیل خرپا را کامل میکند.
کد زیر تمام محاسبات را نشان میدهد. نشان میدهد که
import numpy as np
# --------------------------------------
# Step 1: Input node coordinates
# --------------------------------------
# Example geometry: a triangle truss (3 nodes, 2 elements)
nodes = {
1: [0.0, 0.0],
2: [0.0, 2.0],
3: [2.0, 2.0]
}
# --------------------------------------
# Step 2: Define DOF mapping (ID matrix)
# --------------------------------------
# 4 rows (u1, v1, u2, v2) per element
# Each column corresponds to one element
# Example: two elements (1–2) and (2–3)
ID = np.array([
[4, 5, 4], # u1 global DOF for elem1, elem2
[1, 6, 1], # v1
[5, 2, 2], # u2
[6, 3, 3] # v2
])
# Number of global DOF
num_dof = int(np.max(ID))
Ks = np.zeros((num_dof, num_dof)) # global stiffness matrix initialized to zero
# --------------------------------------
# Step 3: Define truss element stiffness
# --------------------------------------
def truss_element_stiffness(E, A, node1, node2, nodes):
"""
Compute 4x4 stiffness matrix for a 2D truss element in global coordinates.
Parameters
----------
E : float
Young's modulus
A : float
Cross-sectional area
node1, node2 : int
Node IDs of the element
nodes : dict
Dictionary of node coordinates, e.g. {1: [x1, y1], 2: [x2, y2], ...}
"""
x1, y1 = nodes[node1]
x2, y2 = nodes[node2]
L = np.sqrt((x2 - x1)**2 + (y2 - y1)**2)
c = (x2 - x1) / L
s = (y2 - y1) / L
k = (E * A / L) * np.array([
[ c*c, c*s, -c*c, -c*s],
[ c*s, s*s, -c*s, -s*s],
[-c*c, -c*s, c*c, c*s],
[-c*s, -s*s, c*s, s*s]
])
return k
# --------------------------------------
# Step 4: Assembly function (Python version of ADDK)
# --------------------------------------
def ADDK(Ks, Ke, ID, elem_id):
"""
Assemble element stiffness matrix Ke into global Ks using mapping ID.
- ID: 4 x N array (u1,v1,u2,v2 per element)
- elem_id: which element (column index)
"""
n = 4 # local DOF per truss element
for i in range(n):
for j in range(n):
ig = ID[i, elem_id]
jg = ID[j, elem_id]
if ig != 0 and jg != 0:
val = Ke[i, j]
Ks[ig - 1, jg - 1] += val
return Ks
# --------------------------------------
# Step 5: Example assembly
# --------------------------------------
E = 100e9 # Young's modulus (Pa)
A = 2e-4 # cross-sectional area (m^2)
# Element 1:
Ke1 = truss_element_stiffness(E, A, 1, 2, nodes)
Ks = ADDK(Ks, Ke1, ID, elem_id=0)
# Element 2: Node 2 → Node 3
Ke2 = truss_element_stiffness(E, A, 2, 3, nodes)
Ks = ADDK(Ks, Ke2, ID, elem_id=1)
# Element 3: Node 2 → Node 3
Ke2 = truss_element_stiffness(E, A, 1, 3, nodes)
Ks = ADDK(Ks, Ke2, ID, elem_id=2)
# --------------------------------------
# Step 6: Print the result
# --------------------------------------
np.set_printoptions(precision=3, suppress=True)
print("Global stiffness matrix Ks: (1e7)")
print(Ks/1e7)
Kff=Ks[0:3,0:3]
Kfs=Ks[0:3, 3:6]
Ksf=Ks[3:6,0:3]
Kss=Ks[3:6,3:6]
Pf=np.array([[0],[20e3],[-30e3]])
qf = np.linalg.inv(Kff) @ Pf
print(qf)
Ps = Ksf @ qf
Psarray([[ 30000.],
[-50000.],
[ 30000.]])- روشهای بهتر و کمهزینهتری از نظر محاسباتی برای حل نسبت به معکوس کردن وجود دارد.↩︎