I've made a model in ModelBuilder in ArcMap 10.3, what it basically does is creating polygons over open areas such as farm-lands, grass-lands, marshes etc that has a low slope.
My challenge is that I don't want polygons that are smaller than a specific area. lets say in this example that the area can not be smaller than 160m2. This is easy by creating an expression removing polygons with area less than that. But I'm interested in the actual size, it needs to be at least 40x40m. (diameter of 40m if it is doable with circle vs square).
Figure 1 and 2 are OK because they both have an area inside which is 40x40m, but figure 3 does not and should thus be removed/deleted. It also visualizes the trouble with square meters, as the figure 3 has the same area as figure 1.
As long as the polygon have one area of at least 40x40 the remainder "noise"/bulbs in the polygon does not matter.
@FelixIP gave one solution in the first answer on this post that almost worked. But after some testing I found that there were some flaws in the output after running the two scripts. It solved my problem since, luckily enough, no errors occurred in my analysis extent. Here are two pictures that depicts the two errors i found:
As you can see here, if we had moved the point from which the buffer was made, it would be possible to arrange it so that the buffer would fit inside the polygon boundaries.
Use my script from Checking if polygon fits inside another polygon using ArcGIS or QGIS?
to create points inside your polygons. Each point is a centre of maximum inscribed circle of the parcel. Please note, script tested on shapefiles only and it does not handle polygons with holes, i.e. donut like polygons.
Table of centre point contains field theDist, that is the radius of above circle.
Select all points with theDist=>20, and create 20m buffers around them: Use Minimum Bounding Geometry to create rectangles from buffers Attach this script to tool with no parameters. It is a tool to run from mxd
import arcpy, traceback, os, sys,math from math import radians,sin,cos mxd = arcpy.mapping.MapDocument("CURRENT") parent=arcpy.mapping.ListLayers(mxd,"parent") child=arcpy.mapping.ListLayers(mxd,"child") # NUMERIC ! common field linkField="PAR_ID" d=arcpy.Describe(parent) SR=d.spatialReference g=arcpy.Geometry() gr=(math.sqrt(5)-1)/2 try: def showPyMessage(): arcpy.AddMessage(str(time.ctime()) + " - " + message) #golden section to find minimum def gss(a,b,tol): c=b-gr*(b-a) d=a+gr*(b-a) while abs(c-d)>tol: fc=f(c);fd=f(d) if fc
Script works on shapefiles and assumes:
- that your original polygons named PARENT
- that your squares polygons named CHILD
- They have common numeric field "PAR_ID"
It child fits completely into original, script adds this square to selection. If not it attempts to fit it by rotating around centre points, and adds to selection if successful
OK thinking out aloud here and untested so may not capture all possible shapes. It looks like you are mapping to a cell size of 10m and that your rectangular polygons are raster based. The logic I am suggesting only works if the original raster based polygons do not touch each other. In @FelixIP answer he has polygons sharing boundaries. If this is truly the case how about this approach?
- Convert your polygons to a binary grid where a cell covered by your polygon becomes 1, everything else a 0.
- Run the Focal Statistics tool with a circular window of 2 pixels with SUM as the option.
- Any pixel surrounded by 4x4 1's will sum up to 16.
- You could then convert only pixels that are 16 into points and use those to select the polygons as the required minimum dimension. You just need to invert the selection to find the ones you don't want.