33 QStringList
const &workspaceNames = QStringList(),
double startX = 0.0,
37 void notifyPresenter(
ViewEvent const &event, [[maybe_unused]] std::string
const &arg1 =
"",
38 [[maybe_unused]] std::string
const &arg2 =
"")
override;
39 void notifyPresenter(
ViewEvent const &event, std::vector<std::string>
const &
vec)
override;
41 void handleAddDomainAccepted(std::vector<Mantid::API::MatrixWorkspace_const_sptr>
const &workspaces,
44 void openFitScriptGenerator()
override;
46 void setGlobalTies(std::vector<GlobalTie>
const &globalTies)
override;
47 void setGlobalParameters(std::vector<GlobalParameter>
const &globalParameters)
override;
50 void handleADSDeleteEvent(std::string
const &workspaceName);
51 void handleADSClearEvent();
52 void handleADSRenameEvent(std::string
const &workspaceName, std::string
const &newName);
53 void handleRemoveDomainClicked();
54 void handleAddDomainClicked();
55 void handleSelectionChanged();
56 void handleStartXChanged();
57 void handleEndXChanged();
58 void handleFunctionRemoved(std::string
const &function);
59 void handleFunctionAdded(std::string
const &function);
60 void handleFunctionReplaced(std::string
const &function);
61 void handleParameterChanged(std::string
const ¶meter);
62 void handleAttributeChanged(std::string
const &attribute);
63 void handleParameterTieChanged(std::string
const ¶meter, std::string
const &tie);
64 void handleParameterConstraintRemoved(std::string
const ¶meter);
65 void handleParameterConstraintChanged(std::string
const &functionIndex, std::string
const &constraint);
66 void handleGlobalParametersChanged(std::vector<std::string>
const &globalParameters);
67 void handleEditLocalParameterClicked(std::string
const ¶meter);
68 void handleEditLocalParameterFinished();
69 void handleOutputBaseNameChanged(std::string
const &outputBaseName);
70 void handleFittingModeChanged(
FittingMode fittingMode);
71 void handleGenerateScriptToFileClicked();
72 void handleGenerateScriptToClipboardClicked();
74 void setWorkspaces(QStringList
const &workspaceNames,
double startX,
double endX);
75 void addWorkspaces(std::vector<Mantid::API::MatrixWorkspace_const_sptr>
const &workspaces,
77 void addWorkspace(std::string
const &workspaceName,
double startX,
double endX);
80 double startX,
double endX);
83 void removeDomains(std::vector<FitDomainIndex>
const &domainIndices);
85 void updateStartX(std::string
const &workspaceName,
WorkspaceIndex workspaceIndex,
double startX);
86 void updateEndX(std::string
const &workspaceName,
WorkspaceIndex workspaceIndex,
double endX);
88 void updateParameterValue(std::string
const &workspaceName,
WorkspaceIndex workspaceIndex,
89 std::string
const ¶meter,
double newValue);
90 void updateAttributeValue(std::string
const &workspaceName,
WorkspaceIndex workspaceIndex,
93 void updateParameterTie(std::string
const &workspaceName,
WorkspaceIndex workspaceIndex, std::string
const ¶meter,
94 std::string
const &tie);
96 void removeParameterConstraint(std::string
const &workspaceName,
WorkspaceIndex workspaceIndex,
97 std::string
const ¶meter);
98 void updateParameterConstraint(std::string
const &workspaceName,
WorkspaceIndex workspaceIndex,
99 std::string
const &functionIndex, std::string
const &constraint);
101 void removeFunction(std::string
const &workspaceName,
WorkspaceIndex workspaceIndex, std::string
const &function);
102 void addFunction(std::string
const &workspaceName,
WorkspaceIndex workspaceIndex, std::string
const &function);
103 void setFunction(std::string
const &workspaceName,
WorkspaceIndex workspaceIndex, std::string
const &function);
107 template <
typename GetX,
typename UpdateX>
void updateXLimitForDomain(GetX &&getX, UpdateX &&updateX);
109 template <
typename UpdateFunction>
110 void updateFunctionStructure(UpdateFunction &&updateFunction, std::string
const &function);
112 template <
typename UpdateFunction,
typename... Args>
113 void updateFunctionsInModel(UpdateFunction &&updateFunction, Args... arguments);
115 template <
typename Function,
typename... Args>
116 void invokeFunctionForDomain(
FitDomainIndex domainIndex, Function &&func, Args... arguments);
118 [[nodiscard]] std::vector<FitDomainIndex> getRowIndices()
const;
120 void insertLocalParameterData(std::string
const ¶meter, std::vector<std::string> &workspaceNames,
121 std::vector<std::string> &domainNames, std::vector<double> &values,
122 std::vector<bool> &fixes, std::vector<std::string> &ties,
123 std::vector<std::string> &constraints)
const;
124 void insertLocalParameterDataForDomain(
FitDomainIndex domainIndex, std::string
const ¶meter,
125 std::vector<std::string> &workspaceNames,
126 std::vector<std::string> &domainNames, std::vector<double> &values,
127 std::vector<bool> &fixes, std::vector<std::string> &ties,
128 std::vector<std::string> &constraints)
const;
130 void setLocalParameterDataForDomain(
FitDomainIndex domainIndex, std::string
const ¶meter,
double value,
bool fix,
131 std::string
const &tie, std::string
const &constraint);
133 std::vector<FitDomainIndex> getDomainsWithLocalParameter(std::string
const ¶meter)
const;
135 std::tuple<std::string, std::string> convertFunctionIndexOfParameterTie(std::string
const &workspaceName,
137 std::string
const ¶meter,
138 std::string
const &tie)
const;
140 void checkForWarningMessages();
142 template <
typename Generator>
void generateFitScript(Generator &&func)
const;
143 void generateScriptToFile()
const;
144 void generateScriptToClipboard()
const;