2014 dxdy logo

Научный форум dxdy

Математика, Физика, Computer Science, Machine Learning, LaTeX, Механика и Техника, Химия,
Биология и Медицина, Экономика и Финансовая Математика, Гуманитарные науки


Правила форума


Посмотреть правила форума



Начать новую тему Ответить на тему На страницу Пред.  1, 2, 3  След.
 
 Re: Изгиб плоской молекулы
Сообщение06.08.2019, 23:35 
Аватара пользователя


26/05/12
1694
приходит весна?
Тогда проблема.

С другой стороны, поскольку смещение по Z мало, то поправки на координаты X и Y будут вообще второго порядка малости. Ими точно нельзя пренебречь?

-- 06.08.2019, 23:37 --

madschumacher, у вас есть возможность с нуля рассчитать координаты атомов в плоскости? Или они берутся "из справочника" в каждом случае?

 Профиль  
                  
 
 Re: Изгиб плоской молекулы
Сообщение06.08.2019, 23:38 
Заслуженный участник
Аватара пользователя


28/04/16
2395
Снаружи ускорителя
B@R5uk в сообщении #1409012 писал(а):
Тогда проблема.

Я заметил. :lol: Поэтому и разместил вопрос в ПРР(М).
B@R5uk в сообщении #1409012 писал(а):
Ими точно нельзя пренебречь?

Ну наверное, раз я пишу, что нельзя, наверное я уже пробовал, и знаю, что нельзя?

B@R5uk в сообщении #1409012 писал(а):
у вас есть возможность с нуля рассчитать координаты атомов в плоскости?

Да, могу и рассчитать, могу и из справочника (базы данных) стырить.

 Профиль  
                  
 
 Re: Изгиб плоской молекулы
Сообщение06.08.2019, 23:42 
Аватара пользователя


26/05/12
1694
приходит весна?
madschumacher в сообщении #1409013 писал(а):
Да, могу и рассчитать...

Ну тогда нет проблем! Делайте тот же расчёт, только размещая атомы не в плоскости, а на поверхности второго порядка, которая жёстко привязана к центру масс молекулы и к её ориентации. Длины связей должны остаться теми же, а вот углы между ними поплывут.

 Профиль  
                  
 
 Re: Изгиб плоской молекулы
Сообщение06.08.2019, 23:47 
Заслуженный участник
Аватара пользователя


28/04/16
2395
Снаружи ускорителя
B@R5uk в сообщении #1409016 писал(а):
Ну тогда нет проблем! Делайте тот же расчёт, только размещая атомы не в плоскости, а на поверхности второго порядка, которая жёстко привязана к центру масс молекулы и к её ориентации.

Ага, спасибо. Если бы это было так просто, я б не спрашивал об извращенных аналитичесих методах отображения плоскости на более сложную поверхность. Тем более, про простую версию этого, предложенную DeBill (модель пружинок) я уже комментировал, говоря, что это существенно усложняет задачу.

B@R5uk в сообщении #1409016 писал(а):
Длины связей должны остаться теми же, а вот углы между ними поплывут.

А это уже другое решение. У Вас есть идеи как сделать это конкретно, алгоритмически?

 Профиль  
                  
 
 Re: Изгиб плоской молекулы
Сообщение06.08.2019, 23:55 
Аватара пользователя


26/05/12
1694
приходит весна?
madschumacher в сообщении #1409006 писал(а):
Об этом я тоже писал, и сказал, что некие деформации все ж допустимы...
Я так понимаю, вы имеете в виду случаи цилиндрической деформации. Этому есть простое объяснение: у плоскости и цилиндра одна и та же кривизна, поэтому плоскость можно навернуть на цилиндр без растяжений. В общем случае этого не получится, поэтому надо честно считать.

-- 06.08.2019, 23:56 --

madschumacher в сообщении #1409017 писал(а):
У Вас есть идеи как сделать это конкретно, алгоритмически?
А вы можете поделиться тем, что у вас уже считает в плоском случае? Или секрет фирмы? Просто не хочется строить алгоритм на пустом месте.

 Профиль  
                  
 
 Re: Изгиб плоской молекулы
Сообщение07.08.2019, 00:06 
Заслуженный участник
Аватара пользователя


