pnetcdf-openmpi-1.12.2-1.1 >  A `ChZp9|udaؚ_gE+M*$@&;O$ɼX;Q2N_FzN5w{qm ]4o8#q4M`.("9# JcfT̼69 blJWE.!7ǹP4QZT|!mۄJ$VV87]{2S(Be'[W:]o+1bb4418e30abc6f37b04b9dba3eb8fa2611a179a14a3d97389ac19f03fd16daa0a79bdf2d0c09539579b89b0efd277d12990a011`ChZp9|/A ܭ _V |-_v6C\fx62Vo<%/ 4:">I+9̅Vά(R7 7L<aFP~8D5<r"P6| V[deĤgL[a@by8k-cٗZbR>X"o=Kbh71tSd#f&X4 2v۫^;afceȳYp>,?d  b )JQ g$ N x  a x 5    X  S( 8 9 : FGH4IXY\]^bcNdefluv wtxy(zCpnetcdf-openmpi1.12.21.1High-performance parallel I/O with the NetCDF scientific data formatNetCDF is a set of software libraries and self-describing, machine-independent data formats that support the creation, access, and sharing of array-oriented scientific data. Parallel netCDF (PnetCDF) is a library providing high-performance I/O while still maintaining file-format compatibility with NetCDF by Unidata. This package contains the openmpi version of utility functions for working with NetCDF files.`Ch sheep95eSUSE Linux Enterprise 15SUSE LLC NetCDFhttps://www.suse.com/Productivity/Scientific/Otherhttp://cucis.ece.northwestern.edu/projects/PnetCDF/index.htmllinuxx86_64`pTp`3( f 0#39 ]lGAA큤A큤`Cg>`Cg>`Cg>`Cg>`Cg>`Cg>`Cg:`Cg>`Cg:`Cg:`Cg9`Cg9`Cg7`Cg6`Cg:`Cg:`Cg:`Cg:`Cg:`Cg:`Cg:40c3098eb37dcd0b5b78cc0fef71a0b2a0c3503ee77a64f0537568a46fdca228c1a6fbd3a1f6d5c7c393d3d079dbffe297c18ca41e47a9661dc5ac126b1006b4f173fef82133d56f725c9cb965afd3b7113f5cd4a0c12ed055301aed5ae70d918678bc728349727e724f51c9807cf9f7953ecbc3e974691b0d265e65d6d8ac119ed0198d37376d1617705f4ad17b0adb2cf006d050daec9b0715e7f8120191b5a4449405fdfa2bc1aa8101d7bd5d39e8157c980c6dae197a11f3adb4b599f74da8122710ba6048d89c2495317f2f9a706277023dab514fa8e81a6b2228e0594a7b84c47b8b862ab2a6366a84678a34ee2d20d4efccaef94ce27210fa645d7879e6679872bc99ba9789e58d344eb12b23431e80097436cbb97d1753fb6c28f517aa1ad911b5d43293549f696bb26fbbb355dc114f011eecd9131679670d1797c4305e01c739561b4adf1f440adbd00260434a4ce6b21e4474d7f6a9188f134ba5da72565eead3990b9d0e3f5f441d6fd82ecfe0b1de3d9354c6ca7e64134124139cb65d4a3c318c95be7debf73c37d22ae88e52f6adbdb20aa08b73603f4c84a618b97cb8bb0cb399e641284a3344d57acee9acebad1e3191a076d8e4aea9d8f43bfba009b1334bd9e6d7664bf0a87d26fb3d37a5a87468f4e764d8c566b21b715cf12b8a078e44ab4609157dc2622c60d82a1e845169d52a3616624269fcd7e23bc53680ee8b984d04e032cff58bf58d7d012966d9725112c8d155568478776b6fdc0c543c36092b34f7bd91bdf4085836ea946a2bf936989cf79da4daf29858rootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootrootpnetcdf-openmpi-1.12.2-1.1.src.rpmparallel-netcdf-openmpipnetcdf-openmpipnetcdf-openmpi(x86-64)@@@@@@@@@@@@    /bin/shlibc.so.6()(64bit)libc.so.6(GLIBC_2.14)(64bit)libc.so.6(GLIBC_2.2.5)(64bit)libc.so.6(GLIBC_2.3)(64bit)libc.so.6(GLIBC_2.3.4)(64bit)libc.so.6(GLIBC_2.4)(64bit)libc.so.6(GLIBC_2.7)(64bit)libmpi.so.12()(64bit)libpnetcdf.so.4()(64bit)libpnetcdf4-openmpilibpthread.so.0()(64bit)libpthread.so.0(GLIBC_2.2.5)(64bit)openmpirpmlib(CompressedFileNames)rpmlib(FileDigests)rpmlib(PayloadFilesHavePrefix)rpmlib(PayloadIsXz)1.12.23.0.4-14.6.0-14.0-15.2-14.14.1`8_/@_@]Y]]w@Ws@W~UWUnU@UK@cgoll@suse.comeich@suse.comeich@suse.comstefan.bruens@rwth-aachen.destefan.bruens@rwth-aachen.dechristophe@krop.frjengelh@inai.detoddrme2178@gmail.comtoddrme2178@gmail.comtoddrme2178@gmail.comtoddrme2178@gmail.comtoddrme2178@gmail.com- Update to version 1.12.2: * Updated utility program * ncvalidator now reports the name of variable that violates the NetCDF limitation on large variables for CDF-2 files * add corrupted file bad_large_fixed_var.nc2 that contains one large fixed-size variables that is not defined last * add corrupted file bad_large_rec_2_vars.nc2 that contains 2 large record variables * add corrupted file bad_large_rec_var.nc2 that contains 1 large record variable that is not defined last * add URLs of NetCDF limitations on large variables for CDF-1 and 2 file formats * Other updates: * When calling ncmpi_create() with NC_CLOBBER flag, PnetCDF now calls access() to check whether file exists first. If the file does not exist, successive calls to truncate() or unlink() can be skipped. * Improve detection of HDF5 signature. The HDF5 signature is located at the beginning of the HDF5 superblock, but the location of HDF5 superblock may not be at the beginning of the file. It is located at byte offset 0, byte offset 512, and at successive locations in the file, each a multiple of two of the previous location; in other words, at these byte offsets: 0, 512, 1024, 2048, and so on. * Bug fixes * Fix NC_CLOBBER mode for ncmpi_create() when files are existing symbolic links. Prior to this release, symbolic links, like other regular files, was first deleted and then created. This can result in an unexpected outcome, i.e. the deletion of symbolic link. NetCDF-4 library implements this differently, by adding O_TRUNC flag when calling open() to truncate the file to length 0. Historically, PnetCDF did not adopt the same approach because MPI does not define a similar flag to O_TRUNC and the only way to achieve the file clobber effect is to through MPI_File_set_size(), which can be expensive as the function takes an MPI file handler argument, which requires to open the file first with a call to MPI_File_open(). * Fix a bug of calling Fortran getarg() with the first argument k with a value > 0 when there is no command-line argument is used. NAG Fortran may crash the program. [f16bd3c](https://github.com/Parallel-NetCDF/PnetCDF/commit/f16bd3c1ba1b08eade2384f094c519f3f2dc114e) * Fix a bug that limits FLASH-IO to run on less than 16K MPI processes. See [1d84fa5](https://github.com/Parallel-NetCDF/PnetCDF/commit/1d84fa5d54ca9179da4a5b1a4ee3b92cc92287ed) - enable non HPC openmpi4 builds- Enable openmpi4 builds for SLE >= 15-SP2.- Update to version 1.12.1: v.1.12.1 - Option '-t' added to 'cdfdiff' to compare variable differences within a tolerance. - Make PnetCDF build with OpenMPI 4. - Fix aliasing bug with -O3. - String length of I/O hint 'nc_burst_buf_dirname' must be less than MPI_MAX_INFO_VAL. v.1.12.0 - Add 'cdfdiff' utility - serial version of 'ncmpidiff' supports classic NetCDF formats only i.e. CDF-1, CDF-2, and CDF-5. - 'ncmpidiff' now checks file format versions of two files, and reports difference if not the same. - Option '-t' added to 'ncpmidiff' to compare variable differences within a tolerance. - MPI info object now includes all PnetCDF hints once obtained form call to ncmpi_inq_file_info(). - Fix segfault when calling nonblocking API with zero-lenght request and request ID NULL. - Per-file thread-safe capability is not supported when using OpenMPI with ROMIO backend. v.1.11.2 - Utility program `ncoffsets` updated to skip printing dimension names if the number of dimensions of a variable is larger than 64. - Utility program `ncvalidator` updated to be able to repair the file header to fill in null-byte paddings in the space between the header size and header extent. v.1.11.1 - Optimization: When inserting nonblocking requests into the PnetCDF internal pending queues, queues are now kept sorted (using an insert sort) into an increasing order of variable starting file offsets. - Fix ncmpidiff when comparing dimension names of 2 variables between files whose dimension define orders are different. - Padding -- NetCDF classic file format specifies null (\x00) byte header padding, but does not enforce it. v.1.11.0 - New features * NetCDF-4 driver -- Accessing HDF5-based NetCDF-4 files is now supported. - New optimization * Burst buffer driver is updated to run varn APIs more efficiently. - New Limitations * For creating new files, the NetCDF-4 driver in PnetCDF supports only the classic model I/O operations. - New APIs * C++ API `NcmpiFile::set_fill()` is added for setting and inquiring the fill mode of an opened NetCDF file. - New PnetCDF hint * `nc_ibuf_size`: set the size of temporal buffer to be allocated by PnetCDF internally to pack noncontiguous user write buffers supplied to the nonblocking requests into a contiguous space. - Other updates: * The automatic file layout alignment for fixed-size variables is disabled. * The internal data buffering mechanism used in the burst buffer driver is removed. - Bug fixes * Fix bug of checking interleaved requests for scalar variables. * For put and get APIs when buftype is MPI_DATATYPE_NULL, bufcount is ignored. This is not implemented correctly in blocking put and get APIs. * ncmpidiff -- when comparing two files that contain record variables but no record has been written. * ncmpidiff -- when comparing two scalar variables, error NC_EBADDIM may mistakenly reported. * Fix crash when the MPI communicator used in ncmpi_create or ncmpi_open is freed by the user after the call and before file is closed. * Discrepancy from NetCDF library * No read/write variables in define mode when file format is NetCDF-4. * Diffrent to nc_set_fill() defined in NetCDF-4, ncmpi_set_fill() changes fill mode of all variables newly defined in current scope of define mode. * Error codes return precedence can be different between NetCDF and PnetCDF. - Discrepancy from NetCDF library * NetCDF-4 allows to read/write variables in define mode when file format is NetCDF-4, while PnetCDF requires data mode. * In contrast to nc_set_fill() in NetCDF-4, ncmpi_set_fill() changes fill mode of all variables newly defined in current scope of define mode. * Error code precedence may differ between NetCDF and PnetCDF. - Clarifications PnetCDF currently does not support Fortran default integer type set to 8 bytes (option -fdefault-integer-8 with gnu compiler). v.1.10.0 - New Features: * A new I/O layer that makes use of burst buffers is added. - New Optimizations: * Internal memory management for nonblocking APIs has been improved to reduce memory footprint. * Blocking and nonblocking varn APIs have been improved for better performance and less memory footprint. * on noncontiguous layout in user buffer use the user buffer directly in MPI-IO calls when neither byte-swap nor type-conversion is required to reduce memory footprint. - New APIs: * ncmpi_flush() flushes data buffered by PnetCDF to the destination file system. - API semantics: * ncmpi_put_vard and ncmpi_get_vard APIs + Allow to write/read two or more variables in a single call. + When argument filetype is MPI_DATATYPE_NULL, request is considered zero-length. + Limitation of vard APIs: element data type of filetype must conform with variable external NC data type. + element data types of all variables accessed in filetype must be the same. + buftype must contain only one same element data type if it is used to read or write multiple variables from file. - New error codes: * NC_EFLUSHED when request got flushed before when calling ncmpi_cancel(). * NC_EBADLOG when burst buffer log files are found corrupted. - New hints: * nc_in_place_swap; enable/disable in-place byte swap on Little Endian architectures. * nc_burst_buf -- to use the burst buffering feature. * nc_burst_buf_dirname -- directory where internal log files for burst buffer will be stored. * nc_burst_buf_del_on_close -- whether log files should be deleted when closing NetCDF file. * nc_burst_buf_flush_buffer_size -- Amount of memory allowed by users to allocate when flushing the burst buffer log files. - Rutime environment variable * PNETCDF_RELAX_COORD_BOUND set to 0 to disable or 1 to enable more relaxed boundary check for argument start. - Utility programs: * ncvalidator adds a new option -t to turn on tracing mode. - Other updates: * Add a check for NC_EUNLIMIT in API ncmpi_open to detect whether two or more unlimited dimensions are defined to detect a corrupted file. - Bug fixes: * Fix type_create_subarray64() for case when some dimensions of the global array is larger than 4G and oldtype is not MPI_BYTE. * Fix the bug that writing scalar attributes of type NF_INT64 was mistakenly casted to NF_INT. * Fix calculation of new record number in put_vard API. * Fix calculation of growing size of nonblocking request queues to include the number of records of a record variable, as such request is split into multiple additional requests, one for each record. * Remove freeing name object because NC_ENULLPAD is not a fatal error. * Add a check against NULL before freeing Member "value" of NC_dimarray, NC_attrarray, and NC_vararray when reading from file where respective tags are corrupt. - Conformity with NetCDF library * Attribute _FillValue of any NC data type may be put to global variable NC_GLOBAL for all classic files. v.1.9.0 - New optimizations: * use hash functions for faster attribute name lookup. - New limitations: * max number of files to be opened simultaniously is now 1024. * maximum number of variable dimensions (NC_MAX_VAR_DIMS) is now 2147483647. * maximum number of attributes per file (NC_MAX_ATTRS) is now 2147483647. * maximum number of variables per file (NC_MAX_VARS) is now 2147483647. * maximum size of of single put/get request or aggregate size if non-blocking request per MPI process is INT_MAX. - New constants: * NC_FORMAT_UNKNOWN, NF_FORMAT_UNKNOWN, NF90_FORMAT_UNKNOWN will be returned on ncmpi_inq_file_format if file is unrecognizable. * NC_MAX_NFILES, NF_MAX_NFILES, NF90_MAX_NFILE define max number of files that can be kept open my an MPI process. - API Syntax change: * Argument fill_value of ncmpi_def_var_fill is 'const' now. - Semantic updates: * Calling ncmpi_end_indep_data() in collective data mode no longer considered illegal. * For CDF-5 files, the maximum size of a variable or a variable's record is NC_MAX_INT64-3. * on inconsistent create/open among processes, the modes on all processes will be replaced by rank 0's mode. NC_EMULTIDEFINE_CMODE or NC_EMULTIDEFINE_OMODE will returned on processes disagreeing with rank 0's mode. * ncmpi_inq_nreqs() allows argument nreqs to be NULL. * ncmpi_inq_buffer_usage() & ncmpi_inq_buffer_size() allows argument usage to be NULL. * New error codes: + NC_EMAX_REQ, NF_EMAX_REQ and NF90_EMAX_REQ + NC_ENULLPAD, NF_ENULPAD and NF90_ENULPAD - Utility programs: * ncmpivalid renamed to ncvalidator - Update: * Update UTF8 encoding utility to use utf8proc library version 2.1.0. * Add quiet mode command-line option "-q" to utility program ncvalidator. * Add an internal check for whether the file starting offsets of all variables are in an increasing order as the variables defines. - Bug Fixes: * Fix a bug in nonblocking APIs when two separate nonblocking requests that can be coalesced into a contiguous MPI fileview or buffer type but the coalesced length becomes too big. * Fix a bug in nonblocking APIs when one request's access region covers more than one other non-interleaved requests. * Fix a bug in string parsing the environment variable PNETCDF_HINTS and print warning messages when hint strings are ill-formed. * Fix a bug in F90 APIs for reading and writing scalar variables, i.e. number of dimensions is zero. * Fix a bug that fails to do byte-swap when retrieving user-defined fill values. - Conformity to NetCDF: * API ncmpi_open now checks the number of large variables that is legal for CDF-1 and CDF-2 files. * Add checking for error code NC_ELATEFILL. * No longer disallow _FillValue for global variable NC_GLOBAL. * Don't turn fill mode on/off automatically when putting/deleting _FillValue attribute. This restores consistency with NetCDF. * PnetCDF can no longer be built on 32-bit machines if using OpenMPI versions 2.0.2 and 1.10.6 and earlier versions. - Clarifications: * External numerical data types can no longer be type casted to NC_CHAR type upon reading/writing. Only legal APIs the read/write a NC_CHAR variable are the '_text' APIs. New translations of internal data types to MPI data types - check release notes for a table. v.1.8.1 - Fortran parameters NF_MAX_DIMS, NF_MAX_ATTRS, NF_MAX_VARS, and NF_MAX_NAME have been fixed to conform with their corresponding C constants. v.1.8.0 - Copy fill values to data elements that cause out-of-bound error (i.e. NC_ERANGE.) New macros added to pnetcdf.h, to indicate the configurable options that were enabled/disabled. These macros are: PNETCDF_ERANGE_FILL, PNETCDF_SUBFILING, PNETCDF_RELAX_COORD_BOUND, and PNETCDF_DEBUG_MODE. - Detect HDF5 file format: * ncmpi_inq_file_format reports NC_FORMAT_NETCDF4 on HDF5 signature. * 'ncmpidump' checks for HDF5 format when -k option is specified. * ncmpi_open checks for HDF5 signature and returns NC_ENOTNC3 error. - New API: * ncmpi_strerrno, nfmpi_strerrno, nf90mpi_strerrno return the string name of a NC error code. * ncmpi_inq_path, nfmpi_inq_path, nf90mpi_inq_path for inquiring file pathname used when open/create the CDF file. - Optimizations: * Use of Bernstein hash for checking if variable or dimension name is used already. * Storage of nonblocking requests. - Changed syntax: * ncmpi_cancel can now be called in define mode. - New error codes: NC_EPENDING, NC_EINVAL_OMODE, NC_EMULTIDEFINE_CMODE for both C and FOTRAN functions. - New error code precedences when multiple errors in API argument detected. * Utility pnetcdf-config to display build configuration. - Semantic changes: * For collective APIs, the following errors are considered fatal: NC_EBADID, NC_EPERM, NC_EINDEFINE, NC_EINDEP, and NC_ENOTINDEP. Once detects these errors the calling APIs return immediately. * Consistency check for header data (defining dimensions, variables, and attributes) is moved to individual APIs and only enabled when safe mode is enabled. * For CDF-5 files, regular NC_ERANGE check is performed in PnetCDF for all APIs that access NC_BYTE variables. For CDF-1 and 2 files, PnetCDF still honors that exception. * Error code NC_EPENDING will be returned when pending requests are detected at the file close. * API ncmpi_set_default_format is changed to an independent API. - Build separate doc package. - Run package internal tests. - Remove: parallel-netcdf-1.6.1-destdir.patch - obsolete build patch. - Add support for HPC build. - Add build support for gcc10 to HPC build (bsc#1174439). - Add build support for openmpi4. - Disable 32-bit build architectures: package cannot be built there.- Add convenience provides to allow e.g. netcdf-openmpi2 to pull in libpnetcdf-openmpi2. - Also build openmpi3 flavor.- Build MPI pacakges as multibuild flavors, add openmpi2 - Adapt to openmpi -> openmpi1 rename on Tumbleweed- Use -ffat-lto-objects when building static libraries.- Trim descriptions.- Update to 1.7.0 o New features * Nonblocking requests now can be posted while the program is in the define mode. This feature enables applications to add new variables and post the nonblocking write requests without separating the codes by ncmpi_enddef(). Note ncmpi_wait_all and ncmpi_wait must still be called in the data mode. * When using immutable write buffer in put APIs on a Little Endian machine, the in-place byte swap operation performed internally in PnetCDF can cause a fatal error (by trying to change the contents of an immutable memory space). The solution of copying user's write request to a temporary buffer and perform byte swap there conflicts with PnetCDF's design principle of avoiding internal memory allocation as much as possible. Since the size of immutable buffer in most cases is small, PnetCDF now compromise the two by making a copy of write requests that is less than 4KB. Users are warned that using immutable write buffer larger than 4KB will still cause the fatal error in the PnetCDF default configuration. The way to completely disable in-place byte swap is to build PnetCDF with --disable-in-place-swap option at the configure time. In this case, the internal memory allocation in PnetCDF will increase. o Syntax changes * In ncmpi_wait_all(), ncmpi_wait(), and ncmpi_cancel(), the API's third argument, array of requests IDs, is changed to INOUT. Upon successful completion or cancellation of individual nonblocking requests, the corresponding request IDs are set to NC_REQ_NULL. o New run-time environment variables * PNETCDF_VERBOSE_DEBUG_MODE environment variable can be used to print the location in the source code where the error code is originated, no matter the error is intended or not. This run-time environment variable only takes effect when PnetCDF is configure with debug mode, i.e. - -enable-debug is used at the configure command line. Set this variable to 1 to enable. Set it to 0 or keep it unset disables this mode. Default is 0, i.e. disabled. Users are warned that enabling this mode may result in a lot of debugging messages printed in stderr. o New example programs * examples/C/nonblocking_write_in_def.c shows an example of posting nonblocking write requests in the define mode. * examples/C/req_all.c shows an example of using NC_REQ_ALL to flush all pending nonblocking requests without providing the requests IDs. o New test program * test/cdf_format/dim_cdf12.c tests defining maximal dimension size for CDF-1 and CDF-2 file formats * test/testcases/test_erange.c tests if the error code NC_ERANGE can be correctly returned for two cases 1) get a NC_UBYTE value of 255 from a netCDF file to a memory buffer of type signed char and 2) put a value of -1 of signed char to a NC_UBYTE variable in a netCDF file * test/testcases/check_type.c tests if the error codes can be correctly returned when conflicted in-memory and extenal data types are used. * test/testcases/put_parameter.f tests the use of immutable write buffer (e.g. a buffer declared as PARAMETER). Note the buffer size must be smaller than 4KB. * test/nonblocking/i_varn_indef.c tests posting nonblocking requests in define mode. * test/nonblocking/req_all.c tests the use of NC_REQ_ALL for flushing all pending nonblocking requests without providing the requests IDs. * test/last_large_var.c tests the special case when there is no record variable, the last fixed-size variable can be larger than 2GiB in size if its starting file offset is less than 2GiB. * test/testcases/buftype_free.c and test/testcases/buftype_freef.f test the bug in r2160. * testcases/add_var.c checks the starting file offsets of newly added variables from re-entering the define mode. * testcases/attrf.f checks NF_ERANGE is returned instead of coredump. This is particularly for NAG Fortran compiler that may report "Arithmetics exception". * testcases/check_striping.c checks if the file striping unit and factor returned from MPI-IO hints are consistent among processes. * test/nonblocking/column_wise.c checks if PnetCDF detects interleaved fileviews from multiple nonblocking requests and correctly breaks and reconstructs the fileviews so the combined fileview is monotonic non-decreasing in file offsets. o New optimization * Filling variables at ncmpi_enddef() is now done by aggregating all write requests into one MPI collective write call. In v 1.6.1, this is done by filling one variable at a time. o New utility program * ncoffsets reports the file offset information, including the starting and ending file offsets, of variables stored in a netCDF file. ncoffsets is compiled with gcc if gcc is presented on the build system. Additional command-line options are: (-v) reports only for a selected list of variables in interest, (-s) prints the variable sizes, (-g) outputs the file space gap size from the end of previous variable, (-x) reports whether there is a gap between any two adjacent fixed-size variables. See the man page for descriptions of all command-line options and examples. o Semantics updates * All nonblocking APIs now take a NULL pointer for the request ID argument, meaning users do not wish to keep track of the request ID. If NULL request IDs are used, NC_REQ_ALL should be used when calling ncmpi_wait_all/ncmpi_wait to commit all the pending nonblocking requests. This feature relinquishes users from the responsibility of tracking the IDs of pending requests. * Using NC_REQ_ALL as the 2nd argument "num" in ncmpi_wait_all/ncmpi_wait APIs will flush all the pending nonblocking requests. In this case, the 3rd and 4th arguments "array_of_requests" and "array_of_statuses" will be ignored and thus these two arguments can be NULLs. * Using NC_REQ_ALL in ncmpi_cancel() will cancel all the pending nonblocking requests. * Using NC_GET_REQ_ALL or NC_PUT_REQ_ALL in ncmpi_wait_all(), ncmpi_wait(), and ncmpi_cancel() for all the pending get-only or put-only requests, respectively. o Other updates: * Conform with netCDF on the maximal dimension size for CDF-2 file format to be (2^32 - 4) * NC_ERANGE checks have been removed from nc_test for text APIs and variables that are defined as NC_CHAR type * Add README.K-Computer build recipe for using Fujitsu MPI compilers on the K computer at RIKEN in Japan * Add README.INTEL build recipe for using Intel MPI compilers 4.x * Build dependency rule is added for files configure and configure.in * PnetCDF checks MPICC/MPICXX/MPIF77/MPIF90 instead of CC/CXX/F77/F90/FC. If MPICC/MPICXX/MPIF77/MPIF90 are set, PnetCDF will ignore CC/CXX/F77/F90/FC. If CC/CXX/F77/F90/FC is set instead of MPICC/MPICXX/MPIF77/MPIF90, PnetCDF will now copy them to MPICC/MPICXX/MPIF77/MPIF90. * Enforce netCDF convention on error code priority: NC_ECHAR trumps NC_EINVALCOORDS, NC_EEDGE, and NC_ESTRIDE. * Return error code NC_EGLOBAL instead of NC_ENOTVAR for APIs where using NC_GLOBAL as the variable ID argument is prohibited. * All Fortran 77 test and example programs (files with .f and .F extensions) have been revised to conform with 77 standard, and was tested using pgf77. * Now provides a pkg-config file (http://www.freedesktop.org/wiki/Software/pkg-config/), making it slightly easier to set the correct pnetcdf include and library paths. o Bug fixes * Fix the bus error of invalid address alignment when build with Fujitsu compiler. See r2171 and r2180. * Fix the bug for the special case when there is no record variable, the last fixed-size variable can be larger than 2GiB in size if its starting file offset is less than 2GiB. See r2166. * Fix the nonblocking flexible APIs that fail to save (duplicate) the user MPI derived data type that later is needed to unpack read data to the user buffer (a call to MPI_Unpack). See r2160. * Fix Fortran 77 constants nf_fill_uint and nf_fill_int64 (thanks Jim Edwards) that pgf77-based MPI compiler does not like "_8" modifier. See r2045 and r2051. The same issue for NAG Fortran compiler is also resolved. See r2089 and r2093. * In the example program examples/tutorial/pnetcdf-write-nb.c, the write buffers used in two iput API calls should be different. See r2095. * Fix the error reporting mechanism for NC_ERANGE, for when an arithmetic overflow happens. Overflow checking is now performed before I/O.- Fix license- Fix building on non-x86_64 64-bit platforms- Update subpackage groups - Make subpackage summaries and descriptions more consistent - Provide rpm macros for version identification - Spec file cleanups- Update to version 1.6.1 o New features * PnetCDF now supports fill mode. ncmpi_set_fill() can be used to set the fill mode for the entire data set. Note the differences from netCDF: 1. The default mode in PnetCDF is NC_NOFILL. 2. Setting fill mode for the entire file or individual variables must be done in define mode. 3. For non-record variables, they are filled at the time ncmpi_enddef() is called. 4. For record variables, users must explicitly call ncmpi_fill_var_rec() to fill one record at a time before writing to the record of that variable. o New APIs * ncmpi_def_var_fill() sets fill mode for an individual variable. This API must be called in define mode. * ncmpi_inq_var_fill() inquires fill mode of a variable. * ncmpi_fill_var_rec() is a collective API that fills a record of a record variable. This API must be called at data mode. * ncmpi_inq_default_format() for inquiring the default file format for new file creation. Note the default format can be changed by ncmpi_set_default_format(). * The above new API are also available in Fortran and C++ versions. o New error code * NC_ENOTRECVAR when attempting operation only for record variables * NC_ENOTFILL when attempting to fill a variable when its fill mode is off * NC_EMULTIDEFINE_FILL_MODE when inconsistent dataset fill mode is detected * NC_EMULTIDEFINE_VAR_FILL_MODE when inconsistent variable fill mode is detected * NC_EMULTIDEFINE_VAR_FILL_VALUE when inconsistent variable fill value is detected * Fortran versions of the above error codes are also added. o New example programs * C/fill_mode.c shows the use of ncmpi_set_fill(), ncmpi_def_var_fill(), ncmpi_inq_var_fill() and ncmpi_fill_var_rec() F77/fill_mode.f is the Fortran version. F90/fill_mode.f90 is the Fortran 90 version. CXX/fill_mode.cpp is the C++ version. * C/ghost_cell.c shows how to use varm API for writing from a user buffer as a 2D array with ghost cells on both ends of every dimension. o New test programs * nc_test/tst_nofill.c borrowed from netCDF * testcases/ivarn.c tests bug fix r2023 when the request IDs stored in argument array_of_requests[] of ncmpi_wait_all() are not in an increasing order. o Other updates: * Change the chunk size used for moving variable data when the file header extent expands. The default is now 1MB. If the file's striping unit size is known (from MPI-IO hint striping_unit) then the chunk size is set to the striping unit size. o Bug fixes * Add missing F90 function overloading for f90mpi_put_var_all, f90mpi_get_var_all, f90mpi_put_vard_all, and f90mpi_get_vard_all, when the user buffer is a scalar. * Fix when the request IDs passed in argument array_of_requests[] of ncmpi_wait_all() are not in an increasing order. See r2023. * Fix C++ compile error for converting NULL to string. See r2039. - Update to version 1.6.0 o Format conformation updates: * Conform with netCDF4 on CDF-1 and CDF-2 formats. The only difference now between the two formats are the OFFSET item in the format spec (32 vs. 64 bit integers.) All names (variable, dimension, attribute) now allow extended characters (eg. special2 and MUTF8). o New APIs * Nonblocking buffered varn API family. For C, ncmpi_bput_varn_() For F77, nfmpi_bput_varn_() For F90, nf90mpi_bput_varn() For C++, NcmpiVar::bputVarn() * Nonblocking varn API family. For C, ncmpi_iput_varn_() and ncmpi_iget_varn_() For F77, nfmpi_iput_varn_() and nfmpi_iget_varn_() For F90, nf90mpi_iput_varn() and nf90mpi_iget_varn() For C++, NcmpiVar::iputVarn() and NcmpiVar::igetVarn() * Blocking vard API family takes an argument of MPI derived data type that describes the file access layout, as opposed to vara and vars APIs that use start[] and count[]. For C, ncmpi_put_vard() and ncmpi_get_vard() For F77, nfmpi_put_vard() and nfmpi_get_vard() For F90, nf90mpi_put_vard() and nf90mpi_get_vard() For C++, NcmpiVar::putVard() and NcmpiVar::getVard() * Collective var1 API family For C, ncmpi_put_var1_all() ncmpi_get_var1_all() ncmpi_put_var1__all() ncmpi_get_var1__all() For F77, nfmpi_put_var1_all() nfmpi_get_var1_all() nfmpi_put_var1__all() nfmpi_get_var1__all() For F90, nf90mpi_put_var_all() nf90mpi_get_var_all() For C++, NcmpiVar::putVar_all() NcmpiVar::getVar_all() * ncmpi_inq_buffer_size() returns the size of buffer previously attached for use of bput APIs. With ncmpi_inq_buffer_usage() one can calculate the space remaining for additional bput requests. For F77, nfmpi_inq_buffer_size() For F90, nf90mpi_inq_buffer_size() For C++, NcmpiFile::Inq_buffer_size() * ncmpi_inq_recsize() returns the size of record block, i.e. the sum of single records of all record variables. For F77, nfmpi_inq_recsize() For F90, nf90mpi_inq_recsize() For C++, NcmpiGroup::getRecSize() * ncmpi_inq_num_rec_vars() and ncmpi_inq_num_fix_vars() report the number of record and fixed-size variables, respectively. For F77, nfmpi_inq_num_rec_vars() and nfmpi_inq_num_fix_vars() For F90, nf90mpi_inq_num_rec_vars() and nf90mpi_inq_num_fix_vars() For C++, NcmpiGroup::getRecVarCount() and NcmpiGroup::getFixVarCount() o New PnetCDF hint * pnetcdf_subfiling -- it can be set in an MPI info object or in the environment variable PNETCDF_HINTS to enable/disable subfiling. The value is either "enable" or "disable". o PnetCDF hint priority * The alignment hints set in the environment variable "PNETCDF_HINTS" have the highest priority, which overwrite the alignment hints set in ncmpi__enddef(), which overwrite the alignment hints set in the MPI_Info object used in the call of ncmpi_create() and ncmpi_open(). o New error code * NC_ESTRICTCDF2 for attempting CDF-5 operation on CDF-2 file. For example, define a variable of type NC_INT64 in a CDF-2 file. * NC_ETYPESIZE when filetype size is bigger than the variable size * NC_ETYPE_MISMATCH when the element type of filetype mismatches the variable type * NC_ETYPESIZE_MISMATCH when filetype size mismatches buffer type size * NC_ENULLSTART when argument start is a NULL pointer * NC_ENULLCOUNT when argument count is a NULL pointer * NC_EINVAL_CMODE when invalid file create mode is set, (e.g. cannot have both NC_64BIT_OFFSET & NC_64BIT_DATA. In PnetCDF 1.5.0 and earlier versions, if both flags were set, then NC_64BIT_DATA triumphs NC_64BIT_OFFSET.) o New example programs * C/bput_varn_uint.c and F77/bput_varn_int8.f show the use of nonblocking bput_varn APIs * C/i_varn_int64.c and F77/i_varn_real.f show the use of nonblocking iput_varn and iget_varn APIs * C/vard_int.c F77/vard_int.f F90/vard_int.f90 CXX/vard_int.cpp show the use of vard API to write/read record and fixed-size variables. * C/transpose.c shows the use of ncmpi_put_vara_int_all to write a 3D array that is dimensional-transposed from the one stored in memory. Six transposed 3D arrays are saved whose dimensions are organized as ZYX, ZXY, YZX, YXZ, XZY, and XYZ. The C++, Fortran 77, and Fortran 90 versions are also provided. o New test program * nonblocking/wait_after_indep.c tests if ncmpi_end_indep_data() returns properly when nonblocking APIs are called in independent data mode and the wait call is made after exiting the independent mode. * nonblocking/flexible_bput.c tests flexible bput APIs that use noncontiguous buffer type, noncontiguous imap and require type conversion * testcases/flexible2.c tests flexible APIs that perform type conversion * testcases/flexible_varm.c tests flexible varm APIs * testcases/varn_contig.c tests the case when the fileview is actually a contiguous chunk. PnetCDF should be able to merge all. * nonblocking/bput_varn_uint.c tests nonblocking bput_varn APIs * nonblocking/i_varn_int64.c tests nonblocking iput_varn and iget_varn APIs * test/testcases/test_vard.c test/testcases/test_vardf.f test/testcases/test_vardf90.f90 test the new vard APIs. * test/testcases/inq_recsize.c tests if one can correctly inquire the size of record block from in a netCDF file. A similar program in F90, named inq_recsizef.f90, is also added. * In test/nc_test, the test programs below are borrowed from netCDF test programs: t_nc.c tst_misc.c tst_norm.c tst_small.c tst_names.c tst_atts3.c tst_atts.c * test/testcases/one_record.c tests the special case defined in CDF-1 and CDF-2 specification that "A special case: Where there is exactly one record variable, we drop the requirement that each record be four-byte aligned, so in this case there is no record padding." * test/testcases/modes.c tests if correct error codes are returned when various file create/open modes are used. * Under test/testcases, varn_int.c varn_intf.f varn_real.f90 test varn APIs * test/testcases/inq_num_vars.c test if one can correctly inquire the numbers of record and fixed-size variables defined in a netCDF file. A similar program in F90, named inq_num_varsf.f90, is also added. * test/nonblocking/interleaved.c tests a combination of interleaved file types. This is to test the bug fix in r1758. o New optimization * Prior to this release, PnetCDF wraps each MPI read/write call in put/get APIs with two MPI_File_set_view(). One is before the MPI read/write call to take advantage of MPI's fileview feature for accessing non-contiguous file locations. The other is after the MPI read/write call to make the whole file visible, as the root process may write to file header later in the data mode and it alone cannot make a call to MPI_File_set_view() because the function is collective. In this release, the second MPI_File_set_view() has been removed. The root process's fileview is changed to always keep the whole file header visible. Saving a collective call to MPI_File_set_view() is expected to improve some performance. o Semantics updates * Header consistency mechanism has been updated. See README.consistency for details. * The use of NC_SHARE is also revised. See README.consistency for details. o Other updates: * The subfiling feature is now disabled in ncmpidump and ncmpidiff until a bug fix to allow reading the master file with the number of processes that is smaller than the number of subfiles. * The attribute names reserved for subfiling feature are now changed to use a prefix of "_PnetCDF_SubFiling". The leading "_" underscore is a CDL convention. * The flexible APIs now allow argument buftype to be MPI_DATATYPE_NULL. In this case, argument bufcount is ignored and argument buf's data type must match the data type of variable defined in the file - no data conversion will be done. This extension makes the flexible APIs be able to correspond to the netCDF APIs whose names do not contain a data type, e.g. nc_put_vara(). * Type conversion between NC_BYTE and unsigned char no longer checks for out of range error (NC_ERANGE). CDF file format specification make a special case for this kind of data type conversion. See: "Note on byte data" in the format specification. * Conform with the CDF-2 and CDF-5 formats that names are normalized according to Unicode NFC normalization rules during encoding as UTF-8 for storing in the file header. * A new configure option, --enable-large-file-test, to enable testing I/O on large files and large variables. Note the testing prgrams will run very slowly. o Bug fixes * fix the bug for flexible get_varn API. When buftype is noncontiguous, the bug forgot to "unpacks" the temporary buffer that reads data from file to the user buffer using buftype. * fix the bug in blocking flexible get APIs when buftype is noncontiguous, swap is needed, type conversion is not. The bug sets a NULL pointer to the read buffer and passes it to MPI_File_read functions. See r1815. * fix the bug for the NetCDF special case when there is only one record variable and the record size is not four-byte aligned. In this case, NetCDF spec says the alignment must dropped (no padding). See r1791. * fix the bug in nonblocking APIs when requests are resorted into nonoverlapping groups and the first group of file types are interleaved, it was mistakenly identified as non-interleaved. See r1758. * fix the setting for PNETCDF_RELEASE_DATE in configure.in. Using read command together with IFS does not work as expected in bash 4.3.11. See http://lists.mcs.anl.gov/pipermail/parallel-netcdf/2014-July/001586.html for further detailed discussion. - Update to version 1.5.0 o New features * A new configure option "--disable-in-place-swap" is added. It disables the byte-swap operations running in-place on the user's write buffers. The purpose of providing this option is to deal with the problem when a Fortran program uses a immutable buffer for put APIs, e.g. the buffer is declared as a PARAMETER, and in-place byte swap on this buffer causes segmentation fault. See discussion threads of http://lists.mcs.anl.gov/pipermail/parallel-netcdf/2013-July/001498.html Impacts: 1. It takes effect only on Little Endian machines. 2. It only affects put/iput data APIs, but not attribute APIs. 3. The INTENT of buffer arguments in all Fortran 90 put/iput APIs will be declared as "IN". Without this setting, the default is "INOUT". 4. It has an impact on performance, as an extra internal temporary buffer will be allocated to copy data over from user's put buffer, so byte swap can be run on the temporary buffer. The default setting is to enable in-place byte swap. PnetCDF tries not to allocate additional memory space, due to performance concern. Users are discouraged to use Fortran PARAMETER buffers in put APIs. * A new configure option "--enable-debug" is added. It enables a memory allocation tracing mechanism internal in PnetCDF. In addition, it enables the PnetCDF safe mode. (Note that setting the environment variable PNETCDF_SAFE_MODE at the run time can still overwrite the safe mode.) Default debug mode is disabled. When enabled, a user program can call three new APIs below: ncmpi_inq_malloc_size, ncmpi_inq_malloc_max_size, and ncmpi_inq_malloc_list to obtain the size in bytes of current memory allocated internally. This feature uses a binary tree to manage all malloc buffers, e.g. tsearch() and tdelete(). * Add three Fortran parameters for PnetCDF library version numbers: PNETCDF_VERSION_MAJOR, PNETCDF_VERSION_MINOR, and PNETCDF_VERSION_SUB. Similarly in C programs, these are defined in pnetcdf.h as constants. o New APIs * C++ APIs are now available. They are developed based on netCDF-4 C++ library. However, users are encouraged to use C APIs, instead C++. * ncmpi_put_att, ncmpi_get_att, nfmpi_put_att, and nfmpi_get_att - these APIs correspond to nc_put_att, nc_get_att, nf_put_att, and nf_get_att. Note they are not the "flexible" APIs. Flexible APIs have an MPI derived datatype argument. * ncmpi__enddef, nfmpi__enddef, and nf90mpi_enddef - these APIs correspond to netCDF nc__enddef, nf__enddef, and nf90_enddef (with additional optional arguments). * ncmpi_inq_file_info - the naming for ncmpi_get_file_info may cause confusion, as "get" has a different meaning on PnetCDF. The correct name should use "inq". However, ncmpi_get_file_info is kept for backward compatibility. * ncmpi_inq_striping, nfmpi_inq_striping, nf90mpi_inq_striping report the file system striping settings of the opened file: striping size and striping count, if the underneath MPI-IO can find their values from the file system in use. * ncmpi_inq_malloc_size, ncmpi_inq_malloc_max_size, ncmpi_inq_malloc_list report the size in bytes of current memory allocated internally by PnetCDF. Similar APIs for Fortran 77 and 90 are also available. These APIs are enabled only when PnetCDF is configured with option - -enable-debug. When this option is not enabled, calling these APIs will return the error code NC_ENOTENABLED. These APIs are usefully for debugging. * ncmpi_inq_files_opened reports the number of files that are currently opened. Similar API for Fortran 77 and 90 are also available. The API takes 2 arguments: number of files and array of file IDs. If the second argument, array of IDs, is not NULL, then it will filled with the netCDF dataset IDs. This API is useful for debugging. o Syntax changes * For all Fortran put/iput APIs, the INTENT of write buffer arguments is changed to "INOUT" on Little Endian machines, if option "--disable-in-place-swap" is not used at configuration. Otherwise, i.e. on Big Endian machines or PnetCDF is configured with "--disable-in-place-swap" on Little Endian machines, the INTENT is "IN". o New PnetCDF hint * nc_record_align_size - aligns the starting file offset of the record variable section. Note this is for the entire section, not individual records. o New error code * NC_ENOTENABLED indicates the API is available only when the corresponding feature is enabled. For example, nfmpi_inq_malloc_size() returns this error code when "--enable-debug" is not used at configure. * NC_EBAD_FILE corresponds to MPI error code MPI_ERR_BAD_FILE, meaning "Invalid file name (e.g., path name too long)." * NC_ENO_SPACE corresponds to MPI error code MPI_ERR_NO_SPACE, meaning "Not enough space." * NC_EQUOTA corresponds to MPI error code MPI_ERR_QUOTA, meaning "Quota exceeded." * NC_EMULTIDEFINE_FNC_ARGS corresponds to MPI error code MPI_ERR_NOT_SAME, meaning "inconsistent function arguments used in collective API." o New run-time environment variables * none o New example programs * Example programs now report if there is any PnetCDF internal malloc residues yet to be freed, if --enable-debug option is used at configure. * Under examples/C, three examples are added: create_open.c, get_vara.c, and global_attributes.c. File examples/README contains their descriptions. * Under examples/CXX, several example programs corresponding to those in examples/C are added. o New programs for I/O benchmarks * none o New test program * Many test programs now report if there is any PnetCDF internal malloc residues yet to be freed, if --enable-debug option is used at configure. * add tests for flexible APIs. The tests borrow from nc_test/test_write.c that tests nc_put_var1, nc_put_vara, nc_put_vars, and nc_put_varm. Similarly for get APIs. * testcases/record.c checks if the number of records is updated correctly. It writes to a variable's 2nd record followed by the 1st record. A call to ncmpi_inq_dim() or ncmpi_inq_dimlen() should report 2 records after the writes complete. * testcases/noclobber.c checks if error code NC_EEXIST can be returned correctly when NC_NOCLOBBER modes is used in ncmpi_create and in the meantime the file exists. * Some test programs are developed to run in parallel. The test mechanism for parallel runs is command "make ptest". Two environment variables can be used to set the MPI run command and output file directory: TEST_MPIRUN and TEST_OUTDIR. Their defaults are mpiexec and "." (current directory), respectively. For example, make ptest TEST_MPIRUN="aprun -n NP" TEST_OUTDIR=/scratch Note the keyword "NP" will be replaced by the different numbers of processes used to run the tests. The testing uses up to 8 MPI processes. * A sample PBS script file is provided to test "make ptest" on machines with a batch queue system: pbs.script. This example script can be submitted from the build root directory (where you run "make" command to build PnetCDF library). * For cross compile environment (and batch queue system), the environment variable TEST_SEQRUN can be used to set the MPI run command. For example, the command for testing sequential programs: make check TEST_SEQRUN="aprun -n 1" TEST_OUTDIR=/scratch For non-cross compile environment, there is no need to set the environment variables, as long as one can run the MPI executable without mpirun or mpiexec. o New optimization * none o New utility program * pnetcdf_version prints the version information of the PnetCDF library and command-line arguments used at configure o Other updates: * Revise FLASH-IO benchmark to use nonblocking APIs for both checkpoint and plot writes. The control variable to switch between nonblocking and blocking API is "use_nonblocking_io". Set it to .FALSE. in flash_benchmark_io.F90 to switch to blocking APIs. Using nonblocking APIs is now the default. * To match ncdump, ncmpidump now only supports one input file. * Makefiles are revised for better recursive make and fixed some build target dependency for parallel make. * File creation was revised for handling NC_CLOBBER and NC_NOCLOBBER modes. On systems where Unix calls access() and unlink() are available, they are used to check if a file exits and to delete an existing file. * subfiling is now enabled by default. Users can use --disable-subfiling to disable it * man page of ncmpigen is updated to add the description for option "-v" which lets users to specify the desired output file formats, e.g. CDF-1, CDF-2, or CDF-5. * flex, lex, bison, or yacc are no longer needed for building ncmpigen. o Bug fixes * fix ncmpigen.y on parsing CDL file to get the number of records. The bug failed the command "make b-test", due to getting a wrong number of records (current value for the unlimited dimension). * fix the update for number of records when writing to a record that is not the last record. - Update to version 1.4.1 o Bug fix: * Improve pnetcdf.inc portability for fixed/free-form Fortran programs o Fortran API syntax changes * For nfmpi_put_att and nf90mpi_put_att family, the intent modifier for the put buffer arguments are now declared as INTENT(IN). * For nfmpi_put_var* and nf90mpi_put_var family + On Big Endian machines, the the intent modifier for the put buffer arguments are now declared as INTENT(IN). + On Little Endian machines, the the intent modifier for the put buffer arguments are still declared as INTENT(INOUT). This is because PnetCDF does in-place byte-swap on user's put buffer. If user's buffer is declared as parameter, then segment fault can happen when PnetCDF tries to byte-swap a read-only memory. o Subfiling * Subfiling is a new PnetCDF feature that divides a file transparently into several smaller subfiles, each of which stores subarrays in CDF file formats. The file name supplied by the users serves as a master file that contains all metadata about array partitioning information among the subfiles. Because data partitioning is made transparently from users, data accessing is kept the same through the conventional PnetCDF APIs and the master file. * To enable this feature at configure time, add configure option "--enable-subfiling". - Update to version 1.4.0 o New APIs * Fortran 90 APIs (adopted from netcdf-fortran-4.2). All F90 APIs have prefix name "nf90mpi_". The APIs support function overloading. * get/put_varn_ for reading/writing a list of subrequests (each is specified by starts[i][ndims] and counts[i][ndims] for subrequest i. ndims is the number of dimension of the variable) to a single variable. * multiple put/get requests with explicit buffer type names: ncmpi_mput_var_type(), ncmpi_mput_var1_type(), ncmpi_mput_vara_type(), ncmpi_mput_vars_type(), ncmpi_mput_varm_type(). Similar for get APIs. "type" is one of the followings: text, schar, uchar, short, ushort, int, uint, long, float, double, longlong, or ulonglong. * ncmpi_inq_nreqs() reports the number of pending nonblocking requests * ncmpi_inq_header_size() reports the size of the file header * ncmpi_inq_header_extent() reports the space currently allocated for the file header, (also the file offset of the first variable) * ncmpi_inq_put_size() reports the write amount committed by far * ncmpi_inq_get_size() reports the read amount committed by far * ncmpi_sync_numrecs() a collective API that can be called in independent data mode to synchronize the number of records in memory across all processes, and update to the file if NC_SHARE is set. o Syntax change for Fortran put APIs * intent of buffer argument in all Fortran APIs is changed to inout, as byte-swap might be performed directly on the buffer. This change is for performance consideration. For example, if the buffer is declared as Fortran parameter, then compile will fail. o New PnetCDF hint * nc_header_read_chunk_size: PnetCDF reads the file headers in chunks. This hint indicates the chunk size (in bytes). The default is 256 KB. o New error code * NC_EINTOVERFLOW reports the error of 4-byte integer overflow. This usually happens due to MPI-IO data type constructor APIs' arguments using 4-byte integers. * Error codes to report metadata defined inconsistently across processes. o New run-time environment variables * PNETCDF_SAFE_MODE environment variable can be used to enable/disable the internal checking for data/argument consistency across all processes (by calling collective MPI_Allreduce). Set it to 1 to enable the checking. Default is 0, i.e. disabled. * PNETCDF_HINTS environment variable can be used to pass the I/O hints to PnetCDF library. Hints include both PnetCDF and MPI-IO hints. PNETCDF_HINTS is a string of hints separated by ";" and each hint is in the form of hint=value. E.g. romio_ds_write=disable;nc_header_align_size=1048576 If this environment variable is set, it overrides any values that were set by using calls to MPI_Info_set in the application code. o New example programs * example programs are now categorized into C, F77, and F90 directories * nonblocking_write.f and nonblocking_write.f90 are the Fortran version of nonblocking_write.c * put_varn_float.c for using the new APIs ncmpi_put_varn_float_all() put_varn_real.f and put_varn_real.f90 are the Fortran versions * put_varn_int.c, put_varn_int.f, and put_varn_int.f90, for using the new APIs ncmpi_put_varn_int_all() and nfmpi_put_varn_int_all() * hints.c, hints.f, and hints.f90 for using PnetCDF hints * flexible_api.c, flexible_api.f, and flexible_api.f90, for using blocking and nonblocking flexible APIs * mput.c for using ncmpi_mput_vara_all() to write a series of arbitrary start[] and count[] * block_cyclic.c, block_cyclic.f, and block_cyclic.f90 are for a * -(block-cyclic) 2D partitioning pattern * column_wise.c, for a *-cyclic 2D partitioning pattern * put_vara.c, put_vara.f, and put_var.f90 for using for nfmpi_put_vara_int_all() o New programs for I/O benchmarks * benchmarks/C/aggregation.c -- evaluate PnetCDF's performance on I/O aggregation across multiple requests with different data access patterns. * benchmarks/C/write_block_read_column.c -- writes variables and reads back using different data partitioning patterns * benchmarks/FLASH-IO -- I/O kernel of FLASH, a reacting hydrodynamics code developed at University of Chicago. This benchmark can be built independently from PnetCDF release. o New test program * test/F90 contains test programs adopted from netcdf-fortran-4.2 * test/nf90_test contains test programs adopted from test/nf_test * testcases/alignment_test.c -- test for header and fixed variable file offset alignments when entering redef mode * testcases/nonblocking.c -- test nonblocking APIs ncmpi_iput_vara_int() and ncmpi_iget_vara_int() * testcases/flexible.c -- test flexible API ncmpi_get_vara_int_all() using an MPI derived data type created by MPI_Type_create_hindex() * test/header/header_consistency.c -- test header inconsistency and see if inconsistent metadata is overwritten by root's o New semantics for attribute APIs in data mode o New synchronization for number of records o New optimization: I/O request aggregation pointer). o Other updates: * configure.in and Makefile.in have been revised to detect MPI compilers and other compile options automatically. * A new configure option "--disable-file-sync" to disable calling file sync. This is to be used when the underlying file system provides data consistency control. * add build recipe for IBM BGQ (e.g. Vesta/Mira/Cetus @ANL) in README.IBM * add build recipe for CRAY-XE6, Hopper @NERSC in README.CRAY * add build recipe for CRAY-XC30, Edison @NERSC in README.CRAY * add build recipe for Endeavour @ NASA in README.SGI * add declaration of flexible APIs for Fortran90 * "make testing" now hides most of the stdout. Use "make verbose_testing" for verbose output. * ncmpidump: add the command-line option "-k" to report the format of netCDF file. * ncvalid is renamed to ncmpivalid, a tool to validate the structure of netCDF files for conforming with CDF formats. * Fortran type NFMPI_OFFSET is removed. It was merely a shortcut to integer(KIND=MPI_OFFSET_KIND). Some Fortran 77 compiler does not recognize keyword KIND. In that case, please set MPIF77 to the MPI Fortran 90 compiler, e.g. ./configure MPIF77=mpif90 * configure now automatically checks Fortran module compile flags * Support additional Fortran netCDF data types: nf_ubyte, nf_ushort, nf_uint, nf_uint64, nf90_ubyte, nf90_ushort, nf90_uint, nf90_uint64. * Error codes and messages conform with netCDF's o Bug fixes * Argument unlimdimid of nfmpi_inq() returns -1 when no unlimited length dimension has been defined (to conform nf_inq()). * Argument varid of nfmpi_inq_varoffset() is fixed to be the C's varid plus one. * For collective APIs, many places have been changed to prevent program from hanging if a subset of the processes got errors. The fix will allow all processes participating the MPI collective calls in the PnetCDF, even if errors are detected on a subset of processes. * set the nonblocking request ID to NULL when the request length is zero * report error when bogus request IDs are passed in ncmpi_wait * when entering redef with different alignment hints, fixed-size variables' file starting offsets will only be changed when it is bigger than the old ones * Fix some Fortran API intent in/out argument declarations * ncmpi_def_var is fixed to detect if CDF-5 data types is used on CDF-1 or CDF-2 files. Error code NC_ESTRICTNC3 will return. - Update to version 1.3.1 (September 24, 2012) This release is primarily a bug-fix release, tidying up a few issues and incorporating some early feedback on our "buffered put" interface (see http://trac.mcs.anl.gov/projects/parallel-netcdf/wiki/BufferedInterface for more information) - add a new API ncmpi_inq_buffer_usage/nfmpi_inq_buffer_usage for inquiring the current usage of the internal buffer allocated by the "buffered"-put APIs. - bug fix to make bput APIs properly return error code NC_EINSUFFBUF. - bug fixes for ncmpidump to avoid residue contents from a previous read when it read beyond EOF. - bug fixes in the the tutorial example codes. - add more in-line comments for the tutorial example codes. - add the error string for error code NC_ENOENT. - Replace parallel-netcdf-1.3.0-destdir.patch with parallel-netcdf-1.6.1-destdir.patch. The patch accomplishes the same thing but is created new for the substantially different makefiles.sheep95 1615030281 1.12.2-1.11.12.2-1.1cdfdiffncmpidiffncmpidumpncmpigenncoffsetsncvalidatorpnetcdf-configpnetcdf_versionmanman1cdfdiff.1ncmpidiff.1ncmpidump.1ncmpigen.1ncoffsets.1ncvalidator.1pnetcdf_version.1man3pnetcdf.3pnetcdf_f77.3pnetcdf_f90.3/usr/lib64/mpi/gcc/openmpi/bin//usr/lib64/mpi/gcc/openmpi//usr/lib64/mpi/gcc/openmpi/man//usr/lib64/mpi/gcc/openmpi/man/man1//usr/lib64/mpi/gcc/openmpi/man/man3/-fmessage-length=0 -grecord-gcc-switches -O2 -Wall -D_FORTIFY_SOURCE=2 -fstack-protector-strong -funwind-tables -fasynchronous-unwind-tables -fstack-clash-protection -gobs://build.suse.de/SUSE:SLE-15-SP3:GA/standard/1c1fd31b7cc68f216163e3116397bf49-pnetcdf:openmpi1cpioxz5x86_64-suse-linux  ELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, BuildID[sha1]=6cfa5752e878d9beb4ee976b1626683b4f71a036, for GNU/Linux 3.2.0, strippedELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, BuildID[sha1]=1253bd1671c31134373becf914d52ccdbc31267f, for GNU/Linux 3.2.0, strippedELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, BuildID[sha1]=96761c4904f2edb0cb3f4c9d6158719ff11cd423, for GNU/Linux 3.2.0, strippedELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, BuildID[sha1]=e67520cbf77d283dce8b14632c614da3e02bc94c, for GNU/Linux 3.2.0, strippedELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, BuildID[sha1]=617454ce657687a2a11b305c2493560714eba215, for GNU/Linux 3.2.0, strippedELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, BuildID[sha1]=ae2b0d2f980fcbb78422e570dc029bc0f0223884, for GNU/Linux 3.2.0, strippedPOSIX shell script, ASCII text executable, with very long linesELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, BuildID[sha1]=66214db1635cec54f3b49ab4c35ad6addc091a59, for GNU/Linux 3.2.0, strippeddirectorytroff or preprocessor input, ASCII texttroff or preprocessor input, ASCII text, with very long linesC source, ASCII text "%& RRRRRRRR RR RR RRRRR RR RRRRRRRR R RR RRRRRRRRRRI1F "utf-870fa3dc83bb8f4bec6a8950bd2dabcafb0a55c2b090ff03a12eeee7b0c876ea6? 7zXZ !t/] crv9wJ)pj.` Ֆ$dV7oH^d=M׊eLk0wX,ă <V~;p/$(w>f|f3'US7 Ȩ U}&+8夫ɼP  V.Nmҍ8k oÂnެ~#$(/RVk Z(ȍU,>*A]dZCCzS!B{]ߩ}v~Aق$x@yqpqz~G+4fw5##Db" M/WڜNǠl:˼w? o&-!z_ Ijt7C&b-(հ&pGm>_ٔW0'n:+V^qUrhLs]rV[![u;I(lTs!АgV58TUFwvdI&tρ~2B2"Tqs A[ԞgVWxpXL%3^q & 0xcy4i:Q.\#^b8ԢW)}%G/+MSާf]\5L/Fa}B=;yOZ<,q8G:B.h}-{]j^?.M܂Q uR.qlA\ZgyA謉Cγ1Q=f 1Lꂻ*0솽Ks@rv]56 jhEV}vҏڊii9g,wV~US8%m`륆`}ִ~uJ6:19܃r^5?\GΘHM-) L2#lw)l fJBe5!*3t!r:$w|2+X\DGid05S`ɓ[5mK0!.g\ް~\KI,eUjӱ_a GU Axj;w5p&$Z,YYFRJ>V$Ysah%Y)kGWQWədǶDb/r kGI|PPFNgv~޲i[Mt_ ShCx}G˪ 7m#'?"@|.bxCfBIp z~-G4CP]-D0)>MaTz$àC :ZZag~7޵΍Q`c׋a:=- RʂZLYK e8AjɀΞUP_N+<[=y?8Ԓb'\ .񃲕f239map$%lHQ}nʶqR{BmY]Cd(K3m%j5b!.>\~דBKl:Z.m`Qh\''NxLr*h/޶qK H00s)HUMD@||64⛘B?{3Z {c4JbQUyu.ol{R?Kp0;imm!>U vOwaSY) UPMrK<{7Mu+ni;$r|LOφ ׇUeqyO;8uTŤvTFP3톙h{B#Ufy\UhOKr0dYm tėX%( / [vJ,9-09\+k=u:=+?nf xw77GonFM[M`tk$WU˔ jH[A-9!v4FqG=+nVo$.刞\j9;MGs5.}7"f͜& 5ZyB\x;ibEyAsO/e?/y8X;K% $U.t6Ji7՗ծyYJF>f\͐XhKO&nmOO=J達KgҟX̐z+1n*=CPq%\z".Ph?V=&ŭZ;^$wc (27͓0Nxmҥt(TYj.g }4]%H_lqB^NRWta+$:.~ZFw3O~mv+~eV:5"n^̾K]rZd!Ux ܨ1$8| ~_&ּ|aO}@0Ԡ/o&2?g4$D'BXXyK[L4~EM|{Ow b~*ei966nfrcϩ=YC CkUur9QB~!q)79ZʫY+[AwXY/];hN-y K+@Xf 8seק^F'"m` K5,T)~&M/&@e1 ^#zԺ>1[{j83-k'MCu)ϨrG:+H\.oyEAPL@Xa߻; uqۊ9VRXZ1FE}P)u_Wy&;,H #-٨} u@zɦ-(,:%(K.j=LqFSNvTp[[-S˨wF 7\E]]-ŧv jzmt~U[+m Xߘ!˄&5{0EjzBI@#lK Z*Xp!DN>b%s1@/i@nCI3>ɞz|C+8m6[1b)/} NU*w_^Ȏm^PtT*UJ [N/|.7ܧ'=eC;̘5Rht($R,'yco: Ȭjq5A~$ڣ'WDfhY_Ws h?# ]\ U&͡hÞ )j fѯRoBc7v+.~"8.`|l11Jl?/4?ձѼՅ U6^.=PbwˏZs.c=Q)y6yP]X<(,f8%\?!̇u˧iM(AA+kc!Ф.CEG:%$5iZmrb~ߚ2dF) Ν>2dy lL-7Ev3AyAlaJ*T W80U{\P}ճ ɠbK\TsjdPE"Őrj 97od}SH\qqA nԨG\@T!S͜<+dj1;=Io'2)[ 1L%3qQ6:hINiaO7Tp_} ^#Ԝٮ~fln9O&k즑5 2[91E[! 5C^{lܱATN^5io4`+5_"^՜L F%@(rf.鱟L0<_6s>ϏoD{ O9U,1 _^^gH9:b]HUg7VR)w VX[W &=Cȗ9Цq ꖬt[>/^C_#[&Ţo]|L>uqu'P FWWu㔰d=[bnesq.[.];'y6QPٜ­ vȎŸErN&f4TVtѢ\du`e]+#VY˕Bt2j6fZ&Κ:U" }bՌOB2On]ⴖ+:QAkz9 mඇ3׋6S{רWP kY7,EwX 26*Sv|F 7nY>xn.8s$6޺ƥe?:sv }*^U'|̦%N/O%Wh~f/Th)U$`PfO!e-gx]5j}XbbV4LWhhZ=: $})N@Do>ij2ہQDo#^pAk1(C&( m%`T"G*neF!Z1!o$DO-x^ɮݬaj}coʈ=l҆cYILIЀ`~Yqet@5sf0 U4ێmz\Q |8zh8Dog:#Z:,Z7oz\'òaнvd!8RDoǛZۗBMd5:Yp~(UE=Aji91\a3@a)49x2"CW[cdX#DSV@= D'0gFmO@ :? ]!nPP#yf*ɹ&` y!L[ *z۔GF%{ʔ]-Ч@7,0&'B)/Sj=JkJWk|iހõj&%iS7=Znz*s#;jj\BQҎr4xYk[iX @'pw?^ ,2wW ={ћE^lc9o8 dz`c*R('k# lp9}Sx0cEv$R蹜y᪺N|51lѣ4 m)yꀜR?C)h!My\!:8 PhxQ2֠mF3EYce>ܤgͼ9~KD@ݢ-fjW]Wͣ8.#JUG{qSiFi"KiZh%uoĊ37܅Sȁʙ+ӸI:sn: bxub45I1,7;y6 KF|B(Wz$j {)/s4ꮇ޶ Ok'4ϊcޥgi[uUraɵ]|tbI,Aל4i)Q렻$^P(r&;v]'e(z̊ʒMV6t/LSnM{lG2W-&Nt1&7]WHЀgb>'#F(c4LȀ%,r&0ݍRvIMve] |B-:n )/R(O}:\'նxb+*u}&bc*T3Y `0?ZwQq .6XW4E@V'nI7~,)+=`zlMkp 7,uFR/ؘt/gsːEdK8×VA'"qhk_AC0zv%2'J=}x\*g i6w87YfYoVMֆ`tN5/~ѧ6C*jHbq{"+Ls`2q@` a`S;/su( WYZ5" >:L AvC`B"e?jidVA!1*=V̲g+O w?kp2-Ѿ. SzqI|t Wh~JPҴ7Ӗ*avDj/O[^_R@YB/cIyNe/ BŧW;|9M&:,."Bzo[**òx:hi?bL©~vn+">cE$tw?.)1ϊCM @QrĪ [ ƒ\%&''ܛ;jjT]U=jKpduSh6?-Qq+82/vkm|ȍViXKW$ ϫ.QSYL 3KCү}]#E>@?+PP\Wj36HoUƄMB+ u|)v Y}Hj$}Ds0U`!/_ $C+k E|dK~0Ԋ򲻩~@j2뙫%Mw9w"QK3BC&T\ L %zǒaFJ!=4҇>;BaA`8t9\bLw59RUhVBg@-[;Rk./} :`th}Yɧ D1"_0A͌H2VV ӯ࿨].2Q+8\(&M:$E>U52x@MAx}k5#K_Xqn[-/S)dH6-\NɳY X~XW[dHeQtM;Vwhߪ9u 8.0bpC=y"qY< dPr>p lȂhUz]u9! @`Ӕije\zo Pg\ӧ2 HYNuʹָuʡ}vSx`+,Dh*J$*m'f PI. qsuu&U%Q @DW[4O"#ee'S+W }kv(O*QzOmAI͐K:͒&OiGW1DȂLg- $xF.bn{k\.?wyFr)u(5*?" Nԡ-K}Ӭ9ZjGIfR` H[uwQ08fƱ{BܧIv ?JݞSPWkOp̔D3}{y> 'K3wl{ܑ?~4h& n)v ^;Q$O:޻S6@/ #oJ ֬xE/ NK#/6\o0Bp'' O,ee)BNgZ$ 3@Ȧy7:BOך`H2D&P]݌pZfWҐ\\_.:ă,sSzg}'?bDZ0!$a%,j;LolzN-Pޘck?pE<ۈLtIגL۔ j E x\`;xjX, vR`.~q](uM~H A'q,V,TLvy7\ ,, :JSDDn|b99RN? ҦBOvP_ƴlȈ_6d9tBuB750~⽛.4cX Goz׍xre5B&6/4}w}sEH<5_) T< ھTe&|Цˈ X^o9 84`,`YZ >LX}KyWRhkZUNw4DM_j%4N$rѳXnmX݂=5KȴF\Ϧ?T.YI fnv(3ALK3&!.M Vzlj XήwQ(YearVs zb% x0hW*? 8ʩ%#{kJh֌'YJp9\'/[%^f, v[rH vBؐwΰB,wTΗ}6 -.}dD[L2ȓDs]w Vu:{YQ8+݌gA„6ZzH.}5㪣p3D#"ZJE9n@I XֹρIBt#ږZ[j6[B͋]ٶ]{׆:egw #g8hg1N R,!ʹ0btzS!Ӈ/Zw'T%ǃrN%oAvTz{ިߑؙb2<{\n{f^|EsI(4grF\]@o[6q\0P αU}s} e,KrK Sr~%aXn>tZ.]{S ݧ`WWQ*h!=!r..eNߓQBm1$2F/e(k YS#9T-o5fCynPS,rHk)$jaX3EWmP23t'ٞ洑vPj9GC^T?-^Z0|{EoWꨦ~iKC33zڷ`ZJ5cJ\U=X^=qlPUue\gu:ӓB!* fQE)M"P gGpOSJ[[7Ů#}qW]%v .!v* KB,.VM {E/& .CV6*t م 0&3h/O7&it9yqh7ko-.?> 8iNֺN [%1CD)Զ?q̯)\o عP7Ƌ*h+4Flc&8Dъ4P8Xw=%x]i{V]jاV~N,Nala;G$=8`C"PZIgo>0 }4n/72wи}WG&Z1W(#J~7kv蕣Y Oճ<+db[4pV!{ f_֒ `G\gVVe&ܡ`p>Y5o-XoX2W@((_W>}su 7jz/ZЭV 2t?k(MD&Q* SL E}҈.$RVKr+߲Cm+V!䡱}'@.ܺO: <)(s4b: '1s?BN[ӇՄ QL{6mKtzC ,,XTm\Ԙ2`~T&J 4bd;FtԾ>"O!#2*Ʉ|Y!.v#T d?.X Bt^Ry:}˺;t8׾,msr})ꞛ=@s¼&[?0_| DXrQd.yC Ϫ[+[+n H͍2%>v1uNy!i]l65&8<*Hr۝7~5]~iYRDDo:D kdjk0\F; H( kt@(y܉hE?hS3j`KN}_qbNB<O$TqcÌ{nZŰO@iS:ծ!]p(ۍV .Q'&*8p7*aǐm<a-.;j rZY1: _/$G:B?u0N.W}uNzcuU ? W'zP΍c(&)PjDtL]K 20):˕"wrأ mTKǫCl ]b J@ez8ʝp !MQ\`F -g:ٍ]BQ٦ﰮ>K8yM3| pq[)p2=JBd ,ÁTo ?lW > RNU؄:@#txk \ J< 5k4sMwI\~^:rE?Wˑ+`Fyst]"L,if3] d|U1݆GUn*>?C: c$r?SUE? g ϋ۫H1M_q\QAr8]LR) 2 cW:i". ESP kpdʇlmWn%pc{&[)C}͂yaÔiBX\g4I5 nYv/vV m=xOqsӧ8j} VsuGX@>(Wմ\H~EW:;w>k_1#N?Rqv܀.Н4;eBEO}em΅Ѝ*_t4}Ŋ V;aDQ8߇d'59{܈GPyqT,iGc|>ngyThO[s<+vGi:ғ^' c1kU9Q-v\4["4\@8L'|>eb4C 8 ] VH)D'Cǿ'XdxvTdA9(&n6Â̚4-tpGʑEmJ@NjB*ܴ@1s>š=GuJfshseXMY*/2!eرmGZk@J_ fonRݞΐ ӥj$Ҽn# JqH~{s%p ʰ|jp =} l"3Όfp^Nceztoü4܉1L'k7gI &=+ϐ'isTŕ濞)+1u,H:cub %OGΑ9|vQHj38~f?7fA>eAvx2ʌgU@4T Cҳ"v+넦 Tu FMv{+^IHDMOЃ̃ke`nq%iy2˪qH /tzsB^6:|Ɂh,oy~B صiEv$w-wU@fU)3E+<ثrDܡq⨎ +hK܋Q MT5K_[RV8U~S0|E* ̿L/7"~3H+8ϳ) "V&I'm-X1 1lFRgq`xlFuGB!&u{@$^4C0t>|U^2u+#]K0/䧿Nx e%`7ϑ%I+;S!j Z+8T6 sv?+zkJ Mh-,Yc ! 06dp@u t N]UC WYDC#{|o~)Ն@}QsGm"=AEqPచ\̚[.(io>^=u&!>MP dw4)LlaPsY_N3Ǐ]dA݋.YaZř=N;*ve<V=?'> k1׺37h,.S2`6rlhVe6p -߻ÞDK)%A ibvHskO!P8q-J)k6snsp?oL#mxİO^&3 ?ie\ 0aPA4}ۜ){p]~SO?:!d꟭?U hgP4p K:dF.~(}c'-͸if.-S3K{uղL7nĶ> 3x uzkɊ+rK kk  m2x3 sTq4R4f-dB)5d:{Y:,<;6Kcs?cIr0VgLU.uѵ#5MrmHGT@=+:5Mt:f. l''&W/ Wʣ~ջېHS{G ZCπ=8M x*Ps.%fSv]EiUA (lt)$BJL2U 6j>(,1MXepȅw]ʼn)8Z,Țn4.Tx:R5Κr1I".ɕ䷻dDJC!aЇC_|MP kJNۣ#[/_E,J7qtd(j7}!UT>C>_xIrcG$7 "DlfȚe/LUPwr(u\ƛs3~9Tey* VK NI)"Yp6U}S^{ҁiQ 񆐷6CEp;hxTMODakhs?s{)vMP'4CxMoi^_$qu oA96v(pZG%PpN0BMZ&넟m1>? "z4= 0J" *jX "8"%8ʅtَslGǎ1˱i-_?W. Rlvp)fr1n$iKF#4[w9K[gĞ:ʫ.)"@d9V\G̉3?F$,wD#K>(T0wbQLrIz讉/;oQ4vl xO4L0vu&Y7ŪEHݒ6G'NISf>i CpkghE#{)JialKӖ ,Qh܏ @Yd-f|Yx6UIf67!eEZE>6]j#7%U`lMi*MTxv4.NR#"ŗ~C:Cb /a 6! =kGC:-:pŹtsI&R!0 _}3 RxZ! 7BĭkhVThR sn%O:=X#G?OTZD^m /s |hRVrk~*NH!sg `7OX }ȧsrg%-M G}/w=/j 0$˩0IɷsQuX7#dWDtMXn Jة0L~I|@~p3eI~ z]>GK]~wcvuл./NILդƓAu|OnJIF>جZ }("JlԪgh>*]98P#I'*xA14=;}P}iD{gtdxq{[=DKP߃6M2~ .(8CRwßU> ZXB/{He:G^SI.0V{KF#EX E+gcyWń/T]} GzUfrdKu&X]%wnzxkw}TƼ P+YQ魽ꨵi/@JkE[Is4'1&!E /SŽ\זaLZ00‘ƴ۝-RH;4Xw޶55orNwB%~' %#Nw8NHQ-+mL>/70&J逷ȭjEnS'7^eKaO TQűSz)x Co cNǒKA$+?s=vYzvp52=U~% `AJaf]ZOfZ,`j/uT6>l"~Tlw/;ly qfcv9%;{9Ho ީnyW?^Jx<$}*[O&RkdwD]iP`zQтkĥG| DI-zR=7;.D5|K?nZ6t5t:k/Ha4its\qh>-@R#z;(qB> {q}t <93k:].Wy.Nˀe𐤭1EMeo%\f67G˼zv6\iUOQ,`u!ms9;I2nvp[#S`$@nvs4MzT.E{!n6t.0 q Ltq u/{eJV..@N'Fb-A8;"YQxZr=XvQ9p,T*C>O[NQ%L1_<ƹ3Mp/@.=V7Gx!'z.<7ǤEvXx/ ͎pZ2L ={׺#Y`a8`i`] Kll֪{@~BlsXE_fD UZ~P ߄\CgbކR䭲Nb,2x[cPi@(oL|i5 @KJ;\:4Л&Mkn .' { hN*p|{2V :)k~.[đH^?ȼg$]Ҹqןz,K>*,{UVH ͚ls*qy'AK~chD!oL +ԍڣ-QrF=9c' P b}߈(ͼn =aq$`|Oyǵm.^TFA{UԽ768;2~-1CrN)"UWRۉcoI2 :t?74i<ـ1ۺwġ?j!C:I?I:r=\r[>koG.nn#Ka~w֚lюؽ 'tѼ`&8Kx&'zF룏脀 ޼CiV0j7U3߹;6~:9R1ʂSierPl監o; o4#J8 dǘȷ84iM v@qkSt  K`<.+ 2o١#']qv-5&>uؽ 5(7]!:grV=b70\tWdzζ:(xAz>Jo!*ͪtnf|4sxWc$2V%'g J$GSµcm&ǫh=r&ɧ MD . ژ1G:ٽF9]6$xM >Ԛ{^G,)-=KuጬZ%SǴ?!2 Xʧ؛3h]4hYu!B% GL]`夃K+COه-PrzGq3txe:@.i$2:gZ|qM!Q%\mWG#ڸ/G:#KL'S ?1;zԹFm)reVs%#?kd[?bALW'=oig3R)%l)rc_M%-t#-no?.'LҜ4_n2˴a5T pGe:x?8dSFP]iC W&Xz~-6$z6;ˏ Cz N)B> j2INAhfuKN=-ltxV yMoNN]hݍZ&;zwcDdݒ{eWC 0ޗ~- 7F%3T?/hˬ@mTqa^TF`@In-V^xWȕ$2^ZP?%ʥIh֐w"LM >d=n3j$f g EV1RRt#"\ڴĊfzh8|/isicݷH1\:Y;J@Pf˷Dj~:xr(8qiF7iHp[v68εlF͵wOɷ@Nq'8R/2,PHLBDM;@zvGȶ~J<^=3h6OtOX#|?= ċi ${OWNU8EopŬ{d.D>K]!Z%vm>?ԄRj>F7A cK);s,~êYW=?+fGr v`cXn#mF iN>fSq>}V]9(e;@%HƧD;CO ('I)39L5Ǚ4Nl yhOX|p!< ?;װ) 0-j&ZsPZdq.D@gʼ xI͔l&Xvb8ink)4Z־i$ smdms3j^om5C&gY.`l{R)6^$͚>َuJ:ث Dj̣(WfW $z9)%Gc,&% ʵ_T}D2^)ֳ4]cpOʑ|ÄI ܙ@?;,:Kە崁u$5^vf&KD(׬/W+9r76x"– X 9N5SY/$ŌJ{)Q谍e/&K?:oI,keZ^ $+1򰻜D(xŤ(]^z_H 4ۛ]vkCVĀ≝S^ȯz9oN3j=oMkʿ_y*6 )sSP) y%*t8smq.P-AEgdq#K n"} Np$S*)lgg SP"6>x ϸ-/Ƽf%>9su4,/ǣk1D%H>ːe#ѥpZ슂YШ0rz$ 5 oZ J(([[ ibw#>yG~Ju<^$_!6۞b޾CC( Rx0| r(v7*}`K߂>]A \i<\%.%=. ͒W*P⇑x@ ub>ę$wqC*$NoVϻ2 hd2n1KKZ2i>♅3RxHtbѤ:#[Ӧ4Y(YSɤGX,{W:?GZA]?,h:F;m7{ݻUC4K\c{K/Aq3|6Q OZ沋[vE:"3+4Ak($j|voz7&A]j*|@he7]0`oxN9"Z#TdE NsX 58|J#u89Z*`Q'Q]u$j)4IU`5]0YTI% BW<$M{pW`{)"_L8`8 H r4tAp$ `Wk Hv8 N4-Qm愍o EJװ3WFϛbDy NrjD.ww=aѪ Uea|.%o|L*oC"0笸6z_z13X If]62ml`؍Io; *N/`*"}&hXިRyBqN׿}nfr%'\R%3{#,נA鞞i\ (5vAM $es2wQ_a @-6*KJRг$(z1`; 29qY_r$ЮԈB= S.K+};vw+)8olHv 4B.\Р_4AbYy\f[ `,.h$ͭXęJcIdjD"oq5"4"0M̂&|qZ ҄޼] C܏ܾ" ?-IDUaaߩ韬g]oP%w䳩3M~FzK αףQ[⫼mJ,n֤/ TnL#KY96+=oir/oF܊Z!bZ@M-M:iI|zO4 [8 ty*XV(gtg+'ih)}CNC2АvdwUZcԑ]is}>a5Ԥve) BVb,cZm&6GޭYqL,Su\52zߴif=I0T8GmhXw임g>܄{..+mxP0fRB2[ҊXW ۨ)1 v`^\FsQx{K PoD$S$xB&?gg ҍ:$.#J|ThBr~R?,Q :MkNl`w ȯu_iO3lN_I(oLpc"PM6.:u9~rI**}هʒy LcN)4qpxlQZh{! _c]7}Y{>/."gBI$["!H9q f*D7BgB\ YNT+{ssjA*0XřӠSt(^6mu"v/{|< (Z>;R:8n9H(Z2Gy8܏Z xO+{F˔)G$7?9zڰ+̐2Lry=-AUTMɑ^0vtk[C&|~VHAsFp ٘+sKN#_::X02t[]FAC/!d9 \AoY6-PR{S7 g2\adp%>wm܃ ~Hjtru]CVnU'{&˰XVk42Xjv]5}R=ɢ9nad)kCRbIlonfz@Bط?Y Z#3e\V9]߇K? 7i=P$# Z1kp: =C)KIWfx1F>)f; DXkFjnF$Dw/η:iFTEQAi:p"s?A!>9n}k7 )DܝMy5' j겢 R:.YGOQKB HФ7X6>Q1QNpezk⍟V8sB~2h͑%m*W+ozt qp3&M\b .iõ6;CIW}_x5Gix|R-5 U33oW֌@ ?)`?ou=C\y ڜsbv1{GWbM*cl67 a x~t:co`ȝ(;mP6)gu]T!d`7OIo 1gvIte|DTr-e'ۻcw0>Y:y]Iv +v iŦÒ\Ag[6K0AӪa[Mehf)BJr!y@ 4"mwߔhm:[z-&y!“s[5U%n<1ʤ$CVv)S/pC`j{nCKJ u<3.{l^AПnAȝCр3eKeehIbCg(NAnagXb %Rz Na$(cɡGsE'/TKS 3U ).V%4T{Ô?@iYnhUÁOcL}]h(F6L]_FcPV YKzln @ǣAa!g3+EXgwZARe]IR KO1W+Ftibؚ 4 I ? tw% ӵP> u=\쒕;,q=֭8=;Z+ĉ))gɇ334C'vh٬R:w9Q /MeVcv)S%ںbhM}(>B'V __#Wq"=a flM[ֈ&q= 3HC,v#t @@"CbjL#[$ ͔D oVt.P&Q[#$62q ! %KcjM\5L=tmFCZP9^G11,% I0߸Y^A<"xJ oGzyK{ky 3\t8)) 7Y r` XkcIG[aS 62!r+=ʄ=}:gmbEmNn)U<,ikU9Sc6)g-J7uٰ w(b `fЙAr(o[&XQ $-pAVT" )3}kVQѡe "Vh9m^b9$X8V(>w$I o[|{C ךF@ ho-_M]kU3gՌ"I+Jv+9Dt`\eHbgzax+00dZf f8i3݀ tf3<+PBHq)]_\xcH"'lDvr|sʼnXhgX O UY\o՚E`p3 Ԭ þEƈ.bgŽlj i@Ա9Q~0f&ԢY9KfWX}7ʫL;]iǘ#=@mI]\ LyHOv4ُcxg~JoF诘)̫@t=nFƒPh2]Hl-l.+(JPN!ը XK܆3KT۠2+v5^K b,"Qb,UXY9S(b7oZ5I` ya> >tu?3Dfsz8ydܲ!NdWՄA6(uO5W rlpbW'=?<AfܕE@@-ZsX>]AЗ\χ Vq+֢ufb J2hoo}`j%/KTJ5UD;#@]l}UHhN"\ [gIaƄ>}RQkHn#rSl Ijnd 5(:\ |D?cjipK3F8D~ vo'{Rf%1j_qf&G-\WHUi@H:s3CǕ*p(w7"Hx5yY:Z98,ϣvB'%lHwf\G24:QĎQd/?fe{p|Cy_-7bT{a?6X(EdMng6܍ڰ?P;ة >_?ge7/[tD])C~} r27̕2E" YGam:*153~j:Tsم4R`v A1355kwחz`)fL('V%.ou1RX-z3Y{.-k=)tmXyZ(?>XIp21` YkTzw p/ATѿO`q`E'A5({WAy%ʧq9~9P ;Sm/"RʧP۫=$%'ށɨH~aAGq*+D}{39ewbW3gN N&(4:oԡ !\Bei~%jNtO9YMH?@ HEğmQ8=RFope&qs^ `B/8e=|veقD芉~==h/GxMY۪B ܈ӹi@UDcIlELnAB{[ k QEMhsº5{yg_b-=xW>BBkll?"18?)(ͻ0Ⱦ\te /qm#J~ ">MC5Щ"R4|0{G"r mB@pexb|y#f-ZL6UH  pP×d,C/Q+pXQZ;@J^lTEevh7:'`53[LKu`"`(DʦvZ/,̊ O4m4ɶmp#g⣃ D8Ъ]Nƥ)HSPpMVoYV$7ٛR;g]PCZZD"Jl7vXs[h!1j`~S)*ц+{>Rէkhş4P&4ry/O nW&Nf]]k* !2p6 <dA%]Vȑld]]1AJ ÝIUqm|%X4}dpSxȡN5e/n JftdW'QH|r?Sy7Pē2x V?a%9ʐ BGDrޫ9HeKtztKg+@~ί a։oAIYdA\muNjX4FL%ցґJ}߇QF1UYXv'}Gu[XlP}˙\C[ XAYhAnYY{IF<)5H`$(Ew'ga^~Q 1hJ`ObQvfԶiu~'XwYXMB1|z7=;ĒKOqUfwE>Oa`Jw[;nuF7k4]3)X?煆~|Md0n*rBNrgɈ`pKwŚY#Y?@˦2_F3@-)vTzq)X);N>ZP&U h'PcZDn2;.j"@#D92_pUli>: /$Ȯ6(*ŗbq:Si?5T}L ^l'lJQJcVaF^B?20jNN~{`^)݊Ti Vuj8*>wTJO2&ױ7/is/S/O+38yAj{ryl[Nnǿ֞i7bDe?B+]ՇKR,I^ IgOO>&XI&&l4Mҟ9jm >MH6g+}nOU80VzKP}G'cy.Y{1l!ͬkW}3@+?- 9PnetV3Z rhP7B G Ȗ"ҫbqEr17,0:1Ll(٪?/lz^Q}vKҭvc,\#Úzr5xq&l9h^v]hOi7-z5~ XF=Cˡ+4^I@]Yi)c <|N( V-.G TO?!o)FBsQd@B,4V z9^<jpoh.*ofbŃIa>>;, FWTS὇gG҇KeIJZMTx7|V9>ƣHN^(Z*Дo^ ً-ۉA);{RM1:_ag劗_oAѨTcο`#s*bZ>b_޲CA(*XV'xWC!EC&]q3X1a8áN޷_p&Hn@U Z诽# ):kt0PFzٗxjOJ9ykE\R&IZ`->ݜqmG.3<{UFN8ǒٖ(ĝ_6c3Œ-)s켙 ?xͦF'ɖwExvE<&Nbtӑ[홮gr}@NXBߚ5[ܺΤiTJs`@#RNX%1rV39`Z9d7{!am_B.@2Dվ|,0vc s?(ϩh?+,8>Nל?*p@F>R;?j+ܲ[{4*`b |]vO(%ěi kče Jf` P6/=+ʄͤfecbatj__uc>$gݮS%aUz*ʊWM{w'ud}Y08 i82e&Fv1"ޘ8QrLA`]K٤=s-**-ɠF n//ZHS$5t|gawUv*Q6R}a/{~o7j#/= ݄uQ)]e>Gg+F\p0C6Vd+,ڵcu h%7n+|Ԯsiۇ1R6hhuan1ΧhDͫAӫa.ܕ|5HUܾRri/)@Ko]oayLKrvP4G=oUt?eG2,WfAuNM"ۻd͔0k [gJvXG5v?+S&lꦂknt %auAES*C7``7CJ_Ė(%3@ƭ֓ťFXO}_$YjPDh؇:+ɭRԧZ_w 9"qmH׳խM^v RZAy^0+Id(gO[\m[d :<D㳌TcG57\!|.a7F]vێ#,4e̚}.|W7gĮljZ SL(.Aުu$#m.;B%C&>ww %W ]aʏfhaz^ OʰRs¤Jz ul&2mԉhJ=jEW g _ 5`׺\jf)mYYm^]ٖ E^8d*T K. B#cUfLijynRP\rС Qm{aI tln)KrYAu߆Y*t߮e,h=d@!A5y#/\MZUGi\⋫ emػ([4:.ҫ)Ib8~z9ѤRqt|="P4]i 8bڜVJDļC,GCΑ7O/I ;>[E!v6/LӖ'ȹӔMA@-6^6#B}#Ru_ՠOHU˶ݘn@5$,ͭ HM!R`ItCu YPGT3;zGN&,J$YK~[(42j {D$6HR8`[LWy>| 5S- e 6M,Kj48hr]]x,6ߧ)A?9klpl8"&h<@ a9;j3|9J ?2a% "LLLr uᶫ6CKND1:1Ä~nN iYMwRf?{6x_ջG&LP$[,_OҊ@oMc"؁Aև^Ox)BUw VH&$@ٲ{ﭓŞgPY2PGt[f?1"Xg W*}kǝCͻ$6hagrI-Sn2OCM\|./qj(%o$N1@ͧ߄z4?*4}J\M^lom^~ egK9je~d?mm6EY,1ٵRAFq|Od]+ZvvOp5?ua.:*>/2z2Cmᙖ@*p&MbL`)lDN NITV|ظұOȊW]"B q۞Y|m˅hJŶ(> }@SkMrnXLqa323U}WM!hL=|ZϊT!`,:<.ګfaOa nvw-!\dŒ݂p/M%Sd%r~y}=t.s{l tbd|gi>ɠwԌv\캫 G-ɦ=MJRX8-ɀFfZ![1K`kJCWB>p3+;2'W=KdD;#VQ|QּгPB$!WH}D R:Ò:™%lKK% yx1Xq[()m}&F{xf M$IF#'tNe3_Hl?K̤n!vd45# ~ g-; " f2|gk{t e{1^q%keuj \rAgK HB*7*Jd& L /(6T8fVvԒT_HmBA'Fr)2AB~< Є=7ådFFs9lY뻫efT#?ǿ3h$Pf08Po5gFÆ֚I) J&['ӅjfRLqJס;|QBqׅC{i-r%QO2zhŚFst s (E>ޫ*='ZTꖆ#\9g䝕oPoբGcqdєiuE:$_sD*-2+swfO袐|lfD{&SMK;Q-4@˵yt8yw_,HTHQCuɋMjWɏ˥ 9"Le$SCC/NL u-Uc--U$&u Ap -J$;;⇡lMrw$"&2(΋.]W|vhnizpUD\qP}JBʯUo˻+,_K;Mcu1b.IXTpJ!lTUe! Uf#}Bqfwh, ixµj!hx]0LW,c{q~ sFd㠲 %*Α?FyҭIpzg´ڐaC2xCc}v@e 3̆%wȅn=1)̼^=Ju !},pZ7yc*Q4l ǦD 4A62QEsZ4HIȖ6F16b;‘<ŲES"B8.}J8c5@*|]\vdV"=קQ|#Ql(=B̾"X~ǒ:WdLbLǵ n z(u-yj\v$pc1J #q,͏$4zWƲf{rTP)]ZM q̈́mfeO+9Q0dycI(;"C80Pj9·6 zD&l\9/#^3 - ГI!Qx䖽.شR BvX{RW2L6ě_w;ƱxPN&bR)X )ͣ6Lj11,!LEy-=E"KL:Fnr؏f0 ZiW/y'A,܄O9uV#q*}3a%ΣZN >=D8n0gouٝ-+I>.G '5Zd,Y(f|%\NDzvƖ|x9^Ըk[Ap'j?ى)BNkVbϗ0,Nt$UX OøcI GL)UMXbn.Kxeϱrr~4ߊjƸvo$"Oτ~ot¨i: Li`?9=wHl+PDWǬef9[۷_epX݌rv°ߐ UNͶu|ʮ}8 vΚCt OK]J`;F^q1a^]ηyBV-5'"Njkc*N\X4="UcV_d(2/|&\:9jUk Lx?A.j@7{=utfҫ,QtEvgy-čp\ɃmJASWӯ T*˄:-T+g$vKuȊ 'VcX)RK b~5sR0M lehf;ᐎPѧ!< ڠ} cVLJ9jd5bOMA7nDƧ`[$ vBd}>6}/V6""j.Xtrtx>&qS\Bg%G>,2 ^s`F#WqYЦ|WmMf:&+ɅzȫōvČc7e])smҶj S"-R[Ï 5 ?20 Z4 KvKZl#^`v2ƙ yߜg.qqPPll!J垭K[XѰ+[PԪzL>yP۳YtV tFRi ׋o\?pn_NFv6 e":f%,OYUd[6.N޹/]Ȳ ȑ}pRʉDKN{Y,4Rq 68o_Ĥg_ op]ޑKEQۥGemMgJ:r|]LJ:(Ku\zwCXv ds9,k}wKN?~r:U|u$-CB]!(-8/nr϶eZKGLDdb^T"eTgѷƅ#nbt A ]?BZixgN'WJ8[T7$b]?9̬G"bA;unC8${#6mo%uG&pޟ+'8t Y8p*`Igk'q< -sb eaxUϋC=sT>7g9ik홣:W TXQ_3OKC'`)>YelJ̜M;E]_zl+>)M /%1۩x'(j:Klv hef/N=TWulv"qIr*]EG҆o\tЊN ds7Zqx2c.'%'V0|}2#>"4w@7AC Fjupџ1hWV ˜.вe5#U"7V )0 72B" xL1Q?R=XR _ )H[ԊT.SY:F.T%8vh=3 >=0!܍d05'*ս;J,ּ<0}+iJֵwOp#KIe~A'zݬEټgrNʴZUQs;4$m$-̲>7q߃X)K;$S׳ (@dl X[!Qgob#>BHq ^Z{zܥbK)"kcDm EDS8X -xHL5`Бa(p(uКt?XZ2bA ؀ɫL eesh{1PZ0֞ZJ2$AnhF:|2VA\M5sxsVgɝc2qU{%2 y%OH\U p24P,XhH&w%YL~mU-bDY#QvIl&`chY8fG9.@{2m,ptEۃs?!֡[߁w;_^x`^Ng1W?"D@ާ\тC|d ~Ҵ:J93S(wP9yĤxY[G^yKYK4s@(wK; bi!1Iָ `1o̭x&ˈ+ U I;#'z:qH~E@Q]U&#CohI5|Hd( y&,7'Ec}J!}Lo@9&tY R:΃afSb4u`g&ĕN+v%%eRNxЋ/Qs^;HbGa /$,txgU'yǪ+/3p+rωܲ6p(SR@JcfqR -+FJTv't0٧6~+$u1F,fI.nA936>"5b(df_y8Z|gRddm~İPP?EEX߮>C~!3ΰNPk 2{(u#>@XsN+wO*$Te ^:N:¸0$Ox F%=bI_*_ybܭ:WĕBitwJp9x3m/7fu6ͫ 8[dΣ2LhV eD !zψdu+O\zeu9G V6ncV)ҷT3J5Z&wBm䩏4-,&6Js\JF-)8ف{MM'iJ*7kzRXB^,)rSgZNz͕cȪp_UԐGwlR=\''tN'<;w dS$6|e;d: &oD~#rd\8镘waغzGr >$]ss/y[_`_H\l }I?Q#Rh| ,m`,1K1 ^h*?\[&1@'J BP~2X@9s\<&p5:0:9`96GOma5ʴs[ͥh$˄dܘħ>TqZ IǮLaك7A?j/38F^@v]>츅x1Vݢx2UNT&9lE]@ꖸտRG<]4 tD|;{0/l=@ߘ6 lr|٫[0]%CBj^2KsVk*BkdbZ>=nCm{i0_zcdBTOqy&M&v¨U*YʼE>.q baLu|xӖʞ0AvQwԈZ1EoC7)ú<|X,eUV<ݻ-vg;]8}BDkaJ w;-1x?HGtfEym3(MPK@IY]2|2H5ϔ\׮J B >԰U?!MP'ۈ$XSJ|&^vϱXi"OE0. ם2j;˟!tZr B#lPt% L 5?Sy/r߁ ZHRXSAdH#;G?ӦN&Ԍ"AEEP:s,'K  )f ڹ˪cGL2*YTڤ~\W/Qr7T_[/W2ǝ|8AKnRrfwqm|vΪꌾ_Ϩn'ЗNB 7*KSԩ@W9[.<.mP0墍OIpZIzb#X fG|$QHJC}^ ʼsDQ)NT2KȉU.m(?*A4I+{G?@ KHi9=7+!ZP=.kJcrd|b>N{&X"b8LP&ph9 ) A,sI<*rM-G'u /N__%ø~xȕ7ߗl 'l }u3569:ͤGB/X~=0yLTd!]+#+O([Nq\7WΉH~:gg{|Ķio3(w℔)ͦRz[h.V [M`E1;>|Elä:"h;MefF?LZ5݇3owσt$ЄS."5-e@ ]'%4LX, /@;塖uyCcYۙmj& Z+^73&LtTN@l9WCԣbOy^a[Dѱݜ , [Ot oOD U%D4AiM:q&ʠ^!7*.G`pl>ҡtTW zq" Y W9'lhYZtLџb/gێ^iou -Nx6enjF'(ed󺜹cR@hl(25{U!z9~~Mxk ha{eX#1Sô*DƑ Arp~nkTjk%U(\^}nrM5zbN$.hn@˩rG:ey`2*-X]4 0{SyeaPj@J/;5%ӜBᨦׅTm87ID B19xxdos6gKg|UӨ3EU0ES)ejH2l枬P8tx*Q @SY<սRn'ԏ\{g.ϴP`۾ S Q'LJUCrp;tz<|ޔd3̝UtͩNl%ޔ,hm>Q4O@mlOx(FWT ff;)i# mcgxh4t;`\4.*ɄX۽7B{P+LÇݑD9%@&㿘hG4W ^1*0(#[я-42Vt_9!`v_|if^%m-ɗ)|{wN2:QIʡAwQM. ɽaNDT";-'9Ω6xjnczv kS4Z~[|cH +jB1cl@5I*JK<=Ѻh&XjM0i9/̎T%'W<ѭ0֡/T>>#>5/:ANSg6[>lI)NsLz:X F¦3N>s%w۔ x: |?*-i ⤡@L`]#6a Mi܏*QԑA,T(*vH[Rl- R!w(q@r}N;QcjS(K 3;(hUCU+ bb}u` s{v@2:' 0f'h7¬@v85 _]ҋ~AR\NLv72o ?D#z0G'e_8KD֊;ʻT=qljv,ﵟ#Y>P{06ō0gc#PrB aE1:,8~0E䢾'=E;|FM&Qr򕸐0&V@h@(aJ-v0joׇeDL`{u0oy|bM67Nʶ2æh jrv#R ,AvQp~w?D q,RZvpOx9҇)~=VLh.l喝7^ +0|X1ă& SRFEpe 9)@ h 5ug=ldRw'I LeYڑ @CB-LMɐSuǀA=7@8TړYڡ30>Jw&Gq?tV>+^   0o3N62OȷzzT7+!Gm(Pݿ 6>W} uL2Pu1Rn}W4D4sܗ3s!Wr?x.S{8!XA./ B]h>Г{Q|+Jb5j؎-t"wwJƿUj$잶$tc;8cOACg`񘕙R^ 4lDau yx?5v2V4%OyHjo4qEıyiAZ4`#^*ׅ۽ӐCȳ4Az֙Q;mV Q VG$'+ÆaxQIU74r<@M%ҿ7!ԦlDHG Gc/GO4o-A1hztSa=&WTH=O6{:<`Pb{x!LyHF 𛕟&;4ucHv^eЛ)WQW(@2&zDi)MyU 4yH"4 H v Lul`kCg i8IOY(k#';#J@+599tћAѾE۳MYQ팹r'tO5[EI2O3 Hn Y‘?Y R g^9@B7pϢH`.e 3ܫKe|O@&0W;tUK&=T!*ZzE$?AUD Pm1ώk8^&?ZlIW. "U>كjj=]ir)HWG|{_zU>ѿfv ּla,\I (s˔?dvEx9,Ϙ[f䦳R"2fX;6SXJPΤ!I8Jk~ݤ}81y0BOF1F=V0#]s.Ct K&]brQUUZA%+Gm/=p]֠,"96'J+P}!؀Ĥa_R_(v&"/I ԿcWz 75Qg;?af,?fU⚐(n~HVȵBCsKǷنɌpY]7+Sb,/,j%GiRd@5?(ZURv:]5-In7#Sl 'Q¬wypنA]lPo&:(Ik#+wYR>ZG H:F&ȃ q"z!>=UD+ӒI4;#`^2E=.O__eSPH2#n!k@V|.@;= ,f /#gF|0.2ÈVXɜ>.,r꧆'"ᓩiX-?VqWfZ&'h:J(b/;PcAl7%N8>an[O;3n_l;wMe`dTv5j/oaEXʺ;{>3;UK~+h׫R<1_,3kZSьM31ᩚL<%M=MNJ4gV EE$kޫnuB]BmvCA!ĚY3ȓQ0\w݈דqw}t1>zĶq+E1Eچ"`=#%ʁՄUo=aol'#%vDҚI1F4j55A+E>ct~7u {] J V}ĢD`1هk !Դ"e'cl#/W!Lblf?1i 6-l;^ " Zvf`MKmky!7^Z,@]Pr3k jȸpTNv 5U2+n4!G67C뀅D#0X(`qs 7ļ}^˫AHs9Wn~P؜}50粔MgBI^6ꖡNUBP UPya|o/ك~ĩ~ !3PH[P 7X U׉J@y3~)fAm_9p!}SN)xϮ d_Z(TqA < Ƿ8c]9Eɿ_ER8[vC"JuqB-!I,Cdb;zTe?Ylo):%1V~.cY_E !|R/U[<3""hvz#eHP2yq>2͕|GL2ܬ`͇' 6߃ 4_wvq5PoO|#2]}YU.xGb(͌ބaIOOZ.f02k>A&JwMJM'y9f K熜A7g𸐾(@P:ˌy;$ֿ2Ezsr)LPv DAǓmNwNKIN|[A'u=Ρѡ˜1p vMk9sw3$}g!LAo)E).naJ3=2I+|?.88潂b~֮\CfDBur"PiJ^}WrM`ȎRf"@zo1A!i㟖(SQn湋S 86dc}Dz iǧtޝFyIѺ:0.Vbw[%S=dR˩?b6w+šBQG(@hG`JV+]hfL(  _5pAyy0&6軨(bq־t Ǧ]د :i*kI|=Kc/to`?,y)҂t/׸/~?Xe|qEe8x)\|z|y|ͥ\IK񝄀3z`ran.|_yòX$B/*+  {$^]'"xoX/CVη(hbV/ 2l Ї_S ^8\lTZgd(MG%UBLj0N(ؔz!jdWV4_&jS.yǩ 7JRVvd7 25|EaƣX?w6tLèPU߉oe}\ ;FAu14ހHVw)?{c#BMcTɆwʍ*!GG̾2xZ,{.Iv-:o XYMw]g%hGuh?}[-"*ܶ %U(EIPGhhFݹ@z Z}N`p< {iɠ1CRY IL^r!~Q,0WW#/m)']^(bQ5K{VH &54P_Xܓ3sPDاH.҃TÊN&( bH04M-\6Gp=꩒= 0NFy]Ԥ8޵2iZJoNd3\#,D(,!̅n]yr`?pmRX>/.zUw%37(ZZ~+ͳ8,^ B/F- n~i<oEgp3bep&q*<8)~c/n- ITf[29&;Ek" 7 ; Ĕqueᗹ8{@Becd;{'aװZ\>ͳ؎GiHL:dEAV<_wcwwF{sy5_- a`BpU%tU8v"k+ŕ]]b1 OԜgp,*J՝r$ ۜ m14 ?CoVbWlcm' +`"CtiƁ0nĉftiu663*_Q{Uc-Iijc2xH @cYftg$Rit@M_l݇t< BEL\2z>. G޻,X:}E*nQNod=,K'MXkWNdO=d_ܦ=jMsLG$# @;FŧNxb;&gWʟIIr:,ju׆Sh^L\2S|s@v6\F_)םw)sKx2|³)8$?|D&JW18DN`Ma 1wzkDzu5 O g͇욃覩ۦ.|2s9.yi$)jrq kTDZyt'P|NÏ},}][@`r4U0酡M5P}H~BT- ׹r}!% z)G5C~gpbݮ?Ur RzA9m O7dlӭLc EE`r_s-p #xrT㶩TOJYn,.l0GV֥*?蛘ڄЀyr1轸`-_}@sZh\ A:Y=G;,(ȋbHC藸 Z7IS% zeRpH SE M:CˤBsLlNbm5-/| =)>͂VfS5.f )b,bQ6Lt3Bе"[ĵڰL$=;?AON =6KzUog2#=w%&650*j gH8N'QG9Tt(z4A27^2-#4%S ;1 C{A=&ˊ)5ɺӋu7] 3VhFԸׂ|^rS{WޒwiKttؑH ڰ2-{\cL~;2N/MaSWد_\ԹK2`8r@uvy}/(*A$=dqE$;*Ή;AşOy( q"lKM)MoWsc8hAy9g5v&NmEr!$ FN{>&bzKCעS+= Ptʼ9oF/8<6iO`hOG:jXm~,>D<W$2 @,9? #(BDA#-2)IblrX 'voߟ3lbēNmCFX`N<]E-r:(.&vv=qKh9?w+VM|Q?E"yyBn~,v[eXQK?䵹TQ49cKS (s=A4,ŦX]xuYu򀕑a}^, G1gݧu?1'ȱ\MYㄫ/ޥjT?Bd@du0 }sh Ժ*mE ,2 Pl @s6E'0nZa Y& %jE4.~hVˣD 88/f Vq_Ak~SWr%['p~h>t[aD @] l" n T(9B;HyS=@eNFרXBh_A-;#=*CsTi"ZBcVAZՍ'Ϋj!5ɦ]]6lT`F @ Jd@l (a}$"mo_W!7x3.ۂ*=Ndz13q3Ev-XkWpʡN_ v;?'C֘Y̲3bt8q'%$8ae>מϿ߂%v n%Z!69B qK}Vl$ >*JbWU^Wt +t)(̀vIV ~ MFI`ck (e~8oܷS9~jq"s8EnR6lMnWE~NO*GZM040).Y l Xl̾˶dM ].2!<6c6_pe$\obAVbguUWLB˲Pr[ XHZ-̖TBeUtGj|ЍaAUܤ*+R&uPX h?}~B=*SY XG=i ,JMuxC} {W1y°@?9Ɖ   .'&)Q$鐟_jB.*';Q:s@Mz/lM/Wll3 _h%Uʿf@":1i,&rfBVf@L9+P&WoM+^,W/'Qp;kυ Wp1KA;ЮZx\ -CdC׆Y IzYyhf07V u jt~[o3u/K?fբ܃=;-J<=Ed쫟_]A.t9a<e_v.Ǐ;v*61E+\KX6bV.at=1\^u>T W1{-La< ւ$Zi\C\$LbZ&ҬWqJhY <#) , ,5~P!q#yHVS!i?2$MS*"7zNT^(: ׎ 4;( MvA֜'g!EGFH b7*-eITo23VDߥTP}gTА^-^De:ƆNf==Akʱ~‘*1 j2RmyjŻbdF4se<˕Njh l%^,Rh]ftd)oNw.%/\OA$bAy^kJ\'4ǧzCr<J68CvgcM7}._ifn 'm %Ns΁_yh2ꅐ=w[?5tpMCnJ_?YoC\+l"o4P 5BIU~Rv >UGq)Ë!V?*9;A!wy>]5sATY2ek|-|P[њ_ x/'?ܠ#ql,dh0>0*)tmm )Is dOaؔgqˠbM_G|lv>8ABL+bҟSӊs@GA%fy}y[<s<C)NOu?zٛ'8Lp7gFw5Dϱ=_"KHl'_N%b6U kImJZ zMhawSliqD[K_ Aa2qZ֯Y^A-)n-{}s+/=?!3^LQ( oZ=% On V.v# 3'yٲ!VMRʼnJv@cy%y |EEZ(7f^M+us^9D|{{@nP 螺3։lizAbCk5wEA9W!+EAnː[rwMPB$w2Yvz:3G5&\+"1yJZHgvaRׂXB$%3a^Ҷ=\Z'e[{5bd+PmգM"#_o{C;q (+2KmsZrK}XT v=V[k~~kȵj:..ϣC7gB#l :(D/ N2cERuMl悬H` ߬U4pe )2b C '_OxfIf*E?Ts 0t ]|ҨqclPXpÌ G^Z^:\z^4P;…g{jgSg_v4S|9Bd`jm P  B26f¥/)>$Stq$ŹXx4!+Lғ$t~퐨=|(sتb%>-EX&aG Gn =ڲ EmĎJƠw+< amWTW%a}7Mq_sdl @{zlPES>+^{0zFR@NMghp!Rh[S{5ܙH81ˁ3 k zCW]8b\4" |+i`2 IY|D0I_x:Hٛ7TL-Vdg$UB.Rf&eAFRSHozmv@/eœCq,f=o>\:åa>jJFhQ-g1M * ee 8f~WEϪڣf`F= JBU'J n<8cjm ΓTtl@n7V,EόCoIb="daRLr(BQhjSOa-o1.[ @IOꎨ0s_G)'dNx:9aG;27,`Oոp j&C#-am0ԫV[(oۘ!@%h/Ut3 v e{ަSp !!Pv&E"'Fi!Pe-yDtЅE_/8^V5J. n1th%FqG+R/`4z)̽Q]mXҵ"$ L_=_Ī<ТK ɇH2R.yPeC琫G1U?aSOQpb5\;ʹMX"qÂT}xQ R0 4th2ZG=fMNxӖcX&8}6'o:ш)UecΏftc5s<0צUhbB|}&E('PN߬ݴ_!0bUt$NwsԵ+dOi0A㞋n^{8[|XwKKSRicly\*)ඹ9{C _>n܌[*Z@+~!`7|k~.%M/}<$[H9>S1׽{eܾ~<3csD2S(-&=7bֽ pKrA=Tr1$*,9 x-VIX~&M ̩[voZ%M߽rDþk*2 NJ:"lLwY2t$ p$ؓS3jzOW21_,T5K9-qdfț%O' ]a*G?LxUQ~xR  Z?Ɏ7SHP6~%LرNLR  6; eM `G6awT܆?y aߢNS 'L_\VҴˀQn~fB+ᅦQ72WBa]i]Mؤ0DvXj!MI_d; ѧB6RI(p5#G_E9H=yTIksaɌ Z7"N=٦xAw1ehKnMբ%CbE1rhAɖfPt\Xffλt/7/&Em.3܉Y >0yXKL̮.C4LG,ȯ.GnU vLޜL+#mȪG8UE[m16Y`IC9U(d@,dcsm?92SjȘX.@,L[ڨ1;&mFJaLлK-F4O#t\yЎu({ 8Td6̖#~݇8=jt'CCĜf"G"9p< eTmNeE8$-U ddLs+~/b;j;N\y̧^;[K}S}U}E /鵃0=vdŪ)_]ی.-=q8`TxQzh|Z x7 ~xEYl4m%\Hl Ko``O^\ԆʁM68" gbըKƇO_JP":޴tӏ.GsAY/6иg&`P*ơ?S<^o['qp,f˖ e/ iƬ{80:|+N`IW03R1hI=)b/i|+"ɿڼ(;/hV*zÌ&^ Y*vvL١sKJ1SJ$Ky*{-i,\hvAB"%nU 8-WM/R"=6ZT GhU H";9>fwd/)JTu!csg諗g5P-u1R*ɕ2(_̰Ų9 /OK 6D%RK;0ZSEm{v">mW39zwK'88<?D/An(C9nEC<2Csxh'mqztZ^dc=1%0dȑ@ӟHkVSl3\}gs΀n-]SJ5l\@ Yvsq++ʹ`BY ALII6mm1﷏lDנ6$b|fInũuctȑaׁt"{o ohgX !It̔_iUW!V{w%K_ ()evvQ JRS)DHX!C^}R,1JC1 &D4>/fSj. ts\,UÕ^iSY4Vb[%:936ύG[ob>s٩j?)M.Nvp.r4|;؊ ~Num@ 6*s^ X녦ҙi ݦfSd|2ZkYr9ؤĄ nr\?G|gˎ"h nPcA6A[wA'qarBX=!zmƢ~wAB f﨧1LWSڅ*9-ώRl14_ &8,aH]nVCΏh9zuݻ<&=51!|#uU'[i?\4_4%٪~cxcԭ=w3HUK!>p߼5h[~O$3h]P\R´4kִD9k^Ci;d[S1Y+74c=:j`)LEA_.HŶ׵S4NqU5DŽkA2f2;ZWhDJCXE~NyLh:йGZ}J(=H:S%u3pf6fj&tNF Ȑz?On8O6^!/yC̃.2 y%N1Q}(Uqy_mm,;+O kG=8[JK&Z}^Sɑ6)Ș#ѕ^--l:5EG= F!C7^ގ|>6;1!0"Q*!ߓKFQ)/p{E+1 dyYpRMʘ ALo@̡ƟWy:ӊGMIZhS );^,^l LOwK]@~}wƒ]@c/ЇlP&5Yo-g?UreHR-\ʼn'=nVA)j~p-Vti45+H5*ʌ9rDxش`$q[-3^Uq+^n]ժX>s2Fv8-Y3^hmwS=fTShj䓼r94$^+?$""j0-I.*^€CWc>ߚ6bԃ2\\C [_ʓ^9='Nß 6486MJxeqO uR aóXd$͛wK.*8 Z1߅jsPa#aކWW^䊌}+Z_h&)b@j0o?Xe h " C)*HFL>(CNqd6/O6 I62FJ{@[}CC7ɶy,ܣ*'ۋijC|ZE91`Yh8Q$7S; HBEF:%~J#r֎2!9/4 /K=TR.4#!4x7r"BwQ {x]mL~p3\LaF6`Lp'|f|(NzMn.~z%Q;]I ͺ {՟$ >,v,=(蠼>fZ{5K |3Vly~4NJr7=8 *[+UmRb2qbKNlK:%ɶ͊p?& FiM9B5  *K%o+_[kA4Bz =i8sk >}aݷg=>^PbڞVo:ܞ[i\ 0wJ[lD~y_nyʐéO9~ں2B5<1v`Щt_ p惡[kQ(_IyaY/t<^ qo{&iV]uyO7^:ldTq{jv񔚐 `i4X/B`F'im0.B2;-s`Y|Rl)'mOsу8תk{+uf|*6y 0dw K\uidMkv؆ϚiN#ڕNt}i }KUدImM˻ɕJhy/.|}na|>-&dG0Ox{jH XGBWŽR mk8"?5P=?F2E}KCdTR8L=et>d\,%xOş?KW֕ uՙ#-,-!a'2b<@bƈci0?ujc9 ˰x,mDC;f X !>l]gG02x4}L=Бҏ?zF&J;]䒰© 8O7TtR-Ū] ZSֶ^#/#hTN/9:[=UvGuI6vJT@YⳌB@|O& .e{0f΋r>5i&%L(zQ|)1 DBTX5Qdc$iɷz.@B/|ɈM>͙1x'1pDr4~WXi<1XYw@fVRm)$ ڇ {;Tz硩h0WUc٨{3NՊ-]"AwdG2$^AM=#:saYB:́0/޿q3k9R- &tvuscQf`f*ճ4' )`)(3@ w\v ~F:m5wdUc]9 i.L}պ = 󂤓Nuf:rQA$ٵZް;Jd&Zrۨ+/A@t>>Qm},}WWi='shJn7brڲi{&+v %u7~nb- jVo)uOþwC#ٯz7ۧ(':Lm2lKvAgaTW듉`)sI ۆC_Gpz\UŽQ" o;Dv?8=_c}֚h2@w'jzd¼ZiGVsf W˧ .pt^HG%Mnqdd!yW^n% N0 C1Zn0ׇJcxŧ4 Ȩ!~GC 1U>HԠ/3*Oմ6\Y_^L<fI#fGQ3n}J&1tx60{, 43Clp8$[чߦ;D|[6t̚XYR`Hu̻͂>Eyb$(*ev٧2~<89ʘX X?\&2 }G]2a{] uҗBA/Yuwgot}הTgnA ѱ㚴73ׂU[v-]Dޜ nנS\  /i5-C5+H'MLG#R߅o Bvdbx ."XطAcp\j0uxZҩIJuƅBFV̑^.+U XIVřzXيs'}jfN2+?__w,m"ęN? 1(>Dl//JIA2}c梵op8uzLE$eiq3,R ըIä"&) C"tިΟ=ծ[yz[_h2SR+u\]Yq0 v )XǕ|mba6yG\0DR Y{YMPI#3#p,AnF= 4xPEvt ٭ﺓݟz/*%~-;ii ۄ{oΔff>\U<$ oJmI uKFqުODw|m˧NM!}q/PfLVwSIj&0\liF[O~2Eo0vn>Ԫ[?ޡx\x(IBF+]DKmU N;3؇ 6o}|M4t|Y; 0~r jd>+출 C`4|O&!јօtأ0  \^ugH%cMQ̥hP?)ZFСA<~m z%np@g>NVtV qes[:zu8Txnzf*D?#[V/Z"UH`留x^N@صy!ֹ@z6nu6֜GMBVASA8IuvEJ6URi2L!>4`%%.s=(BՃ-)v%S6hNxل[?ͳ"4T}$ g],$h0֥KE2ά' ,=:7PF}rZf3uFXHr7tr^ihEehCtA}A<Ӣ-5gְ msɒk` Xo'jBa=1kuݓ $ D墘]} ^iVS }1EMu#F-2Qx< r]<}A2{:֟qBq3%X9~3b.(+BtNyqm!6A4.G\Ϗ+4߃1e޴zW<t.FOQMjk \l}2uχCfIq}7oٷ|t(0<(,x7zu-b4 2 15-fjy27QGlV˭D%%}fſ`>V`9miGwWGJޗ}OwHǹp[wqY zu  O-RGKKz7v5u&i4m']s92{L"*BY|x֣|FƴE8r~3|I#l[åP~EOU:pȿ*H[iIdܢ{HPqys€1aճA$ե-2S EU%E5h( 4ؐXVٯ.4|;UuDE6.a}ܦsأڈZ'>_uV# q2;WT)rcýC6LVGC'ب P>R-<T]}Rl)GwHP~;ʱOD'-yhζD+Sյ7#ipl1 jkzhQ[逼u)[oY#57rEo`Z}Ԡ8J)-NB<(qC.Jo$bO_Sz 橫NGХ8YiDk$ F1+,r?ұ?^ՙa?iW愝4F,G4AtƩ6*.Oh v*6*)Bx*P5+7K}QUƖ Sf`XJk9l"tbb{8gQDx$>$v3(5VIQ=PCsK *%S 4iuSf m&?afwܪO7oa Cs 7%%ÍO{6y7?~_/VA:%3K . wԦ1"|eoBKC'*tZz l_-xa"eѺ6ywFN 0SCoBG)\{9 o4j2x6F4F]'BS𞬯g/VZ*7<# `0BWU[}ϳ}(nZUrx} ^ä~ [A,~~<3 #X&4PQd6V "Kv^ȸ~u1O#VCjJ䨽QZfmD5j-ErZC!qbz^]jLAʹ}@&%iw9U[ÿAraJ*6a.(x aIcYЙ3U똳;vp5gܸzg)أeF_Ul@()a[A?x|P,=م9]/ϲI++TL%nr~b@kM IMZzn?2$]mGǶSٙ=XK$ 6=z ^]hH*M uNCpc횡Z@.<V|٢ "ŋmO-O6ش~hÒ =%:+v"V=o,NBsy)I>v$L{}` 䘊,X×T`=:KVgзk cd;x̢6dx\G֝Y7'7FgW/9K(nҐ/"עmPR׷tV߂T/@题hY<=EI c6Li/k 8ER8 LL&R00}Յ\{B2*@w'<~O+G8~>%[ߡ(x'GxTIʺrRK.849K̊rPQukr!Q*j:Ahh߶M:g(p+KATM`_>3l>=\"'EG^~#]U#m78ZrPNcjj|laxHW}]bӳ)f»eo v>ăufC@p}QwZNB =Oqː5Q}z_YRؙ@Q]*u2Y-\sqrҹf6|¨;*xtOzq8K݆%E88dJZl4=<ȇ$_^;}"lUQ:79nINBk=!Z/\SEBb;li~_r6 :h4}t+zfqAUZ[SL>ߊ>h;S |C۶`=$6%nxbN>jؙ%\EuY@V 7zzʴAxwƋ6)"i-.)G. ؁mu''DAŢ23|뢾BBgx* : лە6%.3Ht5=*[u}pta"*D8@Ci*R=ȑL//>}pfQ %U~wbs.u6"ӍUQtfQ9OKtiG0\$ .#?]ahҝ^HRPW-LWFܝNcF2bT8aL6dHwY3"˦^1ϻM5dUP3 <)azҌnqYP|Tw#12m蜣 2l)?N*Vc4B$9!N]gPj0 8UXF{}H~XO?lZ Ϋnpвс.djy˜}+gmDЅ >`Ju4.IȻiXs͔1`{ IBF紉6PQ2c))Ta'v\V9=sR\)7x2^&z*ojs[&EOw4p_s tU>(yP~L1y4CgFl&mVlnrwS (ZW~{׾RtsF.G7Fp*7z fu7QV $ %xAwoJ<iCw Ts6sat[ l'$wjن)߿1rY6yQn)Yf&~-xRбs!13.gt9bp(mpe157B:\ZVꑙ  x<::n/;uG/PV(hb(KNo&ei C|t$}*A $7ie3^v QR&gvgōJF%`k2-z8ZuJOi=Yz[&Vuʨok2GX BOi S#sIn}1sGX—*2)qihpM} ; $ s( p1uν3踢Uj| ax01 M""npS_t:'%S‰Zf(:3_&0yQha1pMŪ\P(m7mԍQL^0G׃K>vwD}F%~-?a/g$K'Mz 5vu'5a=MGYX?"faq_qs=ѲB >tD0Vи]|P%k*BqݔeZ}({ FPTOk7wJs|We~zk] G U-S5 ?^ܼ\ͫ?=XG䝆 !a"|RSCĽ̒.hoʻd҄ ]20zD>k&<øu:n]qL(V68~[Jp"ᨘ-nFOR#BI~ q>{!GT 4H5G|w2n)9&|4I r̚J ~;-̒%ZƁxxg hsSF[%q/7fuW Dy*q '[gp\ ix߿{u- :e*yȱ1|K+Uf^ CD[.{uWjP onɑ/rHgD~<{rC"1ܾ4QÕm r֡$(ua*]+D%(1~)AϺ_OE=:NzLڄRHs4,~ɣnjQNzVO dPlAܞB s_Cgx_*W}/fZ[R[4?~\V0S7n1M?:LK@℥z}1 ,q+rC2;R*iժsRD2w-ἓ6]iUQ kAi)9ewD׌%aAd5"ÞZ#hW(Z~NbC3n6O ٖ:jGrƒ>Mf*`Z~k d[k-B3jyheZHLU~t(bIIH$ggOnkPđQ*.GY6C-$O* FҮHMK1ǥ˥g $ZHUk_o wHVsGE hKG@5B7"pRFb%c`-dp8Ε;乄fKF +Y5*#":cqw3`$k5 ج1&+L@E:H_:xp^78n*=֮]O&Gm*&4{'Atrce =oc +z~iN>I酧\,~p AM6JC2!3tIS$^*ώOO{suݦSAĺ) hCHqU&u}!R$)Y\;b]ڟvV%Yo;]_RZ]1&YjKKf8ncNbO4vyj9jvI΍ !iW Y"Gx{p}V3YDp޵?^J Zy~|[ (|̽-Ӌ5k7P2&xt^~0%we"hlφ)ی ICT4ǟ%s8z&fş:M88NA?&EJ`Sb56|]{L 31U,\VB+k+ˍ_i1kAVy|̽`ב=K WP4WdJ~haEj. N8}~UY0Q"Exdi-|а_.A՗4]l=8%v%GRO&1*yA}=iEx4Zg[N `컔$CDFY! MAȰZ3j*<1?F$SdWe4${!9U$#+xf!#<{H}A[R.=nj7P]ŢTD22 0<ֺPr UE MEF촀tɒ++M?mK ۆ"S *_D SڔnGl0+3M mITخ[:p B.I؄1Lg'Iv=N5Su_pȚC݇Y;2vՕ?N^: !-m筶{!6$OGn(ٗ8Icc.-C~:y>4tO/vɥI㵖tu¿ں4i9EjJl1߂|]"sN 7zbv0Yep0] '" {Η/끒 D:e45yUry05y޼#Ƥ,)wf1#Υ%ʛU.=B#oաj$&N|%{.&{侴ִ&m3#dX}' Xvu~ѦdAU?'K Wa4PiüiYl4(m |3éwf;vzmH3Hā/9YqE"PЕm4\'g `/%Z|Tڙ,"~&ڈ &/MW /{POh}8vߞ8Z%J!"@d kJ 3R~Y)䫈&6A8䊼̔Lkv0 mlE@"?IQ̅'7!G/LP:.Dex@=Ν,G-_RD/K6]w`6:Fp@e4~ \p 1 JRLiT$HXHr)4/7Mo7Č0 f6rtoyMsR/oRN)zcRŵy3ZS $ps S'?o\(:,NF|%"+vHU.V+GQgY)&;XŘ‚c]?ˬ: Ye!^ Y",|{,Ot/t2hg~|<4ƜwN"1nxHr::uݔ~kuyT{^M'>̟_(RpAC+W5$گX4]>WQ CI_oBhuH7 !}4 R' ͢>h<"ѯžMyP FF;W<ĩBX:"$G[cg*ePB$; ɀ9ǡ2-foc9Eg|.MP!I˧=$H`hfcߎ&FC{,an%6؆\m\a)RiJkuuԎ0joŖO^RN wr}ܐG ǰGz6= @CC8岧7gD-wLp>)iH~2`z,Wl ޏȫ~aY r`5AJdK='ŽnIgp~d]|- R5PCu鄴PveK,rc+S_7l}u?NU+k)c/bEg"9bؙ,L<<5^H̕>rInn@%eKL`/ڹreTnOw۳BHm~]M6f㧏c{"iRWLZlbPqKZP@'=܋auz~?/Ħ}z̯|Yp *󢧶cqC],Aa[˸4WDqpb4r\5`urG #*2=O{[8g=4Y_Y~3~N+irR܋cREtbp7fxO=7j8 .?ZI^vvSm b.6 RɫC_0–,qr&aӜ=Ӎ̤!avIL}XO@r#zuek$YԄWkȱ~!-0֖ULJAb2Ta&c%014D/d$$Gz~c@oeWtHЧ[r8]fA g&6ģ~:,G@IڀSgX |,newQD_B |39}lM@WgKwřu{FibQb|Q|nXrydE[=  . ܬ=wc$Y"wVX\| <0Xs F-VM kloC6Ky^3"sQ-[HIIsNA$FՕmcP:Wh>5 k~B.I}z\fswc\p5 ^au /"9#Xj3(olֱ-B攕bZ7U}:ڱb]{ON;BRWWӍFM~5_L|[ZpXiTI)MR_TߪY ,Y݊9((OJ3xT[hۜ6 ?caݮL[v Pjˠ6VCAe<.솪TB7[VKdܫo&]/ @ڏfBK\}imE !טNlo,Ns;:{Y]~ڪ X_::X'32ºi Q汊Γ # oͣ 9;Sd(K\~#۶J{swRʤSƁDžHTXVŪOC6:})7'$bd92=P`LEQM o1ԌE)H6)q|IW \ˊlhrdru`b5 B M<Tu!2xYJ+c.dek@ƇED*e _wc ]=gw`N_B''@P _kBh<8PQѼ3&^EzV&ÿ^7ɺi.e)P+x)#SRusP&aDnU`cDS 7*W~citQ=Z:1&->p6}x#c҃2w,1=z^2Ljrу7n(WWyf ƩBך 47}2dcO!>E丢 Fƌe{Dx5'n8izi`e)z'aXߕViyCYGLbRsڇ4q}AZ5;GHr2~ؐQēSg)rj/'?TsrjT~1 =p3=?zp nɞB߬LЯŻ8HNDbE xc^Τ"vd9d5g1zm*qTk&OX(ȅXh9嗕jVg^K\3|sAcQrP>ޤ[,!5.[zKcܰUܻ9*)WH3dOy8A:XY5O L3$/ϧz~,* V~?#H[@%ۆP_$_19gy7qeN9@tۉjx@;wWL蚍,C^ 9kG/բku]]y+sL5CjNbMF%bVaz+RK}=wI,zq>|̿<[,|/Yq%@rnI\q.,ćI&HK61RW"'b?d]|یL5rB<D9sԢ޸zV*YtfYu@~G O,4R@g?8y@0rk SȢ- :nD<Ӣ+DCQ2|PrB{'Qh?ʹ ɍ]<+J#5r|ͶR 61^Kg+օVYr.b{vܺP0G-6NF. _`Z, 1RўMnԽ?$v"vszX%^+Ӿ^Xa㌲Mn&HvO:?ks+9y )2@V4tAk8O4YOv6fdߗZI,- q'Z6ٮ; As@¥Ev8 4r7^%:Аy L5ZUtv@TH PpcIrbokzZTAu7ŝ Vi_s)n˜= e)6*s]|_5˞?Q&2cQwˈz0 ~f5KBc_) (5<-(PLRP' Zg;f_>%R  u^alIg'PݠxQĿu&cj,e+ FE":}Gr&zϵA=ex϶8:TF5\Z]_Rv@2U_h R4T|%qXV:Rb<\{S vZXVNLoV+) x5q8`ġ/,z7ްάu1o3;y<buosu&Uw FhgPj;E4ݝfV핃k )ѳ9 `Ե=Ɛ:vO?赱Ʒٔa'/pZ(| kڕFDLpD+m* ޘv= ;ʝ5~O&a}n\ R3B8LS03/˚*RLWB磱'ڽP9r'DeQGĎ'!9M? $f!4W1}0/+BZZG?2D4nsA' 0bX&(|s˧:$LN6sĹ~5Qв{G5+u(6u9SK8wH8CD9 _ŸE뉷8a%>L"3pr9#h|2a 6h9x L]i&oۨ+P} \UV5ѢX7 Do3m.´uv3'ӭ , GdMw8@JI>>&#!MdAGW+EGr @ PNm0D´m#.g[ tIPTg-j@k-3;98n\J8QxE1Di87P$ Vwu~rrݦ)\[VX9=:Vu@S24X'E9nk7sHN0dP@Ji 4鷾H/S) <K._u81Ljsj8}ާeC4 WT+9g&SfHG9(D@HfN̄> Teê|uP3\D_,c97\l-u m?P03K=s}-J[9B amMtԨu׼!Mx5 v7@Ч-*v"@Zͱi goLC:WՕO?lb"!!p$U8jkG}rN tG3I+;j4^ȋkRP(U@U`,YfZ@?Yqi*`9hZ ̰[*MeG,xtg0-1c dv[Yw6ZTTs~8QgQWu#+ aiE!;W+ŕ ~PR}jV@*{Xӧf$T#hJ!jvd3f*w70uѕR]Ԝ 3&2|Gdp \̛E\pf|N6рl7U0SႋlKQqH8KBݏaXrbn)(ť&u5²k1s UUxgxS"i$ެZ5Ui\,!OA{'4k)!b.)Ewa@P J)- "԰LGHn$'2N/ W_lPCY$ H4^fv^+\WP-B/ׄƪ# )[&dA;""v[H@bOID{c.f0&'RWЈK[3W$m.ސ)5#!!3/ fP $y5IZ6J0nZ̓:":(QCPfRtfdmQ=Sצx(PSNLz$Ý(F1k\fjK GMd|Uf9 ,*:kϋAT(i ޮ cj%ZUە}=wlkR4W1Q> q e/b6+&qt)X{{)6~RtX#Kߕ1$YTra-m 6M+$3ic]2rW[gzEdTc*f{4y1 a<ޥxQ/+F󙈏T!O˖Z\5N?P~&,r!g$3T+0WP>), af'eHLIcumHGUǻ"ʻPIo v)g,nQnǼ9#l'4. `Lu;1rړ6;jAzdf+F<݅[61jk& xK<9"GІ W )\vSU}nJ8{WҎ K,pJFVv.?|˛P_{ nN\o[wq%f]Ц+/;R n{H|R-.yp93 g3w|mk@|(Ӊ>6!|+%WLݤ[P@zfQ7[d1oڪBcM^ݚEzoI`~ܓryBL]mX|*#*GVt,2h `M3?G [u]5jA; '^Ĕ.'*K]Šq12GyG q5 ssG<LU cB5olQIH[Bo< c.-E2GCC08:ec~\4,nH -\2ۛ[jVmVv [|N`]#x, +nC0X!~;l|@T%<# .z-3gk&|Lc$H+|)"j,%8gQu Nqcwzp)`mǛ/2cg=824 & *3>VZˎٍʼ q ɾ!umm4i.ȡ=wxq7CA! -ߡ%X#M}oUDkz~F6svpA#t f=&.b}{zφ,ey,Og\BZ_c &,V6F,Ҳx61?e7fD١9/*&SefVJtSdI{gq)t-P~K\P{.2!flZyij~D~jw_.{hX_TOǼƊ7$XzHٳ]S&m˵m]74=Svc2-P%dSIǮ›j WBTw2qm"zudĎp5}i#h'|KoiE,sJyZ$̧ߛ+̭ [n :,i-&"ssRۈU[nR#KG^B@w x#>p9F| UR["8>N¥~c+=EL<( ͇Q sսs:Asd@SI9s|4J a8v(xA;ԙ3M憔Vk!GZ]( ˻ xܲEaX86]ـC:ݘQXduÞB^‚/䮙8gGA \S]Z~Oj):~)/B0T~ iyyQS6MDWWLt' oUg{wTDDr>uA,NtjPGՐw's %ˊqdi nCEO ]3]ڟRśr;"%C]kI?G}L-[-&lɔ0fO!R}\J31+Ǿ %)))ȰkҳeQb(XB 0+KFKOdDP1C;(a; .{zwڽ˪%k㚦+haq=6bD]51je-j;&wWn NVΈF}n5'dq2w#Qؾ4l|כp_ Ot$z [E(p ͋+ua1  V=!.yӈLч4 qbp"8ܽ߾(q4 SZJ4IT̮<oQ2m_Y7ϰ#Y`OFDE%5Vqv4 #4̺c5Z|5fC-<#Zt[wN68 0ow4~9. -~n֤ȶ ʠ'VUenXƷ~5PE g Y ${z_:sc[E !짅v  ;E% q^X:)1*&Y;_0 p! )(D_Lʹb8W`|eRjI a;+Ɍw_'B⌘5lPbC{|k=0 Ucan?6HTʣQ+~pq1# 10wR<>̓Z(ʌ8ziۯU"n$F%= ~3qLwAD n+5?m < XSiFLa3pOCG'x6n0HVDh7S9?;^}ptq~%<ň~wưb dnEy($"qvp@Iqu7޳\w EyN%&O~)©eI%?5T/|2vJE̍ǟ"Uk?9Aց˙S" Yant/xʛyY.Aqd0;b݈@&;BI5"? WˌE u(: uUi Lf:Xc9{h@N,:AI{#SwQrQA]A@RR ~„^lEGB# qE0nkatTWk̰hXTJxpN_& $(qttUv#oJLƋqz6&:(Ui2G(1/߄K8 pb^.T3Pqfl{Ħ:O~zS8SzPX:3of x\QyaeM} 6l^N$5OXݿI$NO&ۧX;xiTܻ6)WtbQ ®nx o~F/*{9r9a TNqH߅7y p1eve@s$nZuL~eU-UZ /nGrIJ$7{#K:N[qXFf7n/.c<>xЎkB Oƙtkg"c*v]&޵:BΌ3F<+ӛ8=9: Y}mL$T#k݈jl?VO!21 /pRH/lDޤ-)$BT,r%-n*+4?&88Io X"%9`ѫᇋ&Ttp d wd!^MjKA+՛zQl!ʆo}5OƲL00K[KWm_w/4yĠ[2 DTWY wFkvECezvjl]pw\4^IqC*ո>ߴLג@4HŖA: &9ūZLʉxpfz!/`4S&5_7.VT'd4-6u6SJ `ҍg*/Nא{5$W OV&`ZXaخ@)$jjl ?Zc`gU7֊#{N7Bk{хO}slTC`'bܒs'`Ka"x}~^lW(pd0n*~[B?ū}$vVC$But9B Ud-N#H$ #Lul݄Q a#)qui[zgL77I <9勺,e@8a2*oOr bTةf+hAL+?}`j%r9TC !ӻ,÷. E (1"^&o+âW{3ш ~t||r̐KJ")uIHA)}oMnNS/׼0L-VŶn%؈~(Gi} x_k$òex(S O?C&q/1ue̫V(y}>PLuYM'Yhc 58?Zdܢ;35A%iӉO^`8<Q{6+AY:<˝E]-P:4Q {̽~؝Dd@uQҝNK4t(T(A'<86lŎ8]!ؕS?>^Z<]NDQ"mذ?E I"vYN?ǠۉziMb{z0xg$ U&kE%*FM{y:LQG+LXAK}ae'DžT1~s ?ăy\1La!g-/T&{lx)#c#mÒI%Sek~r~1P1Yyt$xm̚Dɷ_܅?aRpK|EBe+<oQ0d=>/]Xe${ Rokʁl>O&/A(]B8R3YNd7ivt*!mjI>"@2M 2|#@NCO X" ^qss Əl65lw3e^53,> 9Vtv%'cS~Yt{Aeb:~CJts*N,[U0`bY.^+Q)#J<1?iSN)_`ўP6wMONAjgXLQN9qT2cc' H(aKk!S%}WD*/~w|٪Y/ԌPA3XF[?D82 o k/,WJ_]TwJDG\"7 % ytO2Pڏfe}T E+u!Tӟ4>m$BrE#Jr,lʾ5 <`ASwǥ(BV]=I``2$ӴpERe&TP7/Plʯ-/;"r~Yz4\Y|E^ŊȢx] )ƨw%';Ш%C1 [O%(Wzog{?WQ:}&C~/洍).)NMdL1=y8loTBvƭaj38nRzɋ態 ȂD!t";5Re:\ AWn+Q@Vma"![X&q .DEW3gIr< 'ns/M&\&H\r j%x72 g Ns5<7rh:z$Yr6?*`OX)QkƎ2Vh2 !rAw@8M;4^'!{t/A]!:E7]Z_VTpw,*p]7šyy І+)xӕ49\)P^)O!㨓)l.=芘a[z<}!K$e.S0GiMڒiJ[]lYx>VpZXpD\#98.6 6Q7wX3q'{Bfr7鼱 ,TSB;5"7ρrYd^n!ﻯ}!wE/:=K6EgL;=e1\vEŁoRbdWM/6,<.3"2n?zsѶbSKJAgۀDWU= 9vpci] .=(Fd)eE2LiaO/Oe,!Z rZ , (|{=bUO_<$-^vȋZd۳ӎfsy(=O.BsQ"0Տg!G²m>}K(KMt\ͨϣO(KR bG]x穭dx!2ͺwAe#q>z |$~+cWY{O2G]ٛ&?-b T.^0OұPF:7<,c*G$4=D[;^УJ ?VO޴nr]۰ۦS~XbVXWШn{>#J4E/\?`1?ں84@L#u .U(^(vB"w5[71"t(Ǎ:?_Z&ξ!Sv5eX! ȼmQ]c`}Ȭjr+hg. 3Oe7iO!>u;XdϺ?ي@&I$ !Sp$5#GjOlkK6g(hW,hWGqAVN,k/v[Ӏ@f&fL;OIT,_ގABh.q:uLX{XW - ]WKj,w:iakgGϏsA6>w[XϱaX'T:0L>W-x{F9@c gIBtE|'xdI~lZkd @fp0 A\&]3t כ15Om =TYE)`x:Dp~|pZoU2m_ZjZ>B%'2򒯼'buL_0QMt""" qch˅ 0&HL]j(rXD&Z8-mDq<gO=L$>\?Yۨnl̽3\* BH3yl{Eܚws.)D[MR2, a/ M'Ȉw/ot #A8­INr<>Ъ~+~>\*s#tl/S_'C/9ǻ%Edނ4HrP#L{7Q.Pl-Vr.n>I*Lp(y{<6r!킭7-tnMbAӼ~#0}MĹc{7oA֘?E7-f*P0B'0a |a]rM?'MqɠMu(fj2P@W2 D'~B8A[ soQBVNJpb٠9| Dur2 vh#]DH}xcjX'P_ T(,(y:X>u\ܒiy@:|& '`i^[TƘ iFirb ؀,c2VꫮkwK$u]:]:6w S$?k^dٹƹ%M8Ԟj\-B=q)&9}lPy@8Ȩb>IdU9h]ND -fF}kD[fQ$ʛݐxz`20&NdzP, hH1W-6Ȅǜ+EϒNu)2sWDWR5Bogte0d*$iw\9 4*Ea_U̅ʝMBԨh`}k!bR4/:CL%;OhQ;ݮ~e!^SWX^k #ː2or9nV͹3WGJ0J)b֞ _7^ʕh62 ¢ ݇A|cW-uumOUő&I`ݮ+!EV?Bb-yDzpÞ\=(U)!dѵhH?Pi{iJɹɖRosD$c!V7]1Wu@g >ahK h4G$V6=&-"[<6nC0s8>,1[O:H}+@B97UXBXR~p+\1GY!>?)SLc3Xc-iKnW3{#? (*ɷı>-BE.#MTKHs|uca]?:W"ѧJQ-".lV?l~C^Qѱ.8rsԤM&{* c0,HF^FV6S@v:NsÔN~w0}lzJBe*,X;[6Ds UT-9XBhG]Q*2{OS:מ (x1<`*ם֫x<[Ǹ$̖aB%]3&T(/uLA7^'] qB{t߮w1~B=8"\D1S%;FZ8Ci @^IVGfx:o4ރflPPl_J T Iei7|)$+wX=8(vyKs֯zR*t`Xßp$e`H[¾>jmiңVF֬%[29 NY'ۧ<_qH-Љn%ɴ#5si\s#g Ϳ`ʛ_0'4|H;3Cg䥂8>Biݸ4Цv!Xj~}OGzo;Rs<ҳ`O`75`+й4I fgvmx$uJZ)˃vV9{QFQkT<ۋp?.A^ހKק6F8-)U;iZy3*՛7*ޫ-~BKTyv|CT yq30Fcolq_я1 {uT(hKjϪ0j(o7J*LjbO[ZpEF6zEEh0ѝ1,K4/AON`!qO> bw`"<3WgP*֞}U*liЕ߅[)q n+4KbT`&U"(78&8 C\N*!8=Rl]xGJZ.%5 HQZw1čfY&SG!p$g^17M3.~C"t(hIi%JMo@&NNo 3XJ.so_6{\hb5G 8b| ']9Z|-&G Hv>1+ ,H9ߒa= 5yEḅyp+^.lJQa+O}Ug[K57KGt7dppjۭlDy#@@*Mb< /9_6Nd xvY>K59}n &OUyfYj.#(;e72dT5^ )SdfO'*dZn]O«Fb#\e4GM8|8!T}E Y&^ tس`n=U@#fBK-g x'uvjdF!V˭{ߤүN=НCԝ g7ÎZmٙqR |^d}˽1qG%շSx],ꕒSù'6oOz2=g*U% m$f&4J3GW'AXӥI l{9U2Fd#Wpꬴxcv]оF&>mv9sHD#样Q`mq~+zWEk҇+ &/!H>p#_P,ۧ7u;|u -dJ.SD+=Ej%NYxᶷԭ䌹?s[ܢ != -p s/@99SmBj8}lպؕޒ+໴YR7ZZ@sY[T7MGe8pWxӋvIGK 0S5C2c ,D~&˥Gڽ"ӗ fըXtG-v%K4êa446i] {_-87*ꕟh R@nE<9=dCJrg3*Ķ >ȀiAJǤ]RŽ9ALķ~〘I.QS'`Id\$oqb wl6WQxIMBbH]1<&◄ORh"QtePZiOӒ `eEi]e%QvUO^W5!]"^p^ଊ}9hb69VOSNN3j%Ubݠ,/2Kw"wAvKQL>HCe‘okaj:/9x%Nî rA_^5FsfW%BlT3>V|3@zY(2Os"%i>[ <po<#>d2iNFha]ƺ$I桽s}@k\US KL骸w$EZyX("OM{sCyR_De>3+[kQso X{<&${K-8| j#d)D>_/\c|'gзgVg4roU~ s.2oLOIE褊nTN!#z(76ZieA>!we9}ImdLD1nt,2I|Ec*|K;ld> YZ