2014 dxdy logo

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

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


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


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



Начать новую тему Ответить на тему
 
 Линейное неравенство с целыми неотрицательными коэфф-тами
Сообщение20.11.2019, 20:48 
Заслуженный участник
Аватара пользователя


28/04/16
2395
Снаружи ускорителя
Добрый день.

Прошу прощения за беспокойства.
Имеется функция
$E = \sum_{i=1}^{N_a} n_{i} A_i + \sum_{j=1}^{N_b} m_{j} B_j$ с целыми $n_i, m_j \geq 0$, $A_i \leq A_{i+1}$, $B_j \leq B_{j+1}$ и условиями $
\begin{cases}
 \sum_i n_i = N \\
 \sum_j m_j = M  
\end{cases}
$
Я хочу перебрать все решения неравенства
$E - E_{\min} \leq \Delta E$
при заданном $\Delta E$.
Пытался решить эту проблему методом МК, генерируя разные перестановки минимального набора $n_i,m_j$, но так получается куча решений, который мне не нужны. Можно ли как-то эту задачу поумнее поставить/более адекватно решить?

 Профиль  
                  
 
 Re: Линейное неравенство с целыми неотрицательными коэфф-тами
Сообщение20.11.2019, 22:20 
Заслуженный участник


18/01/15
3258
madschumacher в сообщении #1426968 писал(а):
Пытался решить эту проблему методом МК, генерируя разные перестановки минимального набора $n_i,m_j$, но так получается куча решений, который мне не нужны.

Мне в этой фразе не понятно ни одного слова. Можете написать подробнее, с каким-нибудь маленьким примером ?

Еще вопрос для контроля, что я правильно постановку задачи понимаю. Верно ли, что $E_{\min}=NA_1+MB_1$ ?

 Профиль  
                  
 
 Re: Линейное неравенство с целыми неотрицательными коэфф-тами
Сообщение20.11.2019, 23:39 
Заслуженный участник
Аватара пользователя


28/04/16
2395
Снаружи ускорителя
vpb в сообщении #1426974 писал(а):
Еще вопрос для контроля, что я правильно постановку задачи понимаю. Верно ли, что $E_{\min}=NA_1+MB_1$ ?

Спасибо большое, хороший вопрос, показывающий, что я опять намудрил с упрощением, в частности забыв важное условие.
Больше я так делать не буду, поэтому напишу физическую задачу, которая, надеюсь, будет иметь понятную постановку.

Итак, имеется система электронов из $N$ электронов, из них $N_\uparrow$ имеют спин "вверх", а $N_\downarrow$ -- "вниз" ($N = N_\uparrow + N_\downarrow$). Первые могут сидеть в ячейках с энергиями $\{ \varepsilon_i^\uparrow \}_{i=1}^{M_\uparrow}$, а другие в ячейках с энергиями $\{ \varepsilon_j^\uparrow \}_{j=1}^{M_\downarrow}$, причём для упрощения энергии ячеек можем считать упорядоченными ($\varepsilon_i \leq \varepsilon_{i+1}$). В каждой ячейке может сидеть только один электрон, перестановка электронов не меняет состояния. Таким образом полная энергия состояния даётся формулой
$E = \sum_{i=1}^{M_\uparrow} n_i^\uparrow \varepsilon_i^\uparrow  + \sum_{j=1}^{M_\downarrow} n_j^\downarrow \varepsilon_i^\downarrow$,
где числа заселённости ячеек $n$ могут принимать значения 0 и 1, соответственно, $\sum_{i=1}^{M_\uparrow} n_i^\uparrow = N_\uparrow$ и $ \sum_{j=1}^{M_\downarrow} n_j^\downarrow = N_\downarrow$.
Минимальной является энергия $E_{\min}$, когда $n_1^q = n_2^q = \ldots = n_{N_q}^q = 1$ и $n_{N_q+1}^q = \ldots = n_{M_q}^q$ ($q = \uparrow, \downarrow$), т.е. заняты только ячейки с наименьшими энергиями.

Похожую задачу (но с непрерывными заселённостями) я уже постил раньше (https://dxdy.ru/topic131010.html).
Соответственно, вопрос состоит в том, чтобы найти все возбуждённые состояния (т.е. состояния с энергией больше или равной минимальной) с энергией меньше заданной разницы $\Delta E$ ($E - E_{\min} \leq \Delta E$).

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

 Профиль  
                  
 
 Re: Линейное неравенство с целыми неотрицательными коэфф-тами
Сообщение21.11.2019, 21:13 
Заслуженный участник


03/01/09
1711
москва
Все же нужны еще некоторые подробности. Конечно или бесконечно число уровней? Как соотносятся энергии $\varepsilon _i $ и $\Delta E$?
Например, приведенному условию не противоречит вариант: число уровней бесконечно и $\varepsilon _1=\varepsilon _2=\cdots =\varepsilon _i=\cdots, \varepsilon _1N<\Delta E$. В этом случае число решений неравенства может быть бесконечно.

 Профиль  
                  
 
 Re: Линейное неравенство с целыми неотрицательными коэфф-тами
Сообщение21.11.2019, 23:03 
Заслуженный участник


10/01/16
2318
madschumacher в сообщении #1426982 писал(а):
Поэтому я находил ячейку, максимально достижимую с последней занятой, ограничивался только ячейками ниже неё по энергии, и пытался гнать Монте-Карло

Зачем сразу МонтеКарло? Ведь получается такая же задача - так рекурсивно ее и решать...
Т.е., план такой :
1. находим макимально возможный уровень для "вверх",
2. (цикл пошел) суем туда электрон, и решаем такую же задачу для оставшихся (электронов и остатка энергии);
перекладываем главный электрон на меньший уровень, и решаем такую же задачу;
и т.д... (только надо будет запретить электроны класть выше главного)
3. (внутренний цикл пошел) внешний цикл закончит работу, когда все электроны "вверх" займут какие-то позиции. Теперь то же делаем с теми, кто "вверх"....

(Оффтоп)

А вот если уровни - просто степени двойки, то количество комбинаций можно найти явно. Скажем, если есть только "вверх", то кол-во комбинаций считается...

 Профиль  
                  
Показать сообщения за:  Поле сортировки  
Начать новую тему Ответить на тему  [ Сообщений: 5 ] 

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



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

Сейчас этот форум просматривают: нет зарегистрированных пользователей


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

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