|
|
|
Wolfram Math: ADT18.02.2012, 22:14. Показов 2155. Ответов 1
Метки нет (Все метки)
Добрый вечер!
Только что сел за Вольфрам посчитать то, что лень руками считать, и подумал, как бы так сделать, чтоб облегчить себе жизнь. ) Первое, на чём я споткнулся, это ADT (Data Types). Как-то до этого мне вполне хватало нативных типов. Сегодня я явно захотел объявить новую структуру. Подскажите, кто знает, как это сделать. Пусть постановка задачи такова
Описать структуру данных Ket, которая имеет стандартный конструктор KetX[y[x,t]]. Описать двухаргументную функцию Multiply[f_,y_], которая проверяет, что оба аргумента являются Ket, и если они были созданы при помощи KetX, то возвращает Integrate[f Conjugate[y],{x,-Infinity,Infinity}]. Надеюсь описал понятно. Может, картинка ниже покажет, какой диалог я хочу видеть, когда всё будет реализовано. В общем, проверка аргументов реализуема (есть спец. символ /; для проверки). Но вот очень туго с пониманием того, как был определить конструктор. Ведь у типа (или как его назвать) Ket может быть не только конструктор KetX. Пусть KetP[y[x]] — другой конструктор. Тогда я ожидаю такое поведение функции Multiply: KetP[f[p]] ~Multiply~ KetP[g[p]] == Integrate[f[p] Conjugate@g[p],{p,-Infinity,Infinity}] KetX[f[x]] ~Multiply~ KetX[g[x]] == Integrate[f[x] Conjugate@g[x],{x,-Infinity,Infinity}] KetP[f[p]] ~Multiply~ KetX[g[x]] == Integrate[FourierTransform[f[p],p,x] Conjugate@g[x],{x,-Infinity,Infinity} Именно в формулах смысла особого нет, просто хочу сказать, что у Ket может быть несколько конструкторов, определяющих представление моего объекта, но на некотором уровне абстракции я не должен знать об этих различных реализациях (KetX, KetP), довольствуясь универсальностью заданных функций (Multiply). Собственно, для этого и нужен ADT.
0
|
|
| 18.02.2012, 22:14 | |
|
Ответы с готовыми решениями:
1
Student+ Wolfram Alpha от Wolfram Researh. Почему Math.round(Math.random() * (max - min) дает неравномерное распределение? Заменить Math.Min, Math.Max операторами if-else |
|
|
|||||||||||
| 07.09.2013, 13:28 [ТС] | |||||||||||
|
Не хочу показаться некромантом, просто увидел свою же тему через полтора года и понял, что сейчас я знаю, как следует сделать.
В Wolfram Mathematica определение функции, будь то lhs=rhs или lhs:=rhs производит на свет правило замены lhs->rhs и lhs:>rhs соответственно. Эти правила существуют не обособленно, а в привязке к какому-то символу (заголовку, Head). Обычно, объявление f[x_]:=P приписывается заголовку f. Но можно это менять. Для этого используется символ ^= или более конкретный /: Ниже приведено решение. Описаны две похожие структуры: KetX и KetP — функции в прямом и обратном пространстве. Функция в прямом пространстве KetX считается доминирующей, к ней при необходимости согласовать сводится KetP. Основной профит этого решения в расширяемости: если будет добавлено ещё какое-то представление KetZ с правилом KetX[KetZ[f_]]^:=..., функция KetXPlot будет работать и на нём без явного приведения.
Это наверняка можно сделать красивее, явно найдя правило KetX[_]:>... в списке UpValues (там, правда, HoldPattern сложно снять) или что-то подобное; вот работающий вариант, который проверяет, редуцируется ли KetX[f], по заголовку аргумента KetX
Подробнее см. Associating Definitions with Different Symbols из туториала Transformation Rules and Definitions, а также справку к UpValues и DownValues
0
|
|||||||||||
| 07.09.2013, 13:28 | |
|
Помогаю со студенческими работами здесь
2
math или не math?! вот в чем вопрос...
Windows Form Math:: или Math Float и метод Math.Ceiling и Math.Round? как округлить float? Adt+DES Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие.
Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
|
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ВВЕДЕНИЕ
Выполняя задание на управление насосной группой заполнения резервуара,. . .
|
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
|
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога
Финальные проекты на Си и на C++:
hello-sdl3-c. zip
hello-sdl3-cpp. zip
Результат:
|
|
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога
MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
|
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд.
Даже если у вас. . .
|
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает
монорепозиторий в котором находятся все исходники.
При создании нового решения, мы просто добавляем нужные проекты
и имеем. . .
|
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение:
В этой книге («Подход, основанный на вариантах использования») Ивар утверждает,
что архитектура программного обеспечения — это
структуры,. . .
|