dolfin team mailing list archive
-
dolfin team
-
Mailing list archive
-
Message #18018
Re: Merge request for some sandbox stuff
-
To:
Anders Logg <logg@xxxxxxxxx>
-
From:
Andre Massing <massing@xxxxxxxxx>
-
Date:
Tue, 6 Apr 2010 18:44:03 +0200
-
Cc:
DOLFIN Mailing List <dolfin@xxxxxxxxxxxxxxxxxxx>
-
In-reply-to:
<20100406155011.GZ6930@olorin>
-
Organization:
Simula Research Laboratory
-
User-agent:
KMail/1.13.1 (Linux/2.6.31.4-centrino-duo; KDE/4.4.1; x86_64; ; )
On Tuesday 6. April 2010 17.50.13 Anders Logg wrote:
> Could you publish your sandbox branch?
It is published under
lp:~massing/dolfin/sandbox_branch
but bzr crashed while I was pushing it, great. Checked it, everything seems
to be there. Something seems to be wrong with launchpad server, my mails
needed half a day to be delivered.
>
> I think we should just merge published sandbox branches without (or
> with minimal) review, but it's good to use the possibility of
> publishing branches on Launchpad + I need to practice how to
> review/approve/merge branches on Launchpad. I've never done it before.
>
> --
> Anders
>
> On Tue, Apr 06, 2010 at 11:25:07AM +0200, Andre Massing wrote:
> > Hi!
> >
> > While I am working on a implementation of Nitsche methods for overlapping
> > meshes in DOLFIN I produce some sand, which might be nice to be added to
> > the sandbox :) It contains among other things some prototypes for
> > building a complete intersection map for two overlapping meshes (which
> > cells/facets are covered by which cells/facest) and for barycenter
> > quadrature formulas on arbitrary polyhedrons and polygons
> > (unfortunately just for the 3D case, up to now).
> >
> > Kind regards,
> > Andre
> >
> > # Bazaar merge directive format 2 (Bazaar 0.90)
> > # revision_id: massing@xxxxxxxxx-20100406091417-ogh30d38n95eh5cq
> > # target_branch: bzr+ssh://bazaar.launchpad.net/~dolfin-\
> > # core/dolfin/sandbox/
> > # testament_sha1: 74c2e1fd30a903bacbd8c50606cb683173e73813
> > # timestamp: 2010-04-06 11:15:17 +0200
> > # base_revision_id: logg@xxxxxxxxx-20100226124738-bk9jlyb9voycqbwa
> > #
> > # Begin patch
> > === renamed directory 'cgal' => 'nitsche_method'
> > === added directory 'nitsche_method/data'
> > === added directory 'nitsche_method/data/meshes'
> > === added file 'nitsche_method/data/meshes/rotator.xml'
> > --- nitsche_method/data/meshes/rotator.xml 1970-01-01 00:00:00 +0000
> > +++ nitsche_method/data/meshes/rotator.xml 2010-03-16 14:39:09 +0000
> > @@ -0,0 +1,402 @@
> > +<?xml version="1.0" encoding="UTF-8"?>
> > +
> > +<dolfin xmlns:dolfin="http://www.fenics.org/dolfin/">
> > + <mesh celltype="triangle" dim="2">
> > + <vertices size="117">
> > + <vertex index="0" x="-0.1" y="-1"/>
> > + <vertex index="1" x="0" y="-1"/>
> > + <vertex index="2" x="0" y="-0.9"/>
> > + <vertex index="3" x="-0.1" y="-0.9"/>
> > + <vertex index="4" x="0.1" y="-1"/>
> > + <vertex index="5" x="0.1" y="-0.9"/>
> > + <vertex index="6" x="0" y="-0.8"/>
> > + <vertex index="7" x="-0.1" y="-0.8"/>
> > + <vertex index="8" x="0.1" y="-0.8"/>
> > + <vertex index="9" x="0" y="-0.7"/>
> > + <vertex index="10" x="-0.1" y="-0.7"/>
> > + <vertex index="11" x="0.1" y="-0.7"/>
> > + <vertex index="12" x="0" y="-0.6"/>
> > + <vertex index="13" x="-0.1" y="-0.6"/>
> > + <vertex index="14" x="0.1" y="-0.6"/>
> > + <vertex index="15" x="0" y="-0.5"/>
> > + <vertex index="16" x="-0.1" y="-0.5"/>
> > + <vertex index="17" x="0.1" y="-0.5"/>
> > + <vertex index="18" x="0" y="-0.4"/>
> > + <vertex index="19" x="-0.1" y="-0.4"/>
> > + <vertex index="20" x="0.1" y="-0.4"/>
> > + <vertex index="21" x="0" y="-0.3"/>
> > + <vertex index="22" x="-0.1" y="-0.3"/>
> > + <vertex index="23" x="0.1" y="-0.3"/>
> > + <vertex index="24" x="0" y="-0.2"/>
> > + <vertex index="25" x="-0.1" y="-0.2"/>
> > + <vertex index="26" x="0.1" y="-0.2"/>
> > + <vertex index="27" x="0" y="-0.1"/>
> > + <vertex index="28" x="-0.1" y="-0.1"/>
> > + <vertex index="29" x="0.1" y="-0.1"/>
> > + <vertex index="30" x="-1" y="-0.1"/>
> > + <vertex index="31" x="-0.9" y="-0.1"/>
> > + <vertex index="32" x="-0.9" y="0"/>
> > + <vertex index="33" x="-1" y="0"/>
> > + <vertex index="34" x="-0.8" y="-0.1"/>
> > + <vertex index="35" x="-0.8" y="0"/>
> > + <vertex index="36" x="-0.7" y="-0.1"/>
> > + <vertex index="37" x="-0.7" y="0"/>
> > + <vertex index="38" x="-0.6" y="-0.1"/>
> > + <vertex index="39" x="-0.6" y="0"/>
> > + <vertex index="40" x="-0.5" y="-0.1"/>
> > + <vertex index="41" x="-0.5" y="0"/>
> > + <vertex index="42" x="-0.4" y="-0.1"/>
> > + <vertex index="43" x="-0.4" y="0"/>
> > + <vertex index="44" x="-0.3" y="-0.1"/>
> > + <vertex index="45" x="-0.3" y="0"/>
> > + <vertex index="46" x="-0.2" y="-0.1"/>
> > + <vertex index="47" x="-0.2" y="0"/>
> > + <vertex index="48" x="-0.1" y="0"/>
> > + <vertex index="49" x="0" y="0"/>
> > + <vertex index="50" x="0.1" y="0"/>
> > + <vertex index="51" x="0.2" y="-0.1"/>
> > + <vertex index="52" x="0.2" y="0"/>
> > + <vertex index="53" x="0.3" y="-0.1"/>
> > + <vertex index="54" x="0.3" y="0"/>
> > + <vertex index="55" x="0.4" y="-0.1"/>
> > + <vertex index="56" x="0.4" y="0"/>
> > + <vertex index="57" x="0.5" y="-0.1"/>
> > + <vertex index="58" x="0.5" y="0"/>
> > + <vertex index="59" x="0.6" y="-0.1"/>
> > + <vertex index="60" x="0.6" y="0"/>
> > + <vertex index="61" x="0.7" y="-0.1"/>
> > + <vertex index="62" x="0.7" y="0"/>
> > + <vertex index="63" x="0.8" y="-0.1"/>
> > + <vertex index="64" x="0.8" y="0"/>
> > + <vertex index="65" x="0.9" y="-0.1"/>
> > + <vertex index="66" x="0.9" y="0"/>
> > + <vertex index="67" x="1" y="-0.1"/>
> > + <vertex index="68" x="1" y="0"/>
> > + <vertex index="69" x="-0.9" y="0.1"/>
> > + <vertex index="70" x="-1" y="0.1"/>
> > + <vertex index="71" x="-0.8" y="0.1"/>
> > + <vertex index="72" x="-0.7" y="0.1"/>
> > + <vertex index="73" x="-0.6" y="0.1"/>
> > + <vertex index="74" x="-0.5" y="0.1"/>
> > + <vertex index="75" x="-0.4" y="0.1"/>
> > + <vertex index="76" x="-0.3" y="0.1"/>
> > + <vertex index="77" x="-0.2" y="0.1"/>
> > + <vertex index="78" x="-0.1" y="0.1"/>
> > + <vertex index="79" x="0" y="0.1"/>
> > + <vertex index="80" x="0.1" y="0.1"/>
> > + <vertex index="81" x="0.2" y="0.1"/>
> > + <vertex index="82" x="0.3" y="0.1"/>
> > + <vertex index="83" x="0.4" y="0.1"/>
> > + <vertex index="84" x="0.5" y="0.1"/>
> > + <vertex index="85" x="0.6" y="0.1"/>
> > + <vertex index="86" x="0.7" y="0.1"/>
> > + <vertex index="87" x="0.8" y="0.1"/>
> > + <vertex index="88" x="0.9" y="0.1"/>
> > + <vertex index="89" x="1" y="0.1"/>
> > + <vertex index="90" x="0" y="0.2"/>
> > + <vertex index="91" x="-0.1" y="0.2"/>
> > + <vertex index="92" x="0.1" y="0.2"/>
> > + <vertex index="93" x="0" y="0.3"/>
> > + <vertex index="94" x="-0.1" y="0.3"/>
> > + <vertex index="95" x="0.1" y="0.3"/>
> > + <vertex index="96" x="0" y="0.4"/>
> > + <vertex index="97" x="-0.1" y="0.4"/>
> > + <vertex index="98" x="0.1" y="0.4"/>
> > + <vertex index="99" x="0" y="0.5"/>
> > + <vertex index="100" x="-0.1" y="0.5"/>
> > + <vertex index="101" x="0.1" y="0.5"/>
> > + <vertex index="102" x="0" y="0.6"/>
> > + <vertex index="103" x="-0.1" y="0.6"/>
> > + <vertex index="104" x="0.1" y="0.6"/>
> > + <vertex index="105" x="0" y="0.7"/>
> > + <vertex index="106" x="-0.1" y="0.7"/>
> > + <vertex index="107" x="0.1" y="0.7"/>
> > + <vertex index="108" x="0" y="0.8"/>
> > + <vertex index="109" x="-0.1" y="0.8"/>
> > + <vertex index="110" x="0.1" y="0.8"/>
> > + <vertex index="111" x="0" y="0.9"/>
> > + <vertex index="112" x="-0.1" y="0.9"/>
> > + <vertex index="113" x="0.1" y="0.9"/>
> > + <vertex index="114" x="0" y="1"/>
> > + <vertex index="115" x="-0.1" y="1"/>
> > + <vertex index="116" x="0.1" y="1"/>
> > + </vertices>
> > + <cells size="152">
> > + <triangle index="0" v0="0" v1="1" v2="2"/>
> > + <triangle index="1" v0="0" v1="2" v2="3"/>
> > + <triangle index="2" v0="1" v1="4" v2="5"/>
> > + <triangle index="3" v0="1" v1="2" v2="5"/>
> > + <triangle index="4" v0="2" v1="3" v2="6"/>
> > + <triangle index="5" v0="3" v1="6" v2="7"/>
> > + <triangle index="6" v0="2" v1="5" v2="8"/>
> > + <triangle index="7" v0="2" v1="6" v2="8"/>
> > + <triangle index="8" v0="6" v1="7" v2="9"/>
> > + <triangle index="9" v0="7" v1="9" v2="10"/>
> > + <triangle index="10" v0="6" v1="8" v2="11"/>
> > + <triangle index="11" v0="6" v1="9" v2="11"/>
> > + <triangle index="12" v0="9" v1="10" v2="12"/>
> > + <triangle index="13" v0="10" v1="12" v2="13"/>
> > + <triangle index="14" v0="9" v1="11" v2="14"/>
> > + <triangle index="15" v0="9" v1="12" v2="14"/>
> > + <triangle index="16" v0="12" v1="13" v2="15"/>
> > + <triangle index="17" v0="13" v1="15" v2="16"/>
> > + <triangle index="18" v0="12" v1="14" v2="17"/>
> > + <triangle index="19" v0="12" v1="15" v2="17"/>
> > + <triangle index="20" v0="15" v1="16" v2="18"/>
> > + <triangle index="21" v0="16" v1="18" v2="19"/>
> > + <triangle index="22" v0="15" v1="17" v2="20"/>
> > + <triangle index="23" v0="15" v1="18" v2="20"/>
> > + <triangle index="24" v0="18" v1="19" v2="21"/>
> > + <triangle index="25" v0="19" v1="21" v2="22"/>
> > + <triangle index="26" v0="18" v1="20" v2="23"/>
> > + <triangle index="27" v0="18" v1="21" v2="23"/>
> > + <triangle index="28" v0="21" v1="22" v2="24"/>
> > + <triangle index="29" v0="22" v1="24" v2="25"/>
> > + <triangle index="30" v0="21" v1="23" v2="26"/>
> > + <triangle index="31" v0="21" v1="24" v2="26"/>
> > + <triangle index="32" v0="24" v1="25" v2="27"/>
> > + <triangle index="33" v0="25" v1="27" v2="28"/>
> > + <triangle index="34" v0="24" v1="26" v2="29"/>
> > + <triangle index="35" v0="24" v1="27" v2="29"/>
> > + <triangle index="36" v0="30" v1="31" v2="32"/>
> > + <triangle index="37" v0="30" v1="32" v2="33"/>
> > + <triangle index="38" v0="31" v1="34" v2="35"/>
> > + <triangle index="39" v0="31" v1="32" v2="35"/>
> > + <triangle index="40" v0="34" v1="36" v2="37"/>
> > + <triangle index="41" v0="34" v1="35" v2="37"/>
> > + <triangle index="42" v0="36" v1="38" v2="39"/>
> > + <triangle index="43" v0="36" v1="37" v2="39"/>
> > + <triangle index="44" v0="38" v1="40" v2="41"/>
> > + <triangle index="45" v0="38" v1="39" v2="41"/>
> > + <triangle index="46" v0="40" v1="42" v2="43"/>
> > + <triangle index="47" v0="40" v1="41" v2="43"/>
> > + <triangle index="48" v0="42" v1="44" v2="45"/>
> > + <triangle index="49" v0="42" v1="43" v2="45"/>
> > + <triangle index="50" v0="44" v1="46" v2="47"/>
> > + <triangle index="51" v0="44" v1="45" v2="47"/>
> > + <triangle index="52" v0="28" v1="46" v2="48"/>
> > + <triangle index="53" v0="46" v1="47" v2="48"/>
> > + <triangle index="54" v0="27" v1="28" v2="49"/>
> > + <triangle index="55" v0="28" v1="48" v2="49"/>
> > + <triangle index="56" v0="27" v1="29" v2="50"/>
> > + <triangle index="57" v0="27" v1="49" v2="50"/>
> > + <triangle index="58" v0="29" v1="51" v2="52"/>
> > + <triangle index="59" v0="29" v1="50" v2="52"/>
> > + <triangle index="60" v0="51" v1="53" v2="54"/>
> > + <triangle index="61" v0="51" v1="52" v2="54"/>
> > + <triangle index="62" v0="53" v1="55" v2="56"/>
> > + <triangle index="63" v0="53" v1="54" v2="56"/>
> > + <triangle index="64" v0="55" v1="57" v2="58"/>
> > + <triangle index="65" v0="55" v1="56" v2="58"/>
> > + <triangle index="66" v0="57" v1="59" v2="60"/>
> > + <triangle index="67" v0="57" v1="58" v2="60"/>
> > + <triangle index="68" v0="59" v1="61" v2="62"/>
> > + <triangle index="69" v0="59" v1="60" v2="62"/>
> > + <triangle index="70" v0="61" v1="63" v2="64"/>
> > + <triangle index="71" v0="61" v1="62" v2="64"/>
> > + <triangle index="72" v0="63" v1="65" v2="66"/>
> > + <triangle index="73" v0="63" v1="64" v2="66"/>
> > + <triangle index="74" v0="65" v1="67" v2="68"/>
> > + <triangle index="75" v0="65" v1="66" v2="68"/>
> > + <triangle index="76" v0="32" v1="33" v2="69"/>
> > + <triangle index="77" v0="33" v1="69" v2="70"/>
> > + <triangle index="78" v0="32" v1="35" v2="71"/>
> > + <triangle index="79" v0="32" v1="69" v2="71"/>
> > + <triangle index="80" v0="35" v1="37" v2="72"/>
> > + <triangle index="81" v0="35" v1="71" v2="72"/>
> > + <triangle index="82" v0="37" v1="39" v2="73"/>
> > + <triangle index="83" v0="37" v1="72" v2="73"/>
> > + <triangle index="84" v0="39" v1="41" v2="74"/>
> > + <triangle index="85" v0="39" v1="73" v2="74"/>
> > + <triangle index="86" v0="41" v1="43" v2="75"/>
> > + <triangle index="87" v0="41" v1="74" v2="75"/>
> > + <triangle index="88" v0="43" v1="45" v2="76"/>
> > + <triangle index="89" v0="43" v1="75" v2="76"/>
> > + <triangle index="90" v0="45" v1="47" v2="77"/>
> > + <triangle index="91" v0="45" v1="76" v2="77"/>
> > + <triangle index="92" v0="47" v1="48" v2="78"/>
> > + <triangle index="93" v0="47" v1="77" v2="78"/>
> > + <triangle index="94" v0="48" v1="49" v2="79"/>
> > + <triangle index="95" v0="48" v1="78" v2="79"/>
> > + <triangle index="96" v0="49" v1="50" v2="80"/>
> > + <triangle index="97" v0="49" v1="79" v2="80"/>
> > + <triangle index="98" v0="50" v1="52" v2="81"/>
> > + <triangle index="99" v0="50" v1="80" v2="81"/>
> > + <triangle index="100" v0="52" v1="54" v2="82"/>
> > + <triangle index="101" v0="52" v1="81" v2="82"/>
> > + <triangle index="102" v0="54" v1="56" v2="83"/>
> > + <triangle index="103" v0="54" v1="82" v2="83"/>
> > + <triangle index="104" v0="56" v1="58" v2="84"/>
> > + <triangle index="105" v0="56" v1="83" v2="84"/>
> > + <triangle index="106" v0="58" v1="60" v2="85"/>
> > + <triangle index="107" v0="58" v1="84" v2="85"/>
> > + <triangle index="108" v0="60" v1="62" v2="86"/>
> > + <triangle index="109" v0="60" v1="85" v2="86"/>
> > + <triangle index="110" v0="62" v1="64" v2="87"/>
> > + <triangle index="111" v0="62" v1="86" v2="87"/>
> > + <triangle index="112" v0="64" v1="66" v2="88"/>
> > + <triangle index="113" v0="64" v1="87" v2="88"/>
> > + <triangle index="114" v0="66" v1="68" v2="89"/>
> > + <triangle index="115" v0="66" v1="88" v2="89"/>
> > + <triangle index="116" v0="78" v1="79" v2="90"/>
> > + <triangle index="117" v0="78" v1="90" v2="91"/>
> > + <triangle index="118" v0="79" v1="80" v2="92"/>
> > + <triangle index="119" v0="79" v1="90" v2="92"/>
> > + <triangle index="120" v0="90" v1="91" v2="93"/>
> > + <triangle index="121" v0="91" v1="93" v2="94"/>
> > + <triangle index="122" v0="90" v1="92" v2="95"/>
> > + <triangle index="123" v0="90" v1="93" v2="95"/>
> > + <triangle index="124" v0="93" v1="94" v2="96"/>
> > + <triangle index="125" v0="94" v1="96" v2="97"/>
> > + <triangle index="126" v0="93" v1="95" v2="98"/>
> > + <triangle index="127" v0="93" v1="96" v2="98"/>
> > + <triangle index="128" v0="96" v1="97" v2="99"/>
> > + <triangle index="129" v0="97" v1="99" v2="100"/>
> > + <triangle index="130" v0="96" v1="98" v2="101"/>
> > + <triangle index="131" v0="96" v1="99" v2="101"/>
> > + <triangle index="132" v0="99" v1="100" v2="102"/>
> > + <triangle index="133" v0="100" v1="102" v2="103"/>
> > + <triangle index="134" v0="99" v1="101" v2="104"/>
> > + <triangle index="135" v0="99" v1="102" v2="104"/>
> > + <triangle index="136" v0="102" v1="103" v2="105"/>
> > + <triangle index="137" v0="103" v1="105" v2="106"/>
> > + <triangle index="138" v0="102" v1="104" v2="107"/>
> > + <triangle index="139" v0="102" v1="105" v2="107"/>
> > + <triangle index="140" v0="105" v1="106" v2="108"/>
> > + <triangle index="141" v0="106" v1="108" v2="109"/>
> > + <triangle index="142" v0="105" v1="107" v2="110"/>
> > + <triangle index="143" v0="105" v1="108" v2="110"/>
> > + <triangle index="144" v0="108" v1="109" v2="111"/>
> > + <triangle index="145" v0="109" v1="111" v2="112"/>
> > + <triangle index="146" v0="108" v1="110" v2="113"/>
> > + <triangle index="147" v0="108" v1="111" v2="113"/>
> > + <triangle index="148" v0="111" v1="112" v2="114"/>
> > + <triangle index="149" v0="112" v1="114" v2="115"/>
> > + <triangle index="150" v0="111" v1="113" v2="116"/>
> > + <triangle index="151" v0="111" v1="114" v2="116"/>
> > + </cells>
> > + <data>
> > + <data_entry name="global vertex indices">
> > + <meshfunction type="uint" dim="0" size="117">
> > + <entity index="0" value="429"/>
> > + <entity index="1" value="430"/>
> > + <entity index="2" value="471"/>
> > + <entity index="3" value="470"/>
> > + <entity index="4" value="431"/>
> > + <entity index="5" value="472"/>
> > + <entity index="6" value="512"/>
> > + <entity index="7" value="511"/>
> > + <entity index="8" value="513"/>
> > + <entity index="9" value="553"/>
> > + <entity index="10" value="552"/>
> > + <entity index="11" value="554"/>
> > + <entity index="12" value="594"/>
> > + <entity index="13" value="593"/>
> > + <entity index="14" value="595"/>
> > + <entity index="15" value="635"/>
> > + <entity index="16" value="634"/>
> > + <entity index="17" value="636"/>
> > + <entity index="18" value="676"/>
> > + <entity index="19" value="675"/>
> > + <entity index="20" value="677"/>
> > + <entity index="21" value="717"/>
> > + <entity index="22" value="716"/>
> > + <entity index="23" value="718"/>
> > + <entity index="24" value="758"/>
> > + <entity index="25" value="757"/>
> > + <entity index="26" value="759"/>
> > + <entity index="27" value="799"/>
> > + <entity index="28" value="798"/>
> > + <entity index="29" value="800"/>
> > + <entity index="30" value="789"/>
> > + <entity index="31" value="790"/>
> > + <entity index="32" value="831"/>
> > + <entity index="33" value="830"/>
> > + <entity index="34" value="791"/>
> > + <entity index="35" value="832"/>
> > + <entity index="36" value="792"/>
> > + <entity index="37" value="833"/>
> > + <entity index="38" value="793"/>
> > + <entity index="39" value="834"/>
> > + <entity index="40" value="794"/>
> > + <entity index="41" value="835"/>
> > + <entity index="42" value="795"/>
> > + <entity index="43" value="836"/>
> > + <entity index="44" value="796"/>
> > + <entity index="45" value="837"/>
> > + <entity index="46" value="797"/>
> > + <entity index="47" value="838"/>
> > + <entity index="48" value="839"/>
> > + <entity index="49" value="840"/>
> > + <entity index="50" value="841"/>
> > + <entity index="51" value="801"/>
> > + <entity index="52" value="842"/>
> > + <entity index="53" value="802"/>
> > + <entity index="54" value="843"/>
> > + <entity index="55" value="803"/>
> > + <entity index="56" value="844"/>
> > + <entity index="57" value="804"/>
> > + <entity index="58" value="845"/>
> > + <entity index="59" value="805"/>
> > + <entity index="60" value="846"/>
> > + <entity index="61" value="806"/>
> > + <entity index="62" value="847"/>
> > + <entity index="63" value="807"/>
> > + <entity index="64" value="848"/>
> > + <entity index="65" value="808"/>
> > + <entity index="66" value="849"/>
> > + <entity index="67" value="809"/>
> > + <entity index="68" value="850"/>
> > + <entity index="69" value="872"/>
> > + <entity index="70" value="871"/>
> > + <entity index="71" value="873"/>
> > + <entity index="72" value="874"/>
> > + <entity index="73" value="875"/>
> > + <entity index="74" value="876"/>
> > + <entity index="75" value="877"/>
> > + <entity index="76" value="878"/>
> > + <entity index="77" value="879"/>
> > + <entity index="78" value="880"/>
> > + <entity index="79" value="881"/>
> > + <entity index="80" value="882"/>
> > + <entity index="81" value="883"/>
> > + <entity index="82" value="884"/>
> > + <entity index="83" value="885"/>
> > + <entity index="84" value="886"/>
> > + <entity index="85" value="887"/>
> > + <entity index="86" value="888"/>
> > + <entity index="87" value="889"/>
> > + <entity index="88" value="890"/>
> > + <entity index="89" value="891"/>
> > + <entity index="90" value="922"/>
> > + <entity index="91" value="921"/>
> > + <entity index="92" value="923"/>
> > + <entity index="93" value="963"/>
> > + <entity index="94" value="962"/>
> > + <entity index="95" value="964"/>
> > + <entity index="96" value="1004"/>
> > + <entity index="97" value="1003"/>
> > + <entity index="98" value="1005"/>
> > + <entity index="99" value="1045"/>
> > + <entity index="100" value="1044"/>
> > + <entity index="101" value="1046"/>
> > + <entity index="102" value="1086"/>
> > + <entity index="103" value="1085"/>
> > + <entity index="104" value="1087"/>
> > + <entity index="105" value="1127"/>
> > + <entity index="106" value="1126"/>
> > + <entity index="107" value="1128"/>
> > + <entity index="108" value="1168"/>
> > + <entity index="109" value="1167"/>
> > + <entity index="110" value="1169"/>
> > + <entity index="111" value="1209"/>
> > + <entity index="112" value="1208"/>
> > + <entity index="113" value="1210"/>
> > + <entity index="114" value="1250"/>
> > + <entity index="115" value="1249"/>
> > + <entity index="116" value="1251"/>
> > + </meshfunction>
> > + </data_entry>
> > + </data>
> > + </mesh>
> > +</dolfin>
> >
> > === added file 'nitsche_method/data/meshes/rotor_cavity.geo'
> > --- nitsche_method/data/meshes/rotor_cavity.geo 1970-01-01 00:00:00 +0000
> > +++ nitsche_method/data/meshes/rotor_cavity.geo 2010-03-16 14:39:09
+0000
> > @@ -0,0 +1,82 @@
> > +//This file defines start geometry for the driven rotor in the cavity
> > problem. +
> > +lb = 0.5;
> > +lc = 0.3;
> > +
> > +// This variable can then be used in the definition of Gmsh's simplest
> > +// `elementary entity', a `Point'. A Point is defined by a list of
> > +// four numbers: three coordinates (X, Y and Z), and a characteristic
> > +// length (lc) that sets the target element size at the point:
> > +
> > +//Cavity geometry
> > +H = 2.0;
> > +
> > +Point(1) = {-H, -H, 0, lb};
> > +Point(2) = {H, -H, 0, lb};
> > +Point(3) = {H, H, 0, lb};
> > +Point(4) = {-H, H, 0, lb};
> > +
> > +Line(1) = {1, 2};
> > +Line(2) = {2, 3};
> > +Line(3) = {3, 4};
> > +Line(4) = {4, 1};
> > +
> > +Line Loop(5) = {1,2,3,4};
> > +
> > +//Physical Point(1) = {1,2,3,4};
> > +//Physical Line(1) = {5};
> > +
> > +
> > +//Rotor geometry
> > +h = 0.1;
> > +l = 1.0;
> > +
> > +//Point(5) = {-h,-h,0,lc};
> > +//Point(6) = {h,-h,0,lc};
> > +//Point(7) = {h,h,0,lc};
> > +//Point(8) = {-h,h,0,lc};
> > +//
> > +//Line(6) = {5,6};
> > +//Line(7) = {6,7};
> > +//Line(8) = {7,8};
> > +//Line(9) = {8,5};
> > +//
> > +//Line Loop(10) = {6,7,8,9};
> > +//Plane Surface(101) = {10};
> > +//Plane Surface(100) = {10};
> > +//Plane Surface(200) = {5,10};
> > +
> > +Point(5) = {h,h,0,lc};
> > +Point(6) = {h,l,0,lc};
> > +Point(7) = {-h,l,0,lc};
> > +Point(8) = {-h,h,0,lc};
> > +Point(9) = {-l,h,0,lc};
> > +Point(10) = {-l,-h,0,lc};
> > +Point(11) = {-h,-h,0,lc};
> > +Point(12) = {-h,-l,0,lc};
> > +Point(13) = {h,-l,0,lc};
> > +Point(14) = {h,-h,0,lc};
> > +Point(15) = {l,-h,0,lc};
> > +Point(16) = {l,h,0,lc};
> > +
> > +Line(6) = {5,6};
> > +Line(7) = {6,7};
> > +Line(8) = {7,8};
> > +Line(9) = {8,9};
> > +Line(10) = {9,10};
> > +Line(11) = {10,11};
> > +Line(12) = {11,12};
> > +Line(13) = {12,13};
> > +Line(14) = {13,14};
> > +Line(15) = {14,15};
> > +Line(16) = {14,15};
> > +Line(17) = {15,16};
> > +Line(18) = {16,5};
> > +
> > +Line Loop(19) = {6,7,8,9,10,11,12,13,14,15,16,17,18};
> > +
> > +//Physical Point(2) = {6,7,8,9,10,11,12,13,14,15,16,17,18};
> > +//Physical Line(2) = {19};
> > +
> > +Plane Surface(100) = {19};
> > +Plane Surface(101) = {5,19};
> >
> > === added directory 'nitsche_method/entity_intersection'
> > === added file 'nitsche_method/entity_intersection/SConstruct'
> > --- nitsche_method/entity_intersection/SConstruct 1970-01-01 00:00:00
> > +0000 +++ nitsche_method/entity_intersection/SConstruct 2010-02-10
> > 03:14:09 +0000 @@ -0,0 +1,16 @@
> > +# This is an example of a simple SConstruct file for building
> > +# programs against DOLFIN. To build this demo, just type 'scons'.
> > +
> > +import os, commands
> > +
> > +# Get compiler from pkg-config
> > +compiler = commands.getoutput('pkg-config --variable=compiler dolfin')
> > +
> > +# Create a SCons Environment based on the main os environment
> > +env = Environment(ENV=os.environ, CXX=compiler)
> > +
> > +# Get compiler flags from pkg-config
> > +env.ParseConfig('pkg-config --cflags --libs dolfin')
> > +
> > +#env.Program(['tetrahedron_triangle_intersection_test.cpp'])
> > +env.Program(['primitive_intersector_test.cpp'])
> >
> > === added file
> > 'nitsche_method/entity_intersection/primitive_intersector_test.cpp' ---
> > nitsche_method/entity_intersection/primitive_intersector_test.cpp
1970-0
> > 1-01 00:00:00 +0000 +++
> > nitsche_method/entity_intersection/primitive_intersector_test.cpp
2010-0
> > 3-05 23:36:16 +0000 @@ -0,0 +1,40 @@
> > +//
> > ========================================================================
> > ============= +//
> > +// Copyright (C) 2010-02-10 André Massing
> > +// Licensed under the GNU LGPL Version 2.1.
> > +//
> > +// Modified by André Massing, 2010
> > +//
> > +// First added: 2010-02-10
> > +// Last changed: 2010-02-22
> > +//
> > +//Author: André Massing (am), massing@xxxxxxxxx
> > +//Company: Simula Research Laboratory, Fornebu, Norway
> > +//
> > +//
> > ========================================================================
> > ============= +
> > +#include <dolfin/mesh/dolfin_mesh.h>
> > +#include <iostream>
> > +
> > +using namespace dolfin;
> > +
> > +int main ()
> > +{
> > + UnitCube cube(3,3,2);
> > + cout <<"Total number of cells in Cube:" << cube.num_cells() <<endl;
> > +
> > + UnitSphere sphere(3);
> > + cout <<"Total number of cells in Sphere:" << sphere.num_cells()
> > <<endl; +
> > + for (CellIterator cube_cell(cube); !cube_cell.end(); ++cube_cell)
> > + {
> > + for (CellIterator sphere_cell(cube); !sphere_cell.end();
> > ++sphere_cell) + {
> > + if (PrimitiveIntersector::do_intersect(*cube_cell, *sphere_cell))
> > + std::cout <<"Cell number " << cube_cell->index() << " intersects with
"
> > + <<"Cell number " << sphere_cell->index() << std::endl;
> > + }
> > + }
> > +
> > + return 0;
> > +}
> >
> > === added directory 'nitsche_method/integration_on_complex_domains'
> > === added directory
> > 'nitsche_method/integration_on_complex_domains/gauss_projection_green'
> > === added file
> > 'nitsche_method/integration_on_complex_domains/gauss_projection_green/Ba
> > ryCenterQuadrature.cpp' ---
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/Bar
> > yCenterQuadrature.cpp 1970-01-01 00:00:00 +0000 +++
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/Bar
> > yCenterQuadrature.cpp 2010-04-01 10:43:19 +0000 @@ -0,0 +1,270 @@
> > +//
> > ========================================================================
> > ============= +//
> > +// Copyright (C) 2010-03-17 André Massing
> > +// Licensed under the GNU LGPL Version 2.1.
> > +//
> > +// Modified by André Massing, 2010
> > +//
> > +// First added: 2010-03-17
> > +// Last changed: 2010-04-01
> > +//
> > +//Author: André Massing (am), massing@xxxxxxxxx
> > +//Company: Simula Research Laboratory, Fornebu, Norway
> > +//Remark: This is an adapted version of Brian Mirtichs original C code
> > for +//computin polyhedral mass properties, which can be found at
> > <web-address> +//
> > ========================================================================
> > ============= +
> > +#include "BaryCenterQuadrature.h"
> > +#include <math.h>
> > +
> > +#define X 0
> > +#define Y 1
> > +#define Z 2
> > +#define SQR(x) ((x)*(x))
> > +#define CUBE(x) ((x)*(x)*(x))
> > +
> > +
> > +using std::sqrt;
> > +using namespace dolfin;
> > +
> > +
> > +void BaryCenterQuadrature::compute_quadrature_rule(const
> > Nef_polyhedron_3 & polyhedron) +{
> > + //coordinates of the bary center
> > + double bary_center [3] = {0,0,0};
> > +
> > + _weight = 0;
> > +
> > + //determine if polyhedron has a non vanishing 3d measure.
> > + //This requires to have volumes marked with one.
> > + bool has_volume = false;
> > + Nef_polyhedron_3::Volume_const_iterator vi;
> > + CGAL_forall_volumes(vi,polyhedron)
> > + {
> > + std::cout <<"vi->mark: " << vi->mark() <<std::endl;
> > + if(vi->mark())
> > + {
> > + has_volume = true;
> > + break;
> > + }
> > + }
> > +
> > + //variables needing during the computation
> > + //components of surface normal
> > + double nx, ny, nz;
> > + double normal [3] = {0,0,0};
> > +
> > + //start and end point of the edge
> > + double source[3] = {0,0,0};
> > + double target[3] = {0,0,0};
> > +
> > + //permutation of the coordinates X,Y,Z
> > + int A,B,C;
> > +
> > + std::cout <<" Number of volumes :" << polyhedron.number_of_volumes()
> > << std::endl; + std::cout << "Outer iteration along faces, next f \n";
> > + std::cout <<"++++++++++++++++++++++++++++++++++++++++" << std::endl;
> > +
> > + std::cout << "Polyhedron is 2d Manifold: " <<
> > const_cast<Nef_polyhedron_3 &>(polyhedron).is_simple() << std::endl; +
> > + for(Nef_polyhedron_3::Halffacet_const_iterator f =
> > polyhedron.halffacets_begin (), + end = polyhedron.halffacets_end();
> > + f != end; ++f)
> > + {
> > + if (f->incident_volume()->mark() || (!has_volume && f->is_twin()))
> > + {
> > + //compute best projection direction.
> > + //get normal of the surface and the offset
> > + //FIXME: check right orientation
> > + Plane_3 face_plane = f->plane();
> > + Vector_3 test_normal = face_plane.orthogonal_vector();
> > + nx = CGAL::to_double(face_plane.a());
> > + ny = CGAL::to_double(face_plane.b());
> > + nz = CGAL::to_double(face_plane.c());
> > +
> > + double normal_length = sqrt(nx*nx + ny*ny + nz*nz);
> > + normal[0] = nx/normal_length;
> > + normal[1] = ny/normal_length;
> > + normal[2] = nz/normal_length;
> > +
> > + nx = fabs(nx);
> > + ny = fabs(ny);
> > + nz = fabs(nz);
> > +
> > + //Choose permutation to get best conditioned projection
> > direction. + if (nx > ny && nx > nz)
> > + C = X;
> > + else
> > + C = (ny > nz) ? Y : Z;
> > + A = (C + 1) % 3;
> > + B = (A + 1) % 3;
> > +
> > + //begin compute the face integrals
> > + //begin compute the projection integrals
> > + double a0, a1, da;
> > + double b0, b1, db;
> > + double a0_2, b0_2;
> > + double a0_3, b0_3;
> > + double a0_4, b0_4;
> > + double a1_2, b1_2;
> > + double C1, Ca, Caa, Cb, Cbb, Cab;
> > + double Kab;
> > + double P1, Pa, Pb, Paa, Pbb, Pab;
> > + P1 = Pa = Pb = Paa = Pab = Pbb = 0.0;
> > + double Fa, Fb, Fc, Faa, Fbb, Fcc;
> > +
> > + for(Nef_polyhedron_3::Halffacet_cycle_const_iterator fc =
> > f->facet_cycles_begin(); + fc != f->facet_cycles_end(); ++fc)
> > + {
> > + //exclude a SHalfloops (whatever this is)
> > + if ( fc.is_shalfedge() )
> > + {
> > + Nef_polyhedron_3::SHalfedge_const_handle h = fc;
> > + Nef_polyhedron_3::SHalfedge_around_facet_const_circulator hc(h);
> > + Nef_polyhedron_3::SHalfedge_around_facet_const_circulator he(hc);
> > + CGAL_For_all(hc,he)
> > + {
> > + std::cout <<"----------------------------------------" <<
> > std::endl; +
> > + Nef_polyhedron_3::SVertex_const_handle v = hc->source();
> > +
> > + const Point_3 & source_point(v->source()->point());
> > + const Point_3 & target_point(v->target()->point());
> > + std::cout <<"Source point " << source_point << std::endl;
> > + std::cout <<"Target point " << target_point <<std::endl;
> > +
> > + source[0] = CGAL::to_double(source_point.x());
> > + source[1] = CGAL::to_double(source_point.y());
> > + source[2] = CGAL::to_double(source_point.z());
> > +
> > + target[0] = CGAL::to_double(target_point.x());
> > + target[1] = CGAL::to_double(target_point.y());
> > + target[2] = CGAL::to_double(target_point.z());
> > +
> > + a0 = source[A];
> > + b0 = source[B];
> > + a1 = target[A];
> > + b1 = target[B];
> > +
> > + da = a1 - a0;
> > + db = b1 - b0;
> > +
> > + a0_2 = a0 * a0;
> > + a0_3 = a0_2 * a0;
> > + a0_4 = a0_3 * a0;
> > + a1_2 = a1 * a1;
> > + b0_2 = b0 * b0;
> > + b0_3 = b0_2 * b0;
> > + b0_4 = b0_3 * b0;
> > + b1_2 = b1 * b1;
> > +
> > + C1 = a1 + a0;
> > + Ca = a1*C1 + a0_2;
> > + Caa = a1*Ca + a0_3;
> > + Cb = b1*(b1 + b0) + b0_2;
> > + Cbb = b1*Cb + b0_3;
> > + Cab = 3*a1_2 + 2*a1*a0 + a0_2;
> > + Kab = a1_2 + 2*a1*a0 + 3*a0_2;
> > +
> > + P1 += db*C1;
> > + Pa += db*Ca;
> > + Paa += db*Caa;
> > + Pb += da*Cb;
> > + Pbb += da*Cbb;
> > + Pab += db*(b1*Cab + b0*Kab);
> > + }
> > + std::cout <<"----------------------------------------" <<
std::endl;
> > + }
> > + }
> > +
> > + P1 /= 2.0;
> > + Pa /= 6.0;
> > + Paa /= 12.0;
> > + Pb /= -6.0;
> > + Pbb /= -12.0;
> > + Pab /= 24.0;
> > +
> > + info("P1 : %e",P1);
> > + info("Pa : %e",Pa);
> > + info("Paa : %e",Paa);
> > + info("Pb : %e",Pb);
> > + info("Pbb : %e",Pbb);
> > + info("Pab : %e",Pab);
> > +
> > + double k1, k2, k3;
> > + k1 = 1 / normal[C]; k2 = k1 * k1; k3 = k2 * k1;
> > + double w = CGAL::to_double(face_plane.d())/normal_length ;
> > + info("Normal[0] : %e ", normal[0]);
> > + info("Normal[1] : %e ", normal[1]);
> > + info("Normal[2] : %e ", normal[2]);
> > + info("w : %e ", w);
> > +
> > + Fa = k1 * Pa;
> > + Fb = k1 * Pb;
> > + Fc = -k2 * (normal[A]*Pa + normal[B]*Pb + w*P1);
> > +
> > + //debug
> > + Faa = k1 * Paa;
> > + Fbb = k1 * Pbb;
> > + Fcc = k3 * (SQR(normal[A])*Paa + 2*normal[A]*normal[B]*Pab +
> > SQR(normal[B])*Pbb + + w*(2*(normal[A]*Pa + normal[B]*Pb) +
w*P1));
> > +
> > + info("Fa : %e",Fa);
> > + info("Fb : %e",Fb);
> > + info("Fc : %e",Fc);
> > + info("Faa : %e",Faa);
> > + info("Fbb : %e",Fbb);
> > + info("Fcc : %e",Fcc);
> > + //end computation face integrals
> > +
> > + if (has_volume)
> > + {
> > + double contribution = (normal[X] * ((A == X) ? Fa : ((B == X) ? Fb :
> > Fc))); + info("Contribution: %e", contribution);
> > + info("Normal[X]: %e", normal[X]);
> > + info("A: %d", A);
> > + info("B: %d", B);
> > + info("C: %d", C);
> > + _weight += normal[X] * ((A == X) ? Fa : ((B == X) ? Fb : Fc));
> > + info("Volume: %e", _weight);
> > +
> > + bary_center[A] += normal[A] * Faa;
> > + bary_center[B] += normal[B] * Fbb;
> > + bary_center[C] += normal[C] * Fcc;
> > + }
> > + else
> > + {
> > + info("No volume: P1 is %e",P1);
> > + info("No volume: normal[C] is %e", normal[C]);
> > + //does not work yet
> > + //@todo does not work yet.
> > + _weight += -P1/normal[C];
> > + info("No volume: weight is %e", _weight);
> > + info("Fa : %e",Fa);
> > + info("Fb : %e",Fb);
> > + info("Fc : %e",Fc);
> > + bary_center[A] += -Fa;
> > + bary_center[B] += -Fb;
> > + bary_center[C] += -Fc;
> > + }
> > + }
> > + }
> > +
> > + //applies also if polyhedron has no no volume, since
> > + //we no iterating two times (each halffacet).
> > + if (has_volume)
> > + {
> > + bary_center[X] /= (2*_weight);
> > + bary_center[Y] /= (2*_weight);
> > + bary_center[Z] /= (2*_weight);
> > + }
> > + else
> > + {
> > + bary_center[X] /= _weight;
> > + bary_center[Y] /= _weight;
> > + bary_center[Z] /= _weight;
> > + }
> > +
> > + //use these later directly.
> > + _point = Point(3,bary_center);
> > +}
> >
> > === added file
> > 'nitsche_method/integration_on_complex_domains/gauss_projection_green/Ba
> > ryCenterQuadrature.h' ---
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/Bar
> > yCenterQuadrature.h 1970-01-01 00:00:00 +0000 +++
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/Bar
> > yCenterQuadrature.h 2010-04-01 10:43:19 +0000 @@ -0,0 +1,69 @@
> > +//
> > ========================================================================
> > ============= +//
> > +// Copyright (C) 2010-03-17 André Massing
> > +// Licensed under the GNU LGPL Version 2.1.
> > +//
> > +// Modified by André Massing, 2010
> > +//
> > +// First added: 2010-03-17
> > +// Last changed: 2010-03-30
> > +//
> > +//Author: André Massing (am), massing@xxxxxxxxx
> > +//Company: Simula Research Laboratory, Fornebu, Norway
> > +//
> > +//
> > ========================================================================
> > ============= +
> > +#ifndef __BARYCENTERQUADRATURE_H
> > +#define __BARYCENTERQUADRATURE_H
> > +
> > +#include <CGAL/Exact_predicates_exact_constructions_kernel.h>
> > +
> > +#include <CGAL/Nef_polyhedron_3.h>
> > +#include <CGAL/Polyhedron_3.h>
> > +
> > +#include <dolfin/mesh/Point.h>
> > +
> > +namespace dolfin {
> > +
> > + typedef CGAL::Exact_predicates_exact_constructions_kernel Kernel;
> > + typedef CGAL::Polyhedron_3<Kernel> Polyhedron_3;
> > + typedef CGAL::Nef_polyhedron_3<Kernel> Nef_polyhedron_3;
> > + typedef Nef_polyhedron_3::Point_3 Point_3;
> > + typedef Nef_polyhedron_3::Plane_3 Plane_3;
> > + typedef Nef_polyhedron_3::Vector_3 Vector_3;
> > +
> > + ///This class computes the barycenter of an arbitrary polyhedron or
> > + ///polygon and therefore allows for bary center quadrature on complex
> > + ///polyhedrons. Note: barycenter quadrature is exact for polynom deg
> > <= 1. + class BaryCenterQuadrature {
> > +
> > + public:
> > +
> > + BaryCenterQuadrature() : _weight(0), _point(0,0,0), _length(1) {}
> > +
> > + ///@todo split the ugly implementation up into some subroutines and
> > removes + //all the macro etc stuff. Make also working polyhedrons
> > which are + //degenerated.
> > + void compute_quadrature_rule(const Nef_polyhedron_3 & polyhedron);
> > +
> > + //return pointer
> > + ///Gives the points for the last computed Polyhedron.
> > + Point * points() {return &_point;}
> > + ///Gives the weights for the last computed Polyhedron.
> > + double * weights() {return &_weight; }
> > +
> > + ///Number of quadrature points/weights.
> > + uint length() {return _length;}
> > +
> > + private:
> > +
> > + double _weight;
> > + Point _point;
> > + uint _length;
> > +
> > +
> > + };
> > +
> > +}
> > +
> > +#endif // ----- #ifndef __BARYCENTERQUADRATURE_H -----
> >
> > === added file
> > 'nitsche_method/integration_on_complex_domains/gauss_projection_green/RE
> > ADME' ---
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/REA
> > DME 1970-01-01 00:00:00 +0000 +++
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/REA
> > DME 2010-03-18 18:15:26 +0000 @@ -0,0 +1,146 @@
> > +1. OVERVIEW
> > +
> > + This code accompanies the paper:
> > +
> > + Brian Mirtich, "Fast and Accurate Computation of
> > + Polyhedral Mass Properties," journal of graphics
> > + tools, volume 1, number 2, 1996.
> > +
> > + It computes the ten volume integrals needed for
> > + determining the center of mass, moments of
> > + inertia, and products of inertia for a uniform
> > + density polyhedron. From this information, a
> > + body frame can be computed.
> > +
> > + To compile the program, use an ANSI compiler, and
> > + type something like
> > +
> > + % cc volInt.c -O2 -lm -o volInt
> > +
> > +
> > + Revision history
> > +
> > + 26 Jan 1996 Program creation.
> > +
> > + 3 Aug 1996 Corrected bug arising when polyhedron density
> > + is not 1.0. Changes confined to function main().
> > + Thanks to Zoran Popovic for catching this one.
> > +
> > +
> > +
> > +2. POLYHEDRON GEOMETRY FILES
> > +
> > + The program reads a data file specified on the
> > + command line. This data file describes the
> > + geometry of a polyhedron, and has the following
> > + format:
> > +
> > + N
> > +
> > + x_0 y_0 z_0
> > + x_1 y_1 z_1
> > + .
> > + .
> > + .
> > + x_{N-1} y_{N-1} z_{N-1}
> > +
> > + M
> > +
> > + k1 v_{1,1} v_{1,2} ... v_{1,k1}
> > + k2 v_{2,1} v_{2,2} ... v_{2,k2}
> > + .
> > + .
> > + .
> > + kM v_{M,1} v_{M,2} ... v_{M,kM}
> > +
> > +
> > + where:
> > + N number of vertices on polyhedron
> > + x_i y_i z_i x, y, and z coordinates of ith vertex
> > + M number of faces on polyhedron
> > + ki number of vertices on ith face
> > + v_{i,j} jth vertex on ith face
> > +
> > + In English:
> > +
> > + First the number of vertices are specified. Next
> > + the vertices are defined by listing the 3
> > + coordinates of each one. Next the number of faces
> > + are specified. Finally, the faces themselves are
> > + specified. A face is specified by first giving
> > + the number of vertices around the polygonal face,
> > + followed by the (integer) indices of these
> > + vertices. When specifying indices, note that
> > + they must be given in counter-clockwise order
> > + (when looking at the face from outside the
> > + polyhedron), and the vertices are indexed from 0
> > + to N-1 for a polyhedron with N faces.
> > +
> > + White space can be inserted (or not) as desired.
> > + Three example polyhedron geometry files are included:
> > +
> > + cube A cube, 20 units on a side, centered at
> > + the origin and aligned with the coordinate axes.
> > +
> > + tetra A tetrahedron formed by taking the convex
> > + hull of the origin, and the points (5,0,0),
> > + (0,4,0), and (0,0,3).
> > +
> > + icosa An icosahedron with vertices lying on the unit
> > + sphere, centered at the origin.
> > +
> > +
> > +
> > +3. RUNNING THE PROGRAM
> > +
> > + Simply type,
> > +
> > + % volInt <polyhedron geometry filename>
> > +
> > + The program will read in the geometry of the
> > + polyhedron, and the print out the ten volume
> > + integrals.
> > +
> > + The program also computes some of the mass
> > + properties which may be inferred from the volume
> > + integrals. A density of 1.0 is assumed, although
> > + this may be changed in function main(). The
> > + center of mass is computed as well as the inertia
> > + tensor relative to a frame with origin at the
> > + center of mass. Note, however, that this matrix
> > + may not be diagonal. If not, a diagonalization
> > + routine must be performed, to determine the
> > + orientation of the true body frame relative to
> > + the original model frame. The Jacobi method
> > + works quite well (see Numerical Recipes in C by
> > + Press, et. al.).
> > +
> > +
> > +
> > +4. DISCLAIMERS
> > +
> > + 1. The volume integration code has been written
> > + to match the development and algorithms presented
> > + in the paper, and not with maximum optimization
> > + in mind. While inherently very efficient, a few
> > + more cycles can be squeezed out of the algorithm.
> > + This is left as an exercise. :)
> > +
> > + 2. Don't like global variables? The three
> > + procedures which evaluate the volume integrals
> > + can be combined into a single procedure with two
> > + nested loops. In addition to providing some
> > + speedup, all of the global variables can then be
> > + made local.
> > +
> > + 3. The polyhedron data structure used by the
> > + program is admittedly lame; much better schemes
> > + are possible. The idea here is just to give the
> > + basic integral evaluation code, which will have
> > + to be adjusted for other polyhedron data
> > + structures.
> > +
> > + 4. There is no error checking for the input
> > + files. Be careful. Note the hard limits
> > + #defined for the number of vertices, number of
> > + faces, and number of vertices per faces.
> >
> > === added file
> > 'nitsche_method/integration_on_complex_domains/gauss_projection_green/SC
> > onstruct' ---
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/SCo
> > nstruct 1970-01-01 00:00:00 +0000 +++
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/SCo
> > nstruct 2010-04-02 18:46:57 +0000 @@ -0,0 +1,22 @@
> > +import os, commands
> > +
> > +# Import("cppunitCfg")
> > +
> > +# Get compiler from pkg-config
> > +compiler = commands.getoutput('pkg-config --variable=compiler dolfin')
> > +
> > +# Create a SCons Environment based on the main os environment
> > +env = Environment(ENV=os.environ, CXX=compiler)
> > +
> > +env.Append(CXXFLAGS = '-ggdb')
> > +
> > +# Get compiler flags from pkg-config
> > +env.ParseConfig('pkg-config --cflags --libs dolfin')
> > +
> > +#Program
> > +env.Program('quadrature_test',['BaryCenterQuadrature.cpp','main.cpp'])
> > +env.Program('iteration_tetrahedron.cpp')
> > +env.Program('iteration_tetrahedron_2.cpp')
> > +
> > +env.Append(LIBS='-lcppunit')
> > +env.Program('unittest',['BaryCenterQuadrature.cpp','test.cpp'])
> >
> > === added file
> > 'nitsche_method/integration_on_complex_domains/gauss_projection_green/al
> > ut_snippet.cpp' ---
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/alu
> > t_snippet.cpp 1970-01-01 00:00:00 +0000 +++
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/alu
> > t_snippet.cpp 2010-03-18 18:15:26 +0000 @@ -0,0 +1,96 @@
> > +//
> > ========================================================================
> > ============= +//
> > +// Copyright (C) 2010-02-17 André Massing
> > +// Licensed under the GNU LGPL Version 2.1.
> > +//
> > +// Modified by André Massing, 2010
> > +//
> > +// First added: 2010-02-17
> > +// Last changed: 2010-02-17
> > +//
> > +//Author: André Massing (am), massing@xxxxxxxxx
> > +//Company: Simula Research Laboratory, Fornebu, Norway
> > +//
> > +//
> > ========================================================================
> > ============= +
> > +
> > +struct
> > +{
> > + Point_3 p1, p2, p3;
> > +}triangle;
> > +
> > +class Shell_explorer
> > +{
> > + bool first;
> > + const Nef_polyhedron& N;
> > + vector<triangle> m_triangle_list;
> > +
> > +public:
> > + Shell_explorer(const Nef_polyhedron& N_)
> > + : first(true), N(N_) {}
> > +
> > + void visit(Vertex_const_handle v){}
> > + void visit(Halfedge_const_handle ){}
> > + void visit(Halffacet_const_handle facet)
> > + {
> > + for (Halffacet_cycle_const_iterator it =
> > +facet->facet_cycles_begin(); it != facet->facet_cycles_end(); it++)
> > + {
> > + SHalfedge_const_handle se = SHalfedge_const_handle(it);
> > + CGAL_assertion(se!=0);
> > + SHalfedge_around_facet_const_circulator hc_start(se);
> > + SHalfedge_around_facet_const_circulator hc_end(hc_start);
> > + vector <Point_3> vertices;
> > + int count = 0;
> > + CGAL_For_all(hc_start,hc_end)
> > + {
> > + SVertex_const_handle svert = hc_start->source();
> > + Point_3 vpoint = svert->center_vertex()->point();
> > + vertices.push_back(vpoint);
> > + }
> > + for (int i=0; i<vertices.size()-2; i++)
> > + {
> > + triangle t;
> > + t.p1 = vertices[0];
> > + t.p3 = vertices[i+1];
> > + t.p2 = vertices[i+2];
> > + m_triangle_list.push_back(t);
> > + }
> > +
> > + }
> > + }
> > + void visit(SHalfedge_const_handle ) {}
> > + void visit(SHalfloop_const_handle ) {}
> > + void visit(SFace_const_handle sf) {}
> > +
> > + vector<triangle>getTriangleList()
> > + {
> > + vector<triangle> templist;
> > + for (int i=0; i<m_triangle_list.size(); i++)
> > + templist.push_back(m_triangle_list[i]);
> > + m_triangle_list.clear();
> > + return templist;
> > + }
> > + void reset_minimal_vertex() { first = true; }
> > +};
> > +
> > +Usage:
> > +void main()
> > +{
> > + Nef_polyhedron nPoly;
> > + Volume_const_iterator c;
> > + Shell_explorer SE(nPoly);
> > +
> > + CGAL_forall_volumes(c,nPoly)
> > + {
> > + Shell_entry_const_iterator it;
> > + int shellcount = 0;
> > + vector <triangle> temp;
> > + CGAL_forall_shells_of(it,c)
> > + {
> > + SE.reset_minimal_vertex();
> > + entrypaths.visit_shell_objects(SFace_const_handle(it),SE);
> > + vector<triangle> tris = SE.getTriangleList();
> > + }
> > + }
> > +}
> >
> > === added file
> > 'nitsche_method/integration_on_complex_domains/gauss_projection_green/cu
> > be' ---
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/cub
> > e 1970-01-01 00:00:00 +0000 +++
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/cub
> > e 2010-03-18 18:15:26 +0000 @@ -0,0 +1,21 @@
> > +8
> > +
> > +-10 -10 -10
> > ++10 -10 -10
> > ++10 +10 -10
> > +-10 +10 -10
> > +-10 -10 +10
> > ++10 -10 +10
> > ++10 +10 +10
> > +-10 +10 +10
> > +
> > +6
> > +
> > +4 0 3 2 1
> > +4 4 5 6 7
> > +4 0 1 5 4
> > +4 6 2 3 7
> > +4 1 2 6 5
> > +4 0 4 7 3
> > +
> > +
> >
> > === added file
> > 'nitsche_method/integration_on_complex_domains/gauss_projection_green/ic
> > osa' ---
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/ico
> > sa 1970-01-01 00:00:00 +0000 +++
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/ico
> > sa 2010-03-18 18:15:26 +0000 @@ -0,0 +1,38 @@
> > +12
> > +
> > ++0.00000000 +0.00000000 +1.00000000
> > ++0.00000000 +0.00000000 -1.00000000
> > ++0.89442719 +0.00000000 +0.44721360
> > ++0.27639320 +0.85065081 +0.44721360
> > +-0.72360680 +0.52573111 +0.44721360
> > +-0.72360680 -0.52573111 +0.44721360
> > ++0.27639320 -0.85065081 +0.44721360
> > ++0.72360680 +0.52573111 -0.44721360
> > +-0.27639320 +0.85065081 -0.44721360
> > +-0.89442719 +0.00000000 -0.44721360
> > +-0.27639320 -0.85065081 -0.44721360
> > ++0.72360680 -0.52573111 -0.44721360
> > +
> > +20
> > +
> > +3 6 11 2
> > +3 3 2 7
> > +3 7 2 11
> > +3 0 2 3
> > +3 0 6 2
> > +3 10 1 11
> > +3 1 7 11
> > +3 10 11 6
> > +3 8 7 1
> > +3 8 3 7
> > +3 5 10 6
> > +3 5 6 0
> > +3 4 3 8
> > +3 4 0 3
> > +3 9 8 1
> > +3 9 1 10
> > +3 4 5 0
> > +3 9 10 5
> > +3 9 5 4
> > +3 9 4 8
> > +
> >
> > === added file
> > 'nitsche_method/integration_on_complex_domains/gauss_projection_green/it
> > eration_tetrahedron.cpp' ---
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/ite
> > ration_tetrahedron.cpp 1970-01-01 00:00:00 +0000 +++
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/ite
> > ration_tetrahedron.cpp 2010-03-25 23:33:08 +0000 @@ -0,0 +1,58 @@
> > +#include <CGAL/Exact_predicates_exact_constructions_kernel.h>
> > +#include <CGAL/Nef_polyhedron_3.h>
> > +#include <CGAL/Polyhedron_3.h>
> > +
> > +typedef CGAL::Exact_predicates_exact_constructions_kernel Kernel;
> > +typedef CGAL::Polyhedron_3<Kernel> Polyhedron_3;
> > +typedef CGAL::Nef_polyhedron_3<Kernel> Nef_polyhedron_3;
> > +typedef Nef_polyhedron_3::Point_3 Point_3;
> > +
> > +int main()
> > +{
> > +
> > + Point_3 a(1.0, 0.0, 0.0);
> > + Point_3 b(0.0, 1.0, 0.0);
> > + Point_3 c(0.0, 0.0, 1.0);
> > + Point_3 d(0.0, 0.0, 0.0);
> > +
> > + //Build a tetrahedron
> > + Polyhedron_3 P;
> > + P.make_tetrahedron(a,b,c,d);
> > + Nef_polyhedron_3 NP(P);
> > +
> > + std::cout << "Iteration along face ...\n";
> > + int face_counter = 0;
> > + for(Nef_polyhedron_3::Halffacet_const_iterator f = NP.halffacets_begin
> > (), + end = NP.halffacets_end();
> > + f != end;
> > + ++f)
> > + {
> > + if(f->is_twin())
> > + continue;
> > + std::cout <<"########################################" << std::endl;
> > + std::cout << "Face number " << face_counter++ << std::endl;
> > + for(Nef_polyhedron_3::Halffacet_cycle_const_iterator fc =
> > f->facet_cycles_begin(), + cycles_end = f->facet_cycles_end();
> > + fc != cycles_end;
> > + ++fc)
> > + {
> > + if ( fc.is_shalfedge() )
> > + {
> > + std::cout <<"Edge consist of points: " << std::endl;
> > + Nef_polyhedron_3::SHalfedge_const_handle se = fc;
> > + Nef_polyhedron_3::SHalfedge_around_facet_const_circulator hc(se);
> > + Nef_polyhedron_3::SHalfedge_around_facet_const_circulator he(hc);
> > + CGAL_For_all(hc,he)
> > + {
> > + Nef_polyhedron_3::SVertex_const_handle v = hc->source();
> > +// Nef_polyhedron_3::Halfedge_const_handle v = hc->source();
> > + const Point_3 & source_point(v->source()->point());
> > + const Point_3 & target_point(v->target()->point());
> > + std::cout <<"Source point " << source_point << std::endl;
> > + std::cout <<"Target point " << target_point <<std::endl;
> > + }
> > + }
> > + }
> > + }
> > + return 0;
> > +}
> >
> > === added file
> > 'nitsche_method/integration_on_complex_domains/gauss_projection_green/it
> > eration_tetrahedron_2.cpp' ---
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/ite
> > ration_tetrahedron_2.cpp 1970-01-01 00:00:00 +0000 +++
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/ite
> > ration_tetrahedron_2.cpp 2010-04-01 10:43:19 +0000 @@ -0,0 +1,140 @@
> > +#include<vector>
> > +
> > +#include <CGAL/Exact_predicates_exact_constructions_kernel.h>
> > +#include <CGAL/Nef_polyhedron_3.h>
> > +#include <CGAL/Polyhedron_3.h>
> > +#include <CGAL/Gmpz.h>
> > +#include <CGAL/Homogeneous.h>
> > +
> > +typedef CGAL::Exact_predicates_exact_constructions_kernel Kernel;
> > +typedef CGAL::Polyhedron_3<Kernel> Polyhedron_3;
> > +typedef CGAL::Nef_polyhedron_3<Kernel> Nef_polyhedron_3;
> > + typedef Nef_polyhedron_3::Vector_3 Vector_3;
> > +typedef Nef_polyhedron_3::Point_3 Point_3;
> > +typedef Nef_polyhedron_3::Vertex_const_handle Vertex_const_handle;
> > +typedef Nef_polyhedron_3::Halfedge_const_handle Halfedge_const_handle;
> > +typedef Nef_polyhedron_3::Halffacet_const_handle Halffacet_const_handle;
> > +typedef Nef_polyhedron_3::Halffacet_cycle_const_iterator
> > Halffacet_cycle_const_iterator; +typedef
> > Nef_polyhedron_3::SHalfedge_const_handle SHalfedge_const_handle;
> > +typedef Nef_polyhedron_3::SHalfedge_around_facet_const_circulator
> > SHalfedge_around_facet_const_circulator; +typedef
> > Nef_polyhedron_3::SHalfloop_const_handle SHalfloop_const_handle;
> > +typedef Nef_polyhedron_3::SFace_const_handle SFace_const_handle;
> > +typedef Nef_polyhedron_3::Volume_const_iterator Volume_const_iterator;
> > +typedef Nef_polyhedron_3::Shell_entry_const_iterator
> > Shell_entry_const_iterator; +
> > +typedef std::vector<Nef_polyhedron_3> PolyhedronList;
> > +typedef PolyhedronList::const_iterator PolyhedronListIterator;
> > +
> > +class Shell_explorer
> > +{
> > + const Nef_polyhedron_3 & N;
> > +
> > +public:
> > + Shell_explorer(const Nef_polyhedron_3 & N_)
> > + : N(N_) {}
> > +
> > + void visit(Vertex_const_handle v) {}
> > + void visit(Halfedge_const_handle ){}
> > + void visit(Halffacet_const_handle facet)
> > + {
> > + std::cout << "Visting faces ..." << std::endl;
> > + std::cout <<"++++++++++++++++++++++++++++++++++++++++" << std::endl;
> > + Vector_3 test_normal = facet->plane().orthogonal_vector();
> > + std::cout <<"Normal vector of the plane is " << test_normal
> > <<std::endl; +
> > + for (Halffacet_cycle_const_iterator it =
> > + facet->facet_cycles_begin(); it != facet->facet_cycles_end(); it++)
> > + {
> > + std::cout << "Visting Edges ..." << std::endl;
> > + std::cout <<"----------------------------------------" <<
> > std::endl; + Nef_polyhedron_3::SHalfedge_const_handle h = it;
> > + Nef_polyhedron_3::SHalfedge_around_facet_const_circulator hc(h),
> > he(hc); + CGAL_For_all(hc,he)
> > + {
> > + Nef_polyhedron_3::SVertex_const_handle v = hc->source();
> > + const Nef_polyhedron_3::Point_3& source = v->source()->point();
> > + const Nef_polyhedron_3::Point_3& target = v->target()->point();
> > + std::cout <<"Source :" <<source <<std::endl;
> > + std::cout <<"Target :" <<target <<std::endl;
> > + }
> > + }
> > + }
> > + void visit(SHalfedge_const_handle ) {}
> > + void visit(SHalfloop_const_handle ) {}
> > + void visit(SFace_const_handle sf) {}
> > +
> > +};
> > +
> > +int main()
> > +{
> > + Point_3 a1(1.0, 0.0, 0.0);
> > + Point_3 b1(0.0, 1.0, 0.0);
> > + Point_3 c1(0.0, 0.0, 1.0);
> > + Point_3 d1(0.0, 0.0, 0.0);
> > +
> > + Point_3 a2(-1.0, 0.0, 0.0);
> > + Point_3 b2(0.0, 1.0, 0.0);
> > + Point_3 c2(0.0, 0.0, 1.0);
> > + Point_3 d2(0.0, 0.0, 0.0);
> > +
> > + Point_3 a3(1.0, 0.0, 0.0);
> > + Point_3 b3(0.0, -1.0, 0.0);
> > + Point_3 c3(0.0, 0.0, 1.0);
> > + Point_3 d3(0.0, 0.0, 0.0);
> > +
> > + Point_3 a4(-1.0, 0.0, 0.0);
> > + Point_3 b4(0.0, -1.0, 0.0);
> > + Point_3 c4(0.0, 0.0, 1.0);
> > + Point_3 d4(0.0, 0.0, 0.0);
> > +
> > + Point_3 A(2.0, 1.0, 1.0);
> > + Point_3 B(1.0, 2.0, 1.0);
> > + Point_3 C(1.0, 1.0, 2.0);
> > + Point_3 D(1.0, 1.0, 1.0);
> > +
> > + //Build a point tetrahedron
> > + Polyhedron_3 P1;
> > + P1.make_triangle(a1,b1,c1);
> > + Nef_polyhedron_3 N1(P1);
> > +
> > + Polyhedron_3 P2;
> > + P2.make_tetrahedron(a2,b2,c2,d2);
> > + Nef_polyhedron_3 N2(P2);
> > +
> > + Polyhedron_3 P3;
> > + P3.make_tetrahedron(a3,b3,c3,d3);
> > + Nef_polyhedron_3 N3(P3);
> > +
> > + Polyhedron_3 P4;
> > + P4.make_tetrahedron(a4,b4,c4,d4);
> > + Nef_polyhedron_3 N4(P4);
> > +
> > + PolyhedronList polyhedrons;
> > +
> > + polyhedrons.push_back(N1);
> > + polyhedrons.push_back(N2);
> > +
> > + //Build a point tetrahedron
> > + for (PolyhedronListIterator pi = polyhedrons.begin(), end =
> > polyhedrons.end(); + pi != end; ++pi)
> > + {
> > + Volume_const_iterator vi;
> > + Shell_explorer SE(*pi);
> > +
> > + std::cout <<"Next polyhedron:\n"
> > + << "##############################" <<std::endl;
> > + int ic = 0;
> > + CGAL_forall_volumes(vi,*pi)
> > + {
> > + std::cout << "Volume " << ic++ << " has mark " << vi->mark()<<
> > std::endl; +
> > + Shell_entry_const_iterator it;
> > + CGAL_forall_shells_of(it,vi)
> > + {
> > + pi->visit_shell_objects(SFace_const_handle(it),SE);
> > + }
> > + std::cout << "\n\n";
> > + }
> > + }
> > + return 0;
> > +}
> >
> > === added file
> > 'nitsche_method/integration_on_complex_domains/gauss_projection_green/ma
> > in.cpp' ---
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/mai
> > n.cpp 1970-01-01 00:00:00 +0000 +++
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/mai
> > n.cpp 2010-04-01 10:43:19 +0000 @@ -0,0 +1,190 @@
> > +//
> > ========================================================================
> > ============= +//
> > +// Copyright (C) 2010-03-19 André Massing
> > +// Licensed under the GNU LGPL Version 2.1.
> > +//
> > +// Modified by André Massing, 2010
> > +//
> > +// First added: 2010-03-19
> > +// Last changed: 2010-03-31
> > +//
> > +//Author: André Massing (am), massing@xxxxxxxxx
> > +//Company: Simula Research Laboratory, Fornebu, Norway
> > +//
> > +//
> > ========================================================================
> > ============= +
> > +#include "BaryCenterQuadrature.h"
> > +#include <dolfin.h>
> > +
> > +#include <iostream>
> > +#include<vector>
> > +
> > +using namespace dolfin;
> > +
> > +typedef std::vector<Nef_polyhedron_3> PolyhedronList;
> > +typedef PolyhedronList::const_iterator PolyhedronListIterator;
> > +
> > +
> > +using namespace dolfin;
> > +
> > +int main()
> > +{
> > +
> > + Point_3 e0(0.0, 0.0, 0.0);
> > +
> > + Point_3 e1(1.0, 0.0, 0.0);
> > + Point_3 e2(0.0, 1.0, 0.0);
> > + Point_3 e3(0.0, 0.0, 1.0);
> > +
> > + Point_3 _e1(-1.0, 0.0, 0.0);
> > + Point_3 _e2(0.0, -1.0, 0.0);
> > + Point_3 _e3(0.0, 0.0, -1.0);
> > +
> > + Point_3 A(2.0, 1.0, 1.0);
> > + Point_3 B(1.0, 2.0, 1.0);
> > + Point_3 C(1.0, 1.0, 2.0);
> > + Point_3 D(1.0, 1.0, 1.0);
> > +
> > + //Create tetrahedrons with unit vectors
> > + Polyhedron_3 P1;
> > + P1.make_tetrahedron(e0,e1,e2,e3);
> > + Nef_polyhedron_3 N1(P1);
> > +
> > + Polyhedron_3 P2;
> > + P2.make_tetrahedron(e0,_e1,e2,e3);
> > + Nef_polyhedron_3 N2(P2);
> > +
> > + Polyhedron_3 P3;
> > + P3.make_tetrahedron(e0,e1,_e2,e3);
> > + Nef_polyhedron_3 N3(P3);
> > +
> > + Polyhedron_3 P4;
> > + P4.make_tetrahedron(e0,_e1,_e2,e3);
> > + Nef_polyhedron_3 N4(P4);
> > +
> > + Polyhedron_3 P5;
> > + P5.make_tetrahedron(e0,e1,e2,_e3);
> > + Nef_polyhedron_3 N5(P5);
> > +
> > + Polyhedron_3 P6;
> > + P6.make_tetrahedron(e0,_e1,e2,_e3);
> > + Nef_polyhedron_3 N6(P6);
> > +
> > + Polyhedron_3 P7;
> > + P7.make_tetrahedron(e0,e1,_e2,_e3);
> > + Nef_polyhedron_3 N7(P7);
> > +
> > + Polyhedron_3 P8;
> > + P8.make_tetrahedron(e0,_e1,_e2,_e3);
> > + Nef_polyhedron_3 N8(P8);
> > +
> > + //Create triangles
> > + Polyhedron_3 P9;
> > + P9.make_triangle(e0,e1,e2);
> > + Nef_polyhedron_3 N9(P9);
> > +
> > + Polyhedron_3 P10;
> > + P10.make_triangle(e0,e1,e3);
> > + Nef_polyhedron_3 N10(P10);
> > +
> > + Polyhedron_3 P11;
> > + P11.make_triangle(e0,e2,e3);
> > + Nef_polyhedron_3 N11(P11);
> > +
> > + Polyhedron_3 P12;
> > + P12.make_triangle(e1,e2,e3);
> > + Nef_polyhedron_3 N12(P12);
> > +
> > + Polyhedron_3 P13;
> > + P13.make_triangle(e0,_e1,e2);
> > + Nef_polyhedron_3 N13(P13);
> > +
> > + Polyhedron_3 P14;
> > + P14.make_triangle(e0,_e1,e3);
> > + Nef_polyhedron_3 N14(P14);
> > +
> > + Polyhedron_3 P15;
> > + P15.make_triangle(e0,e2,e3);
> > + Nef_polyhedron_3 N15(P15);
> > +
> > + Polyhedron_3 P16;
> > + P16.make_triangle(_e1,e2,e3);
> > + Nef_polyhedron_3 N16(P16);
> > +
> > + PolyhedronList polyhedrons;
> > + PolyhedronList polygons;
> > +
> > + //single polyhedrons
> > + polyhedrons.push_back(N1);
> > + polyhedrons.push_back(N2);
> > + polyhedrons.push_back(N3);
> > + polyhedrons.push_back(N4);
> > + polyhedrons.push_back(N5);
> > + polyhedrons.push_back(N6);
> > + polyhedrons.push_back(N7);
> > + polyhedrons.push_back(N8);
> > +
> > + //combined tetrehedrons
> > + polyhedrons.push_back(N1 + N2);
> > + polyhedrons.push_back(N1 + N2 + N3);
> > + polyhedrons.push_back(N1 + N2 + N3 + N4);
> > +
> > + polyhedrons.push_back(N5 + N6);
> > + polyhedrons.push_back(N5 + N6 + N7);
> > + polyhedrons.push_back(N5 + N6 + N7 + N9);
> > +
> > + polyhedrons.push_back(N1 + N2 + N3 + N4 + N5 + N6 + N7 + N4);
> > +
> > + //polygons
> > + polygons.push_back(N9);
> > + polygons.push_back(N10);
> > + polygons.push_back(N11);
> > + polygons.push_back(N12);
> > + polygons.push_back(N13);
> > + polygons.push_back(N14);
> > + polygons.push_back(N15);
> > + polygons.push_back(N16);
> > +
> > + //combined polygons
> > + polygons.push_back(N9 + N10);
> > + polygons.push_back(N9 + N10 + N11);
> > + polygons.push_back(N9 + N10 + N11 + N12);
> > +
> > + polygons.push_back(N13 + N14);
> > + polygons.push_back(N13 + N14 + N15);
> > + polygons.push_back(N13 + N14 + N15 + N16);
> > +
> > + polygons.push_back(N9 + N10 + N11 + N12 + N13 + N14 + N15 + N12);
> > +
> > + BaryCenterQuadrature quadrature_rule;
> > +
> > + int counter = 0;
> > + std::cout << "Quadrature rule for Polyhdrons\n" ;
> > + std::cout <<"------------------------------\n";
> > + for (PolyhedronListIterator pi = polyhedrons.begin(), end =
> > polyhedrons.end(); + pi != end; ++pi)
> > + {
> > + cout <<"Next polyhedron: " << ++counter << endl
> > + << "##############################" <<endl;
> > + quadrature_rule.compute_quadrature_rule(*pi);
> > + cout <<"Volume: " << *(quadrature_rule.weights()) <<endl;
> > + cout <<"Barycenter: "
> > + << quadrature_rule.points()[0] << endl <<endl;
> > + }
> > +
> > + counter = 0;
> > + std::cout << "Quadrature rule for Polygons\n" ;
> > + std::cout <<"------------------------------\n";
> > + for (PolyhedronListIterator pi = polygons.begin(), end =
> > polygons.end(); + pi != end; ++pi)
> > + {
> > + cout <<"Next polygons: " << ++counter << endl
> > + << "##############################" <<endl;
> > + quadrature_rule.compute_quadrature_rule(*pi);
> > + cout <<"Volume: " << *(quadrature_rule.weights()) <<endl;
> > + cout <<"Barycenter: "
> > + << quadrature_rule.points()[0] << endl <<endl;
> > + }
> > +
> > + return 0;
> > +}
> >
> > === added file
> > 'nitsche_method/integration_on_complex_domains/gauss_projection_green/ma
> > rtin_baeker_snippet.cpp' ---
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/mar
> > tin_baeker_snippet.cpp 1970-01-01 00:00:00 +0000 +++
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/mar
> > tin_baeker_snippet.cpp 2010-03-18 18:15:26 +0000 @@ -0,0 +1,93 @@
> > +//
> > ========================================================================
> > ============= +//
> > +// Copyright (C) 2010-02-17 André Massing
> > +// Licensed under the GNU LGPL Version 2.1.
> > +//
> > +// Modified by André Massing, 2010
> > +//
> > +// First added: 2010-02-17
> > +// Last changed: 2010-02-17
> > +//
> > +//Author: André Massing (am), massing@xxxxxxxxx
> > +//Company: Simula Research Laboratory, Fornebu, Norway
> > +//
> > +//
> > ========================================================================
> > ============= +
> > + for(Nef_polyhedron::Halffacet_const_iterator
> > + f = Cube.halffacets_begin (),
> > + end = Cube.halffacets_end();
> > + f != end; ++f)
> > + {
> > + if(f->is_twin()) continue;
> > + std::cout << "Outer iteration, next f \n";
> > + for(Nef_polyhedron::Halffacet_cycle_const_iterator
> > + fc = f->facet_cycles_begin(),
> > + end = f->facet_cycles_end();
> > + fc != end; ++fc)
> > + {
> > + std::cout << "Inner iteration, next fc \n";
> > + if ( fc.is_shalfedge() )
> > + {
> > + std::cout << "Halfedge consists of points \n";
> > +
> > + Nef_polyhedron::SHalfedge_const_handle h = fc;
> > + Nef_polyhedron::SHalfedge_around_facet_const_circulator hc(h),
> > he(hc); + CGAL_For_all(hc,he)
> > + { // all vertex coordinates in facet cycle
> > + Nef_polyhedron::SVertex_const_handle v = hc->source();
> > + const Nef_polyhedron::Point_3& point = v->source()->point();
> > + std::cout << "p: " << CGAL::to_double(point.x()) << " " <<
> > + CGAL::to_double(point.y()) << " " <<
> > + CGAL::to_double(point.z()) << std::endl;
> > +
> > + }
> > +
> > + }
> > + }
> > +
> > + }
> > +
> > + // Alternative to iterating over halfedges:
> > +// Nef_polyhedron::Halfedge_const_iterator e =
> > Cube.halfedges_begin(); +// CGAL_forall_halfedges(e,Cube) {
> > +
> > +
> > + for(Nef_polyhedron::Halfedge_const_iterator
> > + e = Cube.halfedges_begin(),
> > + end = Cube.halfedges_end();
> > + e != end; ++e)
> > + {
> > + const Nef_polyhedron::Vertex_const_handle& s = e->source();
> > + const Nef_polyhedron::Vertex_const_handle& t = e->twin()->source();
> > + const Nef_polyhedron::Point_3& a = s->point();
> > + const Nef_polyhedron::Point_3& b = t->point();
> > + std::cout << "From a: " << CGAL::to_double(a.x()) << " " <<
> > + CGAL::to_double(a.y()) << " " <<
> > + CGAL::to_double(a.z()) << " to b: " <<
> > + CGAL::to_double(b.x()) << " " <<
> > + CGAL::to_double(b.y()) << " " <<
> > + CGAL::to_double(b.z()) <<std::endl;
> > + typedef Nef_polyhedron::Object_handle Object_handle;
> > + typedef Nef_polyhedron::Vertex_const_handle Vertex_const_handle;
> > + Vertex_const_handle v;
> > + Object_handle o = Cube.locate(a);
> > + if(CGAL::assign(v,o))
> > + std::cout << " a is a vertex" << std::endl;
> > + else
> > + std::cout << " a is not a vertex" << std::endl;
> > + }
> > +
> > +// Nef_polyhedron::Vertex_const_iterator v;
> > +
> > +// CGAL_forall_vertices(v, Cube.sncp())
> > + for(Nef_polyhedron::Vertex_const_iterator
> > + v = Cube.vertices_begin(),
> > + end = Cube.vertices_end();
> > + v != end; ++v)
> > + {
> > + const Nef_polyhedron::Point_3& a = v->point();
> > + std::cout << "Vertex: " << CGAL::to_double(a.x()) << " " <<
> > + CGAL::to_double(a.y()) << " " <<
> > + CGAL::to_double(a.z()) << std::endl;
> > +
> > + }
> >
> > === added file
> > 'nitsche_method/integration_on_complex_domains/gauss_projection_green/te
> > st.cpp' ---
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/tes
> > t.cpp 1970-01-01 00:00:00 +0000 +++
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/tes
> > t.cpp 2010-04-02 22:47:40 +0000 @@ -0,0 +1,598 @@
> > +//
> > ========================================================================
> > ============= +//
> > +// Copyright (C) 2010-04-01 André Massing
> > +// Licensed under the GNU LGPL Version 2.1.
> > +//
> > +// Modified by André Massing, 2010
> > +//
> > +// First added: 2010-04-01
> > +// Last changed: 2010-04-03
> > +//
> > +//Author: André Massing (am), massing@xxxxxxxxx
> > +//Company: Simula Research Laboratory, Fornebu, Norway
> > +//
> > +//Description: Unittest for BaryCenterQuadrature.
> > ========================================================================
> > ============= +
> > +#include<vector>
> > +#include <iostream>
> > +
> > +#include <dolfin.h>
> > +#include <dolfin/common/unittest.h>
> > +
> > +#include <CGAL/Nef_polyhedron_3.h>
> > +#include "BaryCenterQuadrature.h"
> > +
> > +using namespace dolfin;
> > +
> > +typedef Nef_polyhedron_3::Aff_transformation_3 Aff_transformation_3;
> > +
> > +typedef std::vector<Nef_polyhedron_3> PolyhedronList;
> > +typedef PolyhedronList::const_iterator PolyhedronListIterator;
> > +
> > +typedef std::vector<int> IntList;
> > +typedef std::vector<int>::const_iterator IntListIterator;
> > +typedef std::vector<double> DoubleList;
> > +typedef std::vector<double>::const_iterator DoubleListIterator;
> > +typedef std::vector<Point> PointList;
> > +typedef std::vector<Point>::const_iterator PointListIterator;
> > +
> > +class BaryCenter : public CppUnit::TestFixture
> > +{
> > + CPPUNIT_TEST_SUITE(BaryCenter);
> > + CPPUNIT_TEST(testSimplePolyhedrons);
> > + CPPUNIT_TEST(testSimplePolygons);
> > + CPPUNIT_TEST(testComplexPolyhedrons);
> > + CPPUNIT_TEST(testComplexPolygons);
> > + CPPUNIT_TEST_SUITE_END();
> > +
> > +
> > + void almost_equal_points(const Point & p1, const Point & p2, double
> > delta) + {
> > + CPPUNIT_ASSERT_DOUBLES_EQUAL(p1.x(),p2.x(),delta);
> > + CPPUNIT_ASSERT_DOUBLES_EQUAL(p1.y(),p2.y(),delta);
> > + CPPUNIT_ASSERT_DOUBLES_EQUAL(p1.z(),p2.z(),delta);
> > + }
> > +
> > + //Helper function to create reference polyhedrons.
> > + void add_test_polyhedron(const Point_3 & p1,
> > + const Point_3 & p2,
> > + const Point_3 & p3,
> > + const Point_3 & p4,
> > + PolyhedronList & polyhedrons
> > + )
> > + {
> > + Polyhedron_3 P;
> > + P.make_tetrahedron(p1,p2,p3,p4);
> > + Nef_polyhedron_3 N(P);
> > + polyhedrons.push_back(N);
> > + }
> > +
> > + void add_test_polyhedron(const Point_3 & p1,
> > + const Point_3 & p2,
> > + const Point_3 & p3,
> > + PolyhedronList & polyhedrons
> > + )
> > + {
> > + Polyhedron_3 P;
> > + P.make_triangle(p1,p2,p3);
> > + Nef_polyhedron_3 N(P);
> > + polyhedrons.push_back(N);
> > + }
> > +
> > + //Helper function to union disjoint polyhedrons and to compute the
> > volume and barycenter. + //Indices indicate which polyhedrons should be
> > unioned. No checks at all (index, disjointness etc) + //Computed
> > polyhedrons, volumes and barycenters will be append to the given list. +
> > void add_disjoint_polyhedrons(const IntList indices,
> > + PolyhedronList & polyhedrons,
> > + DoubleList & volumes,
> > + PointList & points)
> > + {
> > + double volume = 0;
> > + Point point(0,0,0);
> > + Nef_polyhedron_3 polyhedron;
> > +
> > + for (IntListIterator i = indices.begin(); i != indices.end(); ++i)
> > + {
> > + polyhedron += polyhedrons[*i];
> > + point += volumes[*i] * points[*i] ;
> > + volume += volumes[*i];
> > + }
> > + point /= volume;
> > +
> > + polyhedrons.push_back(polyhedron);
> > + volumes.push_back(volume);
> > + points.push_back(point);
> > + }
> > +
> > +
> > + void testSimplePolyhedrons()
> > + {
> > + //Create origin and unit vectors.
> > + Point_3 e0(0.0, 0.0, 0.0);
> > +
> > + Point_3 e1(1.0, 0.0, 0.0);
> > + Point_3 e2(0.0, 1.0, 0.0);
> > + Point_3 e3(0.0, 0.0, 1.0);
> > +
> > + Point_3 _e1(-1.0, 0.0, 0.0);
> > + Point_3 _e2(0.0, -1.0, 0.0);
> > + Point_3 _e3(0.0, 0.0, -1.0);
> > +
> > + //Create tetrahedrons with unit vectors and reference results.
> > + DoubleList reference_volumes;
> > + PointList reference_bary_centers;
> > + PolyhedronList reference_polyhedrons;
> > +
> > + add_test_polyhedron(e0,e1,e2,e3,reference_polyhedrons);
> > + reference_volumes.push_back(1.0/6.0);
> > + reference_bary_centers.push_back(Point(0.25,0.25,0.25));
> > +
> > + add_test_polyhedron(e0,_e1,e2,e3,reference_polyhedrons);
> > + reference_volumes.push_back(1.0/6.0);
> > + reference_bary_centers.push_back(Point(-0.25,0.25,0.25));
> > +
> > + add_test_polyhedron(e0,e1,_e2,e3,reference_polyhedrons);
> > + reference_volumes.push_back(1.0/6.0);
> > + reference_bary_centers.push_back(Point(0.25,-0.25,0.25));
> > +
> > + add_test_polyhedron(e0,_e1,_e2,e3,reference_polyhedrons);
> > + reference_volumes.push_back(1.0/6.0);
> > + reference_bary_centers.push_back(Point(-0.25,-0.25,0.25));
> > +
> > + add_test_polyhedron(e0,e1,e2,_e3,reference_polyhedrons);
> > + reference_volumes.push_back(1.0/6.0);
> > + reference_bary_centers.push_back(Point(0.25,0.25,-0.25));
> > +
> > + add_test_polyhedron(e0,_e1,e2,_e3,reference_polyhedrons);
> > + reference_volumes.push_back(1.0/6.0);
> > + reference_bary_centers.push_back(Point(-0.25,0.25,-0.25));
> > +
> > + add_test_polyhedron(e0,e1,_e2,_e3,reference_polyhedrons);
> > + reference_volumes.push_back(1.0/6.0);
> > + reference_bary_centers.push_back(Point(0.25,-0.25,-0.25));
> > +
> > + add_test_polyhedron(e0,_e1,_e2,_e3,reference_polyhedrons);
> > + reference_volumes.push_back(1.0/6.0);
> > + reference_bary_centers.push_back(Point(-0.25,-0.25,-0.25));
> > +
> > + //Add sum of polyhedrons
> > + IntList add_indices;
> > + add_indices.push_back(0);
> > +
> > + add_indices.push_back(1);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(2);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(3);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(4);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(5);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(6);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(7);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + //Add translated version
> > + //Upper halfspace
> > + Nef_polyhedron_3 polyhedron = reference_polyhedrons[0];
> > + polyhedron.transform(Aff_transformation_3(CGAL::TRANSLATION,
> > Vector_3(1, 1, 1))); + reference_polyhedrons.push_back(polyhedron);
> > + reference_volumes.push_back(1.0/6.0);
> > + reference_bary_centers.push_back(Point(1.25,1.25,1.25));
> > +
> > + polyhedron = reference_polyhedrons[1];
> > + polyhedron.transform(Aff_transformation_3(CGAL::TRANSLATION,
> > Vector_3(-1, 1, 1))); + reference_polyhedrons.push_back(polyhedron);
> > + reference_volumes.push_back(1.0/6.0);
> > + reference_bary_centers.push_back(Point(-1.25,1.25,1.25));
> > +
> > + polyhedron = reference_polyhedrons[2];
> > + polyhedron.transform(Aff_transformation_3(CGAL::TRANSLATION,
> > Vector_3(1, -1, 1))); + reference_polyhedrons.push_back(polyhedron);
> > + reference_volumes.push_back(1.0/6.0);
> > + reference_bary_centers.push_back(Point(1.25,-1.25,1.25));
> > +
> > + polyhedron = reference_polyhedrons[3];
> > + polyhedron.transform(Aff_transformation_3(CGAL::TRANSLATION,
> > Vector_3(-1, -1, 1))); + reference_polyhedrons.push_back(polyhedron);
> > + reference_volumes.push_back(1.0/6.0);
> > + reference_bary_centers.push_back(Point(-1.25,-1.25,1.25));
> > +
> > + polyhedron = reference_polyhedrons[4];
> > + polyhedron.transform(Aff_transformation_3(CGAL::TRANSLATION,
> > Vector_3(1, 1, -1))); + reference_polyhedrons.push_back(polyhedron);
> > + reference_volumes.push_back(1.0/6.0);
> > + reference_bary_centers.push_back(Point(1.25,1.25,-1.25));
> > +
> > + polyhedron = reference_polyhedrons[5];
> > + polyhedron.transform(Aff_transformation_3(CGAL::TRANSLATION,
> > Vector_3(-1, 1, -1))); + reference_polyhedrons.push_back(polyhedron);
> > + reference_volumes.push_back(1.0/6.0);
> > + reference_bary_centers.push_back(Point(-1.25,1.25,-1.25));
> > +
> > + polyhedron = reference_polyhedrons[6];
> > + polyhedron.transform(Aff_transformation_3(CGAL::TRANSLATION,
> > Vector_3(1, -1, -1))); + reference_polyhedrons.push_back(polyhedron);
> > + reference_volumes.push_back(1.0/6.0);
> > + reference_bary_centers.push_back(Point(1.25,-1.25,-1.25));
> > +
> > + polyhedron = reference_polyhedrons[7];
> > + polyhedron.transform(Aff_transformation_3(CGAL::TRANSLATION,
> > Vector_3(-1, -1, -1))); +
> > reference_polyhedrons.push_back(polyhedron);
> > + reference_volumes.push_back(1.0/6.0);
> > + reference_bary_centers.push_back(Point(-1.25,-1.25,-1.25));
> > +
> > + //Add the disjoint union of the translated polyhedrons.
> > + add_indices.clear();
> > + add_indices.push_back(15);
> > +
> > + add_indices.push_back(16);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(17);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(18);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(19);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(20);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(21);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(22);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + //Instantiate quadrature rule
> > + BaryCenterQuadrature quadrature_rule;
> > +
> > + //Check volume and barycenter for polyhedrons
> > + for (dolfin::uint i = 0; i < reference_polyhedrons.size(); ++i)
> > + {
> > + quadrature_rule.compute_quadrature_rule(reference_polyhedrons[i]);
> > + CPPUNIT_ASSERT_DOUBLES_EQUAL(reference_volumes[i],
> > + quadrature_rule.weights()[0], 1.0e-12);
> > + almost_equal_points(reference_bary_centers[i],
> > + quadrature_rule.points()[0], 1.0e-12);
> > + }
> > + }
> > +
> > + void testSimplePolygons()
> > + {
> > + //Create origin and unit vectors.
> > + Point_3 e0(0.0, 0.0, 0.0);
> > +
> > + Point_3 e1(1.0, 0.0, 0.0);
> > + Point_3 e2(0.0, 1.0, 0.0);
> > + Point_3 e3(0.0, 0.0, 1.0);
> > +
> > + Point_3 _e1(-1.0, 0.0, 0.0);
> > + Point_3 _e2(0.0, -1.0, 0.0);
> > + Point_3 _e3(0.0, 0.0, -1.0);
> > +
> > + //Create tetrahedrons with unit vectors and reference results.
> > + DoubleList reference_volumes;
> > + PointList reference_bary_centers;
> > + PolyhedronList reference_polyhedrons;
> > +
> > + //skew plane upper e3 plane
> > + add_test_polyhedron(e1,e2,e3,reference_polyhedrons);
> > + //todo find exact values
> > + reference_volumes.push_back(8.660254e-01);
> > + reference_bary_centers.push_back(Point(1.0/3.0,1.0/3.0,1.0/3.0));
> > +
> > + add_test_polyhedron(_e1,e2,e3,reference_polyhedrons);
> > + //todo find exact values
> > + reference_volumes.push_back(8.660254e-01);
> > + reference_bary_centers.push_back(Point(-1.0/3.0,1.0/3.0,1.0/3.0));
> > +
> > + add_test_polyhedron(_e1,_e2,e3,reference_polyhedrons);
> > + //todo find exact values
> > + reference_volumes.push_back(8.660254e-01);
> > + reference_bary_centers.push_back(Point(-1.0/3.0,-1.0/3.0,1.0/3.0));
> > +
> > + add_test_polyhedron(e1,_e2,e3,reference_polyhedrons);
> > + //todo find exact values
> > + reference_volumes.push_back(8.660254e-01);
> > + reference_bary_centers.push_back(Point(1.0/3.0,-1.0/3.0,1.0/3.0));
> > +
> > + //skew plane lower -e3 plane
> > + add_test_polyhedron(e1,e2,_e3,reference_polyhedrons);
> > + //todo find exact values
> > + reference_volumes.push_back(8.660254e-01);
> > + reference_bary_centers.push_back(Point(1.0/3.0,1.0/3.0,-1.0/3.0));
> > +
> > + add_test_polyhedron(_e1,e2,_e3,reference_polyhedrons);
> > + //todo find exact values
> > + reference_volumes.push_back(8.660254e-01);
> > + reference_bary_centers.push_back(Point(-1.0/3.0,1.0/3.0,-1.0/3.0));
> > +
> > + add_test_polyhedron(_e1,_e2,_e3,reference_polyhedrons);
> > + //todo find exact values
> > + reference_volumes.push_back(8.660254e-01);
> > + reference_bary_centers.push_back(Point(-1.0/3.0,-1.0/3.0,-1.0/3.0));
> > +
> > + add_test_polyhedron(e1,_e2,_e3,reference_polyhedrons);
> > + //todo find exact values
> > + reference_volumes.push_back(8.660254e-01);
> > + reference_bary_centers.push_back(Point(1.0/3.0,-1.0/3.0,-1.0/3.0));
> > +
> > + //e1-e2 plane
> > + add_test_polyhedron(e0,e1,e2,reference_polyhedrons);
> > + reference_volumes.push_back(1.0/2.0);
> > + reference_bary_centers.push_back(Point(1.0/3.0,1.0/3.0,0.0));
> > +
> > + add_test_polyhedron(e0,_e1,e2,reference_polyhedrons);
> > + reference_volumes.push_back(1.0/2.0);
> > + reference_bary_centers.push_back(Point(-1.0/3.0,1.0/3.0,0.0));
> > +
> > + add_test_polyhedron(e0,_e1,_e2,reference_polyhedrons);
> > + reference_volumes.push_back(1.0/2.0);
> > + reference_bary_centers.push_back(Point(-1.0/3.0,-1.0/3.0,0.0));
> > +
> > + add_test_polyhedron(e0,e1,_e2,reference_polyhedrons);
> > + reference_volumes.push_back(1.0/2.0);
> > + reference_bary_centers.push_back(Point(1.0/3.0,-1.0/3.0,0.0));
> > +
> > + //e1-e3 plane
> > + add_test_polyhedron(e0,e1,e3,reference_polyhedrons);
> > + reference_volumes.push_back(1.0/2.0);
> > + reference_bary_centers.push_back(Point(1.0/3.0,0.0,1.0/3.0));
> > +
> > + add_test_polyhedron(e0,_e1,e3,reference_polyhedrons);
> > + reference_volumes.push_back(1.0/2.0);
> > + reference_bary_centers.push_back(Point(-1.0/3.0,0.0,1.0/3.0));
> > +
> > + add_test_polyhedron(e0,_e1,_e3,reference_polyhedrons);
> > + reference_volumes.push_back(1.0/2.0);
> > + reference_bary_centers.push_back(Point(-1.0/3.0,0.0,-1.0/3.0));
> > +
> > + add_test_polyhedron(e0,e1,_e3,reference_polyhedrons);
> > + reference_volumes.push_back(1.0/2.0);
> > + reference_bary_centers.push_back(Point(1.0/3.0,0.0,-1.0/3.0));
> > +
> > + //e2-e3 plane
> > + add_test_polyhedron(e0,e2,e3,reference_polyhedrons);
> > + reference_volumes.push_back(1.0/2.0);
> > + reference_bary_centers.push_back(Point(0.0,1.0/3.0,1.0/3.0));
> > +
> > + add_test_polyhedron(e0,_e2,e3,reference_polyhedrons);
> > + reference_volumes.push_back(1.0/2.0);
> > + reference_bary_centers.push_back(Point(0.0,-1.0/3.0,1.0/3.0));
> > +
> > + add_test_polyhedron(e0,_e2,_e3,reference_polyhedrons);
> > + reference_volumes.push_back(1.0/2.0);
> > + reference_bary_centers.push_back(Point(0.0,-1.0/3.0,-1.0/3.0));
> > +
> > + add_test_polyhedron(e0,e2,_e3,reference_polyhedrons);
> > + reference_volumes.push_back(1.0/2.0);
> > + reference_bary_centers.push_back(Point(0.0,1.0/3.0,-1.0/3.0));
> > +
> > + //Test sum of polyhedrons
> > + IntList add_indices;
> > + add_indices.push_back(0);
> > +
> > +
> > + add_indices.push_back(1);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(2);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(3);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(4);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(5);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(6);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(7);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(8);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(9);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > +
> > + add_indices.push_back(10);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(11);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(12);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(13);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(14);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + add_indices.push_back(15);
> > + add_disjoint_polyhedrons(add_indices,
> > + reference_polyhedrons,
> > + reference_volumes,
> > + reference_bary_centers);
> > +
> > + Nef_polyhedron_3 polyhedron = reference_polyhedrons[0];
> > + polyhedron.transform(Aff_transformation_3(CGAL::TRANSLATION,
> > Vector_3(1, 1, 1))); + reference_polyhedrons.push_back(polyhedron);
> > + reference_volumes.push_back(reference_volumes[0]);
> > + reference_bary_centers.push_back(reference_bary_centers[0] +
> > Point(1,1,1)); +
> > + polyhedron = reference_polyhedrons[1];
> > + polyhedron.transform(Aff_transformation_3(CGAL::TRANSLATION,
> > Vector_3(-1, 1, 1))); + reference_polyhedrons.push_back(polyhedron);
> > + reference_volumes.push_back(reference_volumes[1]);
> > + reference_bary_centers.push_back(reference_bary_centers[1] +
> > Point(-1,1,1)); +
> > + polyhedron = reference_polyhedrons[2];
> > + polyhedron.transform(Aff_transformation_3(CGAL::TRANSLATION,
> > Vector_3(1, -1, 1))); + reference_polyhedrons.push_back(polyhedron);
> > + reference_volumes.push_back(reference_volumes[2]);
> > + reference_bary_centers.push_back(reference_bary_centers[2] +
> > Point(1,-1,1)); +
> > + polyhedron = reference_polyhedrons[3];
> > + polyhedron.transform(Aff_transformation_3(CGAL::TRANSLATION,
> > Vector_3(-1, -1, 1))); + reference_polyhedrons.push_back(polyhedron);
> > + reference_volumes.push_back(reference_volumes[3]);
> > + reference_bary_centers.push_back(reference_bary_centers[3] +
> > Point(-1,-1,1)); +
> > + polyhedron = reference_polyhedrons[4];
> > + polyhedron.transform(Aff_transformation_3(CGAL::TRANSLATION,
> > Vector_3(1, 1, -1))); + reference_polyhedrons.push_back(polyhedron);
> > + reference_volumes.push_back(reference_volumes[4]);
> > + reference_bary_centers.push_back(reference_bary_centers[4] +
> > Point(1,1,-1)); +
> > + polyhedron = reference_polyhedrons[5];
> > + polyhedron.transform(Aff_transformation_3(CGAL::TRANSLATION,
> > Vector_3(-1, 1, -1))); + reference_polyhedrons.push_back(polyhedron);
> > + reference_volumes.push_back(reference_volumes[5]);
> > + reference_bary_centers.push_back(reference_bary_centers[5] +
> > Point(-1,1,-1)); +
> > + polyhedron = reference_polyhedrons[6];
> > + polyhedron.transform(Aff_transformation_3(CGAL::TRANSLATION,
> > Vector_3(1, -1, -1))); + reference_polyhedrons.push_back(polyhedron);
> > + reference_volumes.push_back(reference_volumes[6]);
> > + reference_bary_centers.push_back(reference_bary_centers[6] +
> > Point(1,-1,-1)); +
> > + polyhedron = reference_polyhedrons[7];
> > + polyhedron.transform(Aff_transformation_3(CGAL::TRANSLATION,
> > Vector_3(-1, -1, -1))); +
> > reference_polyhedrons.push_back(polyhedron);
> > + reference_volumes.push_back(reference_volumes[7]);
> > + reference_bary_centers.push_back(reference_bary_centers[7] +
> > Point(-1,-1,-1)); +
> > + //Instantiate quadrature rule
> > + BaryCenterQuadrature quadrature_rule;
> > +
> > + //Check volume and barycenter for polyhedrons
> > + for (dolfin::uint i = 0; i < reference_polyhedrons.size(); ++i)
> > + {
> > + quadrature_rule.compute_quadrature_rule(reference_polyhedrons[i]);
> > + CPPUNIT_ASSERT_DOUBLES_EQUAL(reference_volumes[i],
> > + quadrature_rule.weights()[0], 1.0e-5);
> > + almost_equal_points(reference_bary_centers[i],
> > + quadrature_rule.points()[0], 1.0e-5);
> > + }
> > + }
> > +
> > + void testComplexPolyhedrons()
> > + {
> > + }
> > +
> > + void testComplexPolygons()
> > + {
> > + }
> > +
> > +};
> > +
> > +CPPUNIT_TEST_SUITE_REGISTRATION(BaryCenter);
> > +
> > +int main()
> > +{
> > + DOLFIN_TEST;
> > +}
> >
> > === added file
> > 'nitsche_method/integration_on_complex_domains/gauss_projection_green/te
> > tra' ---
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/tet
> > ra 1970-01-01 00:00:00 +0000 +++
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/tet
> > ra 2010-03-18 18:15:26 +0000 @@ -0,0 +1,16 @@
> > +4
> > +
> > +0 0 0
> > +5 0 0
> > +0 4 0
> > +0 0 3
> > +
> > +4
> > +
> > +3 0 3 2
> > +3 3 0 1
> > +3 2 1 0
> > +3 1 2 3
> > +
> > +
> > +
> >
> > === added file
> > 'nitsche_method/integration_on_complex_domains/gauss_projection_green/vo
> > lInt.c' ---
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/vol
> > Int.c 1970-01-01 00:00:00 +0000 +++
> > nitsche_method/integration_on_complex_domains/gauss_projection_green/vol
> > Int.c 2010-03-26 13:05:51 +0000 @@ -0,0 +1,383 @@
> > +
> > +
> > + /*******************************************************
> > + * *
> > + * volInt.c *
> > + * *
> > + * This code computes volume integrals needed for *
> > + * determining mass properties of polyhedral bodies. *
> > + * *
> > + * For more information, see the accompanying README *
> > + * file, and the paper *
> > + * *
> > + * Brian Mirtich, "Fast and Accurate Computation of *
> > + * Polyhedral Mass Properties," journal of graphics *
> > + * tools, volume 1, number 1, 1996. *
> > + * *
> > + * This source code is public domain, and may be used *
> > + * in any way, shape or form, free of charge. *
> > + * *
> > + * Copyright 1995 by Brian Mirtich *
> > + * *
> > + * mirtich@xxxxxxxxxxxxxxx *
> > + * http://www.cs.berkeley.edu/~mirtich *
> > + * *
> > + *******************************************************/
> > +
> > +/*
> > + Revision history
> > +
> > + 26 Jan 1996 Program creation.
> > +
> > + 3 Aug 1996 Corrected bug arising when polyhedron density
> > + is not 1.0. Changes confined to function main().
> > + Thanks to Zoran Popovic for catching this one.
> > +
> > + 27 May 1997 Corrected sign error in translation of inertia
> > + product terms to center of mass frame. Changes
> > + confined to function main(). Thanks to
> > + Chris Hecker.
> > +*/
> > +
> > +
> > +
> > +#include <stdio.h>
> > +#include <string.h>
> > +#include <math.h>
> > +
> > +using namespace std;
> > +
> > +/*
> > +
> > ========================================================================
> > ==== + constants
> > +
> > ========================================================================
> > ==== +*/
> > +
> > +#define MAX_VERTS 100 /* maximum number of polyhedral vertices */
> > +#define MAX_FACES 100 /* maximum number of polyhedral faces */
> > +#define MAX_POLYGON_SZ 10 /* maximum number of verts per polygonal face
> > */ +
> > +#define X 0
> > +#define Y 1
> > +#define Z 2
> > +
> > +/*
> > +
> > ========================================================================
> > ==== + macros
> > +
> > ========================================================================
> > ==== +*/
> > +
> > +#define SQR(x) ((x)*(x))
> > +#define CUBE(x) ((x)*(x)*(x))
> > +
> > +/*
> > +
> > ========================================================================
> > ==== + data structures
> > +
> > ========================================================================
> > ==== +*/
> > +
> > +typedef struct {
> > + int numVerts;
> > + double norm[3];
> > + double w;
> > + int verts[MAX_POLYGON_SZ];
> > + struct polyhedron *poly;
> > +} FACE;
> > +
> > +typedef struct polyhedron {
> > + int numVerts, numFaces;
> > + double verts[MAX_VERTS][3];
> > + FACE faces[MAX_FACES];
> > +} POLYHEDRON;
> > +
> > +
> > +/*
> > +
> > ========================================================================
> > ==== + globals
> > +
> > ========================================================================
> > ==== +*/
> > +
> > +static int A; /* alpha */
> > +static int B; /* beta */
> > +static int C; /* gamma */
> > +
> > +/* projection integrals */
> > +static double P1, Pa, Pb, Paa, Pab, Pbb, Paaa, Paab, Pabb, Pbbb;
> > +
> > +/* face integrals */
> > +static double Fa, Fb, Fc, Faa, Fbb, Fcc, Faaa, Fbbb, Fccc, Faab, Fbbc,
> > Fcca; +
> > +/* volume integrals */
> > +static double T0, T1[3], T2[3], TP[3];
> > +
> > +
> > +/*
> > +
> > ========================================================================
> > ==== + read in a polyhedron
> > +
> > ========================================================================
> > ==== +*/
> > +
> > +void readPolyhedron(char *name, POLYHEDRON *p)
> > +{
> > + FILE *fp;
> > + char line[200], *c;
> > + int i, j, n;
> > + double dx1, dy1, dz1, dx2, dy2, dz2, nx, ny, nz, len;
> > + FACE *f;
> > +
> > +
> > +/* if (!(fp = fopen(name, "r"))) {*/
> > +/* printf("i/o error\n");*/
> > +/* exit(1);*/
> > + }
> > +
> > + fscanf(fp, "%d", &p->numVerts);
> > + printf("Reading in %d vertices\n", p->numVerts);
> > + for (i = 0; i < p->numVerts; i++)
> > + fscanf(fp, "%lf %lf %lf",
> > + &p->verts[i][X], &p->verts[i][Y], &p->verts[i][Z]);
> > +
> > + fscanf(fp, "%d", &p->numFaces);
> > + printf("Reading in %d faces\n", p->numFaces);
> > + for (i = 0; i < p->numFaces; i++) {
> > + f = &p->faces[i];
> > + f->poly = p;
> > + fscanf(fp, "%d", &f->numVerts);
> > + for (j = 0; j < f->numVerts; j++) fscanf(fp, "%d", &f->verts[j]);
> > +
> > + /* compute face normal and offset w from first 3 vertices */
> > + dx1 = p->verts[f->verts[1]][X] - p->verts[f->verts[0]][X];
> > + dy1 = p->verts[f->verts[1]][Y] - p->verts[f->verts[0]][Y];
> > + dz1 = p->verts[f->verts[1]][Z] - p->verts[f->verts[0]][Z];
> > + dx2 = p->verts[f->verts[2]][X] - p->verts[f->verts[1]][X];
> > + dy2 = p->verts[f->verts[2]][Y] - p->verts[f->verts[1]][Y];
> > + dz2 = p->verts[f->verts[2]][Z] - p->verts[f->verts[1]][Z];
> > + nx = dy1 * dz2 - dy2 * dz1;
> > + ny = dz1 * dx2 - dz2 * dx1;
> > + nz = dx1 * dy2 - dx2 * dy1;
> > + len = sqrt(nx * nx + ny * ny + nz * nz);
> > + f->norm[X] = nx / len;
> > + f->norm[Y] = ny / len;
> > + f->norm[Z] = nz / len;
> > + f->w = - f->norm[X] * p->verts[f->verts[0]][X]
> > + - f->norm[Y] * p->verts[f->verts[0]][Y]
> > + - f->norm[Z] * p->verts[f->verts[0]][Z];
> > +
> > + }
> > +
> > + fclose(fp);
> > +
> > +}
> > +
> > +/*
> > +
> > ========================================================================
> > ==== + compute mass properties
> > +
> > ========================================================================
> > ==== +*/
> > +
> > +
> > +/* compute various integrations over projection of face */
> > +void compProjectionIntegrals(FACE *f)
> > +{
> > + double a0, a1, da;
> > + double b0, b1, db;
> > + double a0_2, a0_3, a0_4, b0_2, b0_3, b0_4;
> > + double a1_2, a1_3, b1_2, b1_3;
> > + double C1, Ca, Caa, Caaa, Cb, Cbb, Cbbb;
> > + double Cab, Kab, Caab, Kaab, Cabb, Kabb;
> > + int i;
> > +
> > + P1 = Pa = Pb = Paa = Pab = Pbb = Paaa = Paab = Pabb = Pbbb = 0.0;
> > +
> > + for (i = 0; i < f->numVerts; i++) {
> > + a0 = f->poly->verts[f->verts[i]][A];
> > + b0 = f->poly->verts[f->verts[i]][B];
> > + a1 = f->poly->verts[f->verts[(i+1) % f->numVerts]][A];
> > + b1 = f->poly->verts[f->verts[(i+1) % f->numVerts]][B];
> > + da = a1 - a0;
> > + db = b1 - b0;
> > + a0_2 = a0 * a0; a0_3 = a0_2 * a0; a0_4 = a0_3 * a0;
> > + b0_2 = b0 * b0; b0_3 = b0_2 * b0; b0_4 = b0_3 * b0;
> > + a1_2 = a1 * a1; a1_3 = a1_2 * a1;
> > + b1_2 = b1 * b1; b1_3 = b1_2 * b1;
> > +
> > + C1 = a1 + a0;
> > + Ca = a1*C1 + a0_2; Caa = a1*Ca + a0_3; Caaa = a1*Caa + a0_4;
> > + Cb = b1*(b1 + b0) + b0_2; Cbb = b1*Cb + b0_3; Cbbb = b1*Cbb + b0_4;
> > + Cab = 3*a1_2 + 2*a1*a0 + a0_2; Kab = a1_2 + 2*a1*a0 + 3*a0_2;
> > + Caab = a0*Cab + 4*a1_3; Kaab = a1*Kab + 4*a0_3;
> > + Cabb = 4*b1_3 + 3*b1_2*b0 + 2*b1*b0_2 + b0_3;
> > + Kabb = b1_3 + 2*b1_2*b0 + 3*b1*b0_2 + 4*b0_3;
> > +
> > + P1 += db*C1;
> > + Pa += db*Ca;
> > + Paa += db*Caa;
> > + Paaa += db*Caaa;
> > + Pb += da*Cb;
> > + Pbb += da*Cbb;
> > + Pbbb += da*Cbbb;
> > + Pab += db*(b1*Cab + b0*Kab);
> > + Paab += db*(b1*Caab + b0*Kaab);
> > + Pabb += da*(a1*Cabb + a0*Kabb);
> > + }
> > +
> > + P1 /= 2.0;
> > + Pa /= 6.0;
> > + Paa /= 12.0;
> > + Paaa /= 20.0;
> > + Pb /= -6.0;
> > + Pbb /= -12.0;
> > + Pbbb /= -20.0;
> > + Pab /= 24.0;
> > + Paab /= 60.0;
> > + Pabb /= -60.0;
> > +}
> > +
> > +compFaceIntegrals(FACE *f)
> > +{
> > + double *n, w;
> > + double k1, k2, k3, k4;
> > +
> > + compProjectionIntegrals(f);
> > +
> > + w = f->w;
> > + n = f->norm;
> > + k1 = 1 / n[C]; k2 = k1 * k1; k3 = k2 * k1; k4 = k3 * k1;
> > +
> > + Fa = k1 * Pa;
> > + Fb = k1 * Pb;
> > + Fc = -k2 * (n[A]*Pa + n[B]*Pb + w*P1);
> > +
> > + Faa = k1 * Paa;
> > + Fbb = k1 * Pbb;
> > + Fcc = k3 * (SQR(n[A])*Paa + 2*n[A]*n[B]*Pab + SQR(n[B])*Pbb
> > + + w*(2*(n[A]*Pa + n[B]*Pb) + w*P1));
> > +
> > + Faaa = k1 * Paaa;
> > + Fbbb = k1 * Pbbb;
> > + Fccc = -k4 * (CUBE(n[A])*Paaa + 3*SQR(n[A])*n[B]*Paab
> > + + 3*n[A]*SQR(n[B])*Pabb + CUBE(n[B])*Pbbb
> > + + 3*w*(SQR(n[A])*Paa + 2*n[A]*n[B]*Pab + SQR(n[B])*Pbb)
> > + + w*w*(3*(n[A]*Pa + n[B]*Pb) + w*P1));
> > +
> > + Faab = k1 * Paab;
> > + Fbbc = -k2 * (n[A]*Pabb + n[B]*Pbbb + w*Pbb);
> > + Fcca = k3 * (SQR(n[A])*Paaa + 2*n[A]*n[B]*Paab + SQR(n[B])*Pabb
> > + + w*(2*(n[A]*Paa + n[B]*Pab) + w*Pa));
> > +}
> > +
> > +void compVolumeIntegrals(POLYHEDRON *p)
> > +{
> > + FACE *f;
> > + double nx, ny, nz;
> > + int i;
> > +
> > + T0 = T1[X] = T1[Y] = T1[Z]
> > + = T2[X] = T2[Y] = T2[Z]
> > + = TP[X] = TP[Y] = TP[Z] = 0;
> > +
> > + for (i = 0; i < p->numFaces; i++) {
> > +
> > + f = &p->faces[i];
> > +
> > + nx = fabs(f->norm[X]);
> > + ny = fabs(f->norm[Y]);
> > + nz = fabs(f->norm[Z]);
> > + if (nx > ny && nx > nz) C = X;
> > + else C = (ny > nz) ? Y : Z;
> > + A = (C + 1) % 3;
> > + B = (A + 1) % 3;
> > +
> > + compFaceIntegrals(f);
> > +
> > + T0 += f->norm[X] * ((A == X) ? Fa : ((B == X) ? Fb : Fc));
> > +
> > + T1[A] += f->norm[A] * Faa;
> > + T1[B] += f->norm[B] * Fbb;
> > + T1[C] += f->norm[C] * Fcc;
> > + T2[A] += f->norm[A] * Faaa;
> > + T2[B] += f->norm[B] * Fbbb;
> > + T2[C] += f->norm[C] * Fccc;
> > + TP[A] += f->norm[A] * Faab;
> > + TP[B] += f->norm[B] * Fbbc;
> > + TP[C] += f->norm[C] * Fcca;
> > + }
> > +
> > + T1[X] /= 2; T1[Y] /= 2; T1[Z] /= 2;
> > + T2[X] /= 3; T2[Y] /= 3; T2[Z] /= 3;
> > + TP[X] /= 2; TP[Y] /= 2; TP[Z] /= 2;
> > +}
> > +
> > +
> > +/*
> > +
> > ========================================================================
> > ==== + main
> > +
> > ========================================================================
> > ==== +*/
> > +
> > +
> > +int main(int argc, char *argv[])
> > +{
> > + POLYHEDRON p;
> > + double density, mass;
> > + double r[3]; /* center of mass */
> > + double J[3][3]; /* inertia tensor */
> > +
> > + if (argc != 2) {
> > + printf("usage: %s <polyhedron geometry filename>\n", argv[0]);
> > +/* exit(0);*/
> > + return 0;
> > + }
> > +
> > + readPolyhedron(argv[1], &p);
> > +
> > + compVolumeIntegrals(&p);
> > +
> > +
> > + printf("\nT1 = %+20.6f\n\n", T0);
> > +
> > + printf("Tx = %+20.6f\n", T1[X]);
> > + printf("Ty = %+20.6f\n", T1[Y]);
> > + printf("Tz = %+20.6f\n\n", T1[Z]);
> > +
> > + printf("Txx = %+20.6f\n", T2[X]);
> > + printf("Tyy = %+20.6f\n", T2[Y]);
> > + printf("Tzz = %+20.6f\n\n", T2[Z]);
> > +
> > + printf("Txy = %+20.6f\n", TP[X]);
> > + printf("Tyz = %+20.6f\n", TP[Y]);
> > + printf("Tzx = %+20.6f\n\n", TP[Z]);
> > +
> > + density = 1.0; /* assume unit density */
> > +
> > + mass = density * T0;
> > +
> > + /* compute center of mass */
> > + r[X] = T1[X] / T0;
> > + r[Y] = T1[Y] / T0;
> > + r[Z] = T1[Z] / T0;
> > +
> > + /* compute inertia tensor */
> > + J[X][X] = density * (T2[Y] + T2[Z]);
> > + J[Y][Y] = density * (T2[Z] + T2[X]);
> > + J[Z][Z] = density * (T2[X] + T2[Y]);
> > + J[X][Y] = J[Y][X] = - density * TP[X];
> > + J[Y][Z] = J[Z][Y] = - density * TP[Y];
> > + J[Z][X] = J[X][Z] = - density * TP[Z];
> > +
> > + /* translate inertia tensor to center of mass */
> > + J[X][X] -= mass * (r[Y]*r[Y] + r[Z]*r[Z]);
> > + J[Y][Y] -= mass * (r[Z]*r[Z] + r[X]*r[X]);
> > + J[Z][Z] -= mass * (r[X]*r[X] + r[Y]*r[Y]);
> > + J[X][Y] = J[Y][X] += mass * r[X] * r[Y];
> > + J[Y][Z] = J[Z][Y] += mass * r[Y] * r[Z];
> > + J[Z][X] = J[X][Z] += mass * r[Z] * r[X];
> > +
> > + printf("center of mass: (%+12.6f,%+12.6f,%+12.6f)\n\n", r[X], r[Y],
> > r[Z]); +
> > + printf("inertia tensor with origin at c.o.m. :\n");
> > + printf("%+15.6f %+15.6f %+15.6f\n", J[X][X], J[X][Y], J[X][Z]);
> > + printf("%+15.6f %+15.6f %+15.6f\n", J[Y][X], J[Y][Y], J[Y][Z]);
> > + printf("%+15.6f %+15.6f %+15.6f\n\n", J[Z][X], J[Z][Y], J[Z][Z]);
> > +
> > +}
> >
> > === added directory
> > 'nitsche_method/integration_on_complex_domains/monte_carlo' === added
> > directory 'nitsche_method/integration_on_complex_domains/triangulation'
> > === added directory 'nitsche_method/overlapping_meshes'
> > === added file 'nitsche_method/overlapping_meshes/MeshIntersector.cpp'
> > --- nitsche_method/overlapping_meshes/MeshIntersector.cpp 1970-01-01
> > 00:00:00 +0000 +++
> > nitsche_method/overlapping_meshes/MeshIntersector.cpp 2010-03-16
> > 14:39:09 +0000 @@ -0,0 +1,175 @@
> > +//
> > ========================================================================
> > ============= +//
> > +// Copyright (C) 2010-01-16 André Massing
> > +// Licensed under the GNU LGPL Version 2.1.
> > +//
> > +// Modified by André Massing, 2010
> > +//
> > +// First added: 2010-01-16
> > +// back changed: 2010-01-27
> > +//
> > +//Author: André Massing (am), massing@xxxxxxxxx
> > +//Company: Simula Research Laboratory, Fornebu, Norway
> > +//
> > +//
> > ========================================================================
> > ============= +
> > +#include "OverlappingMeshes.h"
> > +
> > +#include <dolfin/mesh/BoundaryMesh.h>
> > +#include <dolfin/mesh/Vertex.h>
> > +#include <dolfin/mesh/Cell.h>
> > +
> > +#include <dolfin/log/dolfin_log.h>
> > +#include <dolfin/common/NoDeleter.h>
> > +
> > +#include <iostream>
> > +
> > +using namespace dolfin;
> > +using dolfin::uint;
> > +
> > +
> > + MeshIntersection::OverlapData::OverlapData(boost::shared_ptr<const
> > Mesh> mesh) +: mesh(mesh)
> > +{
> > + intersected_domain = MeshFunction<uint>(*mesh,mesh->topology().dim());
> > + intersected_domain = 0;
> > +}
> > +
> > +MeshIntersection::MeshIntersection(const Mesh & mesh_1, const Mesh &
> > mesh_2) + :
> > + _overlapped_domain(new
> > OverlapData(reference_to_no_delete_pointer(mesh_1))) +
> > ,_overlapping_domain(new
> > OverlapData(reference_to_no_delete_pointer(mesh_2))) +
> > ,_overlapped_boundary(new OverlapData(boost::shared_ptr<const Mesh>(new
> > BoundaryMesh(mesh_1)))) + ,_overlapping_boundary(new
> > OverlapData(boost::shared_ptr<const Mesh>(new BoundaryMesh(mesh_2))))
> > +{}
> > +
> > +//MeshIntersection::MeshIntersection(boost::shared_ptr<const Mesh>
> > mesh_1, boost::shared_ptr<const Mesh> mesh_2) +// :
> > +// _overlapped_domain(mesh_1)
> > +// ,_overlapping_domain(mesh_2)
> > +// _overlapped_boundary(boost::shared_ptr<const Mesh>(new
> > BoundaryMesh(mesh_1))) +//
> > ,_overlapping_boundary(boost::shared_ptr<const Mesh>(new
> > BoundaryMesh(mesh_2))) +//{}
> > +
> > +
> > +void MeshIntersection::compute_overlap_map()
> > +{
> > +
> > + const Mesh & mesh_1 = *(_overlapped_domain->mesh);
> > + const Mesh & mesh_2 = *(_overlapping_domain->mesh);
> > +
> > + const Mesh & boundary_1 = *(_overlapped_boundary->mesh);
> > + const Mesh & boundary_2 = *(_overlapping_boundary->mesh);
> > +
> > + EntityEntitiesMap & cell_cell_map =
> > _overlapped_domain->entity_entities_map; + EntityEntitiesMap &
> > facet_1_cell_2_map = _overlapped_boundary->entity_entities_map; +
> > EntityEntitiesMap & facet_2_cell_1_map =
> > _overlapping_boundary->entity_entities_map; +
> > + CellIterator cut_cell(mesh_1);
> > + CellIterator cut_facet(boundary_2);
> > +
> > + //Step 1:
> > + //Intersect boundary of mesh_2 with mesh_1.
> > + //to get the *partially*
> > + //intersected cells of mesh_1.
> > + //This calculates:
> > + // a) *partially* intersected cells of mesh1
> > + // b) the exterior facets of mesh_2 which are (part) of the artificial
> > interface. + // c) *partially* intersected exterior facets of mesh1 and
> > mesh2. +
> > + for (CellIterator cell(boundary_2); !cell.end(); ++cell)
> > + {
> > + mesh_1.all_intersected_entities(*cell,
> > facet_2_cell_1_map[cell->index()]); +
> > + if (facet_2_cell_1_map[cell->index()].empty())
> > + facet_2_cell_1_map.erase(cell->index());
> > + //If not empty add cell index and intersecting cell index to the
> > map. + else
> > + {
> > + //Iterate of intersected cell of mesh1, find the overlapping cells
> > of + //mesh 2 and mark cells in mesh1 as partially overlapped. +
> > for (EntityListIter cell_iter =
> > facet_2_cell_1_map[cell->index()].begin(); cell_iter !=
> > facet_2_cell_1_map[cell->index()].end(); ++cell_iter) + {
> > + mesh_2.all_intersected_entities(cut_cell[*cell_iter],
> > cell_cell_map[*cell_iter]); +
> > _overlapped_domain->intersected_domain[*cell_iter] = 1; + }
> > +
> > + //Compute partially overlapped boundary cells of mesh1 and mesh2.
> > + //
> > + //@remark: Clarify whether it is faster to check first if any and
> > then + //if compute indeces or just try to compute immediately and
> > erase if the cell + //index container is empty. Rational: We want
> > to avoid a copy operator + //(linear). A "any intersection" test
> > should have the same complexity as + //a "compute all intersection"
> > if no intersection occurs. If a + //intersection occurrs, we want
> > to compute all intersection anyway. + //1. Version Compute right
> > away and deleting (delete operation is amortized constant) if empty +
> > //2. Version Check first and compute if intersected.
> > + //3. Compute and assign if not empty
> > + //@remark What is faster? Recompute intersecting cells from mesh2
> > for the + //exterior facets in mesh1 or map facet index to cell
> > index, and assign + //their cell set (which might be bigger as the
> > set, which really only + //intersects the facet).
> > +
> > + EntityList cut_faces;
> > + boundary_1.all_intersected_entities(*cell,cut_faces);
> > +
> > + if (!cut_faces.empty())
> > + {
> > + _overlapping_boundary->intersected_domain[cell->index()] = 1;
> > +
> > + //Compute for each cut exterior facet in mesh1 the cutting cells
> > in + //mesh2, mark facet as partially overlapped.
> > + for (EntityListIter face_iter = cut_faces.begin(); face_iter !=
> > cut_faces.end(); ++face_iter) + {
> > +
> > mesh_2.all_intersected_entities(cut_facet[*face_iter],facet_1_cell_2_map
> > [*face_iter]); +
> > _overlapped_boundary->intersected_domain[*face_iter] = 1; + }
> > + }
> > + else
> > + {
> > + _overlapping_boundary->intersected_domain[cell->index()] = 2;
> > + }
> > + }
> > + }
> > +
> > + //Step 2:
> > + //Determine all cells of Mesh 1, which are fully overlapped. This is
> > done by + //going through the cells, check if they are not partially
> > overlapped and + //therefore must then be fully overlapped if any
> > vertex is intersecting + //mesh2.
> > + for (CellIterator cell(mesh_1); !cell.end(); ++cell)
> > + {
> > + if (_overlapped_domain->intersected_domain[cell->index()] != 1 &&
> > mesh_2.any_intersected_entity(VertexIterator(*cell)->point()) != -1) +
> > _overlapped_domain->intersected_domain[cell->index()] = 2; + }
> > +
> > + //Step 3:
> > + //Determine all cells of the boundary of mesh 1, which are fully
> > overlapped. + //Same method as in Step 2.
> > + for (CellIterator cell(boundary_1); !cell.end(); ++cell)
> > + {
> > + if (_overlapped_boundary->intersected_domain[cell->index()] != 1
> > + && mesh_2.any_intersected_entity(VertexIterator(*cell)->point())
> > != -1) + _overlapped_boundary->intersected_domain[cell->index()] =
> > 2; + }
> > +}
> > +
> > +const MeshFunction<uint> & MeshIntersection::overlapped_domain() const
> > +{
> > + return _overlapped_domain->intersected_domain;
> > +}
> > +
> > +const MeshFunction<uint> & MeshIntersection::overlapping_domain() const
> > +{
> > + return _overlapping_domain->intersected_domain;
> > +}
> > +
> > +const MeshFunction<uint> & MeshIntersection::overlapped_boundary() const
> > +{
> > + return _overlapped_boundary->intersected_domain;
> > +}
> > +
> > +const MeshFunction<uint> & MeshIntersection::overlapping_boundary()
> > const +{
> > + return _overlapping_boundary->intersected_domain;
> > +}
> >
> > === added file 'nitsche_method/overlapping_meshes/MeshIntersector.h'
> > --- nitsche_method/overlapping_meshes/MeshIntersector.h 1970-01-01
> > 00:00:00 +0000 +++
> > nitsche_method/overlapping_meshes/MeshIntersector.h 2010-03-16 14:39:09
> > +0000 @@ -0,0 +1,227 @@
> > +//
> > ========================================================================
> > ============= +//
> > +// Copyright (C) 2010-01-15 André Massing
> > +// Licensed under the GNU LGPL Version 2.1.
> > +//
> > +// Modified by André Massing, 2010
> > +//
> > +// First added: 2010-01-15
> > +// Last changed: 2010-03-08
> > +//
> > +//Author: André Massing (am), massing@xxxxxxxxx
> > +//Company: Simula Research Laboratory, Fornebu, Norway
> > +//
> > +//Description:
> > ========================================================================
> > ============= +
> > +#ifndef __MESHINTERSECTOR_H
> > +#define __MESHINTERSECTOR_H
> > +
> > +#include <vector>
> > +#include <map>
> > +#include <utility>
> > +
> > +#include <boost/shared_ptr.hpp>
> > +#include <boost/shared_array.hpp>
> > +
> > +#include <CGAL/Exact_predicates_exact_constructions_kernel.h>
> > +
> > +#include <CGAL/Nef_polyhedron_3.h>
> > +#include <CGAL/Polyhedron_3.h>
> > +#include <CGAL/Gmpz.h>
> > +#include <CGAL/Homogeneous.h>
> > +
> > +#include <CGAL/IO/Polyhedron_iostream.h>
> > +#include <CGAL/IO/Nef_polyhedron_iostream_3.h>
> > +
> > +#include <dolfin/common/Array.h>
> > +#include <dolfin/common/types.h>
> > +#include <dolfin/mesh/Mesh.h>
> > +#include <dolfin/mesh/MeshFunction.h>
> > +#include <dolfin/mesh/Point.h>
> > +
> > +#include "PrimitiveTraits.h"
> > +
> > +namespace dolfin
> > +{
> > + class Mesh;
> > +
> > + typedef std::vector<uint> EntityList;
> > + typedef std::vector<uint>::const_iterator EntityListIter;
> > + typedef std::map<uint, EntityList> EntityEntitiesMap;
> > + typedef std::map<uint, EntityList>::const_iterator
> > EntityEntitiesMapIter; +// typedef std::map<const Mesh
> > *,EntityEntitiesMap> MeshCutEntitiesMap; +
> > +
> > +// typedef CGAL::Homogeneous<CGAL::Gmpz> Kernel;
> > + typedef CGAL::Exact_predicates_exact_constructions_kernel Kernel;
> > + typedef CGAL::Polyhedron_3<Kernel> Polyhedron_3;
> > + typedef CGAL::Nef_polyhedron_3<Kernel> Nef_polyhedron_3;
> > + typedef Nef_polyhedron_3 Polyhedron;
> > +
> > + ///Defines a quadrature rule by a pair of points and weights.
> > + typedef std::pair<std::vector<Point>,std::vector<double> >
> > QuadratureRule; +
> > + class MeshIntersection;
> > +
> > +
> > + ///@todo:
> > + ///@todo Need a function which indicates the end of the iteration.
> > + ///Think about a better design after the first version is running.
> > + template <int dim>
> > + class MeshIntersectionIterator
> > + {
> > + typedef
> > Primitive_Converter<3,CGAL::Exact_predicates_exact_constructions_kernel>
> > PT; + typedef PT::Polyhedron Polyhedron;
> > +
> > + public:
> > + MeshIntersectionIterator(const MeshIntersection & overlapping_mesh);
> > +
> > + /// Step to the next cut cell and computes the relevant quantities
> > aferwards. + MeshIntersectionIterator<dim> & operator++();
> > +
> > + ///Check if we haved reached the end.
> > + bool end() { return _map_pos == _map_end_pos; }
> > +
> > + ///Return a quadrature rule, meaning a list of points and weights.
> > +// Quadrature_Rule quadrature_rule();
> > +
> > + ///Returns a presentation of the cut cell.
> > + Polyhedron polyhedron() { return _polyhedron ; }
> > +
> > + ///Returns a polyhedron as the presentation of the union of the
> > overlapping cells. + Polyhedron overlapping_polyhedron() { return
> > _overlapping_polyhedron; } +
> > + ///Returns a polyhedron as the presentation of the intersected part.
> > + Polyhedron overlapped_polyhedron();
> > +
> > + private:
> > +
> > + void compute_polyhedrons();
> > +
> > + const MeshIntersection & _overlapping_mesh;
> > +
> > + EntityEntitiesMapIter _map_pos;
> > + EntityEntitiesMapIter _map_end_pos;
> > +
> > + //Intersected MeshEntity
> > + MeshEntityIterator _entity_iter;
> > +
> > + //MeshIterator to iterate over the intersecting cells of the other
> > mesh. + MeshEntityIterator _overlapping_entity_iter;
> > +
> > + //Polydreon, which decodes the intersected part of the cell.
> > + Polyhedron _polyhedron;
> > +
> > + //Polydreon, which decodes the the polyhedron, which is built up by
> > the + //overlapping cells belonging to the other mesh.
> > + Polyhedron _overlapping_polyhedron;
> > +
> > + };
> > +
> > + ///This class present a collection of overlapping meshes and provides
> > + ///functionality to compute cell-cell, cell-facet overlaps.
> > + ///@todo Improve design, it is very unflexible concerning extension to
> > more than 2 meshes. + ///e.g. OverlapData should contain a map, which
> > maps the entity_entities_map to the corresponding + ///mesh, which the
> > entitylist is refering to.
> > + class MeshIntersection {
> > +
> > + ///Helper class to store mesh and corresponding data like
> > intersection maps + ///and meshfunctions.
> > + struct OverlapData {
> > + OverlapData(boost::shared_ptr<const Mesh> mesh);
> > + boost::shared_ptr<const Mesh> mesh;
> > + MeshFunction<uint> intersected_domain;
> > +
> > + EntityEntitiesMap entity_entities_map;
> > +
> > +// MeshCutEntitiesMap entity_entities_map;
> > + };
> > +
> > + public:
> > +
> > + ///Constructor takes a list/vector of meshes. The order of meshes
> > defines + ///also the "overlapp" priority, i.e. if 2 meshes overlap,
> > the one who + //appears later in the list actually covers the later
> > one.
> > + MeshIntersection(const Mesh & mesh_1, const Mesh & mesh_2);
> > +// MeshIntersection(boost::shared_ptr<const Mesh> mesh_1,
> > boost::shared_ptr<const Mesh> mesh_2); +
> > + ///Computes the overlap mapping. Mesh2 overlaps mesh1. Computes
> > (for + ///efficient reasons) in addition the boundary overlaps and
> > the artificial + ///interface.
> > + void compute_overlap_map();
> > +
> > + //Return meshfunctions. Only first test, think about better design,
> > for + //example class like OverlapData or suchlike.
> > + const MeshFunction<uint> & overlapped_domain() const;
> > + const MeshFunction<uint> & overlapping_domain() const;
> > + const MeshFunction<uint> & overlapped_boundary() const;
> > + const MeshFunction<uint> & overlapping_boundary() const;
> > +
> > + private:
> > + template<int dim>
> > + friend class MeshIntersectionIterator;
> > +
> > + const boost::shared_ptr<OverlapData> _overlapped_domain;
> > + const boost::shared_ptr<OverlapData> _overlapping_domain;
> > +
> > + const boost::shared_ptr<OverlapData> _overlapped_boundary;
> > + const boost::shared_ptr<OverlapData> _overlapping_boundary;
> > +
> > + };
> > +
> > +template <int dim>
> > +MeshIntersectionIterator<dim>::MeshIntersectionIterator(const
> > MeshIntersection& overlapping_mesh) + :
> > _overlapping_mesh(overlapping_mesh)
> > +
> > +{
> > + _map_pos =
> > overlapping_mesh._overlapped_domain->entity_entities_map.begin(); +
> > _map_end_pos =
> > overlapping_mesh._overlapped_domain->entity_entities_map.end(); +
> > + ///Oh herregud, please simplify datastructures!!!!
> > + _entity_iter =
> > MeshEntityIterator(*(overlapping_mesh._overlapped_domain->mesh), +
> > overlapping_mesh._overlapped_domain->mesh->topology().dim()); +
> > _entity_iter[_map_pos->first];
> > +
> > + _overlapping_entity_iter =
> > MeshEntityIterator(*(overlapping_mesh._overlapping_domain->mesh),
> > + overlapping_mesh._overlapping_domain->mesh-
>topology().dim()); +
> > _overlapping_entity_iter[_map_pos->second.front()];
> > +
> > +}
> > +
> > +template <int dim>
> > +MeshIntersectionIterator<dim> &
> > MeshIntersectionIterator<dim>::operator++() +{
> > + //Update the entity entities mapping.
> > + ++_map_pos;
> > + //Bit clumsy, abusing operator[] to set
> > + _entity_iter[_map_pos->first];
> > + _overlapping_entity_iter[_map_pos->second.front()];
> > +
> > + ///@todo Change this. Use lazy initialization.
> > + compute_polyhedrons();
> > + return *this;
> > +}
> > +
> > +template <int dim>
> > +void MeshIntersectionIterator<dim>::compute_polyhedrons()
> > +{
> > + Polyhedron cell_polyhedron(PT::datum(_entity_iter[_map_pos->first]));
> > + _overlapping_polyhedron.clear();
> > + for (EntityListIter index = _map_pos->second.begin(); index !=
> > _map_pos->second.end() ; ++index) + {
> > + _overlapping_polyhedron +=
> > PT::datum(_overlapping_entity_iter[*index]); + }
> > + cell_polyhedron -= _overlapping_polyhedron;
> > +}
> > +
> > +template <int dim>
> > +typename MeshIntersectionIterator<dim>::Polyhedron
> > MeshIntersectionIterator<dim>::overlapped_polyhedron() +{
> > + Polyhedron cell_polyhedron(PT::datum(_entity_iter[_map_pos->first]));
> > + return cell_polyhedron * _overlapping_polyhedron;
> > +}
> > +
> > +
> > +} //end namespace dolfin
> > +
> > +#endif // ----- #ifndef __MESHINTERSECTOR_H -----
> >
> > === added file 'nitsche_method/overlapping_meshes/PrimitiveTraits.h'
> > --- nitsche_method/overlapping_meshes/PrimitiveTraits.h 1970-01-01
> > 00:00:00 +0000 +++
> > nitsche_method/overlapping_meshes/PrimitiveTraits.h 2010-02-10 03:14:09
> > +0000 @@ -0,0 +1,69 @@
> > +//
> > ========================================================================
> > ============= +//
> > +// Copyright (C) 2010-02-02 André Massing
> > +// Licensed under the GNU LGPL Version 2.1.
> > +//
> > +// Modified by André Massing, 2010
> > +//
> > +// First added: 2010-02-02
> > +// Last changed: 2010-02-03
> > +//
> > +//Author: André Massing (am), massing@xxxxxxxxx
> > +//Company: Simula Research Laboratory, Fornebu, Norway
> > +//
> > +//
> > ========================================================================
> > ============= +
> > +#include <dolfin/mesh/Vertex.h>
> > +#include <dolfin/mesh/Point.h>
> > +
> > +#include <CGAL/Nef_polyhedron_3.h>
> > +#include <CGAL/Point_3.h>
> > +#include <CGAL/Nef_polyhedron_2.h>
> > +#include <CGAL/Polyhedron_3.h>
> > +
> > +namespace dolfin
> > +{
> > +
> > + template <int dim, typename Kernel > struct Primitive_Converter ;
> > +
> > + template<typename Kernel> struct Primitive_Converter<2,Kernel>
> > + {
> > + typedef CGAL::Polyhedron_3<Kernel> Polyhedron;
> > + typedef CGAL::Nef_polyhedron_2<Kernel> Nef_polyhedron;
> > + typedef Nef_polyhedron Datum;
> > + typedef typename Kernel::Point_3 Point_3;
> > +
> > + static const int dim = 2;
> > +
> > +// static Datum datum(const MeshEntity & entity) {
> > +
> > +// return Datum(point);
> > +// }
> > + };
> > +
> > + template<typename Kernel> struct Primitive_Converter<3,Kernel>
> > + {
> > + typedef CGAL::Polyhedron_3<Kernel> Polyhedron_3;
> > + typedef CGAL::Nef_polyhedron_3<Kernel> Polyhedron;
> > + typedef Polyhedron Datum;
> > + typedef typename Kernel::Point_3 Point_3;
> > +
> > + static const int dim = 3;
> > + static Datum datum(const MeshEntity & entity) {
> > + VertexIterator v(entity);
> > + Point_3 p1(v->point());
> > + ++v;
> > + Point_3 p2(v->point());
> > + ++v;
> > + Point_3 p3(v->point());
> > + ++v;
> > + Point_3 p4(v->point());
> > +
> > + Polyhedron_3 Q;
> > + Q.make_tetrahedron(p1,p2,p3,p4);
> > +
> > + return Datum(Q);
> > + }
> > + };
> > +
> > +} //end namespace dolfin.
> >
> > === added file 'nitsche_method/overlapping_meshes/SConstruct'
> > --- nitsche_method/overlapping_meshes/SConstruct 1970-01-01 00:00:00
> > +0000 +++ nitsche_method/overlapping_meshes/SConstruct 2010-03-16
> > 14:39:09 +0000 @@ -0,0 +1,13 @@
> > +import os, commands
> > +
> > +# Get compiler from pkg-config
> > +compiler = commands.getoutput('pkg-config --variable=compiler dolfin')
> > +
> > +# Create a SCons Environment based on the main os environment
> > +env = Environment(ENV=os.environ, CXX=compiler)
> > +
> > +# Get compiler flags from pkg-config
> > +env.ParseConfig('pkg-config --cflags --libs dolfin')
> > +
> > +#Program
> > +env.Program('overlapping_meshes',['MeshIntersector.cpp','main.cpp'])
> >
> > === added file 'nitsche_method/overlapping_meshes/demo.py'
> > --- nitsche_method/overlapping_meshes/demo.py 1970-01-01 00:00:00 +0000
> > +++ nitsche_method/overlapping_meshes/demo.py 2010-02-10 03:14:09 +0000
> > @@ -0,0 +1,35 @@
> > +
> > +__author__ = "Andre Massing (massing@xxxxxxxxx)"
> > +__date__ = "2010-01-27 "
> > +__copyright__ = "Copyright (C) 2010 Andre Massing"
> > +__license__ = "GNU LGPL Version 2.1"
> > +
> > +from dolfin import *
> > +from numpy import *
> > +
> > +if not has_cgal():
> > + print "DOLFIN must be compiled with CGAL to run this demo."
> > + exit(0)
> > +
> > +# Create meshes (omega0 overlapped by omega1)
> > +#mesh_1 = UnitCircle(20)
> > +mesh_1 = UnitSquare(10, 10)
> > +
> > +mesh_2 = UnitSquare(10, 10)
> > +
> > +# Access mesh geometry
> > +x = mesh_2.coordinates()
> > +
> > +# Move and scale second mesh
> > +#x *= 0.5
> > +x += 0.5
> > +
> > +overlap = OverlappingMeshes(mesh_1,mesh_2)
> > +overlap.compute_overlap_map()
> > +
> > +overlapped_domain = overlap.overlapped_domain();
> > +print overlapped_domain
> > +
> > +p = plot(overlapped_domain, rescale=False)
> > +
> > +interactive()
> >
> > === added file 'nitsche_method/overlapping_meshes/main.cpp'
> > --- nitsche_method/overlapping_meshes/main.cpp 1970-01-01 00:00:00 +0000
> > +++ nitsche_method/overlapping_meshes/main.cpp 2010-03-05 23:36:16 +0000
> > @@ -0,0 +1,108 @@
> > +//
> > ========================================================================
> > ============= +//
> > +// Copyright (C) 2010-01-28 André Massing
> > +// Licensed under the GNU LGPL Version 2.1.
> > +//
> > +// Modified by André Massing, 2010
> > +//
> > +// First added: 2010-01-28
> > +// Last changed: 2010-02-15
> > +//
> > +//Author: André Massing (am), massing@xxxxxxxxx
> > +//Company: Simula Research Laboratory, Fornebu, Norway
> > +//
> > +//
> > ========================================================================
> > ============= +
> > +#include <dolfin/mesh/dolfin_mesh.h>
> > +#include <dolfin/common/types.h>
> > +#include <dolfin/plot/dolfin_plot.h>
> > +
> > +//#include <CGAL/IO/Qt_widget_Nef_3.h>
> > +//#include <qapplication.h>
> > +
> > +//#include <dolfin.h>
> > +
> > +#include "OverlappingMeshes.h"
> > +
> > +using namespace dolfin;
> > +using dolfin::uint;
> > +
> > +int main ()
> > +{
> > +// UnitSquare mesh_1(10,10);
> > +// UnitCube mesh_1(10,10,10);
> > + UnitCube mesh_1(10,10,10);
> > +
> > +// UnitSquare mesh_2(10,10,10);
> > +// UnitCube mesh_2(10,10,10);
> > + UnitSphere mesh_2(10);
> > +
> > + MeshGeometry& geometry = mesh_2.geometry();
> > +// double w = 1;
> > + for (VertexIterator v(mesh_2); !v.end(); ++v)
> > + {
> > + double* x = geometry.x(v->index());
> > +// x[0] = cos(w)*(x[0]-0.5) - sin(w)*(x[1]-0.5);
> > +// x[1] = sin(w)*(x[0]-0.5) + cos(w)*(x[1]-0.5);
> > + x[0] *= 0.5;
> > + x[1] *= 0.5;
> > + x[2] *= 0.5;
> > +
> > + x[0] += 0.4;
> > + x[1] += 0.4;
> > + x[2] += 0.4;
> > + }
> > +
> > + MeshIntersection overlap(mesh_1,mesh_2);
> > + overlap.compute_overlap_map();
> > +
> > + MeshIntersectionIterator<3> cell(overlap);
> > +// Nef_polyhedron_3 cut_polyhedron =
> > + cell.polyhedron();
> > + cell.overlapped_polyhedron();
> > + cell.overlapping_polyhedron();
> > +
> > +// Nef_polyhedron_3 overlapped_polyhedron =
> > cell.overlapped_polyhedron(); +// Nef_polyhedron_3
> > overlapping_polyhedron = cell.overlapping_polyhedron(); +
> > +
> > +// uint_set cells;
> > +// mesh_1.all_intersected_entities(BoundaryMesh(mesh_2),cells);
> > +
> > +// MeshFunction<uint> intersection(mesh_1, mesh_1.topology().dim());
> > +// intersection = 0;
> > +
> > +// for (uint_set::const_iterator i = cells.begin(); i != cells.end();
> > i++) +// intersection[*i] = 1;
> > +// plot(intersection);
> > +
> > +// BoundaryMesh boundary_1(mesh_1);
> > +// BoundaryMesh boundary_2(mesh_2);
> > +
> > +// cells.clear();
> > +// boundary_1.all_intersected_entities(boundary_2,cells);
> > +
> > +// MeshFunction<uint> intersection(boundary_1,
> > boundary_1.topology().dim()); +// intersection = 0;
> > +
> > +// for (uint_set::const_iterator i = cells.begin(); i != cells.end();
> > i++) +// intersection[*i] = 1;
> > +// plot(intersection);
> > +
> > + std::cout <<"overlapped_domain:" << std::endl <<
> > overlap.overlapped_domain().str(true); +
> > plot(overlap.overlapped_domain());
> > +
> > + std::cout <<"overlapped_boundary:" << std::endl <<
> > overlap.overlapped_boundary().str(true); +
> > plot(overlap.overlapped_boundary());
> > +
> > + std::cout <<"overlapping_boundary :" << std::endl <<
> > overlap.overlapping_boundary().str(true); +
> > plot(overlap.overlapping_boundary());
> > +
> > + return 0;
> > +// QApplication a(argc, argv);
> > +// CGAL::Qt_widget_Nef_3<Nef_polyhedron_3>* w = new
> > CGAL::Qt_widget_Nef_3<Nef_polyhedron_3>(cut_polyhedron); +//
> > a.setMainWidget(w);
> > +// w->show();
> > +// return a.exec();
> > +
> > +}
> >
> > === added directory 'nitsche_method/polyhedrons'
> > === added file 'nitsche_method/polyhedrons/SConstruct'
> > --- nitsche_method/polyhedrons/SConstruct 1970-01-01 00:00:00 +0000
> > +++ nitsche_method/polyhedrons/SConstruct 2010-03-25 23:33:08 +0000
> > @@ -0,0 +1,17 @@
> > +import os, commands
> > +
> > +# Get compiler from pkg-config
> > +compiler = commands.getoutput('pkg-config --variable=compiler dolfin')
> > +
> > +# Create a SCons Environment based on the main os environment
> > +env = Environment(ENV=os.environ, CXX=compiler)
> > +env.Append(CPPPATH = '/usr/include/qt4/')
> > +env.Append(CPPPATH = '/usr/include/qt4/Qt')
> > +env.Append(CPPPATH = '/usr/include/qt4/QtGui')
> > +
> > +env.Append(CXXFLAGS = '-ggdb')
> > +
> > +# Get compiler flags from pkg-config
> > +env.ParseConfig('pkg-config --cflags --libs dolfin')
> > +
> > +env.Program(['intersect_polyhedrons.cpp'])
> >
> > === added file 'nitsche_method/polyhedrons/intersect_polyhedrons.cpp'
> > --- nitsche_method/polyhedrons/intersect_polyhedrons.cpp 1970-01-01
> > 00:00:00 +0000 +++
> > nitsche_method/polyhedrons/intersect_polyhedrons.cpp 2010-02-10
03:14:09
> > +0000 @@ -0,0 +1,118 @@
> > +#include <CGAL/Simple_cartesian.h>
> > +#include <CGAL/Exact_predicates_inexact_constructions_kernel.h>
> > +#include <CGAL/Exact_predicates_exact_constructions_kernel.h>
> > +
> > +#include <CGAL/Nef_polyhedron_3.h>
> > +#include <CGAL/Nef_polyhedron_2.h>
> > +#include <CGAL/Polyhedron_3.h>
> > +#include <CGAL/Gmpz.h>
> > +#include <CGAL/Homogeneous.h>
> > +
> > +#include <CGAL/IO/Polyhedron_iostream.h>
> > +#include <CGAL/IO/Nef_polyhedron_iostream_3.h>
> > +
> > +//#include <CGAL/IO/Qt_widget_Nef_3.h>
> > +//#include <qapplication.h>
> > +
> > +#include <iostream>
> > +
> > +#include <vector>
> > +#include <list>
> > +
> > +//typedef CGAL::Simple_cartesian<double> K;
> > +//typedef CGAL::Simple_cartesian<double> K;
> > +//typedef
> > CGAL::Exact_predicates_inexact_constructions_kernel<CGAL::Gmpz> K; +
> > +//typedef CGAL::Exact_predicates_inexact_constructions_kernel K;
> > +typedef CGAL::Exact_predicates_exact_constructions_kernel K;
> > +typedef CGAL::Polyhedron_3<K> Polyhedron;
> > +typedef CGAL::Nef_polyhedron_3<K> Nef_polyhedron;
> > +
> > +//typedef CGAL::Homogeneous<CGAL::Gmpz> K;
> > +//typedef CGAL::Nef_polyhedron_3<K> Nef_polyhedron_3;
> > +
> > +typedef K::Tetrahedron_3 Tetrahedron;
> > +typedef K::Triangle_3 Triangle;
> > +typedef K::Segment_3 Segment;
> > +typedef K::Point_3 Point;
> > +
> > +typedef Polyhedron::Vertex_iterator Vertex_iterator;
> > +typedef std::list<Triangle>::iterator Tri_iterator;
> > +
> > +int main()
> > +{
> > +
> > + Point a(1.0, 0.0, 0.0);
> > + Point b(0.0, 1.0, 0.0);
> > + Point c(0.0, 0.0, 1.0);
> > + Point d(0.0, 0.0, 0.0);
> > +
> > + Point A(0.1, 0.0, 0.0);
> > + Point B(0.0, 0.1, 0.0);
> > + Point C(0.0, 0.0, 2.0);
> > + Point D(0.0, 0.0, 0.0);
> > +
> > + //Build a point tetrahedron
> > + Polyhedron P;
> > + P.make_tetrahedron();
> > +
> > + Polyhedron Q;
> > + Q.make_tetrahedron(a, b, c, d);
> > + Nef_polyhedron NQ(Q);
> > +
> > + Polyhedron R;
> > + R.make_tetrahedron(A, B, C, D);
> > + Nef_polyhedron NR(R);
> > +
> > + Nef_polyhedron NQ_NR = NQ * NR;
> > +
> > + Polyhedron F;
> > + F.make_triangle(A,B,C);
> > + Nef_polyhedron NF(F);
> > +
> > + std::cout << "Exact_predicates_exact_constructions_kernel +
> > SNC_indexed_items" + << std::endl
> > + << " allows efficient handling of input "
> > + "using floating point coordinates"
> > + << std::endl;
> > +
> > + Nef_polyhedron N = NF * NQ;
> > +// Nef_polyhedron N = NF;
> > + std ::cout <<"Nef_Polyhedron Tetraeder: " <<std::endl;
> > + std::cout << NQ ;
> > + std ::cout <<"Nef_Polyhedron Triangle: " <<std::endl;
> > + std::cout << NF ;
> > + std ::cout <<"Nef_Polyhedron Intersection: " <<std::endl;
> > + std::cout << N ;
> > +
> > +
> > +// if(N.is_simple()) {
> > +// N.convert_to_polyhedron(P);
> > +// std::cout << P;
> > +// }
> > +// else {
> > +// std::cout << N;
> > +// }
> > +
> > +
> > +// CGAL::set_ascii_mode( std::cout);
> > +// for (Vertex_iterator v = P.vertices_begin(); v != P.vertices_end();
> > ++v) +// std::cout << v->point() << std::endl;
> > +// for (Vertex_iterator v = Q.vertices_begin(); v != Q.vertices_end();
> > ++v) +// std::cout << v->point() << std::endl;
> > +
> > +// if (Q.is_closed())
> > +
> > +// Nef_polyhedron_3 NF(F.vertices_begin(),F.vertices_end());
> > +
> > +// Nef_polyhedron_3 N = NF * NQ;
> > +// std::cout << N;
> > +
> > + return 0;
> > +
> > +// QApplication a(argc, argv);
> > +// CGAL::Qt_widget_Nef_3<Nef_polyhedron_3>* w = new
> > CGAL::Qt_widget_Nef_3<Nef_polyhedron_3>(NQ_NR); +// a.setMainWidget(w);
> > +// w->show();
> > +// return a.exec();
> > +}
> >
> > # Begin bundle
> > IyBCYXphYXIgcmV2aXNpb24gYnVuZGxlIHY0CiMKQlpoOTFBWSZTWUuYf2UAqZL/lH/2YDJ//
> > ///
> > /////v////8AIAgAYLbePKHuz1mwfd67Wt7tOF9vuyvp8g6pfe5fO5xd727EVSXQfT3b1zts
> > 7bN2
> > 599TPbdQ8++bzkPd7qtsU++7u2mvl67stt2HkHtBbffcON7mRRC+hdve5thsACjXvY6Nj5ef
> > fc23
> > z29967rcBfb3nuB66Hnn3sGPDF3du7W7TtYbn14Hb77aa+3zxlh7fcvj7ODbq+Iz733xrZ90
> > u+8s
> > G1dXTzZT1682PHvOdam93mvHXa2X21Wu5vdm7nG2Xbrdw7rEpL6YvsYo+mRfb3DzjWsk9vcY
> > FUnQ
> > myoR7e47sSVae+I5jqUusDlbrWSHzIAUEHuegda93u9a13YzvY6Oh8Qc+82667vl9n195O97
> > 3Q++
> > 2q7bVma1dLifD7456r53NBKJV1rB99u+xqfS31LSueuphtV1x3Hpe7jozrzr3L6ds5vffeTq
> > fPcV
> > e8Zeu5gteTWWq73d6ttmprfeH3ffbtWpdZRZmMzFStarTbsN1bRkCzNL7jna92JXGunCKF0t
> > lCts
> > rbXXOpYZBbLs7Q3t6A9eV2oYW2bWqqO2u1vfdT3aN732+9jVpRteH1t7XmaG2rVlrbWtk0VQ
> > C2H2
> > 7h924jPnnhJECAAII0AEAmk9CnlMymUYTyniIAGhkGRo0AJQQwoCIgE0FR400o9T2kJ6mmyR
> > oep5
> > QAAAGgAABKYUSaKT0mjNJkaBojTTJNNGj1GJozUD1ANGgGgDJ6gAJNJIQhGTJpoCJsqfpMU9
> > Mmqn
> > 6HqKbT9U0RpvVPU9T1NNGnlHlAekD0gBEkQFGg0maJiaNMpiGjIyBM0mEammnpU/J6mSm2qe
> > p6aj
> > GSaGAiSIIyaEyJppNoTEnqbBEKeU/1U/Snij1Bp6h6j1NqNA0AAHqDTaI9PgoqzssqJGCkiD
> > UFBk
> > RJFESiCKEgqodgwSooD42AKLeACdoEQAaAZdfSRAWrf/tVb//Lq1mEJCsEREZBYLFRWAlt/o
> > /u/0
> > aJqMFBZHk1qcODrrLpA1JCMUSISMRkgqQiJIsiMCAkHoAJD76fej972W7VDVtyv9v+0wnKJH
> > 8RsV
> > f4o1IskUwSwREAUAYqoSIiyAiMYiDEUBViiqMYI/20qxT9v5d+oaO9K9e/hbc0Igwn7Z2pJZ
> > mGH5
> > W0LNx5378pP+SXO/2ew7f6/k8650vzaN5j/f+jqIlteUF01xvnL+ysjBf1v/ccZSGnqqotY4
> > rP7N
> > jSK64PpXCwTCxVKqp3RKmbHQ1r6Nj07bGxqCfTeWtQTCxVlReuORnfqhtlJ66wPKNvzsSfxd
> > 6CG9
> > v6QQxP0cBXuz9TgdiuWrhgp58D9HWikNn/z+js20w6hrbU481quJTq4ydRJcGf+3vxrmlAL5
> > ijn2
> > 2WSN+zyrilcwUKcc4eH9//eFTLW6uwjIhe8TaLjvV/bSqvHSjt5Y3rrv6mmg864CDqJA3+ef
> > oMJE
> > cv7MUV9ub/b/rc0Qrab2q88qgb9+3s/08T589FsKnxtP7Wu7Pl3dnBqOfZ460jGLNkOOfGc1
> > FVPR
> > S+oYfb3UmhFJUUhPQMhJvrXfqT96YqqqiH30u297wcQrWHuYfx70DQ9HOlIaFj8EmkFmbNhs
> > MgdG
> > Yq5tg2mc7POztEOXFqHHFy/jmzNkvhVFECqqgrqJwCOb2Z/G+iXcoj3fz3bA+/Ky+Vdc2V82
> > DCg6
> > JtewTGqW04KLEfn0Ztut40Ool9t9+uurH1Tjb2nidk40yIXH0bCoPL6FoO3W+LENippPlKEY
> > vC2E
> > WpSqaxwErVh01k3LLnQonLxQ5M9Ts+CQ9ZteHnlz4e3s+51r9reH33NtLnJNLwN2Ot0aZ1Xd
> > M9Te
> > 5vfg6Pa+DFrJx716CURZz/ZnGrou1umDnTpon7E705IvG9ns8vd6/e/DZ7ex6d8CkbLLmMmH
> > 2wR7
> > 6+49uEH8LsM3hB/oQyzjVPSy4p0NuTU1RS5wYfQOk/xPgX8V/xL2Pm8z1XOzbrnZ8bhR77pU
> > JZU4
> > p3/D0N60uqYurqcNa6eaw8PrZh8EajK7Zaf3fp+J8VQXp9ahq3t+eGV4r49rEPdgvZj0UKJk
> > ReLK
> > rCBNpNM82HaJt5vKEQcZB7/5tcXAWvUhj66h6g2ZHv3/Gw9PmuTPSX0yrSSGtffdy6b5MmZO
> > MDPZ
> > f4RhIs1dRv641SMbRGhxM8A4sxAkFYVXtA0ZK4aCZRa7HSHlSUyIgr5U+3cpnlZJPUnLViIb
> > deGB
> > kOu4lsiyOjDBA/V1U0cNADhN5FAD0+FUUJ2DqehHgSnCaE6rYI4nR3V0c7DNPTJ5DrLU35XT
> > O7Rx
> > v5X2bw6melONrBbDoWV7OqzePGo2trkojIdkVsqoOKtglJ6MGjTj/ogIzbbgphLCE5tCwiXA
> > gqcI
> > kA44tY0AxOu1d364zw1fO7Pb1UwYKaNtlOegxOp5nbEbWu7fhuveHKEwoxZvCJPNPCTsuGZ5
> > eOoY
> > xaDybGvq6/su9I9aSQBWZbfglALl7XSwg4qmCvby25GoYIdrDcy+kftYb92/Iy1x1DhKyaQr
> > Cw+l
> > zfvz3e44nLfdIph1esq3ZzOTP9m3d7bpabmUKx5PcRJDELnE8X/tLZoQlSMEYQghTFW1RTxO
> > uTw7
> > EH7w64zzdnc9IfT9O2OWVTdWv4fX+/rSJVNQpXasjNw5lRsfPvf24iP0Vh/Xcf0vzLfTvXth
> > 52tt
> > CrQoHxENKzOuNFkIxgiUYCiiqGzAxmmUSKIk+T6tzNZmB9ds2+UdIVPoXM9zcMgexDgO/KM6
> > bJEv
> > MoXWrnKXrPxl4yY+NQvocvGam8Tss266ZlO22ewYfwJt42dOfzzr30r167bcEtX1Ocrod/8M
> > 2Djs
> > KLukNIVO8tMiT+F9DJrTSMB6d1MXXxvmHoG0l2eXfo9LDQL52XyaybvWwdtYNV6dVNumtCE1
> > pndC
> > d7Ces9NDpz5Xg7MwX7GbbU73Z6m9222pqOVFJO5q7HPBXGxAmx8i4dmUGyZDRc6cOOcxKQMc
> > XHGJ
> > DZvwSgjBU6NS+Vw0ynV+Xd5/z5d0nH3ZgzAnQV6GMA8wVwKYKsFwM9RvH3PCyNNuO4fYnRzs
> > ulTh
> > 1E07uzoQfuvqPlf1yb8snH000zj7hu6cqvGrqWlFY03zIpiUuqQRkwt2gxFluC01p016t7Sc
> > ioBQ
> > hSmpWmGGDKKdYOYOzv3/h/3u9htBr1A6mhtavRCMjxsv3M6qL6r4OPLjzK+qsq5wekQ2nXHy
> > 9lah
> > dZjGobbz9vU+lOp6MOSTkhuckoEo7NRjDGQrAFYICKSe7bbGr1O9OXLnxv2cdetcHPHDcY0a
> > d7Wd
> > aq3LNBzYgGV+lU7BFVITrvBhYJIEPrYiOBHjFCprAOMU4wROUXAgbQcYDyg4QHKKbRMo5RAr
> > GlHC
> > JzhcKUR2h+kP1kZPCHgdDHMNbmn2FYT3cEJ3AwEYooiiqsEEkWa/D1dpt12vlep67ee9X0bb
> > Phq0
> > c5I7b5vsFnId048N+HD5ZciBopVJrRAuCpU3ERqioU00Xq7LG1I5VZfKjqZV1WqbIpWoxpsm
> > WwPF
> > zmQrUyVSLpXzMO65w9PnWcRSkTVYGaszptLDEM/HGnbY22wuUEePVzwhnQxIerSknawU/DKd
> > dTaC
> > eZvCJhGCScYjUCVKDdKNvD5XURRm7sxJ6MeDeWW2St0dEmRzYIdsmgog3xrxpRQ18FrDUKjG
> > FVJV
> > l/N+4pUVRt706fMqp7fljb8mxkt5L/hZLQk5PZzsmsS7HDtopUFRFdvVlfC6C/rhqTBga/cP
> > TVNC
> > +zqoGvmxcY3IJDhgd+yrpuiFWo4Tgq5z11A65cu3BAAF1z0+WgbVVXKkpvEGppGpcVVRjAMH
> > HW6s
> > kCHw6ZllRMYhCAqjBVUVSRZWNLCDGosrICigsUUkJUAVZRRRISFSUUUQgWDRCKoAVD61ZKhI
> > kBYR
> > B64iFog2gCyKDdqhlFFYLEGVBEGIFEgKLAFCMGQ7Q5YSix2ysFRINcdCh73b2Zd/frMO+2HA
> > 9f17
> > Xlz5c63W++/PjXHTsiEIB2CqqqhEQiIAKBIqixBWEoohNAkQLMZA5emktAbQVAqDh8mFivq4
> > /i5A
> > OsM/DNPop33ocAN8XYODUSEg85KwHA0BE+msb7DbFPuSvAful6nBWJAKwhpQQAqBPax6MHfD
> > /PSP
> > /f2KsSr0O7w7e7v8Ed3hWCvs7T29upk8pnnNAWCbzdqhBqFCfLXBkFDc0YGBBYZqDdoIGISV
> > qsUV
> > SSBuwN5sWBKRNx31Q5BEMh+ScLhuIjMPR7VXIH/SM/Wzc6yeW9JoJpBZDrQMsGPlmk+W2znW
> > wJsn
> > 1DdTbuKGt2BoQRnaYNYkb01GKZIGQWqOX1IcnfhsaISKvBwWLCYOSbnmwDBhpCig1Bd8JsYF
> > eTNk
> > kUi5xSSadDNSKtQZBCRGU0nuPqPX/6Pj+s536bECgusxzMnHwF7Y8z6jt/8w+9AdYOwDMMCs
> > MCoH
> > hngfrM5IcpDpBnIBD2llLxTQmIBoWA/+/22tgbvvd8DpAPWb4vBAkUJAdxe1+vywRh6T/f+Y
> > lIYT
> > bfc70WKYNjB7ev59Dbc5PUhwhSZ7Ify5OL9Y0OobgL/Pchxg8Uc/KprF1LLlZyufgDJYtYzl
> > XouH
> > 7IZ9ldcd4V3Vjlltk1axYVF2A7DDE0h1A8hfdsG69oXzDaSf3n+bwknAenefhzVjsoXFMLEy
> > CrJa
> > ime7H+W94E1kknE7Q9KeXruw9WZeLRbTc8jHs+9E4ftH5E5s/mv5VqI4cMAHE/UfkSb7QJC5
> > n3sz
> > SKAdgokQIiiHwJEgPvFA3A8LUOmrFrJJJJsGksPEm/Q3SQNz0Obc98480syUfEPORV6f2pDg
> > GwVv
> > fTHh36CGScVMEM4hTqajP9RgqhHgtU1Qs5L7F7g8QYKlm2AVncC3oHh3mm5667YnBH7/c93A
> > PJq7
> > urzcb4B2xftIiHqiO+RHRDpB6UzSUlgaSqenpBF5/+DLuUDgsgL9lKlQCRQIQCRWQgqgskFC
> > LBRQ
> > EZCDICAEhIc4KvMzopWQkWDAPagv/YiDj1OJLv9jr1eHte+SIX/lGQ5AqlJpFUvdGDyhRhoS
> > slRq
> > 0XGrK2YlISbL9AswDx7z6iv7JAItIDhubdcK3fXp4/bij+0a9CVEidpw7bbaXM+xlUSII1kX
> > HHHk
> > 5aNs56LuwtzsY3erFaTBCYjstHQtq2rJqRRdMECpnDC0MkNMVkVaTYYhQp2dWMqnHF4N7aK2
> > HLXO
> > svTrzOambQtPSNLhZU0lmuLOsd56wK9dS4rd8dVvOlc8PxHsGR5/hmKF61GEjJkXZaQMM9JQ
> > lA0k
> > 8aqpRnUpZ11O2++ePgBzSDnrqiQpoVcIWwgC+FbM33u7M4PaFlllKULaEtprzb07jz9uVDwV
> > 01vj
> > TKvXVWlVtLXjq6a2tzU7sFI9rq+l83S7q264DZ2IXuz6WLHFwTW3QZ7S+6cXlFnvnUxT5nTi
> > LFBQ
> > zSpUW5ecbb5hXVMqY02PDGMsY1w9eWhWgcnFwlp/SjBmXw7eZvWsWvxa7AzyMc8yFJkYzpos
> > tqy2
> > t7vGl2y9mI04+XdIUJ1hwZonikl1zO/GJLMRszODKFLWmHetqioS1wqqGlkamNarRgGe6V6d
> > ancS
> > WrE6dIWcNWzOqQpUs0mWxGVWNi4hc1TYWKYlcrmGEDNtpYVNKguGRjO2cLxWCElQxyxtppRa
> > GRln
> > e/QbnvH+B5086dyalgsOLQ0OXezsPHj3f2vkPGfdP1NerPX6vq+I9829ff/KJnwcgDEAoPZQ
> > eUbA
> > hcGOAUampZ+cdMhtE3RicJWIwUy01aTBEgYyAYbRNB3aWaHRptljPntAJzYIULDLHlsGEbOz
> > zc3h
> > 9lrFFX60/F3viPUfsf+L9j9lbF56nJXeiHXmuyD6jxrNoxfdR6C7Ll05WK9jT+B1gh25EzmS
> > EGB5
> > cm/Z/I7BGQtDTzUSdQxVU/933Q1eIfaEjA7y/q04++AZ/VPO9urdNPyPybJkmwBhhEulODSW
> > ALTq
> > ed7JO4OEjy8m3fY6niuaWdnktDc7bbbnd3HHKLDj3oZuJTmBlrLkluBxXFbxYOVmWZyQcORw
> > Vqnn
> > jy6JhxioAwIQZrOQDKWhrqXgSW8SwgoQZ05HbGHsESSZIR4i8ha9BL+JI+LuhfiUXNchu2CS
> > oULs
> > D+Ac3/dyP3zwPhQCcgmClLBu81s/2M5hPpChvnXw8T534NJMIXnfl16o8EAMnYQon3h9I01Q
> > hSnq
> > 1N8LMH/PYKFwoVg5YKU62dfl/PwXH1BNvn7EXCsYppqRpBqEgrh01/MSioxaofqC0JTZfqb7
> > /8ZL
> > 3R5z/jlttuiZkWZLbbb3kyVmS2219QTQBMfXQFsBzkXxMce3Wyvi/DarayRcw1wzDRRRo0c/
> > yHmD
> > kbPwPZwatOBH/2TbeIUf9kfGDyoJcuO3tsf+AG4BAb/r5EeG26wBdW5oMCzHZxpO8f3hFQtj
> > Hbgy
> > MQXF/BtOnA0cM+oiJEQRIiREiIiAxIxBiREiJERBPj0j2nPasQOGZnwKO85ev09xO8G0FKRg
> > kJRR
> > QLIlFmYZDju2wmNd7wUB/xjBiDNT0DiSlxvxoQlPO7NbhtkNDPDlLD0CiiiiiwYxjGMRFFFF
> > Dmnm
> > O/z7Hx/f6OrjYs3npmGTJmSSSSQmTG2x48mQmTJkknOeqaA+Tyh54EzMd3qzRzBAuBYqxpS9
> > SVI4
> > crFQbKiooAlIoSbUiVlVVIjjP6vxu9PrAOGCtpCEHNHaSnXt2HCyTrPo3hnhfDUzq2a/FqWm
> > Z1Zr
> > JHHPyvWnxuSSSfe8Xbu6BEZ7Pvyeo/V447bAR032AJJ+9CYmZKuEHp++BIrBaMnNlbXA6q14
> > lvFu
> > h7T7hWC9goo9sC7J7ux9Ga7blMb7tZmV3ZoRYvZRlxeBUM4xIgspqPXwlf4BQUL9WbOA+reQ
> > e7un
> > k0JIhA0ucgPVIkQlYzejbhUYsZmiEvd8WLyfyNtpNtMC5rWaMJk93x6NYW2l1mKVg4KSoJxR
> > mqSm
> > l+R2kJK+7bVQGGBQI5jrn540aYI8Jw+aQ632zVO6+ijkrk/Kzj08BrH0+zr68NH58/vP/NFJ
> > WgtR
> > RknbCij8+MGlzY7MKQ11S6EJkpfmyvhfadJLax7WeRCFvZW/cP1Byy6I17EjN2DxCSDg4YuK
> > WbeN
> > 7wiWta0LiX3FKQUxPGCebySuLLDNj4CrQPiN4yMYjBpXtDjF0kK6tqkfkipzni9+eby6Oy7s
> > 0HrB
> > 1sXl6b3JrZz1xH6r0Cf1WZVQ/gXzftD207oG21cKwo4v7V1fnp5h7CdrU06hjWXVVykyuXce
> > r8sN
> > 2eGDXlbGGtRn1VO0Mi2F1SEo2dWFeMuszjRFrMxwuYla/tbpbNr3zDQJ5Bg33F3DjUqgf9Nh
> > zRrR
> > 6Dt4eoDD5MKnJ4edu2iIPPfA2HqAsSwPEQPc6VfBTg4EEF+mzTWVWtk2bJ1xy9pV88t2rjfG
> > 0i9k
> > oJo96g2bIM4BHTj17+T6nvoehEKTgvdVNeGcsgPwptfiDsmfZhY5ZPvIOiZzA4507bViGgVz
> > Ivkt
> > wakIKthBGWT8s2nFngzwZ4M8yIbILGTc8q7C7eNZNyOlpJMirHte8EcUWwbvH8xq7Qr34MXM
> > R534
> > wnQQ1bZyjHQggyEssXSN1A8iAKLeTMNgYb33YMzcet54X+WXNXi4DF9V72OffV+bf0zUeqpf
> > suXA
> > 63Jx9h2hk8A/3E2k1+rd2c6EnwGKLERRQgqCERWCkBSCgx2+BDp+r+o7uHi6WQf2nIsyDjPI
> > pfB8
> > UashZ7yPjDDWUJeZEHr0rwJU+WuUSqgilUxK2z3fCJhZtpd/BGu4HCPwwJLDgsai7zwh6dk1
> > vZzs
> > Q5Bi7wHSrK2lCpo+6GUth7KVJWgMNsOmMrbCF/mguKJwHiw4wehOy6pH5p7yyo+LblQPsM0u
> > HUXO
> > JrKSiosWzyiMRrWMNqMRt+Lttttttttttttttttttttttttt22222hbZC2yFtkLbLbbbbbbb
> > W222
> > 222222222222222222222222222222222222222222222222222222222222222222222222
> > 2222
> > 2222222222222222222222222222222222222222222227bbbbeO/s1x1ek8eT5Wc06Ont98
> > eYgX
> > J3IqwZ1Y1WEh6j3TpIiUfZ7qG9I+hQw/i8HWMVwXQ9I5H3fM+i46QXsKrkV6PiayvznQs3Pb
> > miZ5
> > vIDwzeZuxM/Aa5W0EN2jzrZzcGlppk58AzhYK8iy8/LDePgcS52tu+Wjn4uNhaRwUHU0C1WZ
> > +GvW
> > BVg+zUzFsr2IZdUFUhVVbK12tkxOuXposySxTS51E/CtODhbTK6MCaebMmDMhnLzGsv/VMuh
> > Xdrf
> > lrz9/O2rZqvhd9BdOwQlWwhLQ3AytXAvuQso7xfaPSJkx2FQqwyBjrhmQTqZaGd6hlE4Rm7W
> > mVGm
> > IfsiOietv2u3mOeCHtHq7jNYxqhYWiNHlznuO08KI9TWOyHcOd+noDbzaHDcHwNndier6Zj2
> > Lh+r
> > zNXoWky7w0Bo306m6L3EawxhzXvIwvk1xtmfs97nAqWKZXSGAY23erI0RT2/M73zn1MO3qd+
> > XM8t
> > E5m23F49PQX1fgq8lVZ0sTDKbuO7w7td8V3AhLcvhqPwchke8K0uIHliEz3GdSMohcGfPHNE
> > ZcW5
> > A3AqeEMoVMzlhakSkgpVLfkYisi6PfmM7oPozaHvhLgq5Y/G/BHt7xOUnYOkAlG1j29MMukA
> > 9yp2
> > 9KH6LdVVzWytS8/OFiktKgvIPENkwyYdFtHtj48YEIQgQeEL4+DP18LK4jloxsAMXEr2nC9y
> > CTAx
> > xC0D4sDDA3AQARInU4G9fIvI2XOF2NWccWJNfqy0q2D40/1RFxHS/GxtxtuTHkRzgD0BzKtB
> > Rkyz
> > aebVnAopUrAD5MUBI5CvGSJzss9FVM0PgVKmWhBTphmMRp2RISExIDEIEVBXQQ2ky8Lcm1bB
> > VNad
> > qiqDHzetE6hACc4ezlnErw9r+uT19rR51kEy2uFSqd3FN5RWhfxZxorMvTZ42wcZla2vWMq7
> > LbD6
> > +QoRpaNQVnC5nLrDuZbFYcd0ZkZnFwoxs59DxH0ySj4hW1lbfEbEdEn1s/GNnVGbyX9taXPo
> > Z34y
> > 6OVqMuNg/e/K8flXZuYXr89S29ytqROxu1T42PpS1AtLDSxRa4FTr3jYyuDE+3HA1MdYz4Gp
> > YCED
> > 0nJHvAQW95DL6fOMzSQhKwRHl2lGNQkLIGGaGbBq+YeMajckwcc1ZCydl2hoqJBghLh9H9NL
> > JcRz
> > wGOuV0DedAzi2cYemEjhEMLjWo9gBElBlfs10ezxadhePSJU/xqQ8tIXtF4wTQ5+b2UoweL1
> > ylzr
> > doBSZuPDpj2Ii32pEX7vA0rtflA/Fnx42tejhS1FkGEh7rZrtuO9k9oSRAmSfGJIKCxTo0ZB
> > /FOl
> > 5At+BMSCbA6YIGZyIe9x16RIEL+mROcEYH0ec/T7ffXtfgm/3pw1x9/6llZ8snt89NvNrc5v
> > WNS+
> > 2y6tlJJl9ackxDRb5NKa+wVK2vWs0ouM6058lpzDq3TfmOx5zzBJ/AgoKz/Aqp4/Kl1bcMzM
> > 0B/6
> > GDZR+9D4e7rzo+07PQTzwvgiEu/xI1o9bvmGhZvg3qF4FwaZOOESnffBWqYUKSTGs5VTGmKj
> > IQ9Z
> > SNEziRw+9OuRfd+n4GhPk77paWH7PDb6eWxm90yu7iVlVmMzfbfReXvTL7+cz7jpZi2oikWY
> > a1jf
> > jnnPFFPHxGXvphS5bLiBkIKpEYGpAWAeEk7OYdn8NOw8E15Y3pjn1Objtmrd99tMW96Yqwbg
> > /Nfx
> > 0mtb30nRaWtKROYevRu9NRl3Pd8emPDe3h8/swdy57ddVmtfJci+u+MYr4mTR7bv3dOWPeY3
> > UyvW
> > 5ydakbOdanrnfeTY6cxvnan3F+Zx3OlOu+uY1qOJ13U6rWG1mqip1Tu9TqqiaaqznVNnOMOr
> > PNC1
> > Is0LqhZoWaFmlqqqqmhZoWaFmhZoqmdnFmhZoXVVTxrVPNZqoqdVU6zhFXBS4KWcqqyZWMOQ
> > uiFj
> > UNCsaWTS0Ygyy4ZZ0sRpolZws0uppqF1STS1hYpZpcZmlmlzlZpafDPUxrGKyuqeaxnOMY0u
> > daKW
> > iF0QuiF1MrFUsyTTNNLUlYfCvWVqdU1PS1NLU0udLlcZrU1qZqqWaMxJNVitTWZqqxVVVZWs
> > riWh
> > tEaNRTS2MVhaisvFa1iW0VAtQlVSzNLItTVTVRVRVRVRVay+daqJmqmaiqiqiq4553qTi8W3
> > nnjn
> > m2219JNa1bvXPHPOrbbdc75ipqpqqqqqqqaqaqFxFZimaCqzjOomn0Q7408Tqq1NVqpHipWI
> > 1UzN
> > Nlyay+dRE51E1nUS+SnxnOtROZV9POcROqqKqqitYp1qqRnxnUTQ3Nbb8cuaKKKKKKLFrmtt
> > +OXP
> > jm3NZ1E1Kqz4zqJilZ8Z1E1NKKoqiqKoqiqKrJvfH2NJ2z7TzNGDz7BLo9WQwGBTKGAlJL3g
> > Asbd
> > b3c1NTUnJtTU1K5Vs1ddZXXWV0roaqKqsLVUVWiiqZmrC1VFVoqiiqoiNJkwSYMQuSDRROFo
> > g0ZM
> > MuDA5rNOuiiCiZWiRyijGk0jJpVNJkfCZSMKSlI5CpQqttVVRRVVbaqqvOkFILhMppH08Yka
> > hpJe
> > B6GgmRpMvA8DQNWnVlWih6KKKKqoUooop1oooorRVVVVVVJVVVVVVFUrDUNVgiAicKiIggJy
> > Ihv8
> > C+uGvV/r27Pj07ayzxb8uPQz5rWBATpkQTjEBhhx2wtlIMKyYWTIjAyTBEogkKURlGEwksC4
> > BkMC
> > mSRYAVAKkKhIREFCBC5LCSskBEINqtYCx+p/mIQfUEaEPVFyYAGhFSQVh/SkPrfa5UYjlCfA
> > a6tx
> > CBARkB9oJPeRh/GJ4JCnxSk28LIbsDYpSlKH+MA3QD8RkHlj7518bE4UFGpmd1Ws/yDBZo82
> > CVPj
> > hphhhceUfRBj61UikYb4FFtPmw9IbBlALwvOvB3HECEWVEWzYHx/a9Zfhtz9+XHHohFVVVVy
> > Sw2Q
> > 9NZXRuywEkmRVVRF6Q5xV2OjzOOOLbSlKUpeAT8c20Zm34+viW9s1opz5sPOqgkNuXS29UOS
> > Iqkk
> > hYkrozWFE1TPq61kxa+zyErwuuK3okz5fvvLq+UvXf/V4Vdl8Hgcxo5EZQ55Vdjm5VNy6nG/
> > +czn
> > wcTN+JgCqGQtLETv5kOgihpUESH5fbYKAeADB9F8j6H0iILxkXe2aqKFHTfYcdEStKFCE6QW
> > qJky
> > BM/l/dE5ImOsEfxsnOT09hY0AgZHmSFiczU1MlckIARPP0zrpylKGzq2ttttpbars0wp+kPT
> > A7jV
> > SFpj0oKD2mbpCCYmIY8wbHHvHqvO0AsP7PD1ZAG0A946W0Im+Ef0MSwwUbybCAvYEmXbau5A
> > f3pz
> > yz4LvGOJmdp3n5y7du3Ln0H0H6jm3jagnKh/gdNfy6HJg28UA5CwWbznPISjm6zNGoITGwOI
> > SbQn
> > xM0ZrMOLl2LpEvkmno4rSS5PNhc0XRCEPP2ymwGwgIhEZERBgiZ/r0X3EspshH8Srp6B3zAu
> > uq9k
> > sHrJvRxJimbR7OWvfyycs7mjj6jzmu/T0OZkztdzBnIsRrOAcxyJKZQhBoDsXpxxxMYEAuma
> > 1H7F
> > TTnJXwQFESTgWkjqIAVFdvNiqiBiboP/QRNlIsKj5+XLj51iouu8rgNEsPm3E5mwveDB/Mf3
> > H2HD
> > x4n0tHljV3RP5Py+VwN1p8WVR+12gwY/jBSbh1D5Tqvtl5f6jS71vLPWKTyj3DbtdOZg0dJR
> > d4Ec
> > rob9DJebWFvjaOX55rvGfhBV3mjNk+pRPBrW+W3FHLlS1K9vaSdQbA5v/DvAvCqKOnaB0bgz
> > Hn6f
> > Xxp4hr50cXeFjCSJBQVFUL+3LevuPz3+fOlR9fdOf3JrULEPMC1rEkmCEaqVPSuLNkZ/7QXD
> > Bjyy
> > BQO+Hj3Pw4Ss7/ugV6ye0TLD3/J6Pb+HPZeqBv7vQ+Hvqj8i0oKjcTQAVDWPZ0H6S3vKAahD
> > bLDz
> > ErD1iLERSMMNo4y/G6UxLtu0oAybJP1JuB1k/UGAh5TBXXcQP+HfdcA+UHO3U8VCeAgj2/2y
> > Ph8Z
> > HgyLmSNhibfU+ecUQO7iUE2koDbM4jxcISK5z98ZgT/R+M7eu3rylWiLuwzO84PZj6/KUqZf
> > D39e
> > c3awaytGD4SCr4vKrrt8IxjGNPj7bq7kTYEQAVdLa74vH5Y0R8/Zl5R2a9rLlir+xy+GELaj
> > 81UQ
> > TfnzhOre7Vrd+W/zaNtsC+XLLHk8NicMs3HOFkPF+kG68L7nrz3vatjwd4cr5w4W6vx0Liwa
> > Gd34
> > 2Qvjg2zAwjuLLmC1hBfH0GzAL7/j1juJr4x1oqWkkkooqtXz74m9tqrLbF26fDu1hr1ePjr4
> > yOJQ
> > 8tYxZpytd8B3c7uhuFbM0URCKoqIbgHnIHnBBCezW3p8fV5ajGMePLBcrXJebduKmHE1PPCn
> > bYKf
> > I5FRpCDNDlO74NdDFlOxqoBxXi10ZC6/X8pHNasmGOZs6hNTbqSQumi8O3M5FdmZSE122Y4Y
> > zreE
> > ZRlAZ+ztoz+GxeMLFsun5ccHwnPAqVVK4G2udTxd3Cz6z1h4+5ylCuBf7Rzs0w7muHPVAo75
> > nDQH
> > nJnhOuxQzMm/JMwR9Zhni+yfT/k7+b/btn0I/Jv6VKj8E+l5n148++Z+6LAaCwqFEQIMGNyl
> > piEg
> > w/Eo5elaDt3J3Dv+eByGKdIm9s+4L/mwhD9KaqDP6UNyBqmqRIkgzximySDVQeIHqAnAaRgI
> > wElb
> > 2vLtI8ENQ/h0QsLrDRmsZV+MP7GUFMi1WGAZ5hezT7DmPaYJ+/RaxGGTs1/G6oQiAJzQkUoQ
> > 8/zF
> > NB9B78kP9I3ffchO6LpESnrKCEWEJiVRchB/oDeCS4IGSicvEfJXP0HkLK3QU2+AmRfh1PWn
> > xGhc
> > xhH794A8QP+gxRqCLIIEAIAlwhrbayZ/vBvhtvD9h+yifnDFPYvtGJF/L+rxPSmC4LU9oPQ0
> > 6EhI
> > XHvN/8QenBwDQjGQmfWO6Mj/WAP3aNnn/f5nd3b2uzzfsz+zQ+ECHfptGdfIyn2XrEcbFNBc
> > EWcO
> > 3jgXYooi8g4s7HGZskp1xt/XILM4+X+OisWWYfKFVgKyl/vYuQwwZiHIjVZKtSJR4w1KidnF
> > +XOr
> > YxwLWYse8Z1VV53Y1BQ/E6Bx/SBcBwAHAsObDMQXRiLCIAXIwlCWAi4AQBoCIfeVKbO58LmG
> > L959
> > 5WOP/3lZtbO9iqMvyyKTNLB7777jy+/83TuV2Y42Ru+b+u4OIU2jIBIGgMhIHxe6Se+EVEuO
> > Bu/b
> > 7wmpkSZOGHX7woRKFClFeCJiFgqirBRZvBRYKKAiLD6+fvJDXRfHLLz4m4Al3HH4lnRzdjCC
> > VGEC
> > QkQ+s3j/ADkQP9iLSrB6FgMAH6h+ogn5mBNQSeAUoTBJS0niHvIeAF8xQQ7uhDDCwb5+ps33
> > QZyD
> > /QlGMY/5J/H428+6X22iqLOrjkW1dQ37zQ1YUsMipCEOG7cWjJIm3aT0EPSCHpBBCiIlCIFk
> > GIyM
> > SqGiEOp9CEHq5oPaZJQpbQoeqAoQIDovGTDg7i3UMWmhsNdK5zRMmTlCSxpGxr0HXsPjH1P8
> > cGdm
> > HSk75290mujkpovVvf+3ttmrqCHMQxHRDMMmybwM0u4gWaSyIGxuGhYiOwMgIGAQIGwDARcy
> > 4K5j
> > YVcQIAJBigbueLtDv7Dlm69uHUpdaoQNzY2XVlK1ROotGJ4k9Uh0EteQhIQIfvgGAbcTpJyP
> > zLci
> > w2SnrO1Ib8KIoupO7yVTRpWaCHMFjDmRzchIER0vaqq10uHuLu7bQ5cy53kq7hakpozQN41V
> > hGnf
> > hwP64SG3lH2O3zh9PmAMBOfP5hLIp2qpn86oes2PoGOKvSL0C6pq6r8AiZZk04QyxVHsTnFs
> > HqdQ
> > 5FWA6I8Be8XARDkgPJHUMVLKEQtdILklMXouw6/cH4fw8IGJLj43NRq2lOEAbnCCk4/G2EDi
> > 1TPZ
> > dB2ql3UjDtdFvCk2YbpScW7JR5Ud/WhR4u+V53oEfX28ZWTDZNb+jmFf4Hw4znnhnh3rX27E
> > x41w
> > nU+7U4PVU1NqsWgPtCDfBy+qvHZ+a4MGlHRPokHkeeeDIoqqShRVIsBQPSG5EEEEEKVMhShJ
> > YRKg
> > BRERVhGEVJBCCEERKUCUolQ0VFigoAoojIo2SSCT3a2RzxHbRpFUc0ZiKtyZl1C0kIIT4fRh
> > JpIw
> > UVAQEBAQDhhFkBwq4mGPiODDEZATK5Sr7ATTxHkHmBCgVhANku35uHJjgKQPvBA5xoSBcq5z
> > FMTI
> > s0IVifenExu5EamL20W1GiPnjWsscplgy0oYFgoCh81k7E97rOHPhi8PA3libOKPgW0La1j+
> > +oIs
> > mSYMs9RoIG311iGTspNE43dVjRtvaw+5h3gyYvAgSPe7uvX7HaSOa9/gjNsf2szMzQTDDvXj
> > /P8R
> > dfSlLW/fQcNzMwPQ8fMc8iR5kyZQrr+dRGZWep6ka2a0r8EkkgyOG3OG5O1OohDsbAVgIKWg
> > gSG5
> > qB49S7fHerWBcANozXggnPZt3hCDWdcUvO8+rBx3Fre5iT80mSdMMwkyxJrQ6mhhNaY0fpA7
> > VE/Y
> > oEEGDFFX32CRkeSk6Z7Abv+8/VLE/3/5lxfy/5KQAmRAiMJA5JZyasmuWRFigoMRirLDabs0
> > GwTY
> > BzNgY4GfQ9aNDQJ6HktyESBKUx0YYxNrHaCCgVorJUUUUSTxPWqaNaU3ZirorCx1Ebx7hVEm
> > NCqG
> > YbMefiHgeVWQFC6In2CADBFLI8ER+CASAJ/MCJEjFYLRClP/4L2Fu3ogFDxCJhkWYFEHwfWe
> > fH57
> > fsO226D+yvO2CGssLTRk+xN8ec92oGzDhjxf1Rrpl46Tp9W/LfffM33+MJbQtsAtWkltLbAt
> > stoW
> > 0LbbS228ihE69nf6fpPyn7TmL/GczzZ0ttzqSuqdc6t9maOxe3ZNoP5/v1xtCVJ0j/MmpnKt
> > qS97
> > KvoBqAdh4pv1Ha322XU/WI952xlN4+EqzpwCBYIAq7F+GKPnka5eEWfbDO4YfT0VfJPkMSUN
> > Jkbj
> > /PRRfUBCoLrEeEH9G2+AeZgTZgsAWbashjNss5JCockmIHHHbzNSByZG0NKhjOXKhphNIFUz
> > yrDd
> > SjeCvKLprwgQNP1W3Wz1rnrhoZ2wvBE/Jng7Y2+vOe53fjFVxtutVecM5ZUqtJEE61pbaGWI
> > pZqq
> > q7uauajV3VXaCDatiCDRMkoIazU00Xmc7JKfrXfpBtkU/p9oCKaF/0M4mGYQK20YQC2coVkV
> > GGFU
> > NbdBl1ES5Eys3egXAMwyf2rLCWWAOYNW1UGgCyo5pyETRGAmRgm4ADMCKhAIIAhGlGM/5yZN
> > /Sv/
> > F4qqqqqqqqqqqqqJIMIa3TMVWMeERVHSpVtHiqaVWM2tVWMcjEcg4qggYuBcVQZwQaqrGaVq
> > qCFU
> > SqoM46jnISHcBThJ3pVgLgWBRwO+lBEPrgi8Ry/eQNKx6DANO13oZJveDpLUSAYwsIWFVE4A
> > omvR
> > ERPg/CRjOGbn2cUdBSXP7uSKENpK57sOK51kmG69/AshyxBOQmbcFGmgVcQdr0g6XIvIhlEY
> > GYQQ
> > z4Og1nY3no0OcVlucKWiqukhDACEtTOsLr9DEtxtYgYFtLzHO4oYksouK2uQmASuhNZGUaJK
> > NRrC
> > BEcvzT16QNNZzSJ36ZFs0LUuSCZWUwigLrYVuMzlo4isHCnoRuGZDkLNaLo0Vic2iNAKIPz3
> > OwQQ
> > ukVhuuUs4xv56elwwg3MIiI+eFBtGCQgEQTYUzIlnUGDlqMXXHWmll2ZhtrdEd+iA6KpQnAT
> > EMHn
> > nU2LGPA0LBru/agGgC4wVOCL3HIyIwh1SqhT4F6gQgXUwmikwxNWYF0LAdNIQkmhkM9kn4gK
> > HGCH
> > 8QXgghk5JEiRkSEkIiiigxjGIoKqosYxFHvNpQC7HUGzH3G3EcrSGtltqKMwwSKVELYlSjAo
> > mUlG
> > VRQu1usL5heIqDeVCy4fnyZrnfcLCRhYZs5EPsEXGEbxuZAzBq4ZEBK0SyM41tWG0mECi+Ia
> > Gho4
> > ZGbyGZvBkafkKetT2ifgh4KTAyl7Do3U4DRL2bXSBpHvBKGcmqQi9gA4YApNp8y7JJMS3nxd
> > ALAF
> > JvaN41IRGGP1+bHA4FeZPCnt8Hswd4P2AZJ+aZpfsJ96YJdLXk3nBJ17tvXxeDFXltS1Necp
> > vLZt
> > j+WZ1WGfTDwqzUUNZqXMxM1sfj+R6I6MeUPPnffhEIh2da6WOeWnBm212cqE7AMwSZJRgDiQ
> > H/Dr
> > Wvc/xx7vf79rWqZLdHGuiRqqU1JOpmnu7u1u7urux31FUXdXubwwgMozMMogLiN1qGruLidd
> > Q1YJ
> > mElbK61qrY22Tt8F4niakDYbmvhOhfH0G+e8n2n3cI9xTacbqqwQ9cH5AymUZtRWRyq24SuF
> > t/Iu
> > XMrs5JspBkGKQ4Tf4JGOBCE3EtIxsQhK+HsTY6oZ6ur19nZ2eNz3zSGzmIcJKIVJNrxBzgnC
> > 8LuL
> > AhfR0fF8gQIEDvGAYlIpQLht3A18vX0+7H6vQWCwBjFAYKd8UiIxoIIiMk8MiqwRUFEqqlFt
> > Fqgi
> > 1FEge+6J17TAYmytRtHOoPZ3MPEwuA78xURWM5tVT0BE+vRD5lM+BNdD5enOXx+W/okiqoqb
> > 8jg7
> > p5hwH0QRioQ6N5UcDE0HEuKi1FDMFWIAJUAWXSDc+313uhgCj89kBsOBhQ8FY9VikPfpodsA
> > zlrU
> > Lazaw/OC58B2BfZ9AuAebp0JqnPyOxzg18O4LhedxX4+l05QZJItfQ4mozhgYxLCusWCShzB
> > ooig
> > 8yBBQFmzxul7D7DonswcccR7L2sFkYVALNU0VWiB1WRjWJcxLAs2PeZTOoOBft6YB2leaXEa
> > 4rvz
> > wYvWXuWKKo7cHkPcjxca+Y8s6lVRu9UIKFhY2CxcaUoF5gkG+wSk6EicIDpO8fgn0EihBTnJ
> > RIBC
> > Fsu1BYTETnOSN1IjGg6I9eouveIfVvv9A+beOsfXLu+vnsfKt8W+3njMXUb521nOzyu+7Vu/
> > fJrh
> > bWtuHu9+YmvWm26u3oRPYbnv752xJ6wOeYr4zv9OKqKnhwew6hp0PZo6cjJJc9gaKjduRio4
> > gFIE
> > L1KqEwDsiTFFx0+oiqqQIJMCZKWuZBEIuPMvL+Shwq5DIyPb39U0eBKTtztTxkHzoqqm54na
> > NDme
> > Jo6BiUYsNN0kjESBTnoDp6Akm4hqbqB1yQCkoxOHB41CeAztz25nVlbPyEvaJd4lubLQwNtq
> > XDd4
> > cZtGdAbcbnLbAZwjJJJieE2SSg1PD3IJE+hUhYbRWOD74oSIFWQN+tCRBOkDLpDQt0CFtOB4
> > U9va
> > gPQlsSokjuw41CQjOWxuWjg9hvakGMy3W4c0QkJkSa1uoa80HDpTtod32PUSpbjra6RLVCxj
> > 0Zra
> > 1VBmPBRQfKuSkbpAE8OOoL6wOhG7cQ6uj9fOEg2H50c0zkluc9OtQDn6ewyuccQCZiloinNQ
> > CUcj
> > mXArkpFR3WVRzmZ1SlU8xFudf1civvy3DiU4LBNwKoEcWZG5gkrdjOkUJiZU9b5KAECRyOGH
> > UTwB
> > L5LCHf0lLx+XyoRmTgu3pYrGd2B3B0vrkihEYsRYyREigKAiKCgxBSIioiogKLFkRESIMFIw
> > QRAR
> > ERJA/AA/GQn8CBm8VixiSST0gdnJ5O46TuO7o251R5aDf6vEWwJr9Zk+pQr6klzkbQbYcLwZ
> > 3swd
> > WwUZPzCUOYKgLODOaz31vhtyOjdJGPMzu+X60CqaJZLnIJKB8o1+qrD1vrr1CBpplEtcaZkI
> > RgIR
> > qkc/eIQUA9h0b0Xdzi+7EGYNChQP1jCMiEZHB4bZ6+ckuNk16+M3f2fs1hN+LyfFIYj1Uq7O
> > lUqa
> > Yh2gevr7IqKRYfATxnP+K3p9Gx1tz02mbyJbYkvTt6U75a7aMsU09oiHlOvHj4R6qfTJ4OPO
> > 52o7
> > rkk8XAfR0OJkjmgc6btW7eTUhwhZvwvvtK6wjg94KGtZw7QQka0Q0RLW93cLdXU3dxM5l6uL
> > q/xi
> > acyRC7VRRZYj4natUt3fG+31HhP1H1FO4e+dh75fUkw+8PVgYv2pvlVMLwO5yxtJfQn153wK
> > JDcB
> > mpBKIhTvK+FwLePj3Lt7pWqouPwwEGxqX7EUJUrTo6xJNcZN4fp+2xhcGQ8BOIhCQkJCI9lO
> > CvQF
> > G+9SHy9WWBn2hXW27bdkibDFHux+ITHD4u9MATOIDkIqh4HtMz3/YYnmc+JxueMvm/V99XmY
> > KOpY
> > tZ1+YENNnK75lbNqJsrZIBhtyHBFMcd4FVj2T9/t9UQKOCjDw2RCcE8QiB6JmMMbAninuNDS
> > hZPg
> > rRQHqZvpVWuFVDx4wmxrSCIOahA+4PAYNICkHQxpFGV8hvxl2aA5SjwVuyadzsjCM2luMlSG
> > +gID
> > K4L5XYhUIxMC6y3W4ciLFpaG6qrLzsygdohhBej8maNUcdFdkydUK32VNup2Gd05HDrrNMJo
> > VntU
> > TiAOrYtAlQdAKkhrxGdo6UhDogFAoYhWXLhvtIzA9JxL8ZEmioTB1V27N6nUsZ1gX4s7uyGR
> > UU59
> > KPAUjaNjsteMO7CMKqncyPyrAM4MGzeT4m5tNINGUUAqxCMyAZDbhatSnHgbh/wSSLdtmrdt
> > 7obR
> > YTYvZLWOgqrphsvb7vXco9kpkI7HnVyHSnK9KqJ6aa+/a9WRMlbhx21O05LfFjZfs9PDrMwM
> > 94NC
> > fvMJIPCBiZMG7/WAkH0SDuSR3siIGB03L4Y68hRJ6C6+LAyp8fj7T4F2RMo1JA/wSiJNjBCt
> > XuDY
> > Xi5gwoqOt7QgphejAmLEqFbfjUjxlWXkEqBsd7myWjhoesYENnt+PifM5Pieh6FnMm+EXjKC
> > /JAG
> > aSUwX3JGIj5fFX8fUGF58u4CHPMjybPx7vUs+dAb3+gQe+ObM6J4eXq8IomhIGz5qzAEdohZ
> > iYTM
> > SA+wM3LrseELuyUJwgYSamLY55he1qIYTQDV99NyCAPcEGpju7N+/tdYnCuqiggO3Pv+gb6P
> > pzVy
> > za39/pzzVO0wXBeKSIJxMzNZuy7lbu7q7uavWo1cXV/cIxq9JtJWxaVitrk0q52WV2yySDtN
> > VmMs
> > yIGYwBWcVu/vk655polGFC2wMalh1I3vcrnVxPj1Tw5O9lD7jgW4nE3nAF5fXAT5+Pz4wFYd
> > c6Aa
> > DiSHl07+nCnVKC7O+TBPsY6TUpdvyc1SCKSchuN7S5JKJWRadcfCAW2+HUOZfWF5G8Ks9HVL
> > 1fBk
> > aXxuDXhDainTprXXrpiqhniNtQugC7aVpGjSSYPJjfqnTxnp1A40DoI+M5krwIZPVgOCA8xI
> > rwNz
> > vNGXUOTgHXjrNtd1w46Zm7UvwtvzkhtWw64YYqueLcQvFWaY9nF7HLJQpb9QloSwWNYNYPhj
> > NkV3
> > wSLq5e7XHSYVmlVaL9VAnsVemVbGJoQHthnFG0WGsYdkzMSx0iwGVdhNVhMrsmIQVDIA3NIw
> > GDNj
> > MufCxMX7D7CarCAJgQ/QgcBdogcQdnPXLkdGj1TdRw4W5hxOpoWuiGkBkSQhOaG/kJfSjDcR
> > gpkj
> > FfikGtirLyFVDIjYiaGNGe0V8lGprnzYyL4hbebmWM8wbFXJsUGMUAo5UqDWzEtNt2WlXxwE
> > lnic
> > CtfOivAXhfncMISd0CmGXXXfepKvcteAHiilEEe4ielQgbDn56NMDEdaZBxCHIptXxGr3N2q
> > qOqM
> > 1erkYX2Kr6xEz593lPjxp9vB1JJnXYewHMeEz3KWbHk3g8uGjxjOP2pB10QjawMDExtCvEph
> > eRET
> > MaWLQ0IEcw0NexHLeCW2/Yr8wpgPnVHtVp4Dd5vSnNDpr7R6ZZnSuvcV8phC80ljGrwkWBKi
> > afNy
> > 9mQn5iarHyFx8GTZd8x3DMxz3i58RSmFMXq/sE5zxmNi7p9LGjynLsKqiGHx8CX+fe+L2ne9
> > i6VF
> > JKhVmYSCIuZpre7uFu7qbuzL6iSrur/EIxtkhJggskTbE7CvWrl/pPrOT3nJ7E/D+V1V1+1j
> > Dwg0
> > IRGIzHH4hL58l85hcXFxeLNC4JDI3+fXFNoana5cVmSR8I824ROhSIbFXAt8GWWCIgeoVkaG
> > MoEw
> > kNKkSMooQg5emg15qMX1EWfLy+6BGNyE32D2UbJYaNJkK8ZN1+gvT8CRe/cTjwbw2TAaTwQa
> > yd1s
> > iG/jsdAEnmNk2MbInBv4iOzN2gTy1HlshKIinZgs+ecpuqV4SqhFAKFzrNnDSorPbEevIV9V
> > gpZe
> > 5Coi/YnbngWrc2NClIFCGojO3JVlxsFGMzYJGqIGtVEDvYggbi8O5Xg2NUpr1Bg1wekGjfxJ
> > 5Cih
> > aY/WXp0xRnUA2hYLO6SG0nlDMqMy+RnUMUBMXmt2tRcuBgBUPoo5hZfpXlogxxfNqUeAizEl
> > IqoH
> > mY9XRpOs/wB32vonobua8nCoeV2p90Dz6v5fPsPBouMV6mW8nY6EsGCDDFjDqOG0ME1xe+CD
> > CthI
> > kgCWcI5TzxMJX0IF5gFmsDuYLILFkWCwFgsixQUFjEZYYQtcLViJasCWgCR5dqh18yEIDw+I
> > V0Po
> > IRW5mRyLIGxEx3UircgamdRRI1CRHndG2aDEoYsU4IBnFMSZZPU4Wn9pwH3ImdgiHDcbm3Fk
> > azsy
> > ZDgg7Sx07JPvEQ/iQBNhDR4OXOjfkrODW6McbsQ0oiMNcuoyc+N7OvifOgWku4C1HzRkl+CQ
> > ehV4
> > fJqT6rJ/BNtDt66yG1dPzysZTM7LMwbnEx+R2Ot4pz8v2Erh8oGungLDZsP1uwq85w5qNK+/
> > GYxR
> > lda+b5HNZ7BkTPwx8zQ0Z+ON75553LvCOjvNkDvo0axjWneLu7vC3d3d3cTnOnu4ur8iMYNQ
> > RtTL
> > sbFCNVZyrYqMn7L+mN5oXH1EGbEAb0YaTxGHlqUiQoATYA+UUytttksRCDYVEF6Y3SbZBPNy
> > Bnp3
> > W7SQqB7seId9hNqJ8ZE98zJFo9MRZaJDAWJLdBPEeI95TRX2d7VjUos4Tzlh7s3JDs8J3C7I
> > FIGa
> > YVhhgMMgFakF1MLSnEK0kG2pQ2yCLmy0NMWT6Cqq1MzCTEioshtbJa7J13JLBZtY1LUE8WvM
> > nNb9
> > AiQmIQUpmZhiVKmc6kgKRCUYmBNhNTs48oE04DB24K8G+WxWhkxrTEoYWhEwRUOlDSjOhIgI
> > nUbk
> > lblTIYYU0DpBIREK2MNJqq+kHNMoXaWUvL00xW5gst+OwcFTFg1sKSbnO/Ix58m5066VT0Va
> > QO1v
> > 08a3UHJ4HI4PQO0bSZUHyJt2A9FGehe0aOqM1VUFDULqs9d48Hd3PUMMjE4Y1hrlIj9iQObh
> > rYml
> > wKbVjpIVhvubQkVFBtaoYwLSgXXL0B42GA6xBwmrArgsAnicAjRVyCJERAGDFD0chITJgYYk
> > o8kI
> > shofaS+zQKmZWRqUFj0NkB4lU70fkH6Fd9AfOj9iAXf7SJsHdf7d+BNvO0aYxzOU6U65UsJj
> > WvD2
> > jqSkfryKLNrXR79j4viXPxGdxvodvUqgvAU41oSX3xHWohc74nHFuqjrNZbHNlsp4WpGGMkZ
> > TJkx
> > 4NlMpSgKoqfMxwbbZxP2c541M78XbNJFasZmlIiZkmZtXvFpd6W7upu4rWIq7i6v8AmHNbOQ
> > TJJZ
> > Qm1xtmm21tmOMQeBfuBU/EqKow4U+VNVQ1QHioXUOB+gA69ZJJJOOGepRtsQYQTTGIXp9R1Q
> > 378/
> > XhmhnRsJ2ibsvdkqF1YQItDcGN/TGbVDWC0U1ZQ5WtdNJRa8fALUJCs9PdoW5XpB1VxHjfgG
> > t4/p
> > tZnrmmGYM0F+pWmMS2pIno5HO0yywLsgySSxyYLxSvyOTcXjR5XC7nBtyHG5SF+MYg1HInab
> > 7oEK
> > T4dQZWHBb3kq7W1CL4IsZ8p0E4RJqhGhuFsyogOXBMXkHsVTntM8tsWxqp3CaHaFWLEwVczE
> > vlK+
> > BsZZcLbDJje0HxDPK20mo3hUWb4m0ZOOFVctYi6Arn29VuqcG54GC3PUx53FrKdEKLyIt52O
> > HO0n
> > hPBg9JyMh1o8kz35K1Qav8winemASMObN7we5RqIPtmRtueJEJhdPKhGc8lmMOZ1MIeKHJVt
> > mPFy
> > BQvImxheYBXgDXESKnCVpJOONvBxJwcGQzAV8BxVVFUWjhPiiEHhVntOpbg+0E2xHPK/BA2k
> > 0Vpt
> > Zt0fz2Ug8RtscmuSoaDwqpkq8ihxqfUrtEQ6kA2EVpL13brrw1aWRV8xiGfGWkRxkeZaF8wQ
> > MNPs
> > 24bgY9bPh1hx6Q05x3oUiCZDtZ0o6P0utlzmHJ3SMZyVGXI4Z1vkHfo2IVSWzn6t87a2nfe7
> > SYah
> > 3uYiDWol3u7stru7u7ubxjM1d1fvEYvJoiSzbYoStXidq2vbVbydH4GVdwztAHNl5lwjFRDA
> > EzVF
> > Y989aU0CUDIGMwyfIseobMS5ya7pKd7DFLoduAoWXSQCwiNBu7uJv5Z10sZy8rxI5GYSIxHb
> > KzFP
> > U9YscPmitIICM+wCHUGlkFmZ7GZfad+kPPgQ4XPrszMqC2shI4BwqIBEnrUaIBZ2EWWl++xG
> > MNVI
> > ssE1ghFEGEdNDIlgPQt1cMIlCYOV5IYV96sUSIUWc7vn0LgS7ySbd6s7853B3CeTSLY1p6Js
> > 5qyQ
> > UyLxY10hpW+uRtOeGJUGMg2MbLCpRCfJ0nAHPr3OyeiRxNwHBmSS+8RKBhThbD1YgxgQLhsm
> > wGJF
> > FK+0PMSsEgXM8wvNmngTIDFerE2wtkMomhDKsKVVRMuF2qzKxloaznsqEuY6TYR9GKwp0bBa
> > dka8
> > aNIpicCl6Ng+OhjcdOus4PIyeTcM0YF6KYoZ68HfkgUMnad9vFW+lycHtV8qqaKp3KHYb/d6
> > OHhm
> > XPXcE45nfz7/nh0Mz7N1jKtCqIDqqi5p6j8Jl94va6XKkKLYqzidlzlvjWmfMl5d9OSrqjaw
> > Dvrh
> > MqL8vdMYqsbZ333+PF2yMlDk2tstRKyTMystV3V3d3VXecvqKq7q/qEYwajbYkqhdixNYmYr
> > a81t
> > wdxp3khXjktbv3M3nVV0wEyLvg4QmkMtq5zrhxk4pMKyJtquoSUNqoTrtoYpgNOCpppu4nbx
> > LZ0E
> > kTMQhbFIAwI2lifK7IpUGAqm77M4pRjmr5LD39J48CymzbFodiHjwO/gTKjrty3C8orIggnQ
> > 2w4y
> > MFbaU2reBN14OxqWyEs0Ik2aDDsXgnHuHtlRWTmXl1aXkzIQZYwuE1pviCtydIl6EhMmFcdX
> > 44M8
> > GSEg3LExqcVIzK81Nr7iWs/UWdd4r7ZmEamMRjCjyGGbJ6DR0thMVmD4jMZD26kSBg1Ww2kJ
> > MUJD
> > 5GZcWkyAYynvnjWZ0zWFSNpvLIQ9+5G+VLghUUlIUC4J5SzEm8xLiUNTUyQzFxYFssoGxjwK
> > 2MpH
> > JRuO84yS+2Paht5gbyGd9jz2d87mIC5KWOCCZOTYUOMuYOW2bWrGFKzkNCh+VEQN0ODsjflk
> > 6bZd
> > aCDCchz7uAaCNiKwYxrsOzfJgHPMvsbjGR5fc8VgYhTSntQHuR+YmaYdrN1Z63yXeG0I8sar
> > NudV
> > j21xjSDjlXgiHgAxXObeDiD6Dt6zafDQtztxadukSJ0GThlab1zAQl3lkdpWuA9fW961vjHW
> > d999
> > /ddtlFwuKzK2O9mpFmdTE0YeipqqqZqritZqIu7v5iKYvbRsUbbbFiaxOtr2vGax2fXwp9Lq
> > rOx6
> > n2feCUgDBIqnBdFRyVlcK3nqB7jr1Q5ct9j0GGojtU9UAmEOu/hWuFz0e0V1dJTQrBGd3K5R
> > DjxX
> > 1rAusaTf0k774F7E1o5HTRgPrHMDyHPezm+xKBM8+hQWvSW6MeW6fxK2ca65DroTXXglkrgc
> > 4Xc4
> > NwxB4S08nh03gc7nkSa8+U8d2bnWVgIfGy8WUz2BiGpo0p5oM5jm2pjO/Ani2SamSJyWbwG2
> > oXjl
> > 9lCCSDxSWUmLcqF4q6whFsr1nAxlhjXj1vwVtoS0csfzUHZW24d6Lw0BB3d6LLZDi14hAXxH
> > Z5Y5
> > RPoXGejbxjc7V/rEWKBIYS5EeJHAoGxWIsJwhcFGKIoXG9ZwDv2XXRYbmjibw57OHIzr2eh6
> > 7wXs
> > /YrHWfCfYChExzLLszMyuDFaGhXaGKoZmRQzi4WpZXm+etNnc57cDm2DXILGwFOqP3uSAXbj
> > odo1
> > XV8OFuUiD/qh+n14azXaSJwue0jaC7oAsQTEMiZWp06fgzfhDeVLI/0HkfpLQJlD+ZPAEGAk
> > rHSh
> > WHdcb/uPrPXa+yipyZ2E4jrA555BYqnR+KsOFRURUQsp/zUhc8i9eyXT/9XuHFVVVDY/0cpJ
> > hpFk
> > RixQXdwgfThrQoqqqmi8uDtGHEPTAA7YkJ0nsoAGECGeclFVJY0zBKKAG4Urr3eb0WF5L2E2
> > +jCy
> > L58qeWArnhSIF61OPRDAgnaLA9AthUaUjJoLxWCwAEXYLqLqFYi4FMckFLi2AUsLiLYUGC5i
> > y2IC
> > kFNVQc8xYLYED7D0aV2WLzfYw0nrdJ/Bh9phrR5vd816bKu6zki3i8ccLxuq7ReaTmJzGB6m
> > bdCm
> > umuj0a123+Fzql3ExJ0EDTDmivddnWqmrp04ysML3ng8PnPhH/kxbzOyz0lZAcjLrq+Mg8D4
> > OZFV
> > ISYuZV9XFOjIAchIV4EO9e2w5b7mfQ16cqHqSux7d3uYkOUxIiLHvhPeuCzY/OwL97Anhb3R
> > P4Y1
> > lsQOD4c4hzjpC2unX06T31dGDMVb3EPW2CUGL+XLkw9qZlxFDec/Rnw3qI8Xk9GB7nx593te
> > z28r
> > 5xhVi8uMJwie6ZxmPuwjNjEYPwYubNlcxNmZI/3kC/eI1msmt5GpGiQX/Qj3WNZSzv9kYxjH
> > 2evs
> > qrwZ83Xly4ududpgDPR8eOPdbV393L1uQk5jmN4dYOEKY+Tq322WfLvhy1vYJl/eZuheXt2P
> > bVpI
> > oPP0Z7g5XEFCgCbCEhNre4XlmLz2cl8IfnJh1dY9dlcPm2EDzgB34PxY1NzWNUOCJ96/nddX
> > DnOi
> > e7W+rmwgi2AyNcH9jdULLorg0oP0dDjQuwZoWJpB559sBcj+jsqsVimzBAYSW/mi8vbLbh2e
> > cSJE
> > jHz8/OtBckhVdD373R9szNjPk5Njix3jFW5rwnx9/V+Hxe8bHt68DhDtxstn7HdCDaoc8O9v
> > BRLY
> > EC9jcYZGje/bjza5c+b82va2bqfI9IM2jKbCZ3TjKSRfPDsjaEh4eBTheuUONvXop8GCufsy
> > v29r
> > Wbz44RwYatVdsSQuTnn9vMrCkgc7e/v0sZ0MUTOMOmcYcx7RgleO5Rju64zjhk4jSU6W3ENT
> > DQzS
> > 8xhciGskN/HI/N+b56ZA/EYwI7WSrHs8yjETY7EdoUjnfRmFg3qmwcGBs14zK2Bg/BgfkArk
> > QYxY
> > REX2+78/nw/yw6g9WpAxAjEhJwqsCsiLEikio6QEN7EUM4gO2UJ0ekAMd7QQDHE5/PQB1dl5
> > iKqq
> > 9QQ4JDJ3D54H9cILggDhtiYFhaH0wQ2wMhTAoo3gFC1o5G+ag2gS+ODRiiLs0sq/ihBD/MoT
> > +oMh
> > EP6pVhDQzmm0EmWpBVESJGKRJJLtSQqB+9Fh/WEYuM/07tKCWIJDEQKUoEgMJQkVKISIkiLd
> > s0EQ
> > irIKBeUQFfuRPeRIxjGMYxjGMYxjGMflrxkVLIkRIiRjGMYxjGMYxjGPZmODeEz1/OZk1pnt
> > KRk8
> > eOIgrkGRSMiaGXHcoyqRkTQy47lGW4O1lbSUalHJhTHMpmpcTBolY4WUsqM1NFNOgVFVGGtU
> > 06SG
> > JghRiMuQZUXFay0kSIQdyjLcgpYy0mS4xl6OIhoesoy0drLXEQg7lGWu1lTQyu5RlUIyV0rK
> > XISt
> > lUEUBMrx4xloO1lUIxJjGQo6V4xjKUdK8YxlLIllGyGKEGUUIyqEGUoOlYiDhBlG4x4xjIXI
> > pSDK
> > KEGQeNIYoQZCjpWTG4MZRQjKoQZSulZMY4MZShJRsQmMZR2UjJjHMYyqEGQrpWRQgyldKyND
> > hBlL
> > klGyRwwpo1MxSxqYNErrKYxalNS4iDGkMg4iDGkMgOIhHEQg6VlK6UZS5hAiRBMQyGDiIJoY
> > 2kMh
> > g4iEMHEQg4iCaGTAcRCGEmQhAlxjKpkGRjjZE0MuDuUZVIyJoYpkGRlyWMtcRBjuMplNAQ/1
> > WH1M
> > MKUjIIWwpGSWIsES2lsspSyWCUthApzgAlJFERFVghGAlhCpFgCJIosBYoKCqKlQRisQkRRk
> > BGMR
> > SKpIpGIMQRVUWCH/XLcwQhaACJsAhg/IP/YP1eebLoyDaLovA8H/Pi9gvOvfEcoOQ1nVWL4W
> > 0ta6
> > ohICLl7asQEWq7jMV34pqQqOIimrUk+n35Mg7BcgQgYcWnGiOeWQGHua6nALFN3PQGy4lnDC
> > GAf6
> > 0WN4cKCUE8f5CwVqIqM26g8UePy+QENnIdiqoRcf3vvHmobfwhInw2a3iT1/WB+0P939z/sF
> > JERT
> > 8M4AXfnf0T3N7gEf+A/3gDk/n4A+irTjAKeTaFxbIh/EfxM7EB3bpoN1/i9grvkIAMUkAGQC
> > H0xq
> > GMBaAN8x5Ho3If7bQB3Y7DeCgicyf2CBRk9l7km9p6Usjk9F1bWFkYbZPrTW2Fe6yXTUxtxD
> > /VhQ
> > eVAYN40kFd4hE0Fgn/AghoTUv+yixL37y1rn6s2ziXHo2uFlhyoH7tqZ4a8lrJcaq96G6TEV
> > jMbt
> > kCtnjmEmtSYUxu14UEkk/n9InDA6Bof5IAfhkNgFOeZgShZRZm7AzED1nYDSQqGrikBUHGAj
> > 3Gbh
> > BuYaUapZ8Ce0AuOvb8dBY5mHcfiHm/zqz4P3Q7giWL/jDvu5Jbng+Ae+yfpdHfGjck1zwHAC
> > rJq3
> > 8+G8zm4XrDpInS2fLOnlKuF6eRiHPpB3KwzHRErpvY8YDhuMaKpfkWKIr7nsTL7ZEpRkQG51
> > HOB7
> > U910wHPOs2OmBhhfAgN2XvQ3Y4YFXwcCyPNgP19tcgIjmTqgdPBBUt47OFgfgOVH+vlNMANy
> > 8CVs
> > 2PIsYseh9HL/jlQt15oeRO0ST2sTroHkleY0NKZSSlgk2AEVCGnh9hr/5c4favNQtEZIDH+z
> > 1+xV
> > gqLCpsoeKW0GB9gHkLngnoPuhMTsQvEG+neeMJjvZ+Y3xxAmn5FyGBhIkA3kE9rPXCcNbPkq
> > 6QL1
> > QvoMUCjqOlGAInKej4XyAHpPjT4HRJ7LJzCGQhPL7JWAsqqr4eE9tL6rYImCjMZmOEckWZd5
> > 4/2c
> > 79k1+5V/H5And8p8XnqZn6lIAvsgvNekoQ+ED0ELwG0Q1Ur5KBKyRPD4PmW/u5hlw4WGd/kO
> > 48Tu
> > RRlh6ygF8Zrs2gajGAiAjAREiIwFWRViJBVRAVYCIkRGAqyKokEE2sPb+VOTOA+z7YTJ8udB
> > xhRG
> > bqk6kDR0ehGgu4u+YWyHkaA/ygbqRh5/5eu2/r1NmeJ6aB9byiKqqqiIooqqIwGagU5b0QWM
> > k17L
> > zFHG41MsDTOSRA5ScgzqBjKyFklTgJ+X2+p9y9LBggTqfJxTq7uBxKNZwWNznQU84XfKfRjS
> > GYt3
> > PoQvLek9od8jAsOClWvhfG3r8duhrWH2w9r0RKZN2bt8tjWpS2UtlLZS2UtlLSWMrLNWZbMj
> > MZRK
> > lLZS2UtlLZDyJ6YTvNtBqe2fZJHMCmAT3AG4FY6btm67zyKkdjCMiaaGlmmcyKkiiSaYGGYG
> > EZoa
> > Vl5zIqRIyMkMn6gdHeGpmqs0KkIUMIyGmhpZpnMipEisRN6HhDwV8Zrm7RRGA/49oYCBOLCw
> > lkqL
> > wqIlsfIN5Ts5LYQ5wNFRRhCIooo4s1qQ30Bv9smHP7fvR3OTD1cyqU6izts/4TACxiCTnIyq
> > qqqq
> > iiiiqqqidm/UBhOUhQ6uodG9pvNg/2LnKJ8hc+gR8QZwjY4IliHmF7XuS5whxB9ycJEHPkmJ
> > 9ou/
> > VpO3sQO9to7vQ8D2zQ4lNqea9yjWMZ5jgnRyGuOra0txPb9GsRchj7GGb3p28Yl9BsBxI2u0
> > BaWL
> > NU9qBLPsqQogdEyTWPN3blotygHYmeBj3+F2rUmHqSYl7g7RwKgYVCDxBlS9spiMeGgZkMy5
> > oljo
> > LIBzq0VGQHtT2JgWQBXpuUm3OGQ2lk7idpNk5UX0DBjMC0rL25hBmkc1BeexVJBohdgGYdEY
> > LcFl
> > yVXfeCyPR9Q3veTds+Q8JkoGm8hfteOTFoMjIuEYkB/0CKAOyMCXCjyOebhLrJEBKxg+gupc
> > BfYg
> > B1DgnJOyn6lwRG9+ShsolQSiwav7js9H8lvw0YJ8/truYf1S/E4F2wzF/2YcbhuMuA0ocC4O
> > BJlk
> > ShrjQwNNqmxXaSTG0mazPARKk/f/g+CH8XuLr/3QDtpIvTp0h4c3iyIMjOnUq9Rbz0Jvz588
> > OZuq
> > pEVRUVSUkKGrIpqppzKFWlOkqLnS4CWBZw9xWW63i3ra3DYLeMk7YE4m1A4YLdlxWW6NXWnD
> > QJEe
> > 8DWt1rYVgt2WIa1ar3wtha9ijCmsUJtF3jyDRE4QXzEMKn9BsQkJC/JofiM9dH0t4RT7Tnwd
> > MNs9
> > 35/7j8WimeCPojyRClKNCHL93X/w/n/1w/4z/ppZZY7vhhhOyuSkpKlKpGxsbbbW0tttRo20
> > rSrb
> > S3kcjkFqszbbNbZ5/I7SzebzeWWWcjkci1bau2Zjg8iMh4s7u7u7u+KVnr/hSboYgYoGwnf/
> > yxwC
> > AxgzYYRxrJSlkSKFBhk6v9aqqs9Ntt9EGqBmQQDgcDY5Bre/BKqSTU5WtVzA5tODxvbTQkFU
> > 9GS9
> > m3vyzPAr7HBD8lHZwdnR4Oyjfgrjjwzu+trUp4s0/ThpG3sfVSXEhuDrcpENwunM1NfBevt8
> > 9q20
> > tL+4P4ifp1+X+r/bbX+kikYkikkJ0PgOjpGKQwwKSyRIlJaMFItMWMzbUH6opU2hsqAXRNyy
> > wRkY
> > wcJoYscMSIQh98sCxb8JkCBZmZCyyhEAoBsG1n3gwNkD5CSSb5unGF1qLeMC7LSXRDWSBuDL
> > wMCj
> > AX2JxtwpPb4U6D5ALW+WpUlZP6jUaVC4JWFi4jAzKRAxq96D9AQAiJc5Y3bgJE9BNyEh7QJ/
> > y8lR
> > FVUViIq4TlzaKgE6h5jnOc6AVdcRZvK0L06HrbUMhcmGBKLAGDG5SgwxWbpgwswpqFlDho/r
> > 33Rb
> > 5/yLVOJQOOQiSSBIiqqknQ2AJ6Z+Z+bFkUVjJYhBkBOIp/qJycx5AQx3yGbRR/QdE4Ox+80V
> > tcS9
> > LoLXQpYpULlIId3Hs5VbhIiggxYMGIQGMghDckaIjGRgsSEEgwihEgkid32zeABoHXQnM4Ce
> > 1pYg
> > Uoh82E6gOV33LRpC1kmgDrBYQfxQrRQuqD0xCQkWd9k16sOrLnSFRLXsGafIkIT+vQDowB1P
> > qOB4
> > fAUm+7Hx6KGafb2bD9/Z90t/OfqIf43wvUvkQwL1YmsbKw5MOZIdEPMGBarGKqqqqoqI3+z9
> > +HbH
> > 3qgxBBvpd+NtfsCUosOuJgkggXwQcaojEVDILisFXJstQQYwIpA9tSCjkgfQeMkDIJgAaFq8
> > cQHF
> > kQBsMbtFIA7gkih9Yds3TQIKs5SAJDJAEChTbqEKULr2phmui5xpzcqIOdwoRT9hycSWgmBt
> > axdE
> > Hj5ekKLDDuhU7/zaby9wHsQx/KhMDE/RoohQwKdyXSw3YHRqG4GC5k34boFokgsjCwUJRwcM
> > nu6T
> > /T3aHq8oarqA2mUDyfOLOztGOoLVEUpphTTGc0d1S0DQH0OiqoQxBiecTxK9H8PX8bp7Er9e
> > 3h+H
> > n+cxzAdZrrazwSI1EqJUHzJqfU6/UFeZh3m2au4mutHZFOk2EjTvNuHjtW08cOZkegUHLoEK
> > G5pe
> > KaAEwsEZ56RZkRxv2EIiaH9WbG4XmJ/g2JMVyDaauuob7kN6ozxMR5EjA4lV40MSlwLyIcuM
> > Hftc
> > Q5OTiAy0IxsEHG/gNgggU5N99R0cA/J3vsOc5BRg6IwDhviTwUHQavpa8EmcEn8aIiXO4prS
> > cMWx
> > dkpwVxD35YTj9h/XjFm2+9LsYDHJuX4nUIr8Gw5gs4lRSjpl14z0Hp8iSXpXqel1YdY3HES7
> > AlMW
> > mY1B3KVmQuRcXAwclMnad4dDvPVynLi8sXMcYXEbbZWP92MaZ5QmX0dPN49Qh9nV1dV5g2FK
> > kFLC
> > 2JkH15kRxjDQ5zO82HihY8Y7YHORsbXX32tCEOYRIsmaI48iBK28s9APvBcy4E3sBBVpadLR
> > zQtK
> > iBWebIZCg+EZVAUJAQhEIxQHoPvV3YQBIX7fevkIF7y0qOo6ksM8cu7x6VdmVhaXane69EJN
> > 7EWk
> > AoiQgLBf8vUy1NSjCJPYKLX9ck3p2bja8dySkOT1FX4TvK+FpwvJ2w2iUKFRYbmobt8Tbr5E
> > a5Rn
> > pAPAqDc9IFCFoCuqYbgPPAUP/ggFQ+LyOQxQ4scBRxO5QvWyfl5HMZhTB10ucCbHsEdbAHG3
> > X+0v
> > AKHi2LBYMH/SfeMQSKQUikWZOBqUP5CP6QNT3jELGr2ZLnf+qQcV5RH4d1zWPGgAeMsQxEPM
> > DNoI
> > bEd9bdH7KLMOmkQDya94vvTH4Hfh2pco4JCFmwtlHwic4A7C5CIXA4KDmllAzUQfP5+fXli8
> > AUt7
> > jmnhOPdDQHzErV48miVBiRhCLVJIEoAjSFJEdcHUv2QADKBiQQX/eX5N7knw3PtwSs6BrlZD
> > kT85
> > KLinbsAi9Lhf8DwJAgC2b/NzAcMuZhxKmrbtV4fYG8ZSRmLFxMh2na4080BfuQCAl1VaYMCK
> > mPOS
> > EYSB1lDwy4TFK3qcVOcgUQjCBsMtD4TEEcAVQsdxl7EWHH3m3f4c9IFMCFK7Q/oQkiwIQgRr
> > f0NR
> > 4zQO+1WhO0KTPpoyedycIhllTmhjCpShqaHWC8RMz8J9CzkWHaxUd8QmVkJRsWywyMRC6Afz
> > TI1K
> > UaghAYCGLAKijhxvCkbCi96oc/nB4/QEfq4A3RGGgecHvlBDQ8ePivsZEkHelFHpaIkGhg0k
> > oexo
> > osUWGOF0q7KCReRMUssJpwuPzfYfm+z8Cr7iXnXcfILUQwRVBr2E0SLuPBzEUoohwJRWDQUE
> > MGNE
> > x+wNEU8nvjdPtPoV8f00L9Du0NTuOh3H0y23KHA4Vw4WspI3gFQeY0E0NQunCkTEmmlLcYOh
> > HjeI
> > KuNz2nbRK657oWkAZj8+hcx0EI5wkYjn8JjpquBoXBnMoG8DiVLe3JhkLAwKEpY8UwxdZMyC
> > iuxt
> > LT7vpZyvCmWUCwwjiZZUsENUjZ9dipzPO5IujLZ9jbCbXmY+lDAzLsQsoTLwutC0oxmhwgXk
> > /ejA
> > 3NzG7EyyV28R8oTCFAmq65q+MnMXy7XwcOiG23JnaiShr8Nuc7lJlPOxyFF7p4SRshOTk6az
> > 4wPu
> > Z3nre4kktnttqLGs5rmR2WZFu5llIG42kZnDjlx0XA4bVmfuASFxYXzCCOvwcfIeOEhCmEZJ
> > CYiK
> > Uh7R4xiRKTbynU+pT1uOQrBvrMmOLqGXUvftiprYIKUCKbIY7Bw7LTicudfG5Paz3OPdF2gQ
> > iNyq
> > JInIpCEGduQQTVBV1OXq+9zmdc7+uIZFhZMxT1MFC40DrUoNpdaUsVWOO2JZkWfXxAZgGTIZ
> > CbDm
> > c6N8sZ64ji57A4cTU6B6AiHcsSLA2jmL2pIkN9IiNi5jbRYYuccg5YZoSLGEbqhz7DzIpxKP
> > f+g4
> > P1v0Ip0Khs5aFQlBSmFNAfSq3QHe7Z5Y/4EDvfrgUEDQHxsEBYWL0FPvwO0X1C48DUMAfEXc
> > NSw8
> > TSD4ROYL9ns8a1+0EXkgIyAg+Z6ieKFaaGa2Smg3qB+EvqHD2GXlO3AwhNE+VfhyXffXgOKT
> > WSqn
> > Apsbc3LeGS+HASgNRw7QQeta009T3LYJEJHvKzBQmdnAHDmRe2Ndp9UCZtGBzn7jOv5WvGQ6
> > OjfC
> > a657FJDbRRQx3RsqYGNxcWRel95ILxfgsDAvMTiVluuUTwzNqy8yoeOecbeN1PPDFI3ext66
> > JUO9
> > hzBHcX3EG4T6Fwh5PVsjTeMnJAOcbIqKUcEYpsEHoa5DY3LksChnWXUGxxGl1CsFtmFkPr64
> > nITR
> > rYWQy0LnDA7d5zM+Ce7b3H8gQ/HYbJPcsMcSANWboue+Bv16EOvZtTYq1UTrUnVRRJBxKmRi
> > ye86
> > 01xUVqRNMyKhjgNd/RToObl1kmWJYFCrn0DORg/jj8RjIqQKaoBgHPXrXQgZWOnC7kVIFWIS
> > HEgd
> > CHAAV4UxC+819zjnZhqYu05kPCxh+1njJ6aKO/8hMQ/1blJEIGWLYsIfHR7xYD5J3Iwue1aD
> > 3pO+
> > 1o3IkFn/XhkkMISHt9/IRAX4JWMSSMRFSEFCBCQjFPHSqk3dvYbiukxudR1eTtxMA+oOfLt6
> > i8j6
> > wYnpm0ZFkCV8rB2iw3AB2R87E0IZ23KFK5umg6MCOA4zfF3s7MikAUcBaH6/noJGJ4OUU+IR
> > E5+G
> > nBVT9JAM/mq7UvAvcCx1IEh96wiv0oH3kmodu2g+kQMD+0KAg9kIiO7DyssnWyc/Q20pSFq0
> > djYS
> > wK7QTuAE6/GyHrYgw+UAp2AeeFNCWbpmBZgMswRhVSlCydkkkOyLBARg0ZolKFB7D91BwxdJ
> > wEtD
> > GFiHhAns9BhYk0BXWVRSxitEaIBXcbgE6RAIkUc6+F6WYvE9DsPk0r/BV8adExIwSC1ESlCg
> > YoQQ
> > J5QKEdowIMCAhIJECKEIAsbqF7KVAFJEocNsC7iNuQHN/i/y28BLtDmSCz5PRlBmYIpEiG/E
> > K8/v
> > OoBt2zvnx2q1eZsqVznrqmSFiqcSYZEcm7gqhoskPsQw2GMG6skv+52SZqnrRcfC14TqSGAK
> > cDKi
> > 6sShWLmBcMLYTi1ByhKMOW0gXCMhu+Xy2+G757xNxu9JUiJJIgdEgG1d4YeLBJgwZDsTZwcX
> > zUD5
> > 7hjgs+NCDkMnCvQMTElYfCxH0D1EnI232VbwvScvfx92h7bDMzKBIayd4aqWs0V9DFgaBME1
> > paPk
> > Z5hqIsLW8cTFDoK7JDoXZ6MFY7Ojo7eU7uDc2Dg+QiKPe42BMZRnffKSZWGJDA2WTEcCSopJ
> > 7LRr
> > syMMyMVo4QY4oEh8J22GZE1stiWlCtFxxEgXZ0ObOdm4oTQhkKRSzboRK2wHYfmRPgl6JxG3
> > XTiu
> > aKhyZ8fEZamaPXBXsEFOKQE5xRWwPQiBwFYKlxaAAoRpiIdIBkfDn4v+MAWazJmvQR1h1LQu
> > JaSJ
> > VGxaudxUFiM80IUxdntYf5wZn/j9dFA4cHbh2kBIv44HcLM3W52B2E/wEV1HcWqwpWc+vn11
> > 06hK
> > nX18b9AU6NyrPIp5/QooYdMHPgwkJJKAAdkUOCgbSxlJeiAF4ic73ZukVwL9H0O/gDk1XNZd
> > xucu
> > ZTUtI1BGALiGxJTEgGTIRsv6QCsZgt19+xE9Ux0CbDgvBtQ95eC54RuJotVjlbZiqDlzOddT
> > mVYv
> > 14BR+lVMP4RAYQHiBoVoRQioHGPtAUpG570iH4heiOPomew12XNfRqOqhHlFZiYmf7QA8ApL
> > AKHn
> > UNcBwQHRA+zv3jrELCym0UPMWQ1onZAMYAP2ir/GlLa222lpaq21bL7aFyltgVa2aAJeROsn
> > WSEn
> > mAPuM6pAJAL8ZAInwcNxKRmmVPikmuYF0NQXqgNQX5+R19Xw/DIfA3p1uezfzz+vnv0DOS8K
> > mMdO
> > VDECMxr2GT84HqJb/UrTCCbCvgtCqDFBDxGAFzy9mv76q8mRW5N2xRvI2BjIYpcdACr9mBzv
> > S4rA
> > gzIOBSMyz9G0aMTb0npuV+uz88cI4ooyLn8jHHOtrb9eilFXm6ZuvjXlxFPEjSPEVrPC6jkM
> > VRm0
> > HVQVUAEsYt0xELRplPGkRo7aefDSU0gIgNpzD4w+2yCg5pdqMJOlNmXVIqWqq8MBUFit562e
> > rn0V
> > OLoMh18uRo3HPT14YMFI9VOQWbXKSFJMiM0DmCfSh3Bst2BrYKpNMaXKVMjrJlVFF0GF4vjG
> > +QiG
> > NKb9ZwQo2RRN12t9LSImtDKooLCif7esZpaajb6FrQ+R8/AULpz48h3lzyavRTYi3lRI3bDT
> > gXCh
> > LVVtaQuvEihtM4I1yWkWJVmL5jj2DRQeKG+vfSq+Hwdpb8J9Qw/RJdG2HQKwrBJULugzDZLr
> > wJw1
> > sdrnpJe6AKIKEmQ1FFBZPNYDYssYAWYgJwvr2O1QeE8Qa8+Hsw4P+D07fecjlQ/IPunXP21T
> > saKl
> > aqqxjUokqiRhKhCSM7DuPlt6uf5vf1+Pj6Pv569/y3T8WvFxz4eDbiaHlMw1KPp2vke5aJGS
> > SSSM
> > IREFFFVRRfHpyOvoeXQ6zrPb5ezYPKcTf64dRmxDund3RncFSCCRBUVRRVWZmZmZiJZl0Nco
> > lgab
> > rQwkDBp2D2EDY4EYqnZ7hfch4sVfbds9plRmauvXdI+3fJsjba9IRg7s7KqXSqcl5MKFUn1j
> > St9j
> > MxOL7aA+6SqOO0ypEyrfiGImXGxUSLAoOgE2SSVtXF7AXc8FDdiHJXJya5RDHUn57yYDxPR2
> > NsGe
> > Ak7fwOdHbh1SaPA8Jlk56ncx3WNpOyshZ0az8nO6nacsC0McG4WIczJ3WsJYhVGLtaHzwSIx
> > Bixk
> > CMQYxiMYMYxgJGMYkFABQIjHQBJ81Q3gsgp6AA9CAHJiRRVUVCVQjOYVhyyduQO/TYTvisbw
> > bDcy
> > 04RchFKeJ59xUV1tIsgixB1KseYwYuFBFzRhq1VQpCw4Kg2TzmiXUSFlIFCrQkBJBCgDHNAb
> > zxUD
> > Aigkk4hIzY5dYOcmRxCPLiT8vVi5GP7BxT2HSW3wWgceILnCc2AJ6aqxc9odvcYTPt8Ch3h4
> > eJyN
> > gVy/SdYPZh06GF1+ihjfl3FV6eAMr/NIOYuvoAfnHAt1r9gxeogyIpQEZ4qBbJ5CpBLkUIqE
> > VtE7
> > kIkAf+IjQUNkgcipO3ubxZY4OqF0IEwXYzQpV4zXsGyrHq7rbPl9u0xPGA2cwKinag28M79M
> > jwCK
> > hnz9ucp4OoWKwfBV1S6juPQ6YB5nT0mcDuITQsRJWguWbgHMiJJAS3FCwwS6JyC+94dpkopp
> > btw9
> > 7aoMIBy7yhps5xVAfiLZmHPGbg2G4xKTu8qXE40B7jcHRD6/PEdiXOnhf06Q14DrJhkc0B2y
> > s7Or
> > b4/Hvf3Xdj8bxLwEunppx+Yi/rQAsdCw3F1xIkJLoOdhuIy6xJAvIj2F08RJIDy+trgR+5iJ
> > r0fM
> > FH0G6piEfuHEgnmkvMH8hLqEg9feIQeQu0UkFzIMe/Lz8u3yePn469X6/AS8a++3yjzlF7os
> > UEu/
> > qY4eMZdkLK5n8wlQEuIgOxeH/Hpe0l/gO/9/lqRogQgCSJACKeUWARiSKMZz+P3v6j9RtVQr
> > UPs9
> > P2cT8tDwxQvgjk+snLbGTZnTexTJcseotgFLDXRFQOEdPdP8vbbh/NlBEPuPxCnV23eghGIy
> > IxET
> > CJihBn9E/PBjGQP80VBYjBEF+JDiUPT4UeXcLE+UOiJxEvArlFogItmrNySiQxOqKkIMFYII
> > bOEW
> > cCIsoh+E9bCH4HbFwBvw84iWW2nswFBw+lU5ucMg5n2iepoT/5hooHj3gOdOBv9KKevUw99P
> > 1T5p
> > YHwBNoh1O6GgtaFEKd45Dq+KWRCnLEEDpZC7a3wmwRsfhv0CxowmtJWmVjzT4RNf1WFxgWgg
> > muI0
> > cvNRxgGUBYRJEQIEBI/hyFsQ9aKgSi5/Du6/syxHYcaqjS5sOD++LIBBIQQkfbYUy15BndVD
> > dAQS
> > g3qwDWAAFRCCJwgUgG+CXq4EBSGlGuykNvziOXLePK/MxtZ7gkRjrfaRpC+qxkxGsayxS/Q1
> > 34rJ
> > oyppCRcq+3ljlY4YdtdYXNM7JhUbfKOSqKNisC7GSIsFbEC7cUxt3TS+uMvbOmkIwThKCyrF
> > GCSI
> > Q11JgBaaLJvxIZMZGIhgb22lKJRWFq0hHFQwA13/UWF0PEDgBrzoyQhGJCSIkgpFiSQGQARF
> > VYow
> > RWLBiEDNzCkbhw0osLpjyJ/CEGmqIqEgg3FyxUPs8AcQ6wryAWbQjImJCohUmvZ3gaDY2YEQ
> > ElpI
> > RCkTXB4OzDoUHZsN8g4rygCyBIAdrMEdXWKavJU6RkY19wnqVT6w5m3KtT69xqKode4TqOJA
> > cteP
> > eqNlFYRIRhCIwIIAMCgqhWiBoDrnBJGE91iijyGQXy9aTFD7cxYmgAjiaQ5zI9w+DgF8j7iP
> > kfqH
> > Br2pmUiYTiPYb8JfJVkCRQLAZ/fgbsVYCyAlWwKIZIDGoCSJRAK1+3r5fcb+GPICRDlTRr70
> > /tO0
> > +Y6vNWv3QaR61VVVV/GwFoH+JQta3qOP9ndA+n3vwh+A47z6/6gLk+clGPzno0Tjfo36Jz+r
> > OTfg
> > OVyfPxe2xprMwZFsx4TBucngYYdOu27N+s4N62RxaXkNDnRvg5Eo7I0cHRzRwc8DPIa37wO0
> > yXvA
> > UnHjw/gsLcnoJDk43NdcpxxyU788JyaQbO3Bzc7mEU58YM8JyYkN8zo8Ewxw0GDbRgUAnURB
> > ZUT2
> > lSzJWGRjgGKFzJIVgkgURD6vdtsbHIzOZx58TBuHE7XyxkQ+BFkiSCHv9Es0IiIjGB5/jQoP
> > 6DJ+
> > OWeH6UPfev2zzw1lxchTQQs0pxHQYeIMHr50U6zrz/Qp3d4ejAPDzjkW8iayBIPn8FodvFd9
> > UWXT
> > sDYqH7eiSDAyDI4d87bTYwCki0RiRMLbTCotNt7fOq79tMLBmApzcp6FF0sJtr1aiqB7stf0
> > GcKG
> > ZptiNlDINg/aINBAdOPP4AJFDVeZ/DjR4FUxOFghygnKfggDHzCIRBX08lQKU1UMWBQB60lh
> > TggH
> > lDqFwvMl9G+N0RmuAd8Xz+b8bWkYwjCJhVAmEQKYkMJXuU4ufyALmcF8ouhcQtrHQD37CIfM
> > DEcB
> > 4E6wkE9ZameRy4+WbC4ifLJtPZR+AibFMgfAGg8hz+glK3AiStApdkgUYExAhoPM4GBPmB+Y
> > BSbe
> > qsTntR8KA6I5IDgIhSqYor9bBQU1OHigdcuntFCg+ioaLvNlfWGsHHQ4xJELIJFQb3grcwA4
> > cngB
> > 6JU1vlqQgOg4EnAUFQSx252QbDESg1fmdvc2ChGoDvgJoMSAhAreEVQbyjslnAuDgBzVnxFM
> > gA+o
> > OP3h11CUCPiaIlwTgUgeKoYgcBC0eaUrinS7FPiVD8FQ3eLqPLQMgQ8vCtNwYXoUWwoJaf60
> > MVRR
> > JvaWgX2EDbBknzIyaH2/+Kr/EURBGiucSG5ZuSIGREDziQDYfOpQ6B6hTqH5VQ1Vw3SQgyOo
> > iFRg
> > BpEFEntpFB8DsMBkUmNkEK9OSrH7XKwXoUql+menkNP3wP1mClxYhulE7cDeiDIqkihrAKgh
> > IkYr
> > IjIXXFbndspgwhAmwrMfqIMZECRQikFgjASRBFGIoyIoxFGQRCRYCMgAskkCKAyJCAqxCJ1h
> > UAgR
> > VB3fuFxXGycHb9dg4bdUxg3PZhuAQsYQoNwgWRMTS98IZ1BhJEgxhkYc4/sEQxwg9SqVrEeM
> > gvBv
> > Jr6lDoMDZlRrOMeoFc/R6fa8Y/oHk7PrMzcs95UVg9gQLEieXEx7vsw/JVBKoTIDM/WVf3Q6
> > gwMb
> > 9hdX1oeCuq0mBkwPnDVCET4/k0AoDhR+U6S94sTsYog0F69d/yIjYcNC1BI6kcLlxoMMkSyf
> > xBxG
> > 0kCQirCKBGEEOSJHCfMnnF7PAe0hv5mHtRT1i9QorwmO0OP4D3xrIXzeY5CEOwzYHb0JDjBO
> > sQCP
> > Dqfd9KrBH+UWWtp6kPiwyKojwBIchhOuH7h0NeBfiAeyBPVdGMhP2yoQQkRiHeBlliilJ8nj
> > Q0BB
> > 65uiiEgIsLhRSJA4+BJMfgpzFeQXRc9gQ0t04v3AQUphVHKFA2VVDtDPCcBJRR6RppmUahZk
> > GJeP
> > hcLbrpeWEujyWYoFFJQWQYcy0A0SVskGSCwRPFKiFUUJmNJc/jyRy3fg+VVTzMbGYmU0+CoN
> > wxhk
> > L8K+EEAH3z7GJEWEkEDcnoYpq8Usqbm74gIxQ5Mx9HNgaSahhuw7ZFVfittW2rZaq2yqqqtp
> > XR9f
> > s51tzATt4sJOd/ft1Tl4sMzVVDUjCcSqk6TA3oY2zbZ2JbLyYaHo8d8cjNXe0mF7gqhYUGBA
> > eHYP
> > YVzb5RzkmxDWKFiSSeUnXHdeofYswI4E3YXroQuXzIZxbY0qrDmApVqSMR0qghKoVEp0wRxJ
> > 5OoG
> > pMXW9uqsA/v0YyfUE2CFAxKDOZQnmGHAKMEgmGGwJvoMqAe9Nhf0C8Be+73kIQiRBGSetliC
> > kFUl
> > GSpAiSMAgsFYiLEBILARqCm9NQzSBR5sAf62PRufZiLvIO9u7QDpeoGJIj1/vBfGSdggfCCq
> > MFVk
> > RH3iURVFCHzoda93D4+V0OAUU4xAoNfMmMKjTtoWhjCSDCAkv/c1sMDTIP5QqO3Eqy+lMVDx
> > pcje
> > ggNnPm6UHAQ8j2skh3RklwH64o9qGJAZOZp6lGdQ8wIfbLegf3UWygtJzM2IdK8sRFsV22HK
> > 929w
> > Ru+6hQhX5lm2Al/JSGuRmgjrnbi54c7jGA+UFYEFgAe1FPAptUPm+tV5R98QY7BEMRPsET8A
> > DUQN
> > hxIeb8UbPTzv6+hyJ5pAkQkIYDIIwaAUdGk8oIXFNdFD4/lpzFi64fUFkLRGoR2urzY45G4v
> > HeoU
> > cW/OPaoX4T5AD7UB2LuV9inBmqD4aaunsU4DvETDAnc/aKRAYgFetc1DuXzlv1VnTCYfuQxZ
> > EDSi
> > nZQTHAxGMQYiCHyso8EzoUA1qEnZ/OnqMzMTBXI5UcVbQ1rqjZLBIETVGgF3KoWFoF/sRgLh
> > DhBZ
> > LxRoIpGFURYKbAUBdVYr5YqUjEjEhGAQdFEE3wOnfA+1IixDmVUfbzKGDgPDGBsgWdKjYgtu
> > XrRS
> > grz7OXh3AHGu4J2TYsE6A6owjCPGmoxQvLRwhFR4AZRPM94DMB3AhqpGrc5QzemK5JMIZYbm
> > 8nGq
> > CbBFJQpJYG0LZgyBvcMoTcZJohA8e6CKkWRYqkm+geCpUlOfKBoFOLKJyhWc5DQIthLCksFb
> > Ljrx
> > TLjMQ8mAYnXUCQGkTUmuZTKBMs1gG6UfydiKnGqBF9AiEfOgPaG8DMOHCjHYM493XQDK/0ju
> > 3Qq1
> > /Z/LmtHV3s7hZaNlLZfVmZC0lAQkPAWIJQEAIhNWihXAWUNQhA5ssEg7uxcMwv+85ZfZqsUX
> > Ixqs
> > SZ9EFYwHSLKLj+QHGKUpcYQCQiR0KqQTrRxEsvR7bB/MYi4YAFUaoIxVXqJuQRLbXHP4vFT7
> > Mtxh
> > 21ejyWAx+WSWCBUfiw5KRUAHrP3CJ4bGd8SFnsKalMgRCoQCyYAF7MGA1auzh6bAJ41XaImS
> > PpQH
> > QrQxSAllbAlgo1Nnw+Ou3ooL4UEYpFgQkBPzr+d9RTAgWEOQo6iKcA0Q7XSDCAdrsoUsPJA8
> > H1DE
> > li2w2BQAduGEgwnMglkQpEpAYBQiWhSyRJKAliUiUgwKQSgykSwQoCWCFBKNgliWCUaCWtwu
> > oBjR
> > QgUBy5gPJR1VSioj2KxKUC21sSsgx9sKWAIEkQNx6QbKZ2B0YMmDsHRGj7OkgVhm2LGxqzs2
> > xS0N
> > v56fdo2gbBLAUaWv6fXZykQEE+5mIGPFCrRL/R/Zge0iHQqEOlmHoCcF7G5HpF2i+C+kkpH9
> > iA3F
> > tcnQFrFpY/8WuiHT0i17U9Ym/vIXih0ob2lgJmnHwzsuad7pQszAeMBSChSG9dhCAB/CF0Jd
> > lQbF
> > hsoh4vsEx7fBi31UMd7VVBEN58wl6BydmXyuCBlKIIblAtFZaB1TITBIib2gG2qYI7FOtmoM
> > BE0J
> > oijS2Jma42hix0lN8ijvoC6QTC+BYuxkX04WwuhCJTjKUIkbaYKZcUEF3OlJjNOwyOFP/0Em
> > JSEG
> > GAIyKREgCRFCJJARcEs4KWQBVKMCvxSQpIkiSIiAMiMWSIvJJCokSRhGfjADH5B+BAc1fyDE
> > coqE
> > CEkkiQcWmcabDGbikBqAiSKJb1nrPwttiGJgDskGJgtxwAwFFaGCCQIoSChIThKArVcjLJEW
> > z3lS
> > IYI5HEnHbFFQN3AWhsojPEwAC4WRIJUCgjNEEmzMEVQNaote+IaYMgTWwKoNImAsYiNxbV6x
> > gNAA
> > jywUDBxGCoYiIZAjAC6MSAXlMGpLJCwbICwHoESYIHfbIHWFFuCMyAv741SPr69oZkC4ULql
> > Zqmo
> > pssqLYkkIIsIiCN1A0t8bYBQuyRVP50DgIWa2i2sZXCuCjguG0GxhZD/WRSxWzyXsGHehiU+
> > 8gPD
> > +cB5hy9YPURkCQP1n6s/FZA/C6FiFPppS0taHrXsaKaaA9ELEGiEQgBxGxE5mqRkEBfsiA96
> > Nugg
> > VZgtCRKAtBQk7gQJHAwCXuKSYqIMkUJNrWJRGoqGBFEKCKWiUrgNKJUUaYwkggVAEYCLEAjc
> > gkY0
> > kwiELNoJIUQokAKiMAkyrIKkIMIMZCKwUijEgjgGCS6+CkAjAVYiQALpBEuNUBqkokBkgRh2
> > nRgj
> > D0Fge9BEKmADgImQ0BmB1ghw48ROPbCQuWIkfck2HWyKbHmBmobpgAm20UobR3GTYOzt7/uP
> > 8h7/
> > EFKg3aMMyD97B/K7h5sRn2naQEaIbbWKCwwcSdj5tjnNjsnw9Vh51YK9oI5e4+X0HVbogZkA
> > XcQE
> > eIkUFvj9XnpddYMiz2qH7VDQTpvF5w0AG0eCbXXueG7uKK503nEeGSHp/cjW8gZty3GQJJJJ
> > /Psa
> > qA8Aj/ZQDY7leAFPIOQcASyfainl+/6wIEFiyEn20kKpEIqRggxGMRZCKoEChWMgDiIPnTED
> > x5Kg
> > UB0sYpgXf7xBCMkUIkGAMkCZzggiiArBAggyIkIgkYCMYCjGBESSRGQBBkFgoIisYhIgSIEE
> > UEFg
> > kgDEYgqpGDGRBJBGAAiAgZvRFdxqoOqj417+Xkt0o4Av8wIv4gxFIEWEZBkGEQSSQkDU7VQE
> > GRhE
> > QSByKUIWyeDkLTDApBIwWUYVgCpRawYHY5zBqk8Wg+2wgWKJJBRSKipILEh1F1MkLEgIyIqK
> > oJId
> > ZSRjUEBFSQYICwEIQEJEYsIwFSAEQEkFDpVpRaAihCIsXe1Ak0HmEOXAcH+AuGABxCPlTcTK
> > oQ5o
> > xNgacrA3yqpAPOwAqpCGmpbVFgiKSIQYQSDICMUBlKFxBXAWAJLlGrELEgTPxDqfuUAIoWRI
> > SKjm
> > B1GGg34jJyQIrtRzKlPq7CR6bwR1aAogB3FKJESDIoznQsU7QZswDTCn9Ps31FkScXZwmUhI
> > BSBE
> > dyAcYNKpmQRrMCgBZJH9RoCrMEKJsTZ80Hsuoe/8zoORp8D/KMrBB2IB6AiQiQgKRiNAjtB5
> > 3nDj
> > HrXiDbWgN1EN1nhTIgUh/UIFgOU5S1Cmjxo8IOAwvR8Rq333ecf6YB2qK+VOqxyUHgLK9KAf
> > xAiO
> > 1C/6HYkCCgeg+nwHjA4hAnI7ih1T1hn4ZQ/RnyGtVF+cP8tA+IXulAqm9D1lNow2roWj6jzV
> > HTQE
> > I0caGfNPnuZH9ppSBbI0KS7djG7wdvlOA8J5PWVHqL836PkCB5zu8LMIX0UAp4EPWw+h/mK0
> > kTOj
> > IclijgccjIARuj60Oa6dDykeUXMRDDBPqGqqEMSiiV4jHRvHZVBmQQuRhUKHhSIn5p2q4nYc
> > 6hkL
> > ZsLARYKDQVwRORh9v3YAKVrDfCE1GAAUopzoDbYWW64eGtKKqxgput1wsCZeWGSofSgOnvG8
> > yJvG
> > gf/TF4v5rF9uvGgwBXADvAsjSd7A+4aULKpaC4IwWn6kERS1/UkT2kB7vfQRyiBchBAdhEPC
> > 0BIB
> > IBaPjCqIB2gU1lHRM027McEqVYqqqqqqqIqqyCvUwpwSWSk/pGVjIs5sCF+KeHZRgGrjZCQc
> > gCUg
> > wkigJFdhSgFRFmuSWfrzWCRNi0RVYqqqqIqqAVEpkghOgcwOtwC/M/ECPliqewRDynzeQMBA
> > P2D5
> > e64H61WYAK4EcNCnfUNUh0F7CD6Ko6YdYAUSQe3/7RURzVCFTzC81G9ykCf2PwA2ttNETIfw
> > Vcw2
> > M6DrAUfUekMlEOoCb2AEV5AsJzP4qp/cr2nyopcNB+NRMH+IidgPlQ63aJoKQ5QDrPeCwQgH
> > ekXx
> > /K18Ya2tEU31JyioIowFGCQD3lkoyDCMYIogsnvZVQWIDEZEikWIArBFjCONGfGyS6sowHTJ
> > UUGC
> > qxCKrEUVIPkZgojJDIeyMmMLBBgS1OjZTqYryI/oPhVTFAPWBg0DGMiRgxgZhAgBEdCKWFDz
> > MB+6
> > wt9FC5C3KFyFLlNakRIkgRYMxXZVWVBgqHuY/W/fG6lKh1pKPoFwBSxMjwEUtFIrBCQBHAHI
> > UXzH
> > MRO7XNASA5clazVjeqzAJQwc2LlTIsIluCTDDmSBhCFjCJBB2Tu+ohW02RnxX0wYcnZB3lVq
> > Kc6h
> > 8Tyapw7z/mi9iA0bhPUgF0W4BcEuFkWyA2LCTgacN1w/pJgioGAgBIKDzH9EAvuQ3bY22pDz
> > 74fl
> > pdA7z+gUc4P2f03sJ54feL8haEANgOgc/SIhOqWgCHbAK+5OdVEvJAkjADsg34/EZhbP4C6h
> > Lodo
> > d5AgjtlvsqUEzrQv6bjfM/KZPPlityAGJSRVRpoQ+lGKAlhNUAhQMRGnUyEzc4bxIRgkUhFQ
> > 4PwI
> > LMEQHrCIgpsKBpEFuZkwoMJdAs9ebbM7amqS/g9hWt0JGwkfhPgoECB3UFrKu1i9hVuEAFOg
> > gXKs
> > 0n8loLQooaYAKWCAUsQC6wEoCWiozyAocl6IEgAQvcH4CkMJuoackDASRKKONIKGBGQSSoLT
> > UQFI
> > kVCcwIe0wtMfVzViGJwQx7nbJrLiUg3mmc+mZNgTnyOyGHCHURYmT7wpwEn9FYbGjRoF6Fx3
> > G1cM
> > WsWfnlN6OItdy6EM3+dx4YUQlnZjEi94P0LuDbDyXqFqZvyC7m7G7I2rdbVJVB15V3IMtgxy
> > 8i40
> > hTlotbUZVKNZg+vpTcduXazjsdk4/c9rgXKptVj8KjCq7GlNWps6vgddGzky6HejkzIweq2R
> > ptAw
> > SGTJZkJMBSoYd0rAwsNzmZvyCTbguENJCaq2rILEWXxDUsmEuYY2egIIWAgUKGSeAQTaOAXH
> > Ezxz
> > VNaDwtxJlTvWbo+yeYtj4nK4kqaFWRMOgdAzZRAZ3wpwwMDgADnAw08AYEzBnr2Z2smkBELl
> > GJjg
> > xqXU69rElrrm7tBmsRx0YyGSQhkkJkkG2NsbY2xTDBDEQRBsUUBBDj0oCyRFuoQDFyVC+CuK
> > bluL
> > +G+3H8wuyrWnpTVHVvp3eL6CEhCKoqSIEAbEI28546fGfzPLuGMv5DzQJf6gwAkFFYEwWpbb
> > UQFz
> > sR7qRr1KHc7ufUUepRVQgd4/gpcU0ggHZABDQBRg+XeyAKCkRgKAoCiyAsIqkXoqDrzFgTIu
> > 3jiC
> > hazyFnh2+YOjG+FU0VmR+YEIBH71VQjgqGwuhSCCcC55AS5HpQLUEAN9mhSC36hotEWRQTog
> > OAge
> > LuNnxgEgSEgkgyAoCgpFFixR5kLCB8SHQ5hPbDQDeHTNPoXe0B60e77rWLWtYtalDzsjIzzv
> > hCJs
> > xVP0/kv/amwcVQ94+2ecJNmKRQlKhBaPeGdsFFTbtDCBKTqbAqVKEdF4mgwkmk2KhsXQhhGD
> > Eipk
> > 2BChhSyUZIIu4ghB2WaKBjAwSCESWSm6uDRSAsFGD4dOYO8PyJhP3BlGCd5jcWDGYKrmUFUQ
> > cLhm
> > Mo4Zhcctgqk9TFiKqoLFWIxYMGKCwBH+QZL5+rzn1duJAwOxUG1jzPNHdtri84wUYacdxYeC
> > hHyE
> > 38abQ7gTuEQ/ah92OfHv6B7i557XD4aDbPHC9zOylkyRw8C5Zhl1LY4l8hUxCKiOwKryMaU6
> > KaRY
> > MsA4CBaggqMUti4REtUZZb66p5UG1KmTLBS6rBnCCJsqjAMf31NJy2EdssgM9GI0gaUKi1bd
> > syqA
> > 1Cpr8CYvfLNpsflUQcUvSb7YdCxwc1tlgfdyR5IYhGdmxIqHhNLVZz2JOs4KkJeDkwwI6YrT
> > vaal
> > 2woJ2n8dYM8bg7ogbCCiAymcVMdCFCwgiRQmENDNYEoyINwruspHPe4MqV5gyHC6dL0Rrk9w
> > 2Y8w
> > NbJ3l5EmXa4SWSjEZEElOG+UQshLbWJP2q/mfgD2ZbYu8gJrarmtcbVL2LNECspNZMO2aORI
> > 4EWA
> > s3KCGi+hIGpDQpMBoFoYRg2QQIOUtiQWkHiUIi4FmrrQBcisIqySDcEWCpdiREvSgS7cVgpH
> > qgDk
> > xAG477u4d+6AHUILc1OZqCeJZ/GJPGdv46xzLjmWQPKLFjwTn0pDz4IsQRHqnIDZxDFUUgOD
> > IpIQ
> > tGok50GMsVGmWpt397ZtHMWbnJMyKMa6dblsCrDoQqxWNJ3Xq+MVPfpZUJfY9TJ0pOWVG0Ok
> > P2Jv
> > cScolBDzszNLWKqnZYhaBeePZRkRduAtBYzNHG4reCsRhehkECRURSMiwYCIwZFBBIUOwNd3
> > InDy
> > mKCAa8IBCQIqaOBqSff3Vaw2GMD6E/XMm2betUVs0ZCyAeGG4mENAMQJBKITKWHcbgBShAHU
> > XUE2
> > A2+xIqdsozIpkKDsgSEikgrIOyJz8zawXvS1H4Zl04B7g6o8cg12BguuQGkXhDlwEsglyEGM
> > UIAa
> > XM/MC+K+BGdOzgp6m9IvVBhhuJZFGCIIyJ1WrBrS0oyKBy1RyQsggwYgk0liqUSwhEUisVih
> > MCqR
> > MRUGgqwIY+0RDC81DnGo1BDsg1LRhAMzBK4AB3PrDMSPAYadr6DUA1IC8kkiwsQFIIJBBikj
> > IyMA
> > Ug01QTIBGhhFDUWwMBegdDoGL0RLoKaAHCIbBOTFHoTHuAUOK2SJ/0ulKZl+k2HdfjaygFvO
> > kdAL
> > wqNLrB7wfr1e+nIzf17bOt1IgqyxDQcBpIiYjduMgKYqSz0uKDRdihbEvkZminZFC0UBjmoH
> > Cu42
> > G88pFJEVYRigSXwfO/JGd5VPlmXDApSzBDJhQtopEtEsoVsGAiUs9JhdH8RIf5nyw+YGV6UB
> > 2Kve
> > j6Q9KRISJBSSCkRHxsThOX7gjIsGQInaAAZgeE0+dHoAtFRkD8e5BGh4vi1CFkRbayhNh3Bt
> > fpIc
> > AbtzkJ/jzI+5cnpPQTzdZYghp5jjOEEPj51EE8O5gu0OZfzggw8+SB0qHOaNMpDwov8Isjzg
> > uEFC
> > WpUG005ZofrQIOqoFhHxI/f7MsEM8H061L8yICcCJhEG8UQqFPypayrcjgUp0Za50GoCj6DC
> > AfVD
> > F96odQ9oaGZoKDnLMLBA7iynEN0yYKv9Fi9wOvZbR1GJp7VMQeI+g9/pD/K4P1kjDyE7g0El
> > HBQU
> > RgxiZAn10AKH2QBQ+QT3I7QP7keYG6qe0cTgYcDDihISEwGgACT4gnVD5X6UA5ucgWkCT80i
> > AaGW
> > R84epGghuShz3zN5hE/x3wuwA7ACCwGADFGKKZId5ilBoiLF3kglUVsLVsgeoSfQgQiDDTy8
> > Ca/3
> > Kh9x2OUnojmGWQBxgAl1DQ06J3CfqQ8i7ID9o4ZhR+cI0knmD0AhT1+N3+dDBIJH9PBLhGAw
> > WCyI
> > DhCiCfufsQG2O+j9KKe0RMR5dhk6ngoLiSHOahLFETYRHzmxAOcEPkV5lDB1+Jo9kgO2uiG6
> > fQ+P
> > i9l+dIRAj4lyoMDkaO2K1HrjkMc0MeSwp7ynkE8yvQgLzVRMLmVZ8hH7usyLkgsuZdf9LLNo
> > fs+X
> > siRZGG9DAgB4sGEREQSC+IYJBlGc/YpYs9VPSB5xS5vAGMEAjGAgD2uhGEK0IAEgSKvwqETU
> > GAbh
> > Z2dgiFUEH7lP+nE7+5D0qGKqj+8CKHR5R6DyL/BQ8h37i5Z6L8YODc8JFkgWtnydeOK4Z0Zi
> > 1C9Z
> > y+y92+ITmq8VMr0r0l7HspEET6bxFzcMGMyqI5gxaoz4WWXOg5RM69rCUsJRPlClB5aKFORh
> > RtiY
> > E9Pq2NTrx1DJSggtqw2EbFr70FyaeF3RIodybV7FOiH4PAdwO/SE4oi7WECIkA8SIoFAWwKF
> > L6q4
> > uKofRQPFseZDu7CQ5KFUamAggO4bqa+S/ChrWwiOthE5VekPbQfghp0CIdXQhLE3c9l4+kEp
> > HRI5
> > AeZQ+VXiFLmCdBnOvoeR8QlKI9U51QoXah2g2VD50B8GnyKVvb/vQogQnygJ9gqsVEJpkBEZ
> > C5P5
> > jUyQEYJpEu239ybQJ+CIwjGQEiRQP8PwpnCCCzP/V0/j682L4/lNxaP1qfj12/3b5bTR1BdB
> > GEWC
> > QsdhGYVBKqsapcB1sl0Ngo770ZUkBRUbSg6ppkH07myUGyerY/ClN+/9/6dRP0/Vm9FIwRn+
> > T+5e y6pdIzbcfzosvGMPd1aJwwOHl//Ah8wQ//i7kinChIJcw/so
> >
> > _______________________________________________
> > Mailing list: https://launchpad.net/~dolfin
> > Post to : dolfin@xxxxxxxxxxxxxxxxxxx
> > Unsubscribe : https://launchpad.net/~dolfin
> > More help : https://help.launchpad.net/ListHelp
References