28/04/16
2395
Снаружи ускорителя
B@R5uk в сообщении #1409018 писал(а):
А вы можете поделиться тем, что у вас уже считает в плоском случае? Или секрет фирмы? Просто не хочется строить алгоритм на пустом месте.

Код:
import numpy as np
from math import *
from copy import deepcopy

inpf=open("molecule.xyz", "r")

atn=[]
xyz=[]

nline=0
nat=0
for line in inpf:
    nline+=1
    words=line.split()
    if nline==1:
        nat=int(words[0])
    elif nline>2 and len(words)>3:
        atn.append(words[0])
        xyz.append(np.array(words[1:4], dtype=float))

if nat!=len(xyz):
    print("Number of atoms specified is inconsistent with xyz definition")
    exit(1)

xix=np.array([0.0,  0.2, 0.4, 0.6, 0.8, 1.0, 0.8, 0.6, 0.4, 0.2, 0.0, -0.2, -0.4, -0.6, -0.8, -1.0])*0.05
xiy=np.array([0.0 for i in xix])
def new_xyz(r, txix, txiy):
    tr=deepcopy(r)
    tr[-1] = txix*tr[0]**2 + txiy*tr[1]**2

    nold=np.array([0.0, 0.0, -1.])
    nold/=sqrt(np.dot(nold,nold))
    nnew=np.array([2.0*txix*tr[0], 2.0*txiy*tr[1], -1.0])
    nnew/=sqrt(np.dot(nnew,nnew))

    rpr=np.dot(nold,r)
   
    return (tr+nnew*rpr)

for i in range(0,len(xix)):
    print("%i\n %f  %f" % (nat, xix[i], xiy[i]))
    for n in range(0,len(atn)):
        tr=new_xyz(xyz[n], xix[i], xiy[i])
        print(" %3s  %15.4f %15.4f %15.4f "  % (atn[n],  tr[0], tr[1], tr[2]))


 Профиль  
                  
 
 Re: Изгиб плоской молекулы
Сообщение07.08.2019, 01:07 
Заслуженный участник
Аватара пользователя


18/05/06
13438
с Территории
Не надо извращённых методов. На поверхность, которую можно свернуть из плоскости, плоскость отображается легко. А на такую, которую нельзя - не отображается ни легко, ни сложно. Иначе зачем бы, думаете, люди морочились с проекцией Меркатора и другими? Взяли бы да развернули глобус на плоскость. Но нет, от искажений так не уйти.

В молекуле, скорее всего, было бы правильным найти нормальные колебания и выявить то из них, которое соответствует нужному движению.

 Профиль  
                  
 
 Re: Изгиб плоской молекулы
Сообщение07.08.2019, 06:50 
Заслуженный участник
Аватара пользователя


03/06/08
2319
МО
madschumacher в сообщении #1408993 писал(а):
Да, очень похоже на то, что хочется. Ну или с изгибами листа бумаги (с изломами, которые будут убираться, как на мыльной плёнке).
Это можно как-то описать в человеческих терминах?

Как свойства решений задачи Плато.
Кстати, описание асимптотик по малым отклонениям контура может оказаться довольно забавным, независимо от.

 Профиль  
                  
 
 Re: Изгиб плоской молекулы
Сообщение07.08.2019, 07:47 
Заслуженный участник
Аватара пользователя


28/04/16
2395
Снаружи ускорителя
ИСН в сообщении #1409023 писал(а):
Иначе зачем бы, думаете, люди морочились с проекцией Меркатора и другими?

Именно поэтому я и думал, что готовое решение должно уже иметься в закромах. Если бы моя сова молекула только на глобус натягивалась, я бы просто заюзал какую-нть стереографическую проекцию, и дело с концами.
ИСН в сообщении #1409023 писал(а):
Но нет, от искажений так не уйти.

Ну я об этом и говорю: искажение - - это не страшно, лишь бы они были меньше, чем в простом отображении на поверхность 2го порядка.
ИСН в сообщении #1409023 писал(а):
В молекуле, скорее всего, было бы правильным найти нормальные колебания и выявить то из них, которое соответствует нужному движению.

Ну наверное у меня есть причины, по которым я так не делаю? Первая из них - - то, что я не хочу быть привязанный к конкретному методу, которым считалось поле. Вторая, то, что вектора смещений из плоскости - - это просто перпендикуляры к ней, поэтому при больших амплитудах смещений возникает та же проблема, что и в отображении на поверхность второго порядка.

