|
|
@ -1,6 +1,6 @@
|
|
|
|
--- SuperLU_5.2.1/SRC/mc64ad.c 2016-05-22 17:58:44.000000000 +0200
|
|
|
|
--- a/SRC/mc64ad.c 2016-05-22 17:58:44.000000000 +0200
|
|
|
|
+++ mc64ad.c 2018-04-13 17:13:23.571981656 +0200
|
|
|
|
+++ b/mc64ad.c 2018-04-13 17:13:23.571981656 +0200
|
|
|
|
@@ -1,2645 +1,16 @@
|
|
|
|
@@ -1,2646 +1,16 @@
|
|
|
|
-/* mc64ad.f -- translated by f2c (version 20100827).
|
|
|
|
-/* mc64ad.f -- translated by f2c (version 20100827).
|
|
|
|
- You must link the resulting object file with libf2c:
|
|
|
|
- You must link the resulting object file with libf2c:
|
|
|
|
- on Microsoft Windows system, link with libf2c.lib;
|
|
|
|
- on Microsoft Windows system, link with libf2c.lib;
|
|
|
@ -9,9 +9,7 @@
|
|
|
|
- -- in that order, at the end of the command line, as in
|
|
|
|
- -- in that order, at the end of the command line, as in
|
|
|
|
- cc *.o -lf2c -lm
|
|
|
|
- cc *.o -lf2c -lm
|
|
|
|
- Source for libf2c is in /netlib/f2c/libf2c.zip, e.g.,
|
|
|
|
- Source for libf2c is in /netlib/f2c/libf2c.zip, e.g.,
|
|
|
|
+#include <stdio.h>
|
|
|
|
-
|
|
|
|
+#include <stdlib.h>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
- http://www.netlib.org/f2c/libf2c.zip
|
|
|
|
- http://www.netlib.org/f2c/libf2c.zip
|
|
|
|
-*/
|
|
|
|
-*/
|
|
|
|
-
|
|
|
|
-
|
|
|
@ -119,7 +117,7 @@
|
|
|
|
-
|
|
|
|
-
|
|
|
|
-/* ********************************************************************** */
|
|
|
|
-/* ********************************************************************** */
|
|
|
|
-/* Subroutine */ int_t mc64ad_(int_t *job, int_t *n, int_t *ne, int_t *
|
|
|
|
-/* Subroutine */ int_t mc64ad_(int_t *job, int_t *n, int_t *ne, int_t *
|
|
|
|
- ip, int_t *irn, double *a, int_t *num, int_t *cperm,
|
|
|
|
- ip, int_t *irn, double *a, int_t *num, int *cperm,
|
|
|
|
- int_t *liw, int_t *iw, int_t *ldw, double *dw, int_t *
|
|
|
|
- int_t *liw, int_t *iw, int_t *ldw, double *dw, int_t *
|
|
|
|
- icntl, int_t *info)
|
|
|
|
- icntl, int_t *info)
|
|
|
|
-{
|
|
|
|
-{
|
|
|
@ -135,16 +133,17 @@
|
|
|
|
- double fact, rinf;
|
|
|
|
- double fact, rinf;
|
|
|
|
-
|
|
|
|
-
|
|
|
|
- extern /* Subroutine */ int_t mc21ad_(int_t *, int_t *, int_t *,
|
|
|
|
- extern /* Subroutine */ int_t mc21ad_(int_t *, int_t *, int_t *,
|
|
|
|
- int_t *, int_t *, int_t *, int_t *, int_t *), mc64bd_(
|
|
|
|
- int_t *, int_t *, int_t *, int_t *, int_t *),
|
|
|
|
- int_t *, int_t *, int_t *, int_t *, double *, int_t
|
|
|
|
- mc64bd_(int_t *n, int_t *ne, int_t *ip, int_t *irn, double *a,
|
|
|
|
- *, int_t *, int_t *, int_t *, int_t *, int_t *,
|
|
|
|
- int *iperm, int_t *num, int_t *jperm,
|
|
|
|
- double *), mc64rd_(int_t *, int_t *, int_t *, int_t *,
|
|
|
|
- int_t *pr, int_t *q, int_t *l, double *d__),
|
|
|
|
- double *), mc64sd_(int_t *, int_t *, int_t *, int_t *
|
|
|
|
- mc64rd_(int_t *n, int_t *ne, int_t *ip, int_t *irn, double *a),
|
|
|
|
- , double *, int_t *, int_t *, int_t *, int_t *,
|
|
|
|
- mc64sd_(int_t *n, int_t *ne, int_t *ip, int_t *irn, double *a,
|
|
|
|
- int_t *, int_t *, int_t *, int_t *, int_t *), mc64wd_(
|
|
|
|
- int *iperm, int_t *numx, int_t *w, int_t *len, int_t *lenl,
|
|
|
|
- int_t *, int_t *, int_t *, int_t *, double *, int_t
|
|
|
|
- int_t *lenh, int_t *fc, int_t *iw, int_t *iw4),
|
|
|
|
- *, int_t *, int_t *, int_t *, int_t *, int_t *, int_t
|
|
|
|
- mc64wd_(int_t *n, int_t *ne, int_t *ip, int_t *irn, double *a,
|
|
|
|
- *, double *, double *);
|
|
|
|
- int *iperm, int_t *num, int_t *jperm, int_t *out,
|
|
|
|
|
|
|
|
- int_t *pr, int_t *q, int_t *l, double *u, double *d__);
|
|
|
|
-
|
|
|
|
-
|
|
|
|
-/* *** Copyright (c) 1999 Council for the Central Laboratory of the */
|
|
|
|
-/* *** Copyright (c) 1999 Council for the Central Laboratory of the */
|
|
|
|
-/* Research Councils *** */
|
|
|
|
-/* Research Councils *** */
|
|
|
@ -346,7 +345,7 @@
|
|
|
|
- info[2] = *job;
|
|
|
|
- info[2] = *job;
|
|
|
|
- if (icntl[1] >= 0) {
|
|
|
|
- if (icntl[1] >= 0) {
|
|
|
|
- printf(" ****** Error in MC64A/AD. INFO(1) = %2d"
|
|
|
|
- printf(" ****** Error in MC64A/AD. INFO(1) = %2d"
|
|
|
|
- " because JOB = %d\n", info[1], *job);
|
|
|
|
- " because JOB = %d\n", (int) info[1], (int) *job);
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- goto L99;
|
|
|
|
- goto L99;
|
|
|
|
- }
|
|
|
|
- }
|
|
|
@ -356,7 +355,7 @@
|
|
|
|
- info[2] = *n;
|
|
|
|
- info[2] = *n;
|
|
|
|
- if (icntl[1] >= 0) {
|
|
|
|
- if (icntl[1] >= 0) {
|
|
|
|
- printf(" ****** Error in MC64A/AD. INFO(1) = %2d"
|
|
|
|
- printf(" ****** Error in MC64A/AD. INFO(1) = %2d"
|
|
|
|
- " because N = %d\n", info[1], *job);
|
|
|
|
- " because N = %d\n", (int) info[1], (int) *job);
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- goto L99;
|
|
|
|
- goto L99;
|
|
|
|
- }
|
|
|
|
- }
|
|
|
@ -366,7 +365,7 @@
|
|
|
|
- info[2] = *ne;
|
|
|
|
- info[2] = *ne;
|
|
|
|
- if (icntl[1] >= 0) {
|
|
|
|
- if (icntl[1] >= 0) {
|
|
|
|
- printf(" ****** Error in MC64A/AD. INFO(1) = %2d"
|
|
|
|
- printf(" ****** Error in MC64A/AD. INFO(1) = %2d"
|
|
|
|
- " because NE = %d\n", info[1], *job);
|
|
|
|
- " because NE = %d\n", (int) info[1], (int) *job);
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- goto L99;
|
|
|
|
- goto L99;
|
|
|
|
- }
|
|
|
|
- }
|
|
|
@ -391,7 +390,7 @@
|
|
|
|
- info[2] = k;
|
|
|
|
- info[2] = k;
|
|
|
|
- if (icntl[1] >= 0) {
|
|
|
|
- if (icntl[1] >= 0) {
|
|
|
|
- printf(" ****** Error in MC64A/AD. INFO(1) = %2d"
|
|
|
|
- printf(" ****** Error in MC64A/AD. INFO(1) = %2d"
|
|
|
|
- " LIW too small, must be at least %8d\n", info[1], k);
|
|
|
|
- " LIW too small, must be at least %8d\n", (int) info[1], (int) k);
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- goto L99;
|
|
|
|
- goto L99;
|
|
|
|
- }
|
|
|
|
- }
|
|
|
@ -415,7 +414,7 @@
|
|
|
|
- info[2] = k;
|
|
|
|
- info[2] = k;
|
|
|
|
- if (icntl[1] >= 0) {
|
|
|
|
- if (icntl[1] >= 0) {
|
|
|
|
- printf(" ****** Error in MC64A/AD. INFO(1) = %2d"
|
|
|
|
- printf(" ****** Error in MC64A/AD. INFO(1) = %2d"
|
|
|
|
- " LDW too small, must be at least %8d\n", info[1], k);
|
|
|
|
- " LDW too small, must be at least %8d\n", (int) info[1], (int) k);
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- goto L99;
|
|
|
|
- goto L99;
|
|
|
|
- }
|
|
|
|
- }
|
|
|
@ -439,7 +438,7 @@
|
|
|
|
- if (icntl[1] >= 0) {
|
|
|
|
- if (icntl[1] >= 0) {
|
|
|
|
- printf(" ****** Error in MC64A/AD. INFO(1) = %2d Column %8d"
|
|
|
|
- printf(" ****** Error in MC64A/AD. INFO(1) = %2d Column %8d"
|
|
|
|
- " contains an entry with invalid row index %8d\n",
|
|
|
|
- " contains an entry with invalid row index %8d\n",
|
|
|
|
- info[1], j, i__);
|
|
|
|
- (int) info[1], (int) j, (int) i__);
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- goto L99;
|
|
|
|
- goto L99;
|
|
|
|
- }
|
|
|
|
- }
|
|
|
@ -451,7 +450,7 @@
|
|
|
|
- printf(" ****** Error in MC64A/AD. INFO(1) = %2d"
|
|
|
|
- printf(" ****** Error in MC64A/AD. INFO(1) = %2d"
|
|
|
|
- " Column %8d"
|
|
|
|
- " Column %8d"
|
|
|
|
- " contains two or more entries with row index %8d\n",
|
|
|
|
- " contains two or more entries with row index %8d\n",
|
|
|
|
- info[1], j, i__);
|
|
|
|
- (int) info[1], (int) j, (int) i__);
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- goto L99;
|
|
|
|
- goto L99;
|
|
|
|
- } else {
|
|
|
|
- } else {
|
|
|
@ -465,15 +464,15 @@
|
|
|
|
-/* Print diagnostics on input */
|
|
|
|
-/* Print diagnostics on input */
|
|
|
|
- if (icntl[3] >= 0) {
|
|
|
|
- if (icntl[3] >= 0) {
|
|
|
|
- printf(" ****** Input parameters for MC64A/AD: JOB = %8d,"
|
|
|
|
- printf(" ****** Input parameters for MC64A/AD: JOB = %8d,"
|
|
|
|
- " N = %d, NE = %8d\n", *job, *n, *ne);
|
|
|
|
- " N = %d, NE = %8d\n", (int) *job, (int) *n, (int) *ne);
|
|
|
|
- printf(" IP(1:N+1) = ");
|
|
|
|
- printf(" IP(1:N+1) = ");
|
|
|
|
- for (j=1; j<=(*n+1); ++j) {
|
|
|
|
- for (j=1; j<=(*n+1); ++j) {
|
|
|
|
- printf("%8d", ip[j]);
|
|
|
|
- printf("%8d", (int) ip[j]);
|
|
|
|
- if (j%8 == 0) printf("\n");
|
|
|
|
- if (j%8 == 0) printf("\n");
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- printf("\n IRN(1:NE) = ");
|
|
|
|
- printf("\n IRN(1:NE) = ");
|
|
|
|
- for (j=1; j<=(*ne); ++j) {
|
|
|
|
- for (j=1; j<=(*ne); ++j) {
|
|
|
|
- printf("%8d", irn[j]);
|
|
|
|
- printf("%8d", (int) irn[j]);
|
|
|
|
- if (j%8 == 0) printf("\n");
|
|
|
|
- if (j%8 == 0) printf("\n");
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- printf("\n");
|
|
|
|
- printf("\n");
|
|
|
@ -621,24 +620,24 @@
|
|
|
|
- info[1] = 1;
|
|
|
|
- info[1] = 1;
|
|
|
|
- if (icntl[2] >= 0) {
|
|
|
|
- if (icntl[2] >= 0) {
|
|
|
|
- printf(" ****** Warning from MC64A/AD. INFO(1) = %2d"
|
|
|
|
- printf(" ****** Warning from MC64A/AD. INFO(1) = %2d"
|
|
|
|
- " The matrix is structurally singular.\n", info[1]);
|
|
|
|
- " The matrix is structurally singular.\n", (int)info[1]);
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- if (info[1] == 2) {
|
|
|
|
- if (info[1] == 2) {
|
|
|
|
-/* Scaling factors are large, return with warning */
|
|
|
|
-/* Scaling factors are large, return with warning */
|
|
|
|
- if (icntl[2] >= 0) {
|
|
|
|
- if (icntl[2] >= 0) {
|
|
|
|
- printf(" ****** Warning from MC64A/AD. INFO(1) = %2d\n"
|
|
|
|
- printf(" ****** Warning from MC64A/AD. INFO(1) = %2d\n"
|
|
|
|
- " Some scaling factors may be too large.\n", info[1]);
|
|
|
|
- " Some scaling factors may be too large.\n", (int) info[1]);
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
-/* Print diagnostics on output */
|
|
|
|
-/* Print diagnostics on output */
|
|
|
|
- if (icntl[3] >= 0) {
|
|
|
|
- if (icntl[3] >= 0) {
|
|
|
|
- printf(" ****** Output parameters for MC64A/AD: INFO(1:2) = %8d%8d\n",
|
|
|
|
- printf(" ****** Output parameters for MC64A/AD: INFO(1:2) = %8d%8d\n",
|
|
|
|
- info[1], info[2]);
|
|
|
|
- (int) info[1], (int) info[2]);
|
|
|
|
- printf(" NUM = %8d", *num);
|
|
|
|
- printf(" NUM = %8d", (int) *num);
|
|
|
|
- printf(" CPERM(1:N) = ");
|
|
|
|
- printf(" CPERM(1:N) = ");
|
|
|
|
- for (j=1; j<=*n; ++j) {
|
|
|
|
- for (j=1; j<=*n; ++j) {
|
|
|
|
- printf("%8d", cperm[j]);
|
|
|
|
- printf("%8d", (int) cperm[j]);
|
|
|
|
- if (j%8 == 0) printf("\n");
|
|
|
|
- if (j%8 == 0) printf("\n");
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- if (*job == 5) {
|
|
|
|
- if (*job == 5) {
|
|
|
@ -662,7 +661,7 @@
|
|
|
|
-
|
|
|
|
-
|
|
|
|
-/* ********************************************************************** */
|
|
|
|
-/* ********************************************************************** */
|
|
|
|
-/* Subroutine */ int_t mc64bd_(int_t *n, int_t *ne, int_t *ip, int_t *
|
|
|
|
-/* Subroutine */ int_t mc64bd_(int_t *n, int_t *ne, int_t *ip, int_t *
|
|
|
|
- irn, double *a, int_t *iperm, int_t *num, int_t *jperm,
|
|
|
|
- irn, double *a, int *iperm, int_t *num, int_t *jperm,
|
|
|
|
- int_t *pr, int_t *q, int_t *l, double *d__)
|
|
|
|
- int_t *pr, int_t *q, int_t *l, double *d__)
|
|
|
|
-{
|
|
|
|
-{
|
|
|
|
- /* System generated locals */
|
|
|
|
- /* System generated locals */
|
|
|
@ -685,10 +684,10 @@
|
|
|
|
- double dnew;
|
|
|
|
- double dnew;
|
|
|
|
- int_t jord, qlen, idum, jdum;
|
|
|
|
- int_t jord, qlen, idum, jdum;
|
|
|
|
- double rinf;
|
|
|
|
- double rinf;
|
|
|
|
- extern /* Subroutine */ int_t mc64dd_(int_t *, int_t *, int_t *,
|
|
|
|
- extern /* Subroutine */ int_t
|
|
|
|
- double *, int_t *, int_t *), mc64ed_(int_t *, int_t *,
|
|
|
|
- mc64dd_(int_t *, int_t *, int_t *, double *, int_t *, int_t *),
|
|
|
|
- int_t *, double *, int_t *, int_t *), mc64fd_(int_t *
|
|
|
|
- mc64ed_(int_t *, int_t *, int_t *, double *, int_t *, int_t *),
|
|
|
|
- , int_t *, int_t *, int_t *, double *, int_t *, int_t *);
|
|
|
|
- mc64fd_(int_t *, int_t *, int_t *, int_t *, double *, int_t *, int_t *);
|
|
|
|
-
|
|
|
|
-
|
|
|
|
-
|
|
|
|
-
|
|
|
|
-/* *** Copyright (c) 1999 Council for the Central Laboratory of the */
|
|
|
|
-/* *** Copyright (c) 1999 Council for the Central Laboratory of the */
|
|
|
@ -1550,11 +1549,10 @@
|
|
|
|
-
|
|
|
|
-
|
|
|
|
-/* ********************************************************************** */
|
|
|
|
-/* ********************************************************************** */
|
|
|
|
-/* Subroutine */ int_t mc64sd_(int_t *n, int_t *ne, int_t *ip, int_t *
|
|
|
|
-/* Subroutine */ int_t mc64sd_(int_t *n, int_t *ne, int_t *ip, int_t *
|
|
|
|
- irn, double *a, int_t *iperm, int_t *numx, int_t *w,
|
|
|
|
- irn, double *a, int *iperm, int_t *numx, int_t *w,
|
|
|
|
- int_t *len, int_t *lenl, int_t *lenh, int_t *fc, int_t *iw,
|
|
|
|
- int_t *len, int_t *lenl, int_t *lenh, int_t *fc, int_t *iw,
|
|
|
|
- int_t *iw4)
|
|
|
|
- int_t *iw4)
|
|
|
|
+void mc64id_(int *a)
|
|
|
|
-{
|
|
|
|
{
|
|
|
|
|
|
|
|
- /* System generated locals */
|
|
|
|
- /* System generated locals */
|
|
|
|
- int_t i__1, i__2, i__3, i__4;
|
|
|
|
- int_t i__1, i__2, i__3, i__4;
|
|
|
|
-
|
|
|
|
-
|
|
|
@ -1562,8 +1560,9 @@
|
|
|
|
- int_t i__, j, k, l, ii, mod, cnt, num;
|
|
|
|
- int_t i__, j, k, l, ii, mod, cnt, num;
|
|
|
|
- double bval, bmin, bmax, rinf;
|
|
|
|
- double bval, bmin, bmax, rinf;
|
|
|
|
- int_t nval, wlen, idum1, idum2, idum3;
|
|
|
|
- int_t nval, wlen, idum1, idum2, idum3;
|
|
|
|
- extern /* Subroutine */ int_t mc64qd_(int_t *, int_t *, int_t *,
|
|
|
|
- extern /* Subroutine */ int_t
|
|
|
|
- int_t *, int_t *, double *, int_t *, double *),
|
|
|
|
- mc64qd_(int_t *, int_t *, int_t *, int_t *, int_t *, double *,
|
|
|
|
|
|
|
|
- int_t *, double *),
|
|
|
|
- mc64ud_(int_t *, int_t *, int_t *, int_t *, int_t *,
|
|
|
|
- mc64ud_(int_t *, int_t *, int_t *, int_t *, int_t *,
|
|
|
|
- int_t *, int_t *, int_t *, int_t *, int_t *, int_t *,
|
|
|
|
- int_t *, int_t *, int_t *, int_t *, int_t *, int_t *,
|
|
|
|
- int_t *, int_t *, int_t *, int_t *);
|
|
|
|
- int_t *, int_t *, int_t *, int_t *);
|
|
|
@ -2165,7 +2164,7 @@
|
|
|
|
-
|
|
|
|
-
|
|
|
|
-/* ********************************************************************** */
|
|
|
|
-/* ********************************************************************** */
|
|
|
|
-/* Subroutine */ int_t mc64wd_(int_t *n, int_t *ne, int_t *ip, int_t *
|
|
|
|
-/* Subroutine */ int_t mc64wd_(int_t *n, int_t *ne, int_t *ip, int_t *
|
|
|
|
- irn, double *a, int_t *iperm, int_t *num, int_t *jperm,
|
|
|
|
- irn, double *a, int *iperm, int_t *num, int_t *jperm,
|
|
|
|
- int_t *out, int_t *pr, int_t *q, int_t *l, double *u,
|
|
|
|
- int_t *out, int_t *pr, int_t *q, int_t *l, double *u,
|
|
|
|
- double *d__)
|
|
|
|
- double *d__)
|
|
|
|
-{
|
|
|
|
-{
|
|
|
@ -2185,11 +2184,10 @@
|
|
|
|
- double dmin__, dnew;
|
|
|
|
- double dmin__, dnew;
|
|
|
|
- int_t jord, qlen, jdum;
|
|
|
|
- int_t jord, qlen, jdum;
|
|
|
|
- double rinf;
|
|
|
|
- double rinf;
|
|
|
|
- extern /* Subroutine */ int_t mc64dd_(int_t *, int_t *, int_t *,
|
|
|
|
- extern /* Subroutine */ int_t
|
|
|
|
- double *, int_t *, int_t *), mc64ed_(int_t *, int_t *,
|
|
|
|
- mc64dd_(int_t *, int_t *, int_t *, double *, int_t *, int_t *),
|
|
|
|
- int_t *, double *, int_t *, int_t *), mc64fd_(int_t *
|
|
|
|
- mc64ed_(int_t *, int_t *, int_t *, double *, int_t *, int_t *),
|
|
|
|
- , int_t *, int_t *, int_t *, double *, int_t *,
|
|
|
|
- mc64fd_(int_t *, int_t *, int_t *, int_t *, double *, int_t *, int_t *);
|
|
|
|
- int_t *);
|
|
|
|
|
|
|
|
-
|
|
|
|
-
|
|
|
|
-
|
|
|
|
-
|
|
|
|
-/* *** Copyright (c) 1999 Council for the Central Laboratory of the */
|
|
|
|
-/* *** Copyright (c) 1999 Council for the Central Laboratory of the */
|
|
|
@ -2648,7 +2646,11 @@
|
|
|
|
- return 0;
|
|
|
|
- return 0;
|
|
|
|
-} /* mc64wd_ */
|
|
|
|
-} /* mc64wd_ */
|
|
|
|
-
|
|
|
|
-
|
|
|
|
-
|
|
|
|
+#include <stdio.h>
|
|
|
|
|
|
|
|
+#include <stdlib.h>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
+void mc64id_(int *a)
|
|
|
|
|
|
|
|
+ {
|
|
|
|
+ fprintf(stderr, "SuperLU: MC64 functionality not available (it uses non-free code). Aborting.\n");
|
|
|
|
+ fprintf(stderr, "SuperLU: MC64 functionality not available (it uses non-free code). Aborting.\n");
|
|
|
|
+ abort();
|
|
|
|
+ abort();
|
|
|
|
+}
|
|
|
|
+}
|
|
|
@ -2660,3 +2662,4 @@
|
|
|
|
+ fprintf(stderr, "SuperLU: MC64 functionality not available (it uses non-free code). Aborting.\n");
|
|
|
|
+ fprintf(stderr, "SuperLU: MC64 functionality not available (it uses non-free code). Aborting.\n");
|
|
|
|
+ abort();
|
|
|
|
+ abort();
|
|
|
|
+}
|
|
|
|
+}
|
|
|
|
|
|
|
|
|
|
|
|