2 * This file is part of the GROMACS molecular simulation package.
4 * Copyright (c) 2018, by the GROMACS development team, led by
5 * Mark Abraham, David van der Spoel, Berk Hess, and Erik Lindahl,
6 * and including many others, as listed in the AUTHORS file in the
7 * top-level source directory and at http://www.gromacs.org.
9 * GROMACS is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU Lesser General Public License
11 * as published by the Free Software Foundation; either version 2.1
12 * of the License, or (at your option) any later version.
14 * GROMACS is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 * Lesser General Public License for more details.
19 * You should have received a copy of the GNU Lesser General Public
20 * License along with GROMACS; if not, see
21 * http://www.gnu.org/licenses, or write to the Free Software Foundation,
22 * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
24 * If you want to redistribute modifications to GROMACS, please
25 * consider that scientific software is very special. Version
26 * control is crucial - bugs must be traceable. We will be happy to
27 * consider code for inclusion in the official distribution, but
28 * derived work must not be called official GROMACS. Details are found
29 * in the README & COPYING files - if they are missing, get the
30 * official version at http://www.gromacs.org.
32 * To help us fund GROMACS development, we humbly ask that you cite
33 * the research papers on the package. Check out http://www.gromacs.org.
36 * \brief Launch and manage a GROMACS session.
38 * \author M. Eric Irrgang <ericirrgang@gmail.com>
43 #ifndef GROMACS_SESSION_H
44 #define GROMACS_SESSION_H
47 * \brief Declarations for a workflow execution session and helper functions.
58 // forward declarations
59 class Context
; // defined in gmxapi/context.h
61 class Status
; // defined in gmxapi/status.h
62 class Workflow
; // implementation detail
65 * \brief Private implementation class for a session.
67 * Actual implementation class may depend on the execution context, but this should be irrelevant to
68 * a client. The implementation details are not exposed in the high-level API, but may be in the extension
69 * API. See developer documentation for details.
76 * \brief Workflow execution session.
78 * When a workflow is launched in an execution context, the result is a Session object
79 * that serves as a handle to interact with the running workflow. The handle allows dynamic changes to
80 * the workflow, or control or data crossing the API boundary.
82 * Separating run() from construction allows the client to examine the running execution
83 * environment or to retrieve the communicator before beginning long-running computation.
85 * The session should be explicitly `close()`ed before destruction to allow exception
86 * handling during shutdown. The destructor will close() the session if it is not
87 * closed already, but errors may be hidden.
89 * The session owns a Status object that can be shared and retained by client code
90 * for further inspection.
97 /// A session must be created by launching a workflow in an execution context.
100 /*! \brief A session cannot be copied, only moved.
102 * For shared ownership of a session, use a shared pointer.
105 Session(const Session
&) = delete;
106 Session
&operator=(const Session
&) = delete;
110 * \brief Pass ownership of a Session.
114 Session(Session
&&) noexcept
= default;
115 Session
&operator=(Session
&&) noexcept
= default;
119 * \brief Construct by taking ownership of an implementation object.
121 * \param impl Concrete object to take ownership of.
123 explicit Session(std::unique_ptr
<SessionImpl
> impl
) noexcept
;
126 * \brief Destroy Session.
128 * If the session is still active (has not been closed) then it will be closed
129 * with exceptions suppressed. If possible, problems encountered will be
130 * noted in the Status object, which the client may have retained shared
136 * \brief Close a running session.
138 * close() should be called before destroying the Session object so that the
139 * client can catch any exceptions thrown during shut down that may be
140 * unavoidable in the parallel computing environment.
142 * \return status of close() operation.
147 * \brief Run the current workflow to completion.
149 * The client should examine the Status object for errors and resulting workflow state.
150 * \return the Session's Status after the run.
152 Status
run() noexcept
;
155 * \brief Check if session is running.
157 * A Session will be "open" from the point of launch until "close" is
158 * called. If this is not true, either an error has occurred or there is
159 * a bug in the implementation.
161 * \return `true` if the session is running, else `false`
163 bool isOpen() const noexcept
;
166 * \brief Get a non-owning handle to the implementation object.
168 * Get a raw pointer to the implementation object. The pointer is valid only during the lifetime of the Session,
169 * so retain a shared pointer to this Session object or only hold the pointer for the duration of a code block
170 * guaranteed to exist entirely within the lifetime of a Session object.
172 * \return opaque pointer used by gmxapi implementation and extension code.
174 SessionImpl
* getRaw() const noexcept
;
178 //! \brief opaque pointer to implementation
179 std::unique_ptr
<SessionImpl
> impl_
;
183 * \brief Add a uniquely identifiable restraint instance to the MD simulator.
185 * \param session Session with an MD runner to attach a restraint to.
186 * \param restraint wrapped restraint force calculation object.
187 * \return success if restraint was attached successfully, else failure.
189 * \todo Clarify whether we are adding modules generally, adding restraint modules, or adding restraints.
190 * \todo Update for new scheme in which all restraints are managed by a single Restraint module.
191 * \todo Figure out what this object should return to provide more utility and rigorous error checking.
193 Status
addSessionRestraint(Session
* session
,
194 std::shared_ptr
<gmxapi::MDModule
> restraint
);
197 * \brief Launch a workflow in the provided execution context.
199 * \param context Execution environment
200 * \param work Directed acyclic graph defining workflow and data flow.
201 * \return non-unique ownership of the session or nullptr in failure.
203 * The provided context maintains a weak reference to the executing session, while
204 * the session extends the life of the context.
206 * If session fails to launch (nullptr returned) examine the Status of the context
210 std::shared_ptr
<Session
> launchSession(Context
* context
, const Workflow
&work
) noexcept
;
213 } // end namespace gmxapi
215 #endif //GROMACS_SESSION_H