пианист в сообщении #1409031 писал(а):
Как свойства решений задачи Плато.

Это та, о которой Фоменко как-то в Кванте писал? А где можно почитать про это, чтобы язык был понятен не-математикам?

 Профиль  
                  
 
 Re: Изгиб плоской молекулы
Сообщение07.08.2019, 07:51 
Аватара пользователя


26/05/12
1694
приходит весна?
madschumacher в сообщении #1409021 писал(а):
Код:
Я имел в виду не текст кода, а именно алгоритм словами.

Я тут ещё подумал, что всевозможные растяжения, сжатия, искривления и прочее, которые переводят плоскость в плоскость, а в молекуле изменяют углы без изменения расстояний, тоже будут примитивными компонентами общей деформации наравне с деформациями плоскости.

ИСН в сообщении #1409023 писал(а):
В молекуле, скорее всего, было бы правильным найти нормальные колебания и выявить то из них, которое соответствует нужному движению.
По хорошему то, да... вот только это сложная задача. И подход топикстартера может как раз к этому и ведёт: если в базисе малых искажений рассчитать коэффициенты жёсткости (в том числе перекрёстные), то можно брать различные начальные условия (деформации) и рассчитывать динамику того, как они друг в друга переходят. Потом посмотреть на спектры колебаний каждого коэффициента. Всё, что соответствует одной частоте — будет нормальное колебание. Таким образом нормальное колебание будет разложено по базису простых малых деформаций. Но тут самое главное, чтобы для частот интереса базис оказался полным.

 Профиль  
                  
 
 Re: Изгиб плоской молекулы
Сообщение07.08.2019, 08:19 
Заслуженный участник
Аватара пользователя


28/04/16
2395
Снаружи ускорителя
B@R5uk в сообщении #1409039 писал(а):
Я имел в виду не текст кода, а именно алгоритм словами.

madschumacher в сообщении #1408958 писал(а):
Банальное отображение на плоскость второго порядка, так что координаты $(x,y,0) \rightarrow (x,y,z)$, где $z=k_x x^2 + k_y y^2 + k_{xy} xy$ не канают

 Профиль  
                  
 
 Re: Изгиб плоской молекулы
Сообщение07.08.2019, 08:22 
Заслуженный участник
Аватара пользователя


03/06/08
2319
МО
В Кванте не читал, но у Фоменко, да, есть результаты по этой теме, так что вполне может быть.
Я лично читал про Плато по несколько странному источнику ;), есть такая книжечка (в сети имеется), Полищук "Софус Ли", вот там.
Гляньте, вроде все понятно изложено.

 Профиль  
                  
 
 Re: Изгиб плоской молекулы
Сообщение07.08.2019, 09:44 
Аватара пользователя


26/05/12
1694
приходит весна?
Ладно. Мне видится только такое решение задачи. На координаты всех атомов накладывается ограничение, чтобы они лежали на поверхности 2-го порядка. На длины всех связей накладывается ограничение, чтобы они оставались неизменными. Из всех углов между связями вычитаются их значения в плоской молекуле, разности возводятся в квадрат и суммируются с некими весами, характеризующими жёсткость соответствующих углов между связями. В результате получается некая целевая функция и набор ограничений. Численно рассчитываем минимум этой целевой функции при заданных ограничениях. Получаем искомые координаты.

Это общий план, в него можно внести множество оптимизаций. Например, координаты $\{x,y,z\}$ будут весьма неудачными для сложности расчёта, их лучше заменить на углы, поскольку длины связей фиксированы. Ограничения на длину связи лучше не использовать в расчётах в лоб, а задаться небольшим числом новых угловых координат и по топологии молекулы рассчитать новые значения координат атомов. Это сразу удовлетворит требуемым ограничениям, и о них в последствии не нужно будет беспокоиться. Затем это всё подставляется в целевую функцию и оптимизируется по новым координатам.

 Профиль  
                  
 
 Re: Изгиб плоской молекулы
Сообщение07.08.2019, 10:31 


07/08/14
4231
Эту задачу можно так сформулировать?:
$s=\int\limits_{a}^{b} \sqrt{x'^2(t)+y'^2(t)+z'^2(t)}dt$
Известно $s$ (длина расстояния между точками) и вид функции, заданной параметрически (форма изгиба связей между точками).
Необходимо найти $x,y,z$

 Профиль  
                  
 
 Re: Изгиб плоской молекулы
Сообщение07.08.2019, 11:44 
Заслуженный участник
Аватара пользователя


28/04/16
2395
Снаружи ускорителя
upgrade в сообщении #1409049 писал(а):
Эту задачу можно так сформулировать?:

Да, мне как раз тоже пришла такая идея.

В итоге реализовал что-то, что вроде меня сейчас устраивает. Привожу то, что сделал для проверки.
Допустим, у нас есть изначальный вектор $\mathbf{r}_0 = (x_0, y_0, 0)^\dagger$, мы его хотим перевести в вектор, который параметризован как $\mathbf{r} = (x_0 t, y_0 t , z(t) )^\dagger$, где $z = \underbrace{(ax_0^2 + bx_0 y_0 + cy_0^2)}_{q} t^2$ (т.е. мы уменьшаем проекцию $\mathbf{r}$ на плоскость $xy$, но эта проекция остаётся в том же направлении).
Дополнительным условием сделаем, что расстояние от начала координат $(0,0,0)^\dagger$ до новой точки по поверхности должно остаться прежним, т.е.
$\int \limits_0^{t_\text{fin}} \sqrt{\underbrace{x_0^2 + y_0^2}_{A} + \underbrace{(2q)^2}_{B}t^2} = \frac{A \arcsinh\left(\sqrt{\frac{B}{A}} t_\text{fin}\right)}{2 \sqrt{B}} + \frac{ t_\text{fin} \sqrt{B  t_\text{fin}^2 + A}}{2} = |\mathbf{r}_0| = \sqrt{x_0^2 + y_0^2}$.
Решая это уравнение, находим $t_\text{fin}$, которое и даёт нам искомые координаты.
На примере коронена получилось вот что:
Изображение

(код этого алгоритма)

Код:
import numpy as np
from math import *
from copy import deepcopy
import scipy.optimize as spo

inpf=open("coronene.xyz", "r")

atn=[]
xyz=[]

nline=0
nat=0
for line in inpf:
    nline+=1
    words=line.split()
    if nline==1:
        nat=int(words[0])
    elif nline>2 and len(words)>3:
        atn.append(words[0])
        xyz.append(np.array(words[1:4], dtype=float))

if nat!=len(xyz):
    print("Number of atoms specified is inconsistent with xyz definition")
    exit(1)


def curv_length(t, A, B):
    return (A*np.arcsinh(sqrt(B/A)*t)/(2.0*sqrt(B)) + 0.5*t*sqrt(B*t**2 + A) )

def lsqf(t, r0, A, B):
    return (curv_length(t, A, B) - r0)**2

def get_new_coords(xyz, a, b, c):
    lvec=sqrt(np.dot(xyz,xyz))
    newxyz = deepcopy(xyz)
    Q=2.0*(a*xyz[0]**2 + b*xyz[0]*xyz[1] + c*xyz[1]**2)
    if lvec>1.0e-2 and abs(Q)>1.0e-2:
        A=xyz[0]**2 + xyz[1]**2
        B=Q**2
        res=spo.minimize_scalar(lsqf, bounds=(0., 1.), args=(lvec, A,B), method='Golden')
        if res.success:
            newxyz[0]=xyz[0]*res.x
            newxyz[1]=xyz[1]*res.x
            newxyz[2]=0.5*Q*res.x**2
        else:
            print("Failed convergence in coordinates!")
            exit(1)
    return newxyz

for i in range(0,100):
    abc=0.05*2.0*(np.random.rand(3)-np.array([0.5,0.5,0.5]))
    print("%i\n %f  %f  %f" % (nat, abc[0], abc[1], abc[2]))
    for n in range(0,len(atn)):
        tr=get_new_coords(xyz[n], abc[0], abc[1], abc[2])
        print(" %3s  %15.4f %15.4f %15.4f "  % (atn[n],  tr[0], tr[1], tr[2]))
   



Спасибо большое всем за помощь и участие! :D

 Профиль  
                  
Показать сообщения за:  Поле сортировки  
Начать новую тему Ответить на тему  [ Сообщений: 45 ]  На страницу Пред.  1, 2, 3  След.

Модераторы: Модераторы Математики, Супермодераторы



Кто сейчас на конференции

Сейчас этот форум просматривают: vicvolf


Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете добавлять вложения

Найти:
Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group