map performance

boice tomlin boice at RUNSKIP.COM
Wed Dec 6 10:23:41 PST 2006


The data comes from a MySQL database.  The primary function of the  
site is to collect the data from users.  It is a PHP/MqSQL application.

The map is rendered each time for only a specific layer such as orthos.

So I go to the database(MySQL) and grab all distinct county ids that  
have a status of complete for that layer.

I build the regex string from that array of county ids and then use  
phpmapscript to set the expression for the county layer.

I understand the data structure you explained below.  But I don't  
understand how you would implement it.  Do you propose connecting to  
a data source directly from the mapfile?

At this point the only way I know how to color a county green on the  
map is by using a regular expression.  But I'm open to any method.   
Especially if its faster.

thanks,

boice







On Dec 6, 2006, at 12:39 PM, Steve Lime wrote:

> Ok, I looked back through another email and saw the output. I think  
> the
> bottleneck is in the large regular expressions. You'd be much  
> better off
> with a data structure like I outlined below. How do you determine, for
> example, which counties are do be drawn a certain way. That is, how do
> you build the regex? Using attributes in the shapefile? From another
> source?
>
> Steve
>
>>>> boice tomlin <boice at RUNSKIP.COM> 12/6/2006 10:55:52 AM >>>
>
> Hi Steve,
>
> Assuming I was using static class items.  Do you think my method of
> using a regular expression to specify which geographies to display  
> is a
> good method?
>
> Thanks for the tip on saving the map file.  Very cool.  It looks as I
> expected or at least hoped.  Basically my original map file with a few
> extra classes and regular expressions for the layers I display.
>
> Someone else suggested a method using postgis that would pull in shape
> data with less polygons for certain extents.
>
> Couldn't I use a version of the shape files I have now with less
> detail/polygons when rendering a map at larger extents?
>
> I actually want to explore every method I can for optimization.  My
> goal is a fairly descriptive national view in 1 tenth of a second.  Is
> that too lofty?
>
> thanks,
>
> boice
>
>
>
> On Dec 5, 2006, at 6:32 PM, Steve Lime wrote:
> Might be interesting to see what the resulting mapfile (after your
> dynamic work) looks like (use $map->save(...)).
>
>
> We'd really need to know more about the data, how you're doing
> classifications and such to comment more. There may be lots of ways
> to make things go faster. From the looks of it for each geography
> (city, county, tribe, state, nation) you have a bunch of variables
> that
> indicate
> if a data theme is available. One could organize that data like so
> (for
> example state level data):
>
>
> State  Hydrography  Watersheds ...
> MN     0                    1
> WI      3                    2
> IA       3                    0
> FL       1                    3
>
>
> Where 0 means no responce, 1 complete and so on. So in that case your
> class definitions would always be the same you'd
> be simply changing the variable you're mapping on (e.g. CLASSITEM),
> and
> you wouldn't need dynamic classes (or even MapScript for that
> matter).  Just thinking out loud...
>
>
> Steve
>
>
> boice tomlin <boice at RUNSKIP.COM> 12/4/2006 1:24:58 PM >>>
>
>
> Hello users,
>
>
> The map located here;
>
>
> http://gisinventory.net/status_maps.html
>
>
> takes a while to load.  At least at the national view where there is a
> lot of area to render.
>
>
> I am looking for alternative ways to generate the map that will
> significantly improve performance.
>
>
> Currently I am using php and looping through data and turning on
> layers
> as I go.  The PHP part is lightning fast.  But after I get the map
> ready
> mapserver takes several seconds to generate it.
>
>
> I'm curious about alternative ways to handle this problem and wonder
> if
> anyone had comments on any of them.
>
>
> 1) modifying the shape files in some way so the layer information is
> in
> those files so that all mapserver has to do is load those files and
> not
> depend on the map files.
> 2) using a db such as postgres with postgis so that layer information
> is available all in one compact source.
>
>
> Right now I have to generate a bunch of dynamic classes in PHP using
> the general method below.
>
>
> $lyr = $this->ramona_map->getLayerByName("state_yes");
>                 $cla = $lyr->getClass(0);
>                 $cla->setExpression("/".$expression."/");
>                 $lyr->set("status", MS_ON);
>
>
> I have to do this several hundred times to represent all of the data.
> The time it takes to generate the map seem proportionate to the amount
> of layers I make visible.  And again this is on the mapserver side and
> not PHP.  PHP does its part of the operation in thousandths of a
> second.
>
>
> anyone's thoughts are greatly appreciated.
>
>
> -boice tomlin
>
>
>
>
>
>
> ////////////////////////////
> Run Skip
> http://runskip.com/
>
>
>
>
> boice tomlin
>
>
>
>
> boice at runskip.com
>
>
>
>
> 503-528-6204
>
>
>
>
>
>
>
>
>
>
> ////////////////////////////
> Run Skip
> http://runskip.com/
>
>
> boice tomlin
>
>
> boice at runskip.com
>
>
> 503-528-6204
>
>
>




////////////////////////////
Run Skip
http://runskip.com/

boice tomlin

boice at runskip.com

503-528-6204


-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.osgeo.org/pipermail/mapserver-users/attachments/20061206/e00fc7fb/attachment.htm>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: PGP.sig
Type: application/pgp-signature
Size: 186 bytes
Desc: This is a digitally signed message part
URL: <http://lists.osgeo.org/pipermail/mapserver-users/attachments/20061206/e00fc7fb/attachment.sig>


More information about the MapServer-users mailing list