本文整理匯總了Python中oricrete.folding.YoshimuraCreasePattern.cnstr_rhs[-1]方法的典型用法代碼示例。如果您正苦於以下問題:Python YoshimuraCreasePattern.cnstr_rhs[-1]方法的具體用法?Python YoshimuraCreasePattern.cnstr_rhs[-1]怎麽用?Python YoshimuraCreasePattern.cnstr_rhs[-1]使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類oricrete.folding.YoshimuraCreasePattern
的用法示例。
在下文中一共展示了YoshimuraCreasePattern.cnstr_rhs[-1]方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: cp04
# 需要導入模塊: from oricrete.folding import YoshimuraCreasePattern [as 別名]
# 或者: from oricrete.folding.YoshimuraCreasePattern import cnstr_rhs[-1] [as 別名]
def cp04(L_x = 4, L_y = 4, n_x = 2, n_y = 4, n_steps = 100):
cp = YoshimuraCreasePattern(n_steps = n_steps,
L_x = L_x,
L_y = L_y,
n_x = n_x,
n_y = n_y,
show_iter = False,
MAX_ITER = 500)
n_h = cp.N_h
n_i = cp.N_i
n_v = cp.N_v
z_nodes = n_h[(0, -1), :].flatten()
z_cnstr = [[(n, 2, 1.0)] for n in z_nodes]
y_links = []
for n_arr in n_h.T:
for n in n_arr[1:]:
y_links.append([(n_arr[0], 1, 1.0), (n, 1, -1.0)])
x_cnstr = [[(n_h[0, 0], 0, 1.0)]]
y_cnstr = [[(n_h[0, -1], 1, 1.0)],
[(n_h[0, 0], 1, 1.0)]]
cp.cnstr_lhs = z_cnstr + y_links + x_cnstr + y_cnstr
# lift node 0 in z-axes
cp.cnstr_rhs = np.zeros((len(cp.cnstr_lhs),), dtype = float)
cp.cnstr_rhs[-1] = 3.9
return cp
示例2: cp05
# 需要導入模塊: from oricrete.folding import YoshimuraCreasePattern [as 別名]
# 或者: from oricrete.folding.YoshimuraCreasePattern import cnstr_rhs[-1] [as 別名]
def cp05(L_x = 4, L_y = 4, n_x = 2, n_y = 4,
n_steps = 100, skew_coeff = 0.0):
'''Exploit symmetric constraints
'''
cp = YoshimuraCreasePattern(n_steps = n_steps,
L_x = L_x,
L_y = L_y,
n_x = n_x,
n_y = n_y,
show_iter = False,
MAX_ITER = 500)
n_h = cp.N_h
n_i = cp.N_i
n_v = cp.N_v
z_nodes = n_h[(0, -1), :].flatten()
z_cnstr = [[(n, 2, 1.0)] for n in z_nodes]
y_links = []
for n_arr in n_h[:, (0, -1)].T:
for idx, n in enumerate(n_arr[1:]):
n_x = len(n_arr)
coeff = skew_coeff * float(idx + 1) / float(n_x)
y_links.append([(n_arr[0], 1, 1.0 - coeff), (n, 1, -1.0)])
for n_arr in n_h[:, 1:-1].T:
y_links.append([(n_arr[0], 1, 1.0), (n_arr[-1], 1, -1.0)])
x_links = []
z_links = []
# for n0, n1 in zip(n_h[1:-1, 0], n_h[1:-1, -1]):
# x_links.append([(n0, 0, 1.0), (n1, 0, 1.0)])
# z_links.append([(n0, 2, 1.0), (n1, 2, -1.0)])
for n in n_v[0, 1:]:
z_links.append([(n_v[0, 0], 2, 1.0), (n, 2, -1.0)])
n_h_idx = n_y / 4
x_cnstr = [[(n_h[0, n_h_idx], 0, 1.0)]]
y_cnstr = [[(n_h[0, n_h_idx], 1, 1.0)]]
cntrl = [[(n_h[-1, n_h_idx], 0, 1.0)]]
#cntrl = [[(n_h[-1, 0], 1, 1.0)]]
cp.cnstr_lhs = z_cnstr + x_links + y_links + z_links + x_cnstr + y_cnstr + cntrl
# lift node 0 in z-axes
cp.cnstr_rhs = np.zeros((len(cp.cnstr_lhs),), dtype = float)
cp.cnstr_rhs[-1] = -L_x * 0.1
return cp
示例3: create_cp_dc
# 需要導入模塊: from oricrete.folding import YoshimuraCreasePattern [as 別名]
# 或者: from oricrete.folding.YoshimuraCreasePattern import cnstr_rhs[-1] [as 別名]
def create_cp_dc(L_x = 4, L_y = 4, n_x = 1, n_y = 2,
n_steps = 100):
'''Create scalable rhombus crease pattern with dof_constraints
'''
cp = YoshimuraCreasePattern(n_steps = n_steps,
L_x = L_x,
L_y = L_y,
n_x = n_x,
n_y = n_y,
show_iter = False,
MAX_ITER = 500)
n_h = cp.N_h
n_i = cp.N_i
n_v = cp.N_v
n_h_idx = n_y / 4
x_links = []
y_links = []
z_links = []
z_nodes = n_h[(0, 0, -1, -1), (0, -1, -1, 0)].flatten()
print 'z_nodes', z_nodes
#z_cnstr = [[(n, 2, 1.0)] for n in z_nodes]
x_cnstr = [[(n_h[0, 0], 0, 1.0)]]
y_cnstr = [[(n_h[0, 0], 1, 1.0)]]
z_cnstr = [[(n_h[0, 0], 2, 1.0)]]
for n_arr in n_h[:, (0, -1)].T:
for idx, n in enumerate(n_arr[1:]):
n_x = len(n_arr)
y_links.append([(n_arr[0], 1, 1.0), (n, 1, -1.0)])
for n in n_h[0, 1:]:
z_links.append([(n_h[0, 0], 2, 1.0), (n, 2, -1.0)])
x_links.append([(n_h[0, 0], 0, 1.0), (n, 0, -1.0)])
#x_links.append([(n_h[0, -1], 0, 1.0), (n_h[0, -1], 1, -0.5)])
for n in n_v[-1, 1:]:
x_links.append([(n_v[-1, 0], 0, 1.0), (n, 0, -1.0)])
for n0, n1 in zip(n_v[0, :], n_v[-1, :]):
z_links.append([(n0, 2, 1.0), (n1, 2, -1.0)])
#cntrl = [[(n_h[-1, -1], 1, 1.0)]]
cntrl = [[(n_h[-1, 1], 0, 1.0)]]
print 'x_cnstr', len(x_cnstr)
print 'y_cnstr', len(y_cnstr)
print 'z_cnstr', len(z_cnstr)
print 'x_links', len(x_links)
print 'y_links', len(y_links)
print 'z_links', len(z_links)
cp.cnstr_lhs = z_cnstr + x_links + y_links + z_links + x_cnstr + y_cnstr + cntrl
#cp.cnstr_lhs = z_cnstr
# lift node 0 in z-axes
cp.cnstr_rhs = np.zeros((len(cp.cnstr_lhs),), dtype = float)
cp.cnstr_rhs[-1] = -L_x * 0.34
# cp.cnstr_rhs[-1] = -L_y * 0.9999
return cp