Test RESCUE and IDZ, classical #150
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Test RESCUE and IDZ, classical | |
on: | |
# Trigger the workflow on push or pull request | |
#push: | |
#pull_request: # DANGEROUS! MUST be disabled for self-hosted runners! | |
# Trigger the workflow by cron. The default time zone of GitHub Actions is UTC. | |
schedule: | |
- cron: '0 20 * * *' | |
# Trigger the workflow manually | |
workflow_dispatch: | |
env: | |
GFORTRAN_VERSION: 12 | |
BENCHMARK: rescue_idz | |
jobs: | |
test: | |
name: Profile PRIMA. | |
runs-on: ${{ matrix.os }} | |
strategy: | |
fail-fast: false | |
matrix: | |
os: [ubuntu-latest] | |
matlab: [latest] | |
dim: [small, all] | |
solver: [newuoa, bobyqa, lincoa] | |
steps: | |
- name: Get the solver name | |
run: echo "SOLNAME=$(echo ${{ matrix.solver }} | cut -c1-6)" >> $GITHUB_ENV | |
- name: Check out repository | |
uses: actions/[email protected] | |
with: | |
ssh-key: ${{ secrets.SSH_PRIVATE_KEY_ACT }} # This forces checkout to use SSH, not HTTPS | |
submodules: recursive | |
- name: Clone MatCUTEst | |
uses: actions/[email protected] | |
with: | |
ssh-key: ${{ secrets.SSH_PRIVATE_KEY_ACT }} # This forces checkout to use SSH, not HTTPS | |
repository: equipez/matcutest_compiled | |
path: matcutest | |
- name: Link gfortran for MATLAB on Linux | |
if: startsWith(matrix.os, 'ubuntu') | |
run: bash .github/scripts/link_gfortran ${{ env.GFORTRAN_VERSION }} | |
- name: Install epstopdf and ghostscript | |
if: startsWith(matrix.os, 'ubuntu') | |
run: bash .github/scripts/install_epstopdf && bash .github/scripts/install_ghostscript | |
- name: Check MATLAB | |
id: check_matlab | |
run: if type 'matlab' &> /dev/null ; then echo "::set-output name=has_matlab::true" ; fi | |
- name: Cache MATLAB # N.B.: Clear the cache when the `latest` version of MATLAB changes in March and September | |
uses: actions/[email protected] | |
with: | |
path: ${{ runner.tool_cache }}/MATLAB | |
key: ${{ matrix.os }}-${{ matrix.matlab }}-yes # "yes" means that the Optimization_Toolbox is included in the cache | |
- name: Set up MATLAB with optimization toolbox | |
if: ${{ steps.check_matlab.outputs.has_matlab != 'true' }} | |
uses: matlab-actions/setup-matlab@v2-beta | |
with: | |
release: ${{ matrix.matlab }} | |
products: Optimization_Toolbox | |
- name: Conduct the test | |
uses: matlab-actions/[email protected] | |
with: | |
command: | | |
ver; | |
root_dir = pwd(); | |
% Install MatCUTEst. | |
cd(fullfile(root_dir, 'matcutest')); install(); which macup | |
% Remove unnecessary files to make sure that we are testing the correct version. | |
files = {'.development/archiva', 'fortran', '.development/norma', 'matlab'}; | |
for ifile = 1 : length(files) | |
rmdir(fullfile(root_dir, files{ifile}), 's'); | |
end | |
delete(fullfile(root_dir, 'setup.m')); | |
movefile(fullfile(root_dir, 'benchmark/${{ env.BENCHMARK }}'), root_dir); | |
rmdir(fullfile(root_dir, 'benchmark'), 's'); | |
% Conduct the test. | |
cd(fullfile(root_dir, '${{ env.BENCHMARK }}/matlab/tests')); | |
options = struct(); | |
options.classical = true; | |
options.rhoend = 1.0e-8; | |
options.maxfun_dim = 500; | |
options.strict = 0; | |
options.nr = 3; % 3 random runs for each problem | |
% N.B.: Parallel profiling does not work. The worker will be shut down due to the resource | |
% requested by some problem. Worse, we do not know which problem it is due to the parallelism. | |
if strcmp('${{ matrix.dim }}', 'small') || strcmp('${{ matrix.solver }}', 'newuoa') | |
prof('${{ matrix.solver }}', '${{ matrix.dim }}', 'norma', options, 'seq'); | |
elseif strcmp('${{ matrix.solver }}', 'lincoa') | |
prof('${{ matrix.solver }}', '${{ matrix.dim }}', 'l', 'norma', options, 'seq'); | |
elseif strcmp('${{ matrix.solver }}', 'bobyqa') | |
prof('${{ matrix.solver }}', '${{ matrix.dim }}', 'b', 'norma', options, 'seq'); | |
end | |
% Move the files to prepare for uploading artifacts | |
solver = '${{ env.SOLNAME }}'; | |
cd(fullfile(cd(), 'testdata')); | |
files = dir([solver, '*.summary.*.pdf']) | |
for ifile = 1 : length(files) | |
file = fullfile(files(ifile).folder, files(ifile).name) | |
newfile = fullfile(files(ifile).folder, ['classical_', files(ifile).name]) | |
movefile(file, newfile); | |
end | |
movefile(fullfile(cd(), '*summary*.pdf'), ['/tmp/', solver, '_profile_${{ env.BENCHMARK }}/']); | |
movefile(fullfile(cd(), '*.txt'), ['/tmp/', solver, '_profile_${{ env.BENCHMARK }}/']); | |
files = [dir(['/tmp/', solver, '_profile_${{ env.BENCHMARK }}/*start*']); dir(['/tmp/', solver, '_profile_${{ env.BENCHMARK }}/*end*'])] | |
for ifile = 1 : length(files) | |
file = fullfile(files(ifile).folder, files(ifile).name) | |
newfile = fullfile(files(ifile).folder, ['classical_', files(ifile).name]) | |
movefile(file, newfile); | |
end | |
- name: Store artifacts | |
uses: actions/[email protected] | |
if: always() # Always run even if the workflow is canceled manually or due to overtime. | |
with: | |
path: | | |
/tmp/${{ env.SOLNAME }}_profile_${{ env.BENCHMARK }}/*summary*.pdf | |
/tmp/${{ env.SOLNAME }}_profile_${{ env.BENCHMARK }}/*.txt | |
/tmp/${{ env.SOLNAME }}_profile_${{ env.BENCHMARK }}/*start* | |
/tmp/${{ env.SOLNAME }}_profile_${{ env.BENCHMARK }}/*end* | |
- name: Remove the test data | |
if: always() # Always run even if the workflow is canceled manually or due to overtime. | |
run: rm -rf ./matlab/tests/testdata && rm -rf /tmp/${{ env.SOLNAME }}_profile_${{ env.BENCHMARK }} |