From 72644469bd6ee0d9263fb3bc455a9b6396b5862f Mon Sep 17 00:00:00 2001 From: Peter Greth Date: Sun, 3 Apr 2022 18:17:15 +0200 Subject: [PATCH 1/6] Update proxymusic to 4.0.2 This version's Mxl.Input closes the underlying resources, allowing regression test execution to clean up afterwards --- build.gradle | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/build.gradle b/build.gradle index 949e05584..9615fb41d 100644 --- a/build.gradle +++ b/build.gradle @@ -107,7 +107,7 @@ dependencies { [group: 'javax.media', name: 'jai-core', version: '1.1.3'], [group: 'net.imagej', name: 'ij', version: '1.53j'], [group: 'de.intarsys.opensource', name: 'jPodRenderer', version: '5.6'], - [group: 'org.audiveris', name: 'proxymusic', version: '4.0.1'], + [group: 'org.audiveris', name: 'proxymusic', version: '4.0.2'], [group: 'org.jgrapht', name: 'jgrapht-core', version: '1.5.1'], [group: 'org.jfree', name: 'jfreechart', version: '1.5.3'], [group: 'com.itextpdf', name: 'itextpdf', version: '5.5.13.2'], From de1dbe531eb5d8afd43b4aee722675a8acd2fb96 Mon Sep 17 00:00:00 2001 From: Peter Greth Date: Sun, 3 Apr 2022 18:20:10 +0200 Subject: [PATCH 2/6] Stop log appender before detaching This frees the underlying log file, allowing regression test execution to clean up afterwards --- src/main/org/audiveris/omr/CLI.java | 2 +- src/main/org/audiveris/omr/log/LogUtil.java | 3 ++- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/src/main/org/audiveris/omr/CLI.java b/src/main/org/audiveris/omr/CLI.java index 41477f338..884abf068 100644 --- a/src/main/org/audiveris/omr/CLI.java +++ b/src/main/org/audiveris/omr/CLI.java @@ -585,7 +585,7 @@ protected void processBook (Book book) LogUtil.stopBook(); if (OMR.gui == null) { - LogUtil.removeAppender(book.getRadix()); + LogUtil.stopAndRemoveAppender(book.getRadix()); } } } diff --git a/src/main/org/audiveris/omr/log/LogUtil.java b/src/main/org/audiveris/omr/log/LogUtil.java index e110d8551..9c6e6e0f8 100644 --- a/src/main/org/audiveris/omr/log/LogUtil.java +++ b/src/main/org/audiveris/omr/log/LogUtil.java @@ -299,10 +299,11 @@ public static void initialize (Path CONFIG_FOLDER, * * @param name appender name (typically the book radix) */ - public static void removeAppender (String name) + public static void stopAndRemoveAppender (String name) { Logger root = (ch.qos.logback.classic.Logger) LoggerFactory.getLogger( Logger.ROOT_LOGGER_NAME); + root.getAppender(name).stop(); root.detachAppender(name); } From 9f63f0596bb39e361072003c7caaddf6602794ba Mon Sep 17 00:00:00 2001 From: Peter Greth Date: Sun, 3 Apr 2022 19:17:35 +0200 Subject: [PATCH 3/6] Regression tests for quality measurement Java/Junit adaptation of PR by Alexander Myltsev (@avm). Test cases can be configured using ConversionScoreTestCase.java. Tests are executed using ConversionScoreRegressionTest.java. The similarity of actual output and expected output is calculated in ScoreSimilarity.java. --- src/main/org/audiveris/omr/util/FileUtil.java | 36 +++ .../org/audiveris/omr/util/SetOperation.java | 72 ++++++ .../score/ConversionScoreRegressionTest.java | 206 ++++++++++++++++++ .../score/ConversionScoreTestCase.java | 105 +++++++++ .../conversion/score/ScoreSimilarity.java | 192 ++++++++++++++++ 5 files changed, 611 insertions(+) create mode 100644 src/main/org/audiveris/omr/util/SetOperation.java create mode 100644 src/test/conversion/score/ConversionScoreRegressionTest.java create mode 100644 src/test/conversion/score/ConversionScoreTestCase.java create mode 100644 src/test/conversion/score/ScoreSimilarity.java diff --git a/src/main/org/audiveris/omr/util/FileUtil.java b/src/main/org/audiveris/omr/util/FileUtil.java index b09612351..732a801d0 100644 --- a/src/main/org/audiveris/omr/util/FileUtil.java +++ b/src/main/org/audiveris/omr/util/FileUtil.java @@ -43,6 +43,8 @@ import java.nio.file.attribute.BasicFileAttributes; import java.util.ArrayList; import java.util.List; +import java.util.Optional; +import java.util.function.Predicate; /** * Class FileUtil gathers convenient utility methods for files (and paths). @@ -490,4 +492,38 @@ public FileVisitResult postVisitDirectory (Path dir, return pathsFound; } + + //---------------------// + // findFileInDirectory // + //---------------------// + /** + * Finds a file in the given directory (non-recursive) matching the given predicate. + * + * @param directory the directory in which to look for the file + * @param fileMatches the condition for inclusion, evaluated for each file + * @return the first matching file + */ + public static Optional findFileInDirectory (Path directory, Predicate fileMatches) + throws IOException + { + return Files.walk(directory, 1) + .filter(Files::isRegularFile) + .filter(fileMatches) + .findFirst(); + } + + //---------------------------------// + // fileNameWithoutExtensionMatches // + //---------------------------------// + /** + * Creates a predicate on Path that evaluates to true if the path's name matches the given file name. + * To be used e.g. as parameter to {@link #findFileInDirectory(Path, Predicate)}. + * + * @param fileName the file name to match + * @return the predicate + */ + public static Predicate fileNameWithoutExtensionMatches (String fileName) + { + return path -> FileUtil.sansExtension(path.getFileName().toString()).equals(fileName); + } } diff --git a/src/main/org/audiveris/omr/util/SetOperation.java b/src/main/org/audiveris/omr/util/SetOperation.java new file mode 100644 index 000000000..06c928f77 --- /dev/null +++ b/src/main/org/audiveris/omr/util/SetOperation.java @@ -0,0 +1,72 @@ +//------------------------------------------------------------------------------------------------// +// // +// S e t O p e r a t i o n // +// // +//------------------------------------------------------------------------------------------------// +// +// +// Copyright © Audiveris 2022. All rights reserved. +// +// This program is free software: you can redistribute it and/or modify it under the terms of the +// GNU Affero General Public License as published by the Free Software Foundation, either version +// 3 of the License, or (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; +// without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. +// See the GNU Affero General Public License for more details. +// +// You should have received a copy of the GNU Affero General Public License along with this +// program. If not, see . +//------------------------------------------------------------------------------------------------// +// +package org.audiveris.omr.util; + +import java.util.HashSet; +import java.util.Set; + +/** + * Utility class for operations on Sets. + * + * @author Peter Greth + */ +public abstract class SetOperation +{ + /** + * The union of two sets. + * Returns all elements that are in any of the two sets. + */ + public static Set union (Set a, Set b) + { + Set unionSet = new HashSet<>(); + unionSet.addAll(a); + unionSet.addAll(b); + return unionSet; + } + + /** + * The intersection of two sets. + * Returns only those elements that are in both of the sets. + */ + @SuppressWarnings("CollectionAddAllCanBeReplacedWithConstructor") + public static Set intersection (Set a, Set b) + { + Set unionSet = new HashSet<>(); + unionSet.addAll(a); + unionSet.retainAll(b); + return unionSet; + } + + /** + * The diff of two sets. + * Returns only those elements of set a that are not in set b. + */ + @SuppressWarnings("CollectionAddAllCanBeReplacedWithConstructor") + public static Set diff (Set a, Set b) + { + Set diffSet = new HashSet<>(); + diffSet.addAll(a); + diffSet.removeAll(b); + return diffSet; + } + +} diff --git a/src/test/conversion/score/ConversionScoreRegressionTest.java b/src/test/conversion/score/ConversionScoreRegressionTest.java new file mode 100644 index 000000000..645c1f713 --- /dev/null +++ b/src/test/conversion/score/ConversionScoreRegressionTest.java @@ -0,0 +1,206 @@ +//------------------------------------------------------------------------------------------------// +// // +// C o n v e r s i o n S c o r e R e g r e s s i o n T e s t // +// // +//------------------------------------------------------------------------------------------------// +// +// +// Copyright © Audiveris 2021. All rights reserved. +// +// This program is free software: you can redistribute it and/or modify it under the terms of the +// GNU Affero General Public License as published by the Free Software Foundation, either version +// 3 of the License, or (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; +// without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. +// See the GNU Affero General Public License for more details. +// +// You should have received a copy of the GNU Affero General Public License along with this +// program. If not, see . +//------------------------------------------------------------------------------------------------// +// +package conversion.score; + +import ch.qos.logback.classic.Level; +import ch.qos.logback.classic.Logger; +import org.audiveris.omr.Main; +import org.audiveris.omr.util.FileUtil; +import org.audiveris.proxymusic.ScorePartwise; +import org.audiveris.proxymusic.mxl.Mxl; +import org.audiveris.proxymusic.util.Marshalling; +import org.junit.After; +import org.junit.Before; +import org.junit.BeforeClass; +import org.junit.Test; +import org.junit.runner.RunWith; +import org.junit.runners.Parameterized; +import org.junit.runners.Parameterized.Parameter; +import org.junit.runners.Parameterized.Parameters; +import org.slf4j.LoggerFactory; + +import javax.xml.bind.JAXBException; +import java.io.FileInputStream; +import java.io.IOException; +import java.io.InputStream; +import java.nio.file.Files; +import java.nio.file.Path; +import java.util.*; +import java.util.zip.ZipEntry; + +import static org.audiveris.omr.OMR.COMPRESSED_SCORE_EXTENSION; +import static org.audiveris.omr.OMR.SCORE_EXTENSION; +import static org.junit.Assert.assertFalse; +import static org.junit.Assert.assertTrue; + +/** + * Regression test that checks Audiveris' accuracy according to samples located in src/test/resources/conversion/score. + * Similarity of converted input and expected output is measured using class {@link ScoreSimilarity}. + * To add a new sample, please include its directory name and the resulting conversion score in {@link #TEST_CASES}. + * + * @author Peter Greth + */ +@RunWith(Parameterized.class) +public class ConversionScoreRegressionTest +{ + /** + * List of test cases. Each of these will be tested separately + */ + private final static List TEST_CASES = List.of( + ); + + /** + * The name of the input file for each test case + */ + private final static String INPUT_FILE_NAME = "input"; + + /** + * The current test case (provided by {@link #testCaseProvider()}, executed separately by JUnit) + */ + @Parameter + public ConversionScoreTestCase underTest; + + /** + * The directory into which Audiveris can output the parsed score + */ + private Path outputDirectory; + + /** + * @return a list of test cases that are executed each + */ + @Parameters(name = "{0}") // "{0}" provides a readable test name using conversion.score.TestCase::toString + public static Collection testCaseProvider () + { + return TEST_CASES; + } + + /** + * Reduce logging verbosity (increases execution time significantly) + */ + @BeforeClass + public static void reduceLoggingVerbosity () + { + Logger root = (ch.qos.logback.classic.Logger) LoggerFactory.getLogger(Logger.ROOT_LOGGER_NAME); + root.setLevel(Level.WARN); + } + + @Before + public void createOutputDirectory () + throws IOException + { + outputDirectory = Files.createTempDirectory(String.format("audiveris-test-%s", underTest.subDirectoryName)); + } + + @After + public void removeOutputDirectory () + throws IOException + { + if (Files.exists(outputDirectory)) { + FileUtil.deleteDirectory(outputDirectory); + } + } + + /** + * The actual regression test, executed for each test case defined in {@link #TEST_CASES}. + * Converts the input file using Audiveris, then compares the produced result with the expected result. + * For comparison {@link ScoreSimilarity#conversionScore(ScorePartwise.Part, ScorePartwise.Part)} is used. + * This test will fail if the conversion score changed in any direction. + */ + @Test + public void testConversionScoreChanged () + throws IOException, + JAXBException, + Mxl.MxlException, + Marshalling.UnmarshallingException + { + ScorePartwise expectedScore = loadXmlScore(underTest.findExpectedOutputFile()); + assertFalse("Could not load expected output: Contains no Part", expectedScore.getPart().isEmpty()); + + Path outputMxl = audiverisBatchExport(outputDirectory, underTest.findInputFile()); + ScorePartwise actualScore = loadMxlScore(outputMxl); + assertFalse("Could not load actual output: Contains no Part", actualScore.getPart().isEmpty()); + + int actualConversionScore = ScoreSimilarity.conversionScore(expectedScore, actualScore); + failIfConversionScoreDecreased(underTest.expectedConversionScore, actualConversionScore); + failIfConversionScoreIncreased(underTest.expectedConversionScore, actualConversionScore); + } + + private static ScorePartwise loadXmlScore (Path xmlFile) + throws IOException, + Marshalling.UnmarshallingException + { + try (InputStream inputStream = new FileInputStream(xmlFile.toFile())) { + Object score = Marshalling.unmarshal(inputStream); + assertTrue(score instanceof ScorePartwise); + return (ScorePartwise) score; + } + } + + private static Path audiverisBatchExport (Path outputDirectory, Path inputFile) + { + Main.main(new String[]{ + "-batch", + "-export", + "-output", outputDirectory.toAbsolutePath().toString(), + inputFile.toAbsolutePath().toString() + }); + Path outputMxlFile = outputDirectory + .resolve(INPUT_FILE_NAME) // folder named equal to input file name + .resolve(INPUT_FILE_NAME + COMPRESSED_SCORE_EXTENSION); + assertTrue(Files.exists(outputMxlFile)); + return outputMxlFile; + } + + private static ScorePartwise loadMxlScore (Path mxlFile) + throws Mxl.MxlException, + Marshalling.UnmarshallingException, + JAXBException, + IOException + { + try (Mxl.Input outputMxlFileReader = new Mxl.Input(mxlFile.toFile())) { + ZipEntry xmlEntry = outputMxlFileReader.getEntry(INPUT_FILE_NAME + SCORE_EXTENSION); + Object score = Marshalling.unmarshal(outputMxlFileReader.getInputStream(xmlEntry)); + assertTrue(score instanceof ScorePartwise); + return (ScorePartwise) score; + } + } + + private static void failIfConversionScoreDecreased (int expectedConversionScore, int actualConversionScore) + { + String message = String.format("The conversion score decreased from %d to %d (diff: %d).", + expectedConversionScore, + actualConversionScore, + actualConversionScore - expectedConversionScore); + assertFalse(message, actualConversionScore < expectedConversionScore); + } + + private static void failIfConversionScoreIncreased (int expectedConversionScore, int actualConversionScore) + { + String message = String.format("Well done, the conversion score increased from %d to %d (diff: %d). " + + "Please adapt conversion.score.TestCase::TEST_CASES accordingly.", + expectedConversionScore, + actualConversionScore, + actualConversionScore - expectedConversionScore); + assertFalse(message, actualConversionScore > expectedConversionScore); + } + +} diff --git a/src/test/conversion/score/ConversionScoreTestCase.java b/src/test/conversion/score/ConversionScoreTestCase.java new file mode 100644 index 000000000..5482e9845 --- /dev/null +++ b/src/test/conversion/score/ConversionScoreTestCase.java @@ -0,0 +1,105 @@ +//------------------------------------------------------------------------------------------------// +// // +// C o n v e r s i o n S c o r e T e s t C a s e // +// // +//------------------------------------------------------------------------------------------------// +// +// +// Copyright © Audiveris 2021. All rights reserved. +// +// This program is free software: you can redistribute it and/or modify it under the terms of the +// GNU Affero General Public License as published by the Free Software Foundation, either version +// 3 of the License, or (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; +// without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. +// See the GNU Affero General Public License for more details. +// +// You should have received a copy of the GNU Affero General Public License along with this +// program. If not, see . +//------------------------------------------------------------------------------------------------// +// +package conversion.score; + +import org.audiveris.omr.util.FileUtil; + +import java.io.IOException; +import java.net.URISyntaxException; +import java.net.URL; +import java.nio.file.Path; +import java.util.*; + +import static org.audiveris.omr.util.FileUtil.fileNameWithoutExtensionMatches; + +/** + * A test case configuration for {@link ConversionScoreRegressionTest}. It consists of + * - a directory name that should be a subdirectory of src/test/resources/conversion/score, and + * - an expected conversion score, that will be compared to the actual conversion score. + * + * @author Peter Greth + */ +public class ConversionScoreTestCase +{ + private final static String INPUT_FILE_NAME = "input"; + private final static String EXPECTED_OUTPUT_FILE_NAME = "expected-output.xml"; + + public String subDirectoryName; + public int expectedConversionScore; + + public static ConversionScoreTestCase ofSubDirectory (String subDirectoryName) + { + ConversionScoreTestCase conversionScoreTestCase = new ConversionScoreTestCase(); + conversionScoreTestCase.subDirectoryName = subDirectoryName; + return conversionScoreTestCase; + } + + public ConversionScoreTestCase withExpectedConversionScore (int expectedConversionScore) + { + this.expectedConversionScore = expectedConversionScore; + return this; + } + + public Path findInputFile () + { + Path testCaseDirectory = getTestCaseDirectory(); + try { + return FileUtil + .findFileInDirectory(testCaseDirectory, fileNameWithoutExtensionMatches(INPUT_FILE_NAME)) + .orElseThrow() + .toAbsolutePath(); + } catch (IOException | NoSuchElementException e) { + String message = String.format("Could not find file with name '%s.*' in directory %s", INPUT_FILE_NAME, + testCaseDirectory); + throw new IllegalStateException(message, e); + } + } + + public Path findExpectedOutputFile () + { + return getTestCaseDirectory().resolve(EXPECTED_OUTPUT_FILE_NAME).toAbsolutePath(); + } + + private Path getTestCaseDirectory () + { + try { + return Path.of(getTestCaseDirectoryUrl().toURI()); + } catch (URISyntaxException e) { + throw new IllegalStateException(e); + } + } + + private URL getTestCaseDirectoryUrl () + { + URL resource = getClass().getResource(subDirectoryName); + String message = String.format("Could not find directory with name '%s' in test resources for package %s", + subDirectoryName, getClass().getPackageName()); + Objects.requireNonNull(resource, message); + return resource; + } + + @Override + public String toString () + { + return String.format("TestCase %s", subDirectoryName); + } +} diff --git a/src/test/conversion/score/ScoreSimilarity.java b/src/test/conversion/score/ScoreSimilarity.java new file mode 100644 index 000000000..59f8477b9 --- /dev/null +++ b/src/test/conversion/score/ScoreSimilarity.java @@ -0,0 +1,192 @@ +//------------------------------------------------------------------------------------------------// +//------------------------------------------------------------------------------------------------// +// // +// S c o r e S i m i l a r i t y // +// // +//------------------------------------------------------------------------------------------------// +// +// +// Copyright © Audiveris 2021. All rights reserved. +// +// This program is free software: you can redistribute it and/or modify it under the terms of the +// GNU Affero General Public License as published by the Free Software Foundation, either version +// 3 of the License, or (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; +// without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. +// See the GNU Affero General Public License for more details. +// +// You should have received a copy of the GNU Affero General Public License along with this +// program. If not, see . +//------------------------------------------------------------------------------------------------// +// +package conversion.score; + +import org.audiveris.proxymusic.Backup; +import org.audiveris.proxymusic.Forward; +import org.audiveris.proxymusic.Note; +import org.audiveris.proxymusic.ScorePartwise; +import org.audiveris.proxymusic.ScorePartwise.Part; +import org.audiveris.proxymusic.ScorePartwise.Part.Measure; +import org.audiveris.proxymusic.Step; + +import java.lang.String; +import java.math.BigDecimal; +import java.util.HashSet; +import java.util.List; +import java.util.Map; +import java.util.Set; +import java.util.function.Function; +import java.util.stream.Collectors; + +import static org.audiveris.omr.util.SetOperation.diff; +import static org.audiveris.omr.util.SetOperation.intersection; +import static org.audiveris.omr.util.SetOperation.union; +import static org.junit.Assert.assertEquals; + +/** + * Utility class that calculates the similarity of two Scores. + * Currently the similarity calculation is quite simplistic, just checking pitch and duration for the notes and rests. + * + * @author Peter Greth + */ +public abstract class ScoreSimilarity +{ + /** + * The conversion score of two ScorePartwises is the conversion score of their only Part. + * Multiple Parts currently are not supported. + */ + public static int conversionScore (ScorePartwise expected, ScorePartwise actual) + { + assertEquals("Multiple parts are currently not supported!", 1, expected.getPart().size()); + assertEquals("Multiple parts are currently not supported!", 1, actual.getPart().size()); + return conversionScore(expected.getPart().get(0), actual.getPart().get(0)); + } + + public static int conversionScore (Part expected, Part actual) + { + return conversionScore(expected.getMeasure(), actual.getMeasure()); + } + + /** + * The conversion score of two lists of measures is the sum of corresponding measures' conversion scores. + * Two measures correspond if they have the same measure number. + */ + public static int conversionScore (List expected, List actual) + { + final Map expectedMeasuresByNumber = groupBy(expected, Measure::getNumber); + final Map actualMeasuresByNumber = groupBy(actual, Measure::getNumber); + final Set allMeasureNumbers = union(expectedMeasuresByNumber.keySet(), actualMeasuresByNumber.keySet()); + + return allMeasureNumbers + .stream() + .mapToInt(measureNumber -> conversionScore( + expectedMeasuresByNumber.getOrDefault(measureNumber, new Measure()), + actualMeasuresByNumber.getOrDefault(measureNumber, new Measure()) + )) + .sum(); + } + + /** + * The conversion score of two Measures is calculated by taking several "samples" and then taking their score. + * The measure is sampled using {@link #sampleMeasure(Measure)}. + */ + public static int conversionScore (Measure expected, Measure actual) + { + return conversionScore(sampleMeasure(expected), sampleMeasure(actual)); + } + + /** + * Conversion score of two Sets of samples is calculated by counting the common Samples and then subtracting the + * amount of samples that just occur in one of the two Sets. + */ + public static int conversionScore (Set expected, Set actual) + { + Set common = intersection(expected, actual); + Set missing = diff(expected, actual); + Set superfluous = diff(actual, expected); + return common.size() - missing.size() - superfluous.size(); + } + + /** + * Takes samples of a measure by taking samples of the measure's notes and their in the measure. + */ + public static Set sampleMeasure (Measure measure) + { + Set samples = new HashSet<>(); + + BigDecimal currentOffset = BigDecimal.ZERO; + BigDecimal lastNotesDuration = BigDecimal.ZERO; + for (Object noteOrBackupOrForward : measure.getNoteOrBackupOrForward()) { + // calculate a note's offset by tracking Backups and Forwards + if (noteOrBackupOrForward instanceof Backup backup) { + currentOffset = currentOffset.subtract(backup.getDuration()); + } else if (noteOrBackupOrForward instanceof Forward forward) { + currentOffset = currentOffset.add(forward.getDuration()); + } else if (noteOrBackupOrForward instanceof Note note) { + BigDecimal noteOffset = currentOffset; + if (note.getChord() != null) { // "chord" note + // The "chord" is set for notes that have the same offset than the previous note. Unfortunately, + // the previous note's duration has already been added to the current offset (see below). To + // mitigate, we subtract it again here, s.t. both notes have the same offset. + noteOffset = noteOffset.subtract(lastNotesDuration); + } else { // normal note + currentOffset = currentOffset.add(note.getDuration()); + lastNotesDuration = note.getDuration(); + } + + samples.add(sampleNoteWithOffset(note, noteOffset)); + } + } + + return samples; + } + + /** + * Takes several sample points of a Note while differing between normal notes and rests. + */ + private static NoteSample sampleNoteWithOffset (Note note, BigDecimal noteOffset) + { + if (note.getRest() != null) { + return NoteSample.ofRest(noteOffset, note.getDuration()); + } else { + return NoteSample.ofNote(note.getPitch().getStep(), note.getPitch().getAlter(), + note.getPitch().getOctave(), noteOffset, note.getDuration()); + } + } + + /** + * Utility function that transforms a List to a Map by getting the key from each entry. + * + * @param list the List to convert + * @param getKey the function that is executed for each entry to produce a key + * @param the key type + * @param the value type + * @return a map whose values are the entries of the input list + */ + private static Map groupBy (List list, Function getKey) + { + return list + .stream() + .collect(Collectors.toMap(getKey, m -> m)); + } + + /** + * A sample of a note according to several sample points such as pitch, offset and duration. + */ + private static record NoteSample(boolean isRest, Step step, BigDecimal alter, int octave, BigDecimal offset, + BigDecimal duration) + { + private static NoteSample ofRest (BigDecimal offset, BigDecimal duration) + { + return new NoteSample(true, null, null, 0, offset, duration); + } + + private static NoteSample ofNote (Step step, BigDecimal alter, int octave, BigDecimal offset, + BigDecimal duration) + { + return new NoteSample(false, step, alter, octave, offset, duration); + } + } + +} From b2b2938509984d890d11895d8a743c1da0dcf9f0 Mon Sep 17 00:00:00 2001 From: Peter Greth Date: Sun, 3 Apr 2022 19:19:51 +0200 Subject: [PATCH 4/6] First regression test case "01-klavier" As provided in PR #122 by Alexander Myltsev (@avm). --- .../score/ConversionScoreRegressionTest.java | 1 + .../score/01-klavier/expected-output.xml | 551 ++++++++++++++++++ .../conversion/score/01-klavier/input.png | Bin 0 -> 517694 bytes 3 files changed, 552 insertions(+) create mode 100644 src/test/resources/conversion/score/01-klavier/expected-output.xml create mode 100644 src/test/resources/conversion/score/01-klavier/input.png diff --git a/src/test/conversion/score/ConversionScoreRegressionTest.java b/src/test/conversion/score/ConversionScoreRegressionTest.java index 645c1f713..79877b3be 100644 --- a/src/test/conversion/score/ConversionScoreRegressionTest.java +++ b/src/test/conversion/score/ConversionScoreRegressionTest.java @@ -66,6 +66,7 @@ public class ConversionScoreRegressionTest * List of test cases. Each of these will be tested separately */ private final static List TEST_CASES = List.of( + ConversionScoreTestCase.ofSubDirectory("01-klavier").withExpectedConversionScore(15) ); /** diff --git a/src/test/resources/conversion/score/01-klavier/expected-output.xml b/src/test/resources/conversion/score/01-klavier/expected-output.xml new file mode 100644 index 000000000..a1347e56d --- /dev/null +++ b/src/test/resources/conversion/score/01-klavier/expected-output.xml @@ -0,0 +1,551 @@ + + + + + + MuseScore 2.1.0 + 2018-03-08 + + + + + + + test/01-klavier/source.png + + + + 6.096 + 40 + + + 1948.82 + 1377.95 + + 79.9869 + 79.9869 + 79.9869 + 79.9869 + + + + + + + + Klavier + + Acoustic Grand Piano + + + + 1 + 1 + 77.9528 + 0 + + + + + + + + + 21.00 + 0.00 + + 170.00 + + + 65.00 + + + + 1 + + -1 + + + 2 + + G + 2 + + + F + 4 + + + + + 1 + 1 + quarter + 1 + + + + F + 4 + + 2 + 1 + half + up + 1 + + + + + + + + + + A + -1 + 4 + + 2 + 1 + half + flat + up + 1 + + + + + B + -1 + 4 + + 2 + 1 + half + up + 1 + + + + + D + 5 + + 2 + 1 + half + up + 1 + + + 3 + + + + 1 + 5 + quarter + 2 + + + + D + 4 + + 2 + 5 + half + up + 2 + + + + + + + + 3 + + + + D + 3 + + 3 + 6 + half + + down + 2 + + + + + + + + + + + 1 + 1 + quarter + 1 + + + + B + 3 + + 2 + 1 + half + natural + up + 1 + + + + + + + + + + D + 4 + + 2 + 1 + half + up + 1 + + + + + F + 4 + + 2 + 1 + half + up + 1 + + + + + A + 4 + + 2 + 1 + half + natural + up + 1 + + + 3 + + + + 1 + 5 + quarter + 2 + + + + + + + + 2 + + + + + A + 3 + + 2 + 5 + half + up + 2 + + + 3 + + + + D + 3 + + 3 + 6 + half + + down + 2 + + + + + + + + + + + D + 5 + + 1 + 1 + quarter + 1 + + + + F + 4 + + 2 + 1 + half + up + 1 + + + + + + + + + + A + -1 + 4 + + 2 + 1 + half + flat + up + 1 + + + + + D + 5 + + 2 + 1 + half + up + 1 + + + 3 + + + + D + 4 + + 3 + 2 + half + + down + 1 + + + + + + + + 3 + + + + +

+ + + 2 + + + + + B + -1 + 2 + + 3 + 5 + half + + flat + down + 2 + + + + + + + + + + F + 3 + + 3 + 5 + half + + down + 2 + + + + + + C + 1 + 4 + + 2 + 1 + half + sharp + up + 1 + + + + + + + + + + + A + 4 + + 2 + 1 + half + natural + up + 1 + + + + A + 4 + + 1 + 1 + quarter + up + 1 + + + 3 + + + + F + 4 + + 1 + 2 + quarter + down + 1 + + + + + + + E + 4 + + 1 + 2 + quarter + down + 1 + + + + + + + + 1 + 2 + quarter + 1 + + + 3 + + + + A + 2 + + 2 + 5 + half + natural + down + 2 + + + + + + + + + + + G + 3 + + 2 + 5 + half + down + 2 + + + + 1 + 5 + quarter + 2 + + + light-light + + + + \ No newline at end of file diff --git a/src/test/resources/conversion/score/01-klavier/input.png b/src/test/resources/conversion/score/01-klavier/input.png new file mode 100644 index 0000000000000000000000000000000000000000..0ab7b6a3f3361c9ec756c9aaaab927bd7fb6cecb GIT binary patch literal 517694 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