From ccebc561786b4a4e1d8d0aeeaa80f594002d199f Mon Sep 17 00:00:00 2001 From: Geoff Hutchison Date: Tue, 17 Oct 2023 22:53:16 -0400 Subject: [PATCH 1/2] Fix typos in isovalue and homo/lumo math Signed-off-by: Geoff Hutchison --- avogadro/qtplugins/surfaces/surfaces.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/avogadro/qtplugins/surfaces/surfaces.cpp b/avogadro/qtplugins/surfaces/surfaces.cpp index 05f5cd6586..87071bced1 100644 --- a/avogadro/qtplugins/surfaces/surfaces.cpp +++ b/avogadro/qtplugins/surfaces/surfaces.cpp @@ -144,7 +144,7 @@ bool Surfaces::handleCommand(const QString& command, const QVariantMap& options) cubeResolution = res; } if (options.contains("isovalue") && - options["isolvalue"].canConvert()) { + options["isovalue"].canConvert()) { bool ok; float iso = options["isovalue"].toFloat(&ok); if (ok) @@ -165,7 +165,7 @@ bool Surfaces::handleCommand(const QString& command, const QVariantMap& options) expression = name.remove("homo", Qt::CaseInsensitive); } else if (name.contains("lumo", Qt::CaseInsensitive)) { index = homo + 1; // again modified by the expression - expression = name.remove("homo", Qt::CaseInsensitive); + expression = name.remove("lumo", Qt::CaseInsensitive); } // modify HOMO / LUMO based on "+ number" or "- number" if (expression.contains('-')) { From f6b2ff6c67dfc4532ecbcdb51226808d5dbbf7dc Mon Sep 17 00:00:00 2001 From: Geoff Hutchison Date: Tue, 17 Oct 2023 23:13:55 -0400 Subject: [PATCH 2/2] Fix off-by-one error between user orbital numbers and internal idx Signed-off-by: Geoff Hutchison --- avogadro/qtplugins/surfaces/surfaces.cpp | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/avogadro/qtplugins/surfaces/surfaces.cpp b/avogadro/qtplugins/surfaces/surfaces.cpp index 87071bced1..59ce8e13b9 100644 --- a/avogadro/qtplugins/surfaces/surfaces.cpp +++ b/avogadro/qtplugins/surfaces/surfaces.cpp @@ -143,8 +143,7 @@ bool Surfaces::handleCommand(const QString& command, const QVariantMap& options) if (ok) cubeResolution = res; } - if (options.contains("isovalue") && - options["isovalue"].canConvert()) { + if (options.contains("isovalue") && options["isovalue"].canConvert()) { bool ok; float iso = options["isovalue"].toFloat(&ok); if (ok) @@ -181,9 +180,11 @@ bool Surfaces::handleCommand(const QString& command, const QVariantMap& options) if (ok) index = index + n; } - - } else - index = options.value("index").toInt(); + index = index - 1; // start from zero + } else { + // internally, we count orbitals from zero + index = options.value("index").toInt() - 1; + } } bool beta = false; if (options.contains("spin")